From 3621d8cc44cb8c5682213146348242140e524ef8 Mon Sep 17 00:00:00 2001 From: zhl Date: Mon, 12 Jun 2023 16:42:07 +0800 Subject: [PATCH] project init --- .gitignore | 10 + .vscode/launch.json | 21 + package.json | 54 + src/api.server.ts | 176 ++ src/api.ts | 12 + src/common/AsyncQueue.ts | 107 + src/common/Debug.ts | 6 + src/common/Extend.ts | 966 ++++++++ src/common/ZError.ts | 13 + src/common/base.controller.ts | 7 + src/config/config.ts | 50 + src/config/datas.ts | 2158 ++++++++++++++++ src/controllers/discord.controller.ts | 22 + src/controllers/main.controller.ts | 15 + src/controllers/page.controller.ts | 11 + src/decorators/dbconn.ts | 13 + src/decorators/nojson.ts | 29 + src/decorators/router.ts | 142 ++ src/decorators/singleton.ts | 29 + src/logger/logger.ts | 3 + src/modules/Base.ts | 219 ++ src/modules/PayRecord.ts | 96 + src/plugins/apiauth.ts | 47 + src/plugins/zReqParser.ts | 37 + src/plugins/zTokenParser.ts | 73 + src/plugins/zrbac.ts | 26 + src/services/alchemy.svr.ts | 114 + src/services/discord.svr.ts | 36 + src/services/merchant.svr.ts | 45 + src/utils/net.util.ts | 186 ++ src/utils/promise.util.ts | 47 + src/utils/security.util.ts | 74 + src/utils/string.util.ts | 136 ++ templates/discord_redirect.ejs | 22 + templates/error.ejs | 2 + tsconfig.json | 23 + yarn.lock | 3248 +++++++++++++++++++++++++ 37 files changed, 8275 insertions(+) create mode 100644 .gitignore create mode 100644 .vscode/launch.json create mode 100644 package.json create mode 100644 src/api.server.ts create mode 100644 src/api.ts create mode 100644 src/common/AsyncQueue.ts create mode 100644 src/common/Debug.ts create mode 100644 src/common/Extend.ts create mode 100644 src/common/ZError.ts create mode 100644 src/common/base.controller.ts create mode 100644 src/config/config.ts create mode 100644 src/config/datas.ts create mode 100644 src/controllers/discord.controller.ts create mode 100644 src/controllers/main.controller.ts create mode 100644 src/controllers/page.controller.ts create mode 100644 src/decorators/dbconn.ts create mode 100644 src/decorators/nojson.ts create mode 100644 src/decorators/router.ts create mode 100644 src/decorators/singleton.ts create mode 100644 src/logger/logger.ts create mode 100644 src/modules/Base.ts create mode 100644 src/modules/PayRecord.ts create mode 100644 src/plugins/apiauth.ts create mode 100644 src/plugins/zReqParser.ts create mode 100644 src/plugins/zTokenParser.ts create mode 100644 src/plugins/zrbac.ts create mode 100644 src/services/alchemy.svr.ts create mode 100644 src/services/discord.svr.ts create mode 100644 src/services/merchant.svr.ts create mode 100644 src/utils/net.util.ts create mode 100644 src/utils/promise.util.ts create mode 100644 src/utils/security.util.ts create mode 100644 src/utils/string.util.ts create mode 100644 templates/discord_redirect.ejs create mode 100644 templates/error.ejs create mode 100644 tsconfig.json create mode 100644 yarn.lock diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..51de8a8 --- /dev/null +++ b/.gitignore @@ -0,0 +1,10 @@ +.env.development +.env.production +.idea +node_modules +build +dist +.DS_Store +tmp +target +boundle.log diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 0000000..370882e --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,21 @@ +{ + // Use IntelliSense to learn about possible attributes. + // Hover to view descriptions of existing attributes. + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "configurations": [ + { + "name": "Debug Api", + "request": "launch", + "runtimeArgs": [ + "run-script", + "dev:api" + ], + "runtimeExecutable": "npm", + "skipFiles": [ + "/**" + ], + "type": "pwa-node" + }, + ] +} \ No newline at end of file diff --git a/package.json b/package.json new file mode 100644 index 0000000..d722a93 --- /dev/null +++ b/package.json @@ -0,0 +1,54 @@ +{ + "name": "oauth-svr", + "version": "1.0.0", + "description": "", + "main": "index.js", + "scripts": { + "update": "yarn upgrade-interactive --latest", + "dev:api2": "ts-node -r tsconfig-paths/register src/api.ts", + "debug:api": "node --require ts-node/register --inspect src/api.ts", + "dev:api": "npx ts-node src/api.ts", + "build": "tsc", + "prod:api": "NODE_ENV=production NODE_PATH=./dist node dist/api.js", + "lint": "eslint --ext .ts src/**", + "format": "eslint --ext .ts src/** --fix" + }, + "author": "zhl", + "license": "ISC", + "dependencies": { + "@fastify/cors": "^8.1.0", + "@fastify/formbody": "^7.3.0", + "@fastify/helmet": "^10.0.1", + "@fastify/jwt": "^6.3.2", + "@fastify/view": "^7.4.1", + "axios": "^1.1.3", + "discord.js": "^14.11.0", + "dotenv": "^16.0.3", + "ejs": "^3.1.9", + "fast-rbac": "^2.0.1", + "fastify": "^4.8.1", + "fastify-plugin": "^4.2.1", + "google-auth-library": "^8.5.2", + "mongoose": "^6.6.5", + "mongoose-findorcreate": "^3.0.0", + "nanoid": "^3.1.23", + "node-schedule": "^2.1.1", + "tracer": "^1.1.6" + }, + "devDependencies": { + "@typegoose/typegoose": "^9.12.1", + "@types/dotenv": "^8.2.0", + "@types/node-schedule": "^2.1.0", + "@typescript-eslint/eslint-plugin": "^5.40.1", + "@typescript-eslint/parser": "^5.40.1", + "eslint": "^8.25.0", + "eslint-config-prettier": "^8.5.0", + "eslint-plugin-prettier": "^4.2.1", + "node": "^18.14.0", + "prettier": "^2.7.1", + "ts-node": "^10.9.1", + "ts-node-dev": "^2.0.0", + "tsconfig-paths": "^4.2.0", + "typescript": "^4.8.4" + } +} diff --git a/src/api.server.ts b/src/api.server.ts new file mode 100644 index 0000000..a63d059 --- /dev/null +++ b/src/api.server.ts @@ -0,0 +1,176 @@ +import fastify, { FastifyError, FastifyInstance, FastifyReply, FastifyRequest } from 'fastify' +import helmet from '@fastify/helmet' +import { IncomingMessage, Server, ServerResponse } from 'http' +import { RouterMap } from 'decorators/router' +import { mongoose } from '@typegoose/typegoose' +import logger from 'logger/logger' +import config from 'config/config' +import { ConnectOptions } from 'mongoose' + +const zReqParserPlugin = require('plugins/zReqParser') + +const zTokenParserPlugin = require('plugins/zTokenParser') + +const apiAuthPlugin = require('plugins/apiauth') + +const fs = require('fs') +const join = require('path').join + +require('./common/Extend') + +export class ApiServer { + server: FastifyInstance + + public constructor() { + this.server = fastify({ logger: true, trustProxy: true }) + this.registerPlugins() + console.log('version::' + process.version) + } + private registerPlugins() { + this.server.register(require('@fastify/formbody')) + this.server.register(zReqParserPlugin) + this.server.register(helmet, { hidePoweredBy: false, contentSecurityPolicy: false }) + this.server.register(zTokenParserPlugin) + + this.server.register(apiAuthPlugin, { + secret: { private: config.api.token_secret_private, public: config.api.token_secret_public }, + expiresIn: config.api.token_expiresIn, + }) + if (process.env.NODE_ENV !== 'production') { + this.server.register(require('@fastify/cors'), {}) + } + + this.server.register(require('@fastify/view'), { + engine: { + ejs: require('ejs'), + }, + }) + } + + private registerRouter() { + logger.log('register api routers') + let self = this + for (let [controller, config] of RouterMap.decoratedRouters) { + for (let data of config.data) { + logger.info( + 'add router', + data.method || 'all', + data.path, + `${data.target.constructor.name}.${controller.name}()`, + ) + // @ts-ignore + self.server[data.method || 'all']( + data.path, + { + preValidation: async function (request: FastifyRequest, reply: FastifyReply) { + request.roles = config.roles + await this.apiAuth(request, reply) + }, + }, + controller, + ) + } + } + } + /** + * 加载所有的controller + */ + initControllers() { + logger.info('Bootstrap controllers...') + const controllers = join(__dirname, './controllers') + fs.readdirSync(controllers) + .filter((file: string) => ~file.search(/^[^.].*\.(ts|js)$/)) + .forEach((file: any) => { + // logger.log(file); + return require(join(controllers, file)) + }) + } + + initSchedules() {} + + async connectDB() { + const options: ConnectOptions = { + minPoolSize: 5, + maxPoolSize: 10, + keepAlive: true, + keepAliveInitialDelay: 300000, + } + const uri = config.db_main + logger.info(`connect to ${uri} ...`) + try { + // await mongoose.createConnection(uri, options) + await mongoose.connect(uri, options) + logger.log('DB Connected') + } catch (err) { + logger.log(`DB Connection Error: ${err.message}`) + } + } + private setErrHandler() { + this.server.setNotFoundHandler(function ( + request: any, + reply: { send: (arg0: { errcode: number; errmsg: string }) => void }, + ) { + reply.send({ errcode: 404, errmsg: 'page not found' }) + }) + this.server.setErrorHandler(function (error: FastifyError, request: FastifyRequest, reply: FastifyReply) { + let statusCode = (error && error.statusCode) || 100 + if (statusCode >= 500) { + logger.error(error) + } else if (statusCode >= 400) { + logger.info(error) + } else { + logger.error(error) + } + reply.code(200).send({ + errcode: statusCode, + errmsg: error ? error.message : 'unknown error', + }) + }) + } + /** + * 格式化接口返回数据, 统一封装成如下格式 + * { + * errcode: 0, + * errmsg?: '', + * data: any + * } + * @private + */ + private setFormatSend() { + this.server.addHook('preSerialization', async (request: FastifyRequest, reply: FastifyReply, payload) => { + reply.header('X-Powered-By', 'PHP/5.4.16') + // @ts-ignore + if (!payload.errcode) { + // @ts-ignore + if (payload.direct) { + // @ts-ignore + delete payload.direct + return payload + } + payload = { + errcode: 0, + data: payload, + } + } + return payload + }) + } + public async start() { + let self = this + return new Promise(async (resolve, reject) => { + await self.connectDB() + self.initControllers() + self.registerRouter() + self.setErrHandler() + self.setFormatSend() + self.initSchedules() + this.server.listen({ port: config.api.port, host: config.api.host }, (err: any, address: any) => { + if (err) { + logger.log(err) + process.exit(0) + } + resolve && resolve(address) + }) + }) + } +} diff --git a/src/api.ts b/src/api.ts new file mode 100644 index 0000000..f7e6b5b --- /dev/null +++ b/src/api.ts @@ -0,0 +1,12 @@ +import { ApiServer } from './api.server' +import logger from './logger/logger' + +class Server extends ApiServer { + constructor() { + super() + } +} +let server = new Server() +server.start().then(address => { + logger.log(`Api Server listening at ${address}`) +}) diff --git a/src/common/AsyncQueue.ts b/src/common/AsyncQueue.ts new file mode 100644 index 0000000..792c27e --- /dev/null +++ b/src/common/AsyncQueue.ts @@ -0,0 +1,107 @@ +type Callback = () => Promise + +export type AsyncQueue = { + push: (task: Callback) => Promise + flush: () => Promise + size: number +} + +/** + * Ensures that each callback pushed onto the queue is executed in series. + * Such a quetie 😻 + * @param opts.dedupeConcurrent If dedupeConcurrent is `true` it ensures that if multiple + * tasks are pushed onto the queue while there is an active task, only the + * last one will be executed, once the active task has completed. + * e.g. in the below example, only 0 and 3 will be executed. + * ``` + * const queue = createAsyncQueue({ dedupeConcurrent: true }) + * queue.push(async () => console.log(0)) // returns 0 + * queue.push(async () => console.log(1)) // returns 3 + * queue.push(async () => console.log(2)) // returns 3 + * queue.push(async () => console.log(3)) // returns 3 + * ``` + * */ +export function createAsyncQueue(opts = { dedupeConcurrent: false }): AsyncQueue { + const { dedupeConcurrent } = opts + let queue: Callback[] = [] + let running: Promise | undefined + let nextPromise = new DeferredPromise() + const push = (task: Callback) => { + let taskPromise = new DeferredPromise() + if (dedupeConcurrent) { + queue = [] + if (nextPromise.started) nextPromise = new DeferredPromise() + taskPromise = nextPromise + } + queue.push(() => { + taskPromise.started = true + task().then(taskPromise.resolve).catch(taskPromise.reject) + return taskPromise.promise + }) + if (!running) running = start() + return taskPromise.promise + } + const start = async () => { + while (queue.length) { + const task = queue.shift()! + await task().catch(() => {}) + } + running = undefined + } + return { + push, + flush: () => running || Promise.resolve(), + get size() { + return queue.length + }, + } +} + +export const createAsyncQueues = (opts = { dedupeConcurrent: false }) => { + const queues: { [queueId: string]: AsyncQueue } = {} + const push = (queueId: string, task: Callback) => { + if (!queues[queueId]) queues[queueId] = createAsyncQueue(opts) + return queues[queueId].push(task) + } + const flush = (queueId: string) => { + if (!queues[queueId]) queues[queueId] = createAsyncQueue(opts) + return queues[queueId].flush() + } + return { push, flush } +} + +class DeferredPromise { + started = false + resolve: (x: T | PromiseLike) => void = () => {} + reject: (x: E) => void = () => {} + promise: Promise + + constructor() { + this.promise = new Promise((res, rej) => { + this.resolve = res + this.reject = rej + }) + } +} + +// function main() { +// const queue = createAsyncQueue() +// queue.push(async () => { +// console.log(0) +// }) // returns 0 +// queue.push(async () => { +// console.log(1) + +// return new Promise((resolve, reject) => { +// setTimeout(() => { +// console.log('12') +// resolve() +// }, 1000) +// }) +// }) // returns 3 +// queue.push(async () => console.log(2)) // returns 3 +// queue.push(async () => console.log(3)) // returns 3 +// console.log('hi') +// } + +// main() diff --git a/src/common/Debug.ts b/src/common/Debug.ts new file mode 100644 index 0000000..ca8801c --- /dev/null +++ b/src/common/Debug.ts @@ -0,0 +1,6 @@ +import debug from 'debug' + +debug.log = console.info.bind(console) + +export const error = debug('chain:error') +error.log = console.error.bind(console) diff --git a/src/common/Extend.ts b/src/common/Extend.ts new file mode 100644 index 0000000..dfe36b5 --- /dev/null +++ b/src/common/Extend.ts @@ -0,0 +1,966 @@ +/** + * 对数字进行补0操作 + * @param value 要补0的数值 + * @param length 要补的总长度 + * @return 补0之后的字符串 + */ +function zeroize(value: number | string, length: number = 2): string { + let str = '' + value + let zeros = '' + for (let i = 0, len = length - str.length; i < len; i++) { + zeros += '0' + } + return zeros + str +} + +/****************************************扩展Object****************************************/ +interface Object { + /** + * 返回一个浅副本的对象 + * 此对象会拷贝key value + * + * @memberOf Object + */ + clone?(): Object + + /** + * 将数据拷贝到 to + * @param to 目标 + */ + copyto?(to: Object): void + + /** + * 获取指定属性的描述,会查找当前数据和原型数据 + * @param property 指定的属性名字 + */ + getPropertyDescriptor?(property: string): PropertyDescriptor + + zssign?(target: any): any +} + +Object.defineProperties(Object.prototype, { + clone: { + value: function () { + let o = {} + for (let n in this) { + // @ts-ignore + o[n] = this[n] + } + return o + }, + writable: true, + }, + getPropertyDescriptor: { + value: function (property: string): any { + let data = Object.getOwnPropertyDescriptor(this, property) + if (data) { + return data + } + let prototype = Object.getPrototypeOf(this) + if (prototype) { + return prototype.getPropertyDescriptor(property) + } + return + }, + writable: true, + }, + copyto: { + value: function (to: Object) { + for (let p in this) { + if (!(p in to)) { + // 本身没有这个属性 + // @ts-ignore + to[p] = this[p] + } else { + let data: PropertyDescriptor = to.getPropertyDescriptor(p) + if (data) { + if (data.set || data.writable) { + // 可进行赋值 + // @ts-ignore + to[p] = this[p] + } + } + } + } + }, + writable: true, + }, + zssign: { + value: function (target: Object) { + if (target === undefined || target === null) { + throw new TypeError('Cannot convert undefined or null to object') + } + + let output = Object(target) + for (let nextKey in this) { + if (!(nextKey in output)) { + // 本身没有这个属性 + output[nextKey] = this[nextKey] + } + // else { + // let data: PropertyDescriptor = output.getPropertyDescriptor(nextKey); + // if (data) { + // if (data.set || data.writable) {// 可进行赋值 + // output[nextKey] = this[nextKey]; + // } + // } + // } + } + return output + }, + writable: true, + }, +}) + +/****************************************扩展Math****************************************/ +interface Math { + /** + * 角度转弧度的乘数 + * Math.PI / 180 + * @type {number} + * @memberOf Math + */ + DEG_TO_RAD: number + /** + * 弧度转角度的乘数 + * 180 / Math.PI + */ + RAD_TO_DEG: number + /** + * 整圆的弧度 + */ + PI2: number + /** + * 90°的弧度 + * + * @type {number} + * @memberOf Math + */ + PI_1_2: number + + /** + * 让数值处于指定的最大值和最小值之间,低于最小值取最小值,高于最大值取最大值 + * @param value 要处理的数值 + * @param min 最小值 + * @param max 最大值 + */ + clamp?(value: number, min: number, max: number): number + + /** + * 从最小值到最大值之间随机[min,max) + */ + random2?(min: number, max: number): number +} + +Math.DEG_TO_RAD = Math.PI / 180 + +Math.RAD_TO_DEG = 180 / Math.PI + +Math.PI2 = 2 * Math.PI + +Math.PI_1_2 = Math.PI * 0.5 + +Math.clamp = (value, min, max) => { + if (value < min) { + value = min + } + if (value > max) { + value = max + } + return value +} + +Math.random2 = (min, max) => { + return min + Math.random() * (max - min) +} + +/****************************************扩展Number********************************************/ +interface Number { + /** + * 对数字进行补0操作 + * @param length 要补的总长度 + * @return 补0之后的字符串 + */ + zeroize?(length: number): string + + /** + * 数值介于,`min` `max`直接,包含min,max + * 即:[min,max] + * + * @param {number} min + * @param {number} max + * @returns {boolean} + */ + between?(min: number, max: number): boolean +} + +Object.defineProperties(Number.prototype, { + zeroize: { + value: function (this: number, length: number) { + return zeroize(this, length) + }, + writable: true, + }, + between: { + value: function (this: number, min: number, max: number) { + return min <= this && max >= this + }, + writable: true, + }, +}) + +/****************************************扩展String****************************************/ +interface String { + /** + * 替换字符串中{0}{1}{2}{a} {b}这样的数据,用obj对应key替换,或者是数组中对应key的数据替换 + */ + substitute?(args: any[]): string + + /** + * 对数字进行补0操作 + * @param length 要补的总长度 + * @return 补0之后的字符串 + */ + zeroize?(length: number): string + + /** + * 将一个字符串转换成一个很小几率重复的数值 + * 此方法hash的字符串并不一定唯一,慎用 + */ + hash?(): number + + /** + * 获取字符串长度,中文方块字符算两个长度 + */ + trueLength?(): number + + /** + * 中文字符个数 + * */ + cnLength?(): number + + /** + * 比较版本号 + * */ + versionCompare?(target: string): number +} + +Object.defineProperties(String.prototype, { + zeroize: { + value: function (length: number) { + return zeroize(this, length) + }, + writable: true, + }, + substitute: { + value: function (this: string) { + let len = arguments.length + if (len > 0) { + let obj: IArguments + if (len == 1) { + obj = arguments[0] + if (typeof obj !== 'object') { + obj = arguments + } + } else { + obj = arguments + } + if (obj instanceof Object && !(obj instanceof RegExp)) { + return this.replace(/\{(?:%([^{}]+)%)?([^{}]+)\}/g, function (match: string, handler: string, key: string) { + //检查key中,是否为%开头,如果是,则尝试按方法处理 + // @ts-ignore + let value = obj[key] + if (handler) { + //如果有处理器,拆分处理器 + let func = String.subHandler[handler] + if (func) { + value = func(value) + } + } + return value !== undefined ? '' + value : match + }) + } + } + return this.toString() //防止生成String对象,ios反射String对象会当成一个NSDictionary处理 + }, + writable: true, + }, + hash: { + value: function () { + let len = this.length + let hash = 5381 + for (let i = 0; i < len; i++) { + hash += (hash << 5) + this.charCodeAt(i) + } + return hash & 0x7fffffff + }, + writable: true, + }, + trueLength: { + value: function () { + let arr: string[] = this.match(/[^x00-xff]/gi) + return this.length + (arr ? arr.length : 0) + }, + writable: true, + }, + cnLength: { + value: function () { + // /[\u2E80-\u9FBF] + let arr: string[] = this.match(/[^x00-xff]/gi) + return arr ? arr.length : 0 + }, + writable: true, + }, + versionCompare: { + value: function (target: string): number { + const GTR = 1 //大于 + const LSS = -1 //小于 + const EQU = 0 //等于 + if (!target) { + return GTR + } + let v1arr = String(this) + .split('.') + .map(function (a) { + return parseInt(a) + }) + let v2arr = String(target) + .split('.') + .map(function (a) { + return parseInt(a) + }) + let arrLen = Math.max(v1arr.length, v2arr.length) + let result + + //排除错误调用 + if (this == undefined || target == undefined) { + throw new Error() + } + + //检查空字符串,任何非空字符串都大于空字符串 + if (this.length == 0 && target.length == 0) { + return EQU + } else if (this.length == 0) { + return LSS + } else if (target.length == 0) { + return GTR + } + //循环比较版本号 + for (let i = 0; i < arrLen; i++) { + result = versionComp(v1arr[i], v2arr[i]) + if (result == EQU) { + continue + } else { + break + } + } + return result + + function versionComp(n1: number, n2: number) { + if (typeof n1 != 'number') { + n1 = 0 + } + if (typeof n2 != 'number') { + n2 = 0 + } + if (n1 > n2) { + return GTR + } else if (n1 < n2) { + return LSS + } else { + return EQU + } + } + }, + writable: true, + }, +}) + +interface StringConstructor { + /** + * 对数字进行补0操作 + * @param value 要补0的数值 + * @param length 要补的总长度 + * @return 补0之后的字符串 + */ + zeroize?: (value: number, length: number) => string + + /** + * substitute的回调函数 + * + * @type {Readonly<{ [index: string]: { (input: any): string } }>} + * @memberOf StringConstructor + */ + subHandler?: Readonly<{ [index: string]: { (input: any): string } }> +} + +String.zeroize = zeroize + +/****************************************扩展Date****************************************/ + +interface Date { + /** + * 格式化日期 + * + * @param {string} mask 时间字符串 + * @param {boolean} [local] 是否基于本地时间显示,目前项目,除了报错信息,其他时间都用UTC时间显示 + * @returns {string} 格式化后的时间 + */ + format(mask: string, local?: boolean): string + + /** + * 增加n天 + * @param {number} days + * @return {Date} + */ + addDays(days: number): Date +} + +Object.defineProperties(Date.prototype, { + format: { + value: function (mask: string, local?: boolean) { + let d: Date = this + // @ts-ignore + return mask.replace(/"[^"]*"|'[^']*'|(?:d{1,2}|m{1,2}|yy(?:yy)?|([hHMs])\1?)/g, function ($0: string) { + switch ($0) { + case 'd': + return gd() + case 'dd': + return zeroize(gd()) + case 'M': + return gM() + 1 + case 'MM': + return zeroize(gM() + 1) + case 'yy': + return (gy() + '').substr(2) + case 'yyyy': + return gy() + case 'h': + return gH() % 12 || 12 + case 'hh': + return zeroize(gH() % 12 || 12) + case 'H': + return gH() + case 'HH': + return zeroize(gH()) + case 'm': + return gm() + case 'mm': + return zeroize(gm()) + case 's': + return gs() + case 'ss': + return zeroize(gs()) + default: + return $0.substr(1, $0.length - 2) + } + }) + + function gd() { + return local ? d.getDate() : d.getUTCDate() + } + + function gM() { + return local ? d.getMonth() : d.getUTCMonth() + } + + function gy() { + return local ? d.getFullYear() : d.getUTCFullYear() + } + + function gH() { + return local ? d.getHours() : d.getUTCHours() + } + + function gm() { + return local ? d.getMinutes() : d.getUTCMinutes() + } + + function gs() { + return local ? d.getSeconds() : d.getUTCSeconds() + } + }, + writable: true, + }, + + addDays: { + value: function (days: number) { + this.setDate(this.getDate() + days) + return this + }, + writable: true, + }, +}) + +/****************************************扩展Array****************************************/ +const enum ArraySort { + /** + * 升序 + */ + ASC = 0, + /** + * 降序 + */ + DESC = 1, +} + +interface ArrayConstructor { + // binaryInsert(partArr: T[], item: T, filter: { (tester: T, ...args): boolean }, ...args); + SORT_DEFAULT: { number: 0; string: ''; boolean: false } +} + +/** + * 用于对Array排序时,处理undefined + */ +Array.SORT_DEFAULT = { + number: 0, + string: '', + boolean: false, +} +Object.freeze(Array.SORT_DEFAULT) + +interface Array { + /** + * 如果数组中没有要放入的对象,则将对象放入数组 + * + * @param {T} t 要放入的对象 + * @returns {number} 放入的对象,在数组中的索引 + * + * @member Array + */ + pushOnce?(t: T): number + + /** + * + * 删除某个数据 + * @param {T} t + * @returns {boolean} true 有这个数据并且删除成功 + * false 没有这个数据 + */ + zremove?(t: T): boolean + + /** + * 排序 支持多重排序 + * 降序, 升序 + * @param {(keyof T)[]} kArr 参数属性列表 + * @param {(boolean[] | ArraySort[])} [dArr] 是否降序,默认升序 + * @returns {this} + * + * @member Array + */ + multiSort?(kArr: (keyof T)[], dArr?: boolean[] | ArraySort[]): this + + /** + * 默认排序 + * + * @param {string} [key] + * @param {boolean} [descend] + * + * @member Array + */ + doSort?(key?: keyof T, descend?: boolean | ArraySort): this + + doSort?(descend?: boolean | ArraySort, key?: keyof T): this + + /** + * 将数组克隆到to + * to的数组长度会和当前数组一致 + * + * @template T + * @param {Array} to + */ + cloneTo?(to: Array): void + + /** + * 将数组附加到to中 + * + * @template T + * @param {Array} to + * + * @member ArrayConstructor + */ + appendTo?(to: Array): void + + /** + * 移除数组index位置的元素, 比slice效率高 + * @param index + */ + spliceOne?(index: number): boolean + + /** + * 随机排序 + */ + randomSort?(): void + + /** + * 检查数组中是否含有另外一个object + * @param obj 与数组同类型的obj | 同类型的数组 | 指定child字段的值 | 指定child字段的数组 + * @param child 比较字段 + */ + contains?(obj: T | T[] | {} | {}[], child?: string): boolean + + /** + * 将数组随机插入当前数组中 + * @param arr + */ + randomInsert?(arr: Array): void + + /** + * 随机获取n个元素 + * @param count + */ + randomGet?(count?: number): T[] + + /** + * 随机获取1个元素 + */ + randomOne?(): T + + /** + * 随机移除n个元素 + * @param count + */ + randomRemove?(count?: number): T[] + + /** + * 数组移动n位 + * @param n n > 0 右移, n<0 左移 + */ + moveElement?(n: number): T[] + + /** + * 两个数组并集 + * @param arr + */ + union?(arr: T[]): T[] + + /** + * 两个数组交集 + * @param arr + */ + intersect?(arr: T[]): T[] + + /** + * 相对于arr的差集 + * @param arr + */ + difference?(arr: T[]): T[] + + /** + * 转换成Map + * @param {string} key 用于生成map的key字段名 + * @return {Map} + */ + toMap?(key: string): Map +} + +Object.defineProperties(Array.prototype, { + cloneTo: { + value: function (this: T[], b: any[]) { + b.length = this.length + let len = this.length + b.length = len + for (let i = 0; i < len; i++) { + b[i] = this[i] + } + }, + writable: true, + }, + appendTo: { + value: function (this: T[], b: any[]) { + let len = this.length + for (let i = 0; i < len; i++) { + b.push(this[i]) + } + }, + writable: true, + }, + pushOnce: { + value: function (this: T[], t: T) { + let idx = this.indexOf(t) + if (!~idx) { + idx = this.length + this.push(t) + } + return idx + }, + writable: true, + }, + zremove: { + value: function (this: T[], t: T) { + let idx = this.indexOf(t) + if (~idx) { + this.splice(idx, 1) + return true + } + return false + }, + writable: true, + }, + doSort: { + value: function () { + let key: string, descend: boolean + let len = arguments.length + + for (let i = 0; i < len; i++) { + let arg = arguments[i] + let t = typeof arg + if (t === 'string') { + key = arg + } else { + descend = !!arg + } + } + if (key) { + return this.sort((a: any, b: any) => (descend ? b[key] - a[key] : a[key] - b[key])) + } else { + return this.sort((a: any, b: any) => (descend ? b - a : a - b)) + } + }, + writable: true, + }, + multiSort: { + value: function (kArr: string[], dArr?: boolean[] | boolean) { + let isArr = Array.isArray(dArr) + return this.sort((a: any, b: any): number => { + const def = Array.SORT_DEFAULT + for (let idx = 0, len = kArr.length; idx < len; idx++) { + let key = kArr[idx] + // @ts-ignore + let mode = isArr ? !!dArr[idx] : !!dArr + let av = a[key] + let bv = b[key] + let typea = typeof av + let typeb = typeof bv + if (typea == 'object' || typeb == 'object') { + return 0 + } else if (typea != typeb) { + if (typea == 'undefined') { + // @ts-ignore + bv = def[typeb] + } else if (typeb == 'undefined') { + // @ts-ignore + av = def[typea] + } else { + return 0 + } + } + if (av < bv) { + return mode ? 1 : -1 + } else if (av > bv) { + return mode ? -1 : 1 + } else { + continue + } + } + return 0 + }) + }, + writable: true, + }, + spliceOne: { + value: function (index: number): boolean { + if (index === -1 || index >= this.length) { + return false + } + const len = this.length - 1 + for (let i = index; i < len; i++) { + this[i] = this[i + 1] + } + this.length = len + return true + }, + writable: true, + }, + + randomSort: { + value: function () { + for (let j, x, i = this.length; i; j = (Math.random() * i) | 0, x = this[--i], this[i] = this[j], this[j] = x) {} + }, + writable: true, + }, + contains: { + value: function (obj: T | T[] | {} | {}[], child?: string): boolean { + let result = false + if (child) { + const isArr = Array.isArray(obj) + if (isArr) { + // @ts-ignore + if (obj[0].hasOwnProperty(child)) { + let set0 = new Set() + // @ts-ignore + for (let s of obj) { + // @ts-ignore + set0.add(s[child]) + } + // @ts-ignore + let set1 = new Set(this.filter(x => set0.has(x))) + return set0.size === set1.size + } else { + // @ts-ignore + let set0 = new Set(obj) + let set1 = new Set(this.filter((x: {}) => set0.has(x))) + return set1.size === set0.size + } + } else { + if (obj.hasOwnProperty(child)) { + for (let sub of this) { + if (sub.hasOwnProperty(child)) { + // @ts-ignore + if (sub[child] === obj[child]) { + result = true + break + } + } + } + } else { + for (let sub of this) { + if (sub.hasOwnProperty(child)) { + // @ts-ignore + if (sub[child] === obj) { + result = true + break + } + } + } + } + } + } else { + // 不指定 比较字段 的话, 只处理2种情况 + // 1: obj 为数组 + // 2: obj 不是数组 + if (Array.isArray(obj)) { + let set0 = new Set(obj) + // @ts-ignore + let set1 = new Set(this.filter(x => set0.has(x))) + return set1.size === set0.size + } else { + let idx = this.indexOf(obj) + return !!~idx + } + } + return result + }, + writable: true, + }, + randomInsert: { + value: function (arr: Array) { + const length = this.length + arr.forEach(value => { + this.splice(Math.random() * length, 0, value) + }) + }, + writable: true, + }, + randomGet: { + value: function (count: number = 1): T[] { + let shuffled: T[] = this.slice(0), + i = this.length, + min = i - count, + temp, + index + if (min < 0) { + return shuffled + } + while (i-- > min) { + index = Math.floor((i + 1) * Math.random()) + temp = shuffled[index] + shuffled[index] = shuffled[i] + shuffled[i] = temp + } + return shuffled.slice(min) + }, + writable: true, + }, + randomOne: { + value: function (): T { + let results = this.randomGet(1) + if (results.length > 0) { + return results[0] + } else { + return null + } + }, + writable: true, + }, + randomRemove: { + value: function (count: number = 1): T[] { + let result = [] + while (count-- > 0 && this.length > 0) { + let index = (Math.random() * this.length) | 0 + result.push(...this.splice(index, 1)) + } + return result + }, + writable: true, + }, + + moveElement: { + value: function (n: number): T[] { + if (Math.abs(n) > this.length) n = n % this.length + return this.slice(-n).concat(this.slice(0, -n)) + }, + writable: true, + }, + + union: { + value: function (this: T[], b: any[]): T[] { + let a = this.concat(b) + return [...new Set(a)] + }, + writable: true, + }, + + intersect: { + value: function (this: T[], b: any[]): T[] { + let set0 = new Set(b) + let set1 = new Set(this.filter(x => set0.has(x))) + return [...set1] + }, + writable: true, + }, + + difference: { + value: function (this: T[], b: any[]): T[] { + let set0 = new Set(b) + let set1 = new Set(this.filter(x => !set0.has(x))) + return [...set1] + }, + writable: true, + }, + + toMap: { + value: function (this: T[], key: string) { + let result: Map = new Map() + for (const o of this) { + // @ts-ignore + result.set(o[key], o) + } + return result + }, + writable: true, + }, +}) + +interface Map { + /** + * 只针对V为number的Map, 有值的话, 加上V, 没值则直接set + * V为其他类型时, 直接set + * @param key + * @param value + */ + inc?(key: K, value: V): number +} + +Object.defineProperties(Map.prototype, { + inc: { + value: function (key: K, value: V) { + if (typeof value == 'number') { + this.set(key, (this.get(key) || 0) + value) + } else { + this.set(key, value) + } + return this.get(key) + }, + }, +}) diff --git a/src/common/ZError.ts b/src/common/ZError.ts new file mode 100644 index 0000000..ffe0623 --- /dev/null +++ b/src/common/ZError.ts @@ -0,0 +1,13 @@ +import { FastifyError } from 'fastify' + +export class ZError implements FastifyError { + code: string + statusCode?: number + message: string + name: string + + constructor(statusCode: number, message: string) { + this.statusCode = statusCode + this.message = message + } +} diff --git a/src/common/base.controller.ts b/src/common/base.controller.ts new file mode 100644 index 0000000..2fda6fe --- /dev/null +++ b/src/common/base.controller.ts @@ -0,0 +1,7 @@ +import fastify = require('fastify') + +export const ROLE_ANON = 'anon' +class BaseController { + aotoRoute(req: fastify.FastifyRequest, res) {} +} +export default BaseController diff --git a/src/config/config.ts b/src/config/config.ts new file mode 100644 index 0000000..b62e16e --- /dev/null +++ b/src/config/config.ts @@ -0,0 +1,50 @@ +import * as dotenv from "dotenv"; +import assert from "assert"; +const NODE_ENV = process.env.NODE_ENV || "development"; + +dotenv.config(); +let path; +switch (process.env.NODE_ENV) { + case "test": + path = `${__dirname}/../../.env.development`; + break; + case "production": + path = `${__dirname}/../../.env.production`; + break; + default: + path = `${__dirname}/../../.env.development`; +} +dotenv.config({ path: path, debug: NODE_ENV === "development" }); + +assert( + process.env.API_TOKEN_SECRET_PRIVATE, + "API_TOKEN_SECRET_PRIVATE not set" +); +assert(process.env.API_TOKEN_SECRET_PUBLIC, "API_TOKEN_SECRET_PUBLIC not set"); +assert(process.env.API_TOKEN_EXPIRESIN, "API_TOKEN_EXPIRESIN not set"); + +const privateKey = ` +-----BEGIN PRIVATE KEY----- +${process.env.API_TOKEN_SECRET_PRIVATE} +-----END PRIVATE KEY----- +`; +const publicKey = ` +-----BEGIN PUBLIC KEY----- +${process.env.API_TOKEN_SECRET_PUBLIC} +-----END PUBLIC KEY----- +`; + +let baseConfig = { + api: { + port: parseInt(process.env.API_PORT), + host: process.env.API_HOST, + token_secret_private: privateKey, + token_secret_public: publicKey, + token_expiresIn: process.env.API_TOKEN_EXPIRESIN, + }, + + db_main: process.env.DB_MAIN, + db_second: process.env.DB_SECOND, +}; + +export default baseConfig; diff --git a/src/config/datas.ts b/src/config/datas.ts new file mode 100644 index 0000000..6bb4439 --- /dev/null +++ b/src/config/datas.ts @@ -0,0 +1,2158 @@ +export const TEST_FIAT_LIST = [ + { + country: 'US', + currency: 'USD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 15.0, + payMax: 5000.0, + countryName: 'United States', + }, + { + country: 'DE', + currency: 'EUR', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.41, + feeRate: 0.0399, + payMin: 14.08, + payMax: 1876.7, + countryName: 'Germany', + }, + { + country: 'GB', + currency: 'GBP', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.36, + feeRate: 0.0399, + payMin: 13.0, + payMax: 4452.0, + countryName: 'United Kingdom', + }, + { + country: 'TW', + currency: 'TWD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 12.83, + feeRate: 0.0399, + payMin: 481.0, + payMax: 160343.0, + countryName: 'Taiwan, Province of China', + }, + { + country: 'HK', + currency: 'HKD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 3.14, + feeRate: 0.0399, + payMin: 117.0, + payMax: 39249.0, + countryName: 'Hong Kong', + }, + { + country: 'TH', + currency: 'THB', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 15.27, + feeRate: 0.0399, + payMin: 572.0, + payMax: 190842.0, + countryName: 'Thailand', + }, + { + country: 'SE', + currency: 'SEK', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 4.51, + feeRate: 0.0399, + payMin: 169.0, + payMax: 56403.0, + countryName: 'Sweden', + }, + { + country: 'RO', + currency: 'RON', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 2.02, + feeRate: 0.0399, + payMin: 75.0, + payMax: 25303.0, + countryName: 'Romania', + }, + { + country: 'PL', + currency: 'PLN', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 1.98, + feeRate: 0.0399, + payMin: 74.0, + payMax: 24782.0, + countryName: 'Poland', + }, + { + country: 'NZ', + currency: 'NZD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.72, + feeRate: 0.0399, + payMin: 26.0, + payMax: 8940.0, + countryName: 'New Zealand', + }, + { + country: 'NO', + currency: 'NOK', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 4.25, + feeRate: 0.0399, + payMin: 159.0, + payMax: 53162.0, + countryName: 'Norway', + }, + { + country: 'MY', + currency: 'MYR', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 1.89, + feeRate: 0.0399, + payMin: 70.0, + payMax: 23582.0, + countryName: 'Malaysia', + }, + { + country: 'MX', + currency: 'MXN', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 9.0, + feeRate: 0.0399, + payMin: 300.0, + payMax: 100041.0, + countryName: 'Mexico', + }, + { + country: 'MK', + currency: 'MKD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 25.29, + feeRate: 0.0399, + payMin: 948.0, + payMax: 316147.0, + countryName: 'North Macedonia', + }, + { + country: 'MD', + currency: 'MDL', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 7.74, + feeRate: 0.0399, + payMin: 290.0, + payMax: 96756.0, + countryName: 'Moldova, Republic of', + }, + { + country: 'KZ', + currency: 'KZT', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 190.21, + feeRate: 0.0399, + payMin: 7132.0, + payMax: 2377615.0, + countryName: 'Kazakhstan', + }, + { + country: 'KR', + currency: 'KRW', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 573.5, + feeRate: 0.0399, + payMin: 21506.0, + payMax: 7168700.0, + countryName: 'Korea', + }, + { + country: 'IL', + currency: 'ILS', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 1.42, + feeRate: 0.0399, + payMin: 53.0, + payMax: 17714.0, + countryName: 'Israel', + }, + { + country: 'DK', + currency: 'DKK', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 3.05, + feeRate: 0.0399, + payMin: 114.0, + payMax: 38181.0, + countryName: 'Denmark', + }, + { + country: 'BR', + currency: 'BRL', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 2.13, + feeRate: 0.0399, + payMin: 79.0, + payMax: 26644.0, + countryName: 'Brazil', + }, + { + country: 'CA', + currency: 'CAD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.55, + feeRate: 0.0399, + payMin: 20.0, + payMax: 691.0, + countryName: 'Canada', + }, + { + country: 'AU', + currency: 'AUD', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.64, + feeRate: 0.0399, + payMin: 24.0, + payMax: 8016.0, + countryName: 'Australia', + }, + { + country: 'CH', + currency: 'CHF', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 15.0, + payMax: 5010.0, + countryName: 'Switzerland', + }, + { + country: 'BG', + currency: 'BGN', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 15.0, + payMax: 5008.0, + countryName: 'Bulgaria', + }, + { + country: 'VN', + currency: 'VND', + payWayCode: '201', + payWayName: 'MoMo', + fixedFee: 9000.0, + feeRate: 0.0399, + payMin: 370000.0, + payMax: 72000000.0, + countryName: 'Viet Nam', + }, + { + country: 'VN', + currency: 'VND', + payWayCode: '202', + payWayName: 'ZaloPay', + fixedFee: 9000.0, + feeRate: 0.0399, + payMin: 370000.0, + payMax: 72000000.0, + countryName: 'Viet Nam', + }, + { + country: 'VN', + currency: 'VND', + payWayCode: '203', + payWayName: 'ViettelPay ', + fixedFee: 9000.0, + feeRate: 0.0399, + payMin: 370000.0, + payMax: 72000000.0, + countryName: 'Viet Nam', + }, + { + country: 'VN', + currency: 'VND', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 9000.0, + feeRate: 0.0399, + payMin: 370000.0, + payMax: 72000000.0, + countryName: 'Viet Nam', + }, + { + country: 'BR', + currency: 'BRL', + payWayCode: '30001', + payWayName: 'Pix Pay', + fixedFee: 2.13, + feeRate: 0.0399, + payMin: 79.0, + payMax: 26644.0, + countryName: 'Brazil', + }, + { + country: 'US', + currency: 'USD', + payWayCode: '20001', + payWayName: 'Binance Pay', + fixedFee: 0.3, + feeRate: 0.0299, + payMin: 15.0, + payMax: 2000.0, + countryName: 'United States', + }, + { + country: 'PH', + currency: 'PHP', + payWayCode: '80059', + payWayName: 'GCASH', + fixedFee: 0.1, + feeRate: 0.051, + payMin: 1.0, + payMax: 100000.0, + countryName: 'Philippines', + }, + { + country: 'PH', + currency: 'PHP', + payWayCode: '90007', + payWayName: 'QRPH', + fixedFee: 0.0, + feeRate: 0.035, + payMin: 900.0, + payMax: 50000.0, + countryName: 'Philippines', + }, + { + country: 'PH', + currency: 'PHP', + payWayCode: '80040', + payWayName: 'BPI', + fixedFee: 0.0, + feeRate: 0.035, + payMin: 900.0, + payMax: 50000.0, + countryName: 'Philippines', + }, + { + country: 'PH', + currency: 'PHP', + payWayCode: '80070', + payWayName: 'RCBC', + fixedFee: 0.0, + feeRate: 0.035, + payMin: 900.0, + payMax: 50000.0, + countryName: 'Philippines', + }, + { + country: 'PH', + currency: 'PHP', + payWayCode: '80041', + payWayName: 'UNION_BANK', + fixedFee: 0.0, + feeRate: 0.035, + payMin: 900.0, + payMax: 50000.0, + countryName: 'Philippines', + }, + { + country: 'SG', + currency: 'SGD', + payWayCode: '40001', + payWayName: 'PAY NOW', + fixedFee: 0.0, + feeRate: 0.02, + payMin: 25.0, + payMax: 2000.0, + countryName: 'Singapore', + }, + { + country: 'TH', + currency: 'THB', + payWayCode: '40003', + payWayName: 'THAI_QR', + fixedFee: 0.0, + feeRate: 0.025, + payMin: 600.0, + payMax: 200000.0, + countryName: 'Thailand', + }, + { + country: 'DE', + currency: 'EUR', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.376, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Germany', + }, + { + country: 'DZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Algeria', + }, + { + country: 'AO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Angola', + }, + { + country: 'AR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Argentina', + }, + { + country: 'AU', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Australia', + }, + { + country: 'BS', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Bahamas', + }, + { + country: 'BH', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Bahrain', + }, + { + country: 'BD', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Bangladesh', + }, + { + country: 'AM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Armenia', + }, + { + country: 'BB', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Barbados', + }, + { + country: 'BM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Bermuda', + }, + { + country: 'BT', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Bhutan', + }, + { + country: 'BW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Botswana', + }, + { + country: 'BR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Brazil', + }, + { + country: 'BZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Belize', + }, + { + country: 'BN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Brunei Darussalam', + }, + { + country: 'MM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Myanmar', + }, + { + country: 'BI', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Burundi', + }, + { + country: 'KH', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Cambodia', + }, + { + country: 'CM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Cameroon', + }, + { + country: 'CA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Canada', + }, + { + country: 'CV', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Cabo Verde', + }, + { + country: 'CF', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Central African Republic', + }, + { + country: 'LK', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Sri Lanka', + }, + { + country: 'CL', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Chile', + }, + { + country: 'TW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Taiwan, Province of China', + }, + { + country: 'CX', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Christmas Island', + }, + { + country: 'CO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Colombia', + }, + { + country: 'KM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Comoros', + }, + { + country: 'YT', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mayotte', + }, + { + country: 'CK', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Cook Islands', + }, + { + country: 'CR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Costa Rica', + }, + { + country: 'CU', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Cuba', + }, + { + country: 'CY', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Cyprus', + }, + { + country: 'BJ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Benin', + }, + { + country: 'DM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Dominica', + }, + { + country: 'DO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Dominican Republic', + }, + { + country: 'EC', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Ecuador', + }, + { + country: 'SV', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'El Salvador', + }, + { + country: 'GQ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Equatorial Guinea', + }, + { + country: 'ET', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Ethiopia', + }, + { + country: 'ER', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Eritrea', + }, + { + country: 'FJ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Fiji', + }, + { + country: 'AX', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Åland Islands', + }, + { + country: 'DJ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Djibouti', + }, + { + country: 'GA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Gabon', + }, + { + country: 'GE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Georgia', + }, + { + country: 'GM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Gambia', + }, + { + country: 'GH', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Ghana', + }, + { + country: 'KI', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Kiribati', + }, + { + country: 'GL', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Greenland', + }, + { + country: 'GD', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Grenada', + }, + { + country: 'GP', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guadeloupe', + }, + { + country: 'GU', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guam', + }, + { + country: 'GT', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guatemala', + }, + { + country: 'GN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guinea', + }, + { + country: 'GY', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guyana', + }, + { + country: 'HT', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Haiti', + }, + { + country: 'HN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Honduras', + }, + { + country: 'HK', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Hong Kong', + }, + { + country: 'IS', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Iceland', + }, + { + country: 'IN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'India', + }, + { + country: 'ID', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Indonesia', + }, + { + country: 'IL', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Israel', + }, + { + country: 'CI', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: "Côte d'Ivoire", + }, + { + country: 'JM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Jamaica', + }, + { + country: 'KZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Kazakhstan', + }, + { + country: 'JO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Jordan', + }, + { + country: 'KE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Kenya', + }, + { + country: 'KR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Korea', + }, + { + country: 'KW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Kuwait', + }, + { + country: 'KG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Kyrgyzstan', + }, + { + country: 'LA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: "Lao People's Democratic Republic", + }, + { + country: 'LB', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Lebanon', + }, + { + country: 'LS', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Lesotho', + }, + { + country: 'LR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Liberia', + }, + { + country: 'MO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Macao', + }, + { + country: 'MG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Madagascar', + }, + { + country: 'MW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Malawi', + }, + { + country: 'MY', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Malaysia', + }, + { + country: 'MV', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Maldives', + }, + { + country: 'ML', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mali', + }, + { + country: 'MQ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Martinique', + }, + { + country: 'MR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mauritania', + }, + { + country: 'MU', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mauritius', + }, + { + country: 'MX', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mexico', + }, + { + country: 'MC', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Monaco', + }, + { + country: 'MN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mongolia', + }, + { + country: 'MS', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Montserrat', + }, + { + country: 'MZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Mozambique', + }, + { + country: 'OM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Oman', + }, + { + country: 'NA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Namibia', + }, + { + country: 'NR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Nauru', + }, + { + country: 'CW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Curaçao', + }, + { + country: 'AW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Aruba', + }, + { + country: 'NC', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'New Caledonia', + }, + { + country: 'VU', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Vanuatu', + }, + { + country: 'NZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'New Zealand', + }, + { + country: 'NI', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Nicaragua', + }, + { + country: 'NE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Niger', + }, + { + country: 'NG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Nigeria', + }, + { + country: 'NU', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Niue', + }, + { + country: 'PW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Palau', + }, + { + country: 'PA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Panama', + }, + { + country: 'PG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Papua New Guinea', + }, + { + country: 'PY', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Paraguay', + }, + { + country: 'PE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Peru', + }, + { + country: 'PH', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Philippines', + }, + { + country: 'PN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Pitcairn', + }, + { + country: 'GW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guinea-Bissau', + }, + { + country: 'TL', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Timor-Leste', + }, + { + country: 'QA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Qatar', + }, + { + country: 'RE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Réunion', + }, + { + country: 'RW', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Rwanda', + }, + { + country: 'BL', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Saint Barthélemy', + }, + { + country: 'KN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Saint Kitts and Nevis', + }, + { + country: 'AI', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Anguilla', + }, + { + country: 'LC', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Saint Lucia', + }, + { + country: 'MF', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Saint Martin (French part)', + }, + { + country: 'SA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Saudi Arabia', + }, + { + country: 'SN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Senegal', + }, + { + country: 'SC', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Seychelles', + }, + { + country: 'SL', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Sierra Leone', + }, + { + country: 'SG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Singapore', + }, + { + country: 'VN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Viet Nam', + }, + { + country: 'SO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Somalia', + }, + { + country: 'ZA', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'South Africa', + }, + { + country: 'EH', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Western Sahara', + }, + { + country: 'SR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Suriname', + }, + { + country: 'SZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Eswatini', + }, + { + country: 'TJ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Tajikistan', + }, + { + country: 'TH', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Thailand', + }, + { + country: 'TG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Togo', + }, + { + country: 'TK', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Tokelau', + }, + { + country: 'TO', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Tonga', + }, + { + country: 'AE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'United Arab Emirates', + }, + { + country: 'TN', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Tunisia', + }, + { + country: 'TR', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Turkey', + }, + { + country: 'TM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Turkmenistan', + }, + { + country: 'TV', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Tuvalu', + }, + { + country: 'UG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Uganda', + }, + { + country: 'EG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Egypt', + }, + { + country: 'GG', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Guernsey', + }, + { + country: 'JE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Jersey', + }, + { + country: 'IM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Isle of Man', + }, + { + country: 'TZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Tanzania, United Republic of', + }, + { + country: 'UY', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Uruguay', + }, + { + country: 'UZ', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Uzbekistan', + }, + { + country: 'VE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Venezuela (Bolivarian Republic of)', + }, + { + country: 'WF', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Wallis and Futuna', + }, + { + country: 'WS', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Samoa', + }, + { + country: 'YE', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Yemen', + }, + { + country: 'ZM', + currency: 'USD', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 0.4, + feeRate: 0.0399, + payMin: 1.0, + payMax: 5000.0, + countryName: 'Zambia', + }, + { + country: 'HR', + currency: 'EUR', + payWayCode: '20001', + payWayName: 'Binance Pay', + fixedFee: 0.3, + feeRate: 0.0299, + payMin: 15.0, + payMax: 2000.0, + countryName: 'Croatia', + }, + { + country: 'JP', + currency: 'JPY', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 52.0, + feeRate: 0.0399, + payMin: 1800.0, + payMax: 700000.0, + countryName: 'Japan', + }, + { + country: 'JP', + currency: 'JPY', + payWayCode: '501', + payWayName: 'Apple Pay', + fixedFee: 52.0, + feeRate: 0.0399, + payMin: 1800.0, + payMax: 700000.0, + countryName: 'Japan', + }, + { + country: 'VN', + currency: 'VND', + payWayCode: '210', + payWayName: 'Bank Transfer', + fixedFee: 2000.0, + feeRate: 0.03, + payMin: 300000.0, + payMax: 120000000.0, + countryName: 'Viet Nam', + }, + { + country: 'NG', + currency: 'NGN', + payWayCode: '18000', + payWayName: 'Bank Transfer', + fixedFee: 0.0, + feeRate: 0.0125, + payMin: 5000.0, + payMax: 8000000.0, + countryName: 'Nigeria', + }, + { + country: 'AE', + currency: 'AED', + payWayCode: '10001', + payWayName: 'Credit Card', + fixedFee: 1.4, + feeRate: 0.0399, + payMin: 55.0, + payMax: 18362.0, + countryName: 'United Arab Emirates', + }, +] diff --git a/src/controllers/discord.controller.ts b/src/controllers/discord.controller.ts new file mode 100644 index 0000000..6770a13 --- /dev/null +++ b/src/controllers/discord.controller.ts @@ -0,0 +1,22 @@ +import BaseController, { ROLE_ANON } from "common/base.controller"; +import { ZError } from "common/ZError"; +import { role, router } from "decorators/router"; +import logger from "logger/logger"; +import { exchangeDiscrodCodeForToken, userInfo } from "services/discord.svr"; + +class DiscordController extends BaseController { + @role(ROLE_ANON) + @router("get /discord/redirect_uri") + async discordCallback(req, res) { + let { code } = req.params; + logger.info("discord redirect: ", req.params); + let access_token = ""; + if (code) { + access_token = await exchangeDiscrodCodeForToken(code); + let uinfo = await userInfo(access_token); + return res.view("/templates/discord_redirect.ejs"); + } else { + return res.view("/templates/discord_redirect.ejs"); + } + } +} diff --git a/src/controllers/main.controller.ts b/src/controllers/main.controller.ts new file mode 100644 index 0000000..c64b479 --- /dev/null +++ b/src/controllers/main.controller.ts @@ -0,0 +1,15 @@ +import BaseController, { ROLE_ANON } from "common/base.controller"; +import { ZError } from "common/ZError"; +import { role, router } from "decorators/router"; +import logger from "logger/logger"; + +class MainController extends BaseController { + /** + * Refresh token + */ + @role(ROLE_ANON) + @router("post /open/api/v3/merchant/getToken") + async getToken(req, res) { + return {}; + } +} diff --git a/src/controllers/page.controller.ts b/src/controllers/page.controller.ts new file mode 100644 index 0000000..1bfe34a --- /dev/null +++ b/src/controllers/page.controller.ts @@ -0,0 +1,11 @@ +import BaseController, { ROLE_ANON } from "common/base.controller"; +import { role, router } from "decorators/router"; +import { checkPageSign } from "services/alchemy.svr"; + +class PageController extends BaseController { + @role(ROLE_ANON) + @router("get /discord/redirect_page") + async discordResirect(req, res) { + return res.view("/templates/discord_redirect.ejs"); + } +} diff --git a/src/decorators/dbconn.ts b/src/decorators/dbconn.ts new file mode 100644 index 0000000..9bdf96b --- /dev/null +++ b/src/decorators/dbconn.ts @@ -0,0 +1,13 @@ +import { mongoose } from '@typegoose/typegoose' +import config from 'config/config' +/** + * 为model指定数据库连接 + * @param {string} name 数据库连接名字, 在config中必须要有对应的配置, 比如main, 则必须要有 db_main + * */ +export function dbconn(name?: string) { + return target => { + name = name || 'main' + const url = config['db_' + name] + target['db'] = mongoose.createConnection(url, {}) + } +} diff --git a/src/decorators/nojson.ts b/src/decorators/nojson.ts new file mode 100644 index 0000000..90f4ba2 --- /dev/null +++ b/src/decorators/nojson.ts @@ -0,0 +1,29 @@ +import 'reflect-metadata' +import { singleton } from './singleton' + +@singleton +export class NoJsonClass { + private noJsonPropSet: Set = new Set() + + public addKey(className: string, propertyKey: string) { + this.noJsonPropSet.add(className + '_' + propertyKey) + } + + public checkExist(className: string, propertyKey: string) { + return this.noJsonPropSet.has(className + '_' + propertyKey) + } +} +/** + * 在不需要toJson方法输出的字段上加上 @noJson + * @return {{(target: Function): void, (target: Object, propertyKey: (string | symbol)): void}} + */ +export function noJson() { + // return Reflect.metadata(noJsonMetadataKey, !0) + return function (target: Object, propertyKey: string) { + new NoJsonClass().addKey(target.constructor.name, propertyKey) + } +} + +export function checkJson(target: any, propertyKey: string) { + return !new NoJsonClass().checkExist(target.constructor.modelName, propertyKey) +} diff --git a/src/decorators/router.ts b/src/decorators/router.ts new file mode 100644 index 0000000..366aa6f --- /dev/null +++ b/src/decorators/router.ts @@ -0,0 +1,142 @@ +import BaseController from '../common/base.controller' + +export class RouterData { + target?: any + method?: string + path?: string + fun?: Function +} + +export class RouterMap { + static decoratedRouters: Map< + Function, + { + roles?: string[] + permissions?: string[][] + data?: RouterData[] + depts?: string[] + } + > = new Map() +} + +export function router(route?: string) { + return (target: BaseController, name: string, value: PropertyDescriptor) => { + if (!route) { + const controller = target.constructor.name + const controllerName = controller.toLowerCase().replace('.controller', '') + route = 'all ' + ['', controllerName, name].join('/') + } + const split = route.split(' ') + if (split.length > 2) { + throw new Error('路由中只允许一个空格') + } + const [method, path] = split + // @ts-ignore + const key = target[name] + let routerData = new RouterData() + routerData.target = target + routerData.method = method + routerData.path = path + // @ts-ignore + routerData.fun = target[name] + + if (RouterMap.decoratedRouters.has(key)) { + let objCurrent = RouterMap.decoratedRouters.get(key) + if (!objCurrent.data) { + objCurrent.data = [routerData] + } else { + objCurrent.data.push(routerData) + } + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], objCurrent) + } else { + let routerObj = { + data: [routerData], + } + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], routerObj) + } + } +} + +export function role(roles?: string | string[]) { + return (target: BaseController, name: string, value: PropertyDescriptor) => { + let roleList: string[] = [] + if (roles) { + if (Array.isArray(roles)) { + roleList = roles + } else { + roleList = [roles] + } + } + // @ts-ignore + const key = target[name] + let roleObj = { roles: roleList } + if (RouterMap.decoratedRouters.has(key)) { + let objCurrent = RouterMap.decoratedRouters.get(key) + Object.assign(objCurrent, roleObj) + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], objCurrent) + } else { + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], roleObj) + } + } +} + +export function permission(permissions?: string | string[]) { + return (target: BaseController, name: string, value: PropertyDescriptor) => { + let permissionList: string[][] = [[]] + if (permissions) { + if (Array.isArray(permissions)) { + let arr = [] + for (let sub of permissions) { + arr.push(sub.split(':')) + } + permissionList = arr + } else { + permissionList = [permissions.split(':')] + } + } + // @ts-ignore + const key = target[name] + let permissionObj = { permissions: permissionList } + if (RouterMap.decoratedRouters.has(key)) { + let objCurrent = RouterMap.decoratedRouters.get(key) + Object.assign(objCurrent, permissionObj) + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], objCurrent) + } else { + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], permissionObj) + } + } +} + +/** + * 有dept修饰器的, 需要验证部门id是否存在 + */ +export function dept(depts?: string | string[]) { + return (target: BaseController, name: string, value: PropertyDescriptor) => { + let deptList: string[] = [] + if (depts) { + if (Array.isArray(depts)) { + deptList = depts + } else { + deptList = [depts] + } + } + // @ts-ignore + const key = target[name] + let deptObj = { depts: deptList } + if (RouterMap.decoratedRouters.has(key)) { + let objCurrent = RouterMap.decoratedRouters.get(key) + Object.assign(objCurrent, deptObj) + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], objCurrent) + } else { + // @ts-ignore + RouterMap.decoratedRouters.set(target[name], deptObj) + } + } +} diff --git a/src/decorators/singleton.ts b/src/decorators/singleton.ts new file mode 100644 index 0000000..c43327d --- /dev/null +++ b/src/decorators/singleton.ts @@ -0,0 +1,29 @@ +/** + * 单例化一个class + * 使用方法: + * @singleton + * class Test {} + * new Test() === new Test() // returns `true` + * 也可以不使用 decorator + * const TestSingleton = singleton(Test) + * new TestSingleton() === new TestSingleton() //returns 'true' + */ + +export const SINGLETON_KEY = Symbol() + +export type Singleton any> = T & { + [SINGLETON_KEY]: T extends new (...args: any[]) => infer I ? I : never +} +export const singleton = any>(classTarget: T) => + new Proxy(classTarget, { + construct(target: Singleton, argumentsList, newTarget) { + // Skip proxy for children + if (target.prototype !== newTarget.prototype) { + return Reflect.construct(target, argumentsList, newTarget) + } + if (!target[SINGLETON_KEY]) { + target[SINGLETON_KEY] = Reflect.construct(target, argumentsList, newTarget) + } + return target[SINGLETON_KEY] + }, + }) diff --git a/src/logger/logger.ts b/src/logger/logger.ts new file mode 100644 index 0000000..8bbf745 --- /dev/null +++ b/src/logger/logger.ts @@ -0,0 +1,3 @@ +const level = process.env.NODE_ENV === 'production' ? 'info' : 'log' +const logger = require('tracer').colorConsole({ dateformat: 'yyyy-mm-dd HH:MM:ss.L', level }) +export default logger diff --git a/src/modules/Base.ts b/src/modules/Base.ts new file mode 100644 index 0000000..9d42f79 --- /dev/null +++ b/src/modules/Base.ts @@ -0,0 +1,219 @@ +import { FindOrCreate } from '@typegoose/typegoose/lib/defaultClasses' +import { checkJson, noJson } from '../decorators/nojson' +import { plugin, prop, ReturnModelType } from '@typegoose/typegoose' + +// @ts-ignore +import findOrCreate from 'mongoose-findorcreate' +import { Connection } from 'mongoose' +import { ObjectId } from 'bson' +import { isTrue } from '../utils/string.util' +import { AnyParamConstructor } from '@typegoose/typegoose/lib/types' + +const jsonExcludeKeys = ['updatedAt', '__v'] +const saveExcludeKeys = ['createdAt', 'updatedAt', '__v', '_id'] + +@plugin(findOrCreate) +export abstract class BaseModule extends FindOrCreate { + static db: Connection + + public updateFromReq(data: any) { + for (let key in data) { + if (saveExcludeKeys.indexOf(key) == -1) { + this[key] = data[key] + } + } + } + + /** + * 插入或更新 + * @param condition + * @param data + */ + public static insertOrUpdate( + this: ReturnModelType>, + condition: any, + data: any, + ) { + return this.findOneAndUpdate(condition, data, { upsert: true, new: true, setDefaultsOnInsert: true }) + } + + /** + * 虚拟删除 + * @param {string[]} ids + */ + public static deleteVirtual(this: ReturnModelType>, ids: string[]) { + return this.updateMany( + // @ts-ignore + { + _id: { $in: ids }, + }, + { + $set: { + deleted: true, + deleteTime: new Date(), + }, + }, + ) + } + + public static deleteRecords(this: ReturnModelType>, params) { + return this.updateMany(params, { + $set: { + deleted: true, + deleteTime: new Date(), + }, + }) + } + + /** + * 自定义分页查询 + * @param data + * @param {boolean} json + */ + public static async pageQuery( + this: ReturnModelType>, + data: any, + options?: any, + ) { + let { start, limit, page } = data + limit = +limit || 20 + start = +start || (+page - 1) * limit || 0 + // @ts-ignore + let { opt, sort } = this.parseQueryParam(data, options) + let records = await this.find(opt).sort(sort).skip(start).limit(limit) + let total = await this.countDocuments(opt) + if (options?.json) { + records = records.map((o: T) => o.toJson()) + } + return { records, total, start, limit } + } + + public toJson() { + let result: any = {} + // @ts-ignore + for (let key in this._doc) { + if (checkJson(this, key + '') && jsonExcludeKeys.indexOf(key) == -1) { + result[key] = this[key] + } + } + return result + } + + /** + * 通用的查询条件拼接方法 + * @param {{}} params req.params + * @param options + * sort: 排序 比如: {createdAt: 1} 默认是 {_id: 1} + * opt: 设置一些特殊的过滤条件, 比如{deleted: 0} + * timeKey: 如果需要查询创建时间, 而且创建时间不为 createdAt, 可以用此字段设置 + * matchKey: 指定关键字查询的匹配字段, 可为string或[string] + * + * @return {{opt: any, sort: {_id: number}}} + */ + public static parseQueryParam(params: {}, options?: any) { + const opt: any = { deleted: { $ne: true } } + // @ts-ignore + let obj = this.schema.paths + for (let key in params) { + if (key !== 'sort' && obj.hasOwnProperty(key)) { + switch (obj[key].instance) { + case 'String': + if (typeof params[key] === 'object') { + opt[key] = params[key] + } else { + opt[key] = { $regex: params[key], $options: 'i' } + } + break + case 'Number': + opt[key] = params[key] + break + case 'Array': + if (Array.isArray(params[key])) { + opt[key] = { $in: params[key] } + } else { + opt[key] = params[key] + } + break + case 'Date': + // TODO: + break + case 'Boolean': + opt[key] = isTrue(params[key]) + break + case 'ObjectID': + if (/^[0-9a-fA-F]{24}$/.test(params[key])) { + opt[key] = new ObjectId(params[key]) + } + break + } + } else if (key === '$or' || key == '$and') { + opt[key] = params[key] + } else if (key.indexOf('.') > 0) { + // 如果.在第一个字符, 明显是有问题的, 不需要处理这种 + opt[key] = params[key] + } + } + if (params.hasOwnProperty('key') && params['key']) { + let orArr = [] + if (options?.matchKey) { + if (Array.isArray(options?.matchKey)) { + for (let key in options?.matchKey) { + let _tmp = {} + _tmp[key] = { $regex: params['key'], $options: 'i' } + orArr.push(_tmp) + } + } else { + let _tmp = {} + _tmp[options.matchKey] = { $regex: params['key'], $options: 'i' } + orArr.push(_tmp) + } + } else { + for (let key in obj) { + if (obj[key].instance === 'String') { + let _tmp = {} + _tmp[key] = { $regex: params['key'], $options: 'i' } + orArr.push(_tmp) + } + } + } + + Object.assign(opt, { $or: orArr }) + } + let timeKey = options?.timeKey ? options.timeKey : 'createdAt' + if (params.hasOwnProperty('timeBegin') && !params.hasOwnProperty('timeEnd')) { + let timeBegin = params['timeBegin'] + if (!(timeBegin instanceof Date)) { + timeBegin = new Date(parseInt(timeBegin)) + } + opt[timeKey] = { $gte: timeBegin } + } else if (params.hasOwnProperty('timeBegin') && params.hasOwnProperty('timeEnd')) { + let timeBegin = params['timeBegin'] + if (!(timeBegin instanceof Date)) { + timeBegin = new Date(parseInt(timeBegin)) + } + let timeEnd = params['timeEnd'] + if (!(timeEnd instanceof Date)) { + timeEnd = new Date(parseInt(timeEnd)) + } + let tmpB = {} + tmpB[timeKey] = { $gte: timeBegin } + let tmpE = {} + tmpE[timeKey] = { $lte: timeEnd } + opt['$and'] = [tmpB, tmpE] + } else if (!params.hasOwnProperty('timeBegin') && params.hasOwnProperty('timeEnd')) { + let timeEnd = params['timeEnd'] + if (!(timeEnd instanceof Date)) { + timeEnd = new Date(parseInt(timeEnd)) + } + opt[timeKey] = { $lte: timeEnd } + } + if (options?.opt) { + Object.assign(opt, options.opt) + } + let sort = { _id: -1 } + if (params.hasOwnProperty('sort')) { + sort = params['sort'] + } + return { opt, sort } + } +} diff --git a/src/modules/PayRecord.ts b/src/modules/PayRecord.ts new file mode 100644 index 0000000..ee6cd4b --- /dev/null +++ b/src/modules/PayRecord.ts @@ -0,0 +1,96 @@ +import { getModelForClass, index, modelOptions, mongoose, prop, ReturnModelType, Severity } from '@typegoose/typegoose' +import { dbconn } from 'decorators/dbconn' +import { BaseModule } from './Base' + +export enum PayType { + BUY = 1, + SELL = 2, +} + +export enum PayStatus { + PENDING = 0, + TRANSFERING = 1, + TRANSFERED = 2, //只有国库模式才会有该状态 + SUCCESS = 9, + TRANSFER_FAIL = 98, // 转账错误 + FAIL = 99, +} + +@dbconn() +@index({ merchantOrderNo: 1 }, { unique: true, partialFilterExpression: { outOrderId: { $exists: true } } }) +@modelOptions({ + schemaOptions: { collection: 'pay_record', timestamps: true }, + options: { allowMixed: Severity.ALLOW }, +}) +export class PayRecordClass extends BaseModule { + @prop({ required: true, default: PayType.BUY }) + public type: PayType + + @prop() + public address: string + + @prop() + public network?: string + + @prop() + public crypto?: string + + // 法币 + @prop() + public fiat?: string + // 法币数量 + @prop() + public fiatAmount?: string + + @prop() + public processFee?: string + + @prop() + public networkFee?: string + + // 加密货币数量 + @prop() + public cryptoAmount?: string + + // 加密货币价格 + @prop() + public cryptoPrice?: string + // 该笔交易渠道会给我们多少usdt + @prop() + public usdtAmount?: string + // 国家 + @prop() + public country?: string + + @prop({ required: true, default: PayStatus.PENDING }) + public status: PayStatus + // 渠道返回的原始资料 + @prop({ type: mongoose.Schema.Types.Mixed }) + public outData: any + + // 商户订单id + @prop() + public merchantOrderNo: string + + @prop() + public email: string + + @prop() + public callbackUrl: string + + @prop() + public merchantName: string + + // 交易的txHash + @prop() + public txHash?: string + + @prop({ default: 0 }) + public version: number + + public static async findByRecordId(this: ReturnModelType, merchantOrderNo: string) { + return this.findOne({ merchantOrderNo }).exec() + } +} + +export const PayRecord = getModelForClass(PayRecordClass, { existingConnection: PayRecordClass.db }) diff --git a/src/plugins/apiauth.ts b/src/plugins/apiauth.ts new file mode 100644 index 0000000..2da5590 --- /dev/null +++ b/src/plugins/apiauth.ts @@ -0,0 +1,47 @@ +import { FastifyPluginAsync, FastifyReply, FastifyRequest } from 'fastify' +import fastifyPlugin from 'fastify-plugin' + +declare module 'fastify' { + interface FastifyRequest { + roles?: string[] + user?: any + token?: string + } + interface FastifyInstance { + apiAuth: (request: FastifyRequest, reply: FastifyReply) => {} + } +} + +export interface ApiAuthOptions { + secret: { + private: string + public: string + } + expiresIn: string +} + +const apiAuthPlugin: FastifyPluginAsync = async function (fastify, opts) { + fastify.register(require('@fastify/jwt'), { + secret: opts.secret, + sign: { expiresIn: opts.expiresIn, algorithm: 'EdDSA' }, + }) + // 只有路由配置的role为anon才不需要过滤 + fastify.decorate('apiAuth', async function (request: FastifyRequest, reply: FastifyReply) { + if (!request.roles || request.roles.indexOf('anon') == -1) { + // try { + // if (!request.token) { + // return reply.send({ errcode: 11, errmsg: 'need login' }) + // } + // //@ts-ignore + // const data = this.jwt.verify(request.token) + // if (!data || !data.id) { + // return reply.send({ errcode: 10, errmsg: 'need login' }) + // } + // } catch (err) { + // return reply.send({ errcode: 401, errmsg: 'need auth' }) + // } + } + }) +} + +export default fastifyPlugin(apiAuthPlugin, '4.x') diff --git a/src/plugins/zReqParser.ts b/src/plugins/zReqParser.ts new file mode 100644 index 0000000..b853d22 --- /dev/null +++ b/src/plugins/zReqParser.ts @@ -0,0 +1,37 @@ +import { + FastifyInstance, + FastifyPluginAsync, + FastifyReply, + FastifyRequest, +} from "fastify"; +import fastifyPlugin from "fastify-plugin"; + +/** + * 将post 和 get 的参数统一到 req.params + */ +declare module "fastify" { + interface FastifyInstance { + zReqParser: (request: FastifyRequest, reply: FastifyReply) => {}; + } +} +const zReqParserPlugin: FastifyPluginAsync = async function ( + fastify: FastifyInstance, + options?: any +) { + fastify.addHook( + "preValidation", + async (request: FastifyRequest, reply: FastifyReply) => { + let params = request.params || {}; + if (request.query) { + Object.assign(params, request.query); + } + if (request.body) { + Object.assign(params, request.body); + } + request.params = params; + } + ); + return; +}; + +export default fastifyPlugin(zReqParserPlugin, "4.x"); diff --git a/src/plugins/zTokenParser.ts b/src/plugins/zTokenParser.ts new file mode 100644 index 0000000..223194c --- /dev/null +++ b/src/plugins/zTokenParser.ts @@ -0,0 +1,73 @@ +import { + FastifyInstance, + FastifyPluginAsync, + FastifyReply, + FastifyRequest, +} from "fastify"; +import fastifyPlugin from "fastify-plugin"; + +const getTokenFromHeader = function (request) { + let token: string | undefined; + if (request.headers && request.headers.authorization) { + const parts = request.headers.authorization.split(" "); + if (parts.length === 2) { + const scheme = parts[0]; + if (/^Bearer$/i.test(scheme)) { + token = parts[1]; + } + } + } + return token; +}; +const getTokenFromCookie = function (request) { + let token: string | undefined; + if (request.cookies) { + if (request.cookies["token"]) { + token = request.cookies["token"]; + } + } + return token; +}; + +const getTokenFromParams = function (request) { + let token: string | undefined; + token = request.params && request.params.token; + return token; +}; + +const getTokenFromQuery = function (request) { + let token: string | undefined; + token = request.query && request.query.token; + return token; +}; + +const getTokenFromBody = function (request) { + let token: string | undefined; + token = request.body && request.body.token; + return token; +}; + +const zTokenParserPlugin: FastifyPluginAsync = async function ( + fastify: FastifyInstance, + options?: any +) { + fastify.addHook( + "preValidation", + async (request: FastifyRequest, reply: FastifyReply) => { + request["token"] = + getTokenFromHeader(request) || + getTokenFromCookie(request) || + getTokenFromParams(request) || + getTokenFromQuery(request) || + getTokenFromBody(request); + } + ); + return; +}; +/** + * 依次从request的header, cookie, params, query和body中获取token, 加入到request.token中 + * header中的字段key为authorization, 格式为 Bearer xxxx + * 其他位置的key都为 token + */ + +export default fastifyPlugin(zTokenParserPlugin, "4.x"); diff --git a/src/plugins/zrbac.ts b/src/plugins/zrbac.ts new file mode 100644 index 0000000..3206940 --- /dev/null +++ b/src/plugins/zrbac.ts @@ -0,0 +1,26 @@ +import { FastifyInstance, FastifyPluginAsync } from 'fastify' +import fastifyPlugin from 'fastify-plugin' +import RBAC from 'fast-rbac' + +declare module 'fastify' { + interface FastifyInstance { + /** + * RBAC interface + */ + rbac: RBAC + } +} + +const zRBACPlugin: FastifyPluginAsync = async function fastifyMetrics( + fastify: FastifyInstance, + options?: RBAC.Options, +) { + const rbac = new RBAC(options) + fastify.decorate('rbac', rbac) + return +} + +export = fastifyPlugin(zRBACPlugin, { + fastify: '>=3.0.0', + name: 'zrbac', +}) diff --git a/src/services/alchemy.svr.ts b/src/services/alchemy.svr.ts new file mode 100644 index 0000000..df31771 --- /dev/null +++ b/src/services/alchemy.svr.ts @@ -0,0 +1,114 @@ +import axios from 'axios' +import { hmacsha256, sha1 } from 'utils/security.util' +import crypto from 'crypto' +import { generateKVStr } from 'utils/net.util' +import logger from 'logger/logger' + +export function createSimpleSign(data: any) { + let timestamp = Date.now() + let appid = process.env.ALCHEMY_APPID + let secret = process.env.ALCHEMY_APP_SECRET + let signData = { appid, timestamp } + signData = Object.assign(signData, data) + let signStr = Object.keys(signData) + .sort() + .map(key => `${key}=${signData[key]}`) + .join('&') + let sign = hmacsha256(signStr, secret) + return { + appid, + timestamp, + sign, + } +} + +export function createSha1Sign() { + let timestamp = Date.now() + let appid = process.env.ALCHEMY_APPID + let secret = process.env.ALCHEMY_APP_SECRET + let sign = sha1(appid + secret + timestamp) + return { + appid, + timestamp, + sign, + } +} + +/** + * Check if the pay result sign is valid + * @param data - the data to be checked + * @returns true if the sign is valid, false otherwise + */ +export function checkPayResultSign(data: any) { + const { appId, orderNo, crypto, network, address, signature } = data + const sign = hmacsha256(appId + orderNo + crypto + network + address, process.env.ALCHEMY_APP_SECRET) + return sign === signature +} + +export function createPayResultSign(data: any) { + const { appId, orderNo, crypto, network, address } = data + const sign = hmacsha256(appId + orderNo + crypto + network + address, process.env.ALCHEMY_APP_SECRET) + return sign +} + +export function checkSimpleSign(headers: any, data: any) { + // alchemy 很不严谨, 有时候是 appid, 有时候是 appId + const { appid, appId, timestamp, sign } = headers + let appIdToCheck = appId || appid + let signData = { appid: appIdToCheck, timestamp } + signData = Object.assign(signData, data) + let signStr = Object.keys(signData) + .sort() + .map(key => `${key}=${signData[key]}`) + .join('&') + const expectedSign = hmacsha256(signStr, process.env.ALCHEMY_APP_SECRET) + // const expectedSign = sha1(appIdToCheck + process.env.ALCHEMY_APP_SECRET + timestamp) + return sign === expectedSign +} + +export function checkSha1Sign(headers: any) { + const { appid, appId, timestamp, sign } = headers + let appIdToCheck = appId || appid + const expectedSign = sha1(appIdToCheck + process.env.ALCHEMY_APP_SECRET + timestamp) + return sign === expectedSign +} + +/** + * Create page sign + * @param plainText - plain text to be encrypted + * @returns encrypted text + */ +export function createPageSign(plainText: string) { + let secret = process.env.ALCHEMY_APP_SECRET + try { + const plainTextData = Buffer.from(plainText, 'utf8') + const secretKey = Buffer.from(secret, 'utf8') + const iv = secret.substring(0, 16) + + const cipher = crypto.createCipheriv('aes-128-cbc', secretKey, iv) + + let encrypted = cipher.update(plainTextData) + encrypted = Buffer.concat([encrypted, cipher.final()]) + + return encrypted.toString('base64') + } catch (e) { + console.log(`AES encrypting exception, msg is ${e.toString()}`) + } + return null +} + +export function checkPageSign(params: any) { + const keySet = new Set(['appId', 'address', 'callbackUrl']) + let signData = {} + for (let k in params) { + if (keySet.has(k)) { + signData[k] = params[k] + } + } + + let signStr = generateKVStr({ data: signData, sort: true }) + let expectedSign = createPageSign(signStr) + logger.info(`signStr is ${signStr}, expectedSign is ${expectedSign}, origin sign is ${params.sign}`) + let { sign } = params + return sign === expectedSign +} diff --git a/src/services/discord.svr.ts b/src/services/discord.svr.ts new file mode 100644 index 0000000..18617e4 --- /dev/null +++ b/src/services/discord.svr.ts @@ -0,0 +1,36 @@ +export async function exchangeDiscrodCodeForToken(code: string) { + const clientId = process.env.DISCORD_CLIENT_ID; + const clientSecret = process.env.DISCORD_CLIENT_SECRET; + const redirectUri = "http://localhost:3010/discord/redirect_uri"; + + const response = await fetch("https://discord.com/api/oauth2/token", { + method: "POST", + headers: { + "Content-Type": "application/x-www-form-urlencoded", + }, + body: new URLSearchParams({ + grant_type: "authorization_code", + client_id: clientId, + client_secret: clientSecret, + redirect_uri: redirectUri, + code, + scope: "identify email", + }), + }); + + const data = await response.json(); + console.log(data); + return data.access_token; +} + +export async function userInfo(token: string) { + const response = await fetch("https://discord.com/api/users/@me", { + headers: { + authorization: `Bearer ${token}`, + }, + }); + + const data = await response.json(); + console.log(data); + return data; +} diff --git a/src/services/merchant.svr.ts b/src/services/merchant.svr.ts new file mode 100644 index 0000000..cee2851 --- /dev/null +++ b/src/services/merchant.svr.ts @@ -0,0 +1,45 @@ +import { createSimpleSign } from './alchemy.svr' + +const MECHANT_API_BASE = process.env.MERCHANT_API_BASE_URL +/** + * 购买回调 + */ +export async function byCb(data: any) { + let url = MECHANT_API_BASE + '/pay/out/alchemy/buycb' + const { appid, timestamp, sign } = createSimpleSign(data) + let res = await fetch(url, { + method: 'POST', + headers: { 'Content-Type': 'application/json', appId: appid, timestamp: timestamp + '', sign: sign }, + body: JSON.stringify(data), + }) + let result = await res.json() + return result +} +/** + * 向商户查询币价 + */ +export async function queryCryptoPrice(crypto: string) { + let url = `${MECHANT_API_BASE}/pay/out/alchemy/queryprice?crypto=${crypto}` + const { appid, timestamp, sign } = createSimpleSign({ crypto }) + let res = await fetch(url, { + method: 'GET', + headers: { 'Content-Type': 'application/json', appId: appid, timestamp: timestamp + '', sign: sign }, + }) + let result = await res.json() + let resdata = Object.assign(result.data, { process: 5 }) + return resdata +} +/** + * 通知商户打币 + */ +export async function notifyMechant(data: any) { + let url = MECHANT_API_BASE + '/pay/out/alchemy/distribute' + const { appid, timestamp, sign } = createSimpleSign(data) + let res = await fetch(url, { + method: 'POST', + headers: { 'Content-Type': 'application/json', appId: appid, timestamp: timestamp + '', sign: sign }, + body: JSON.stringify(data), + }) + // let result = await res.json() + return res.json() +} diff --git a/src/utils/net.util.ts b/src/utils/net.util.ts new file mode 100644 index 0000000..456606b --- /dev/null +++ b/src/utils/net.util.ts @@ -0,0 +1,186 @@ +const TIMEOUT_ERROR = new Error('timeout') + +const hexRe = /^[0-9A-Fa-f]+$/gu + +/** + * Execute fetch and verify that the response was successful. + * + * @param request - Request information. + * @param options - Fetch options. + * @returns The fetch response. + */ +export async function successfulFetch(request: string, options?: RequestInit) { + const response = await fetch(request, options) + if (!response.ok) { + throw new Error(`Fetch failed with status '${response.status}' for request '${request}'`) + } + return response +} + +/** + * Execute fetch and return object response. + * + * @param request - The request information. + * @param options - The fetch options. + * @returns The fetch response JSON data. + */ +export async function handleFetch(request: string, options?: RequestInit) { + const response = await successfulFetch(request, options) + const object = await response.json() + return object +} + +/** + * Execute fetch and return object response, log if known error thrown, otherwise rethrow error. + * + * @param request - the request options object + * @param request.url - The request url to query. + * @param request.options - The fetch options. + * @param request.timeout - Timeout to fail request + * @param request.errorCodesToCatch - array of error codes for errors we want to catch in a particular context + * @returns The fetch response JSON data or undefined (if error occurs). + */ +export async function fetchWithErrorHandling({ + url, + options, + timeout, + errorCodesToCatch, +}: { + url: string + options?: RequestInit + timeout?: number + errorCodesToCatch?: number[] +}) { + let result + try { + if (timeout) { + result = Promise.race([ + await handleFetch(url, options), + new Promise((_, reject) => + setTimeout(() => { + reject(TIMEOUT_ERROR) + }, timeout), + ), + ]) + } else { + result = await handleFetch(url, options) + } + } catch (e) { + logOrRethrowError(e, errorCodesToCatch) + } + return result +} + +/** + * Fetch that fails after timeout. + * + * @param url - Url to fetch. + * @param options - Options to send with the request. + * @param timeout - Timeout to fail request. + * @returns Promise resolving the request. + */ +export async function timeoutFetch(url: string, options?: RequestInit, timeout = 500): Promise { + return Promise.race([ + successfulFetch(url, options), + new Promise((_, reject) => + setTimeout(() => { + reject(TIMEOUT_ERROR) + }, timeout), + ), + ]) +} + +/** + * Utility method to log if error is a common fetch error and otherwise rethrow it. + * + * @param error - Caught error that we should either rethrow or log to console + * @param codesToCatch - array of error codes for errors we want to catch and log in a particular context + */ +function logOrRethrowError(error: any, codesToCatch: number[] = []) { + if (!error) { + return + } + + const includesErrorCodeToCatch = codesToCatch.some(code => + error.message.includes(`Fetch failed with status '${code}'`), + ) + + if ( + error instanceof Error && + (includesErrorCodeToCatch || error.message.includes('Failed to fetch') || error === TIMEOUT_ERROR) + ) { + console.error(error) + } else { + throw error + } +} + +/** + * 生成 key1=val1&key2=val2的字符串 + * @param {object} data 需要处理的对象 + * @param {boolean} sort 是否按key生序重排 + * @param {boolean} ignoreNull 是否过滤空值(空格或者null值不参与拼接) + * @param splitChar 连接的字符, 默认是& + * @param equalChar = + */ +export function generateKVStr({ + data = {}, + sort = false, + encode = false, + ignoreNull = true, + splitChar = "&", + equalChar = "=", + uri = "", +}: { + data?: any; + sort?: boolean; + encode?: boolean; + ignoreNull?: boolean; + splitChar?: string; + equalChar?: string; + uri?: string; +}) { + const keys = Object.keys(data); + sort && keys.sort(); + let result = ""; + let i = 0; + for (let key of keys) { + if (ignoreNull && !data[key]) { + continue; + } + if (i++ > 0) result += splitChar; + if (encode) { + result += `${key}${equalChar}${encodeURIComponent(data[key])}`; + } else { + result += `${key}${equalChar}${data[key]}`; + } + } + if (uri) { + const joinChar = uri.search(/\?/) === -1 ? "?" : "&"; + result = uri + joinChar + result; + } + return result; +} + +/** + * 将key1=val&key2=val的字符串组装成对象 + * @param str key1=val&key2=val的字符串 + * @param splitChar 连接的字符, 默认是& + * @param equalChar = + */ +export function keyValToObject( + str: string, + splitChar: string = "&", + equalChar = "=" +): {} { + let result: any = {}; + if (!str) { + return result; + } + let arrs = str.split(splitChar); + for (let sub of arrs) { + let subArr = sub.split(equalChar); + result[subArr[0]] = subArr[1]; + } + return result; +} diff --git a/src/utils/promise.util.ts b/src/utils/promise.util.ts new file mode 100644 index 0000000..1cb6ebe --- /dev/null +++ b/src/utils/promise.util.ts @@ -0,0 +1,47 @@ +/** + * + * @param {Function} cb + * @param {number} maxRetries + * @param {any[]} errorWhiteList + * @param {number} retries + * @return {Promise} + */ +export function retry(cb: Function, maxRetries: number = 3, errorWhiteList: any[] = [], retries: number = 0) { + return new Promise((resolve, reject) => { + cb() + .then(resolve) + .catch(e => { + if (errorWhiteList.indexOf(e.constructor) !== -1 && retries++ < maxRetries) { + setTimeout(() => { + retry(cb, maxRetries, errorWhiteList, retries) + .then(resolve) + .catch(e2 => reject(e2)) + }, Math.floor(Math.random() * Math.pow(2, retries) * 400)) + } else { + reject(e) + } + }) + }) +} + +export class Deferred { + public promise: Promise + + public resolve: Function + public reject: Function + + constructor() { + this.promise = new Promise((resolve, reject) => { + this.resolve = resolve + this.reject = reject + }) + } + + public then(func: (value: T) => any) { + return this.promise.then.apply(this.promise, arguments) + } + + public catch(func: (value: any) => any) { + return this.promise.catch(func) + } +} diff --git a/src/utils/security.util.ts b/src/utils/security.util.ts new file mode 100644 index 0000000..5d21ccf --- /dev/null +++ b/src/utils/security.util.ts @@ -0,0 +1,74 @@ +import crypto from 'crypto' +import { compressUuid } from './string.util' +const ENCODER = 'base64' +const REG_KEY = /^[0-9a-fA-F]{63,64}$/ + +export function isEncrypt(msg: string) { + return !REG_KEY.test(msg) +} + +export function aesEncrypt(text: string, password: string, iv: string) { + var md5 = crypto.createHash('md5') + const key = md5.update(password).digest('hex') + let cipher = crypto.createCipheriv('aes-256-cbc', key, iv) + let encrypted = cipher.update(text, 'utf8', ENCODER) + encrypted += cipher.final(ENCODER) + return encrypted +} + +export function aesDecrypt(encryptedText: string, password: string, iv: string) { + var md5 = crypto.createHash('md5') + const key = md5.update(password).digest('hex') + let decipher = crypto.createDecipheriv('aes-256-cbc', key, iv) + let decrypted = decipher.update(encryptedText, ENCODER, 'utf8') + return decrypted + decipher.final('utf8') +} + +export function hmacsha256(text: string, secret: string) { + const mac = crypto.createHmac('sha256', secret) + const data = mac.update(text).digest('hex').toLowerCase() + console.log(`HmacSHA256 rawContent is [${text}], key is [${secret}], hash result is [${data}]`) + return data +} + +export function sha512(password: string, salt: string) { + let hash = crypto.createHmac('sha512', salt) + hash.update(password) + let value = hash.digest('hex') + return { + salt: salt, + passwordHash: value, + } +} + +export function sha3_256(str: string) { + let hash = crypto.createHash('sha3-256') + hash.update(str) + return hash.digest('hex') +} + +export function genRandomString(length: number) { + return crypto + .randomBytes(Math.ceil(length / 2)) + .toString('hex') + .slice(0, length) +} + +export function uuid() { + return crypto.randomUUID() +} + +export function shortUuid() { + let uid = uuid() + return compressUuid(uid) +} + +export function md5(content: string) { + var md5 = crypto.createHash('md5') + return md5.update(content).digest('hex') +} + +export function sha1(content: string) { + var md5 = crypto.createHash('sha1') + return md5.update(content).digest('hex') +} diff --git a/src/utils/string.util.ts b/src/utils/string.util.ts new file mode 100644 index 0000000..a4c288b --- /dev/null +++ b/src/utils/string.util.ts @@ -0,0 +1,136 @@ +/** + * 根据key升序生成 key1=val1&key2=val2的字符串 + * @param {object} data 需要处理的对象 + * @param {boolean} ignoreNull 是否过滤空值(空格或者null值不参与拼接) + * @param splitChar 连接的字符, 默认是& + * @param equalChar = + */ +export function generateKeyValStr(data: {}, ignoreNull = true, splitChar: string = '&', equalChar = '=') { + const keys = Object.keys(data) + keys.sort() + let result = '' + let i = 0 + for (let key of keys) { + if (ignoreNull && !data[key]) { + return + } + if (i++ > 0) result += splitChar + result += `${key}${equalChar}${data[key]}` + } + return result +} + +/** + * 将key1=val&key2=val的字符串组装成对象 + * @param str key1=val&key2=val的字符串 + * @param splitChar 连接的字符, 默认是& + * @param equalChar = + */ +export function keyValToObject(str: string, splitChar: string = '&', equalChar = '='): {} { + let result = {} + if (!str) { + return result + } + let arrs = str.split(splitChar) + for (let sub of arrs) { + let subArr = sub.split(equalChar) + result[subArr[0]] = subArr[1] + } + return result +} + +/** + * 判断传入的值是否为true + * @param {Object} obj 传入值为'true','TRUE',1,'1','on','ON','YES','yes'时,返回true,其他值均返回false + * @return {boolean} + */ +export function isTrue(obj) { + return ( + obj === 'true' || + obj === 'TRUE' || + obj === 'True' || + obj === 'on' || + obj === 'ON' || + obj === true || + obj === 1 || + obj === '1' || + obj === 'YES' || + obj === 'yes' + ) +} + +/** + * 验证ObjectId格式是否正确 + * @param {string} id + * @return {boolean} + */ +export function isObjectId(id: string): boolean { + //mongoose.Types.ObjectId.isValid(id) + return /^[a-fA-F0-9]{24}$/.test(id) +} + +/** + * 10进制 -> 62进制 + * @param {string | number} number + * @return {string} + */ +export function string10to62(number: string | number) { + const chars = '0123456789abcdefghigklmnopqrstuvwxyzABCDEFGHIGKLMNOPQRSTUVWXYZ'.split('') + const radix = chars.length + let qutient = +number + const arr = [] + do { + const mod = qutient % radix + qutient = (qutient - mod) / radix + arr.unshift(chars[mod]) + } while (qutient) + return arr.join('') +} + +/** + * 62进制 -> 10 进制 + * @param {string} numberCode + * @return {number} + */ +export function string62to10(numberCode: string) { + const chars = '0123456789abcdefghigklmnopqrstuvwxyzABCDEFGHIGKLMNOPQRSTUVWXYZ' + const radix = chars.length + numberCode = numberCode + '' + const len = numberCode.length + let i = 0 + let originNumber = 0 + while (i < len) { + originNumber += Math.pow(radix, i++) * (chars.indexOf(numberCode.charAt(len - i)) || 0) + } + return originNumber +} + +const reNormalUUID = /^[0-9a-fA-F-]{36}$/; +const reLongUUID = /^[0-9a-fA-F]{32}$/; +const reShortUUID = /^[0-9a-zA-Z+/]{22,23}$/; +const n = /-/g; + +export function compressUuid(e:string, t: boolean = false) { + if (reNormalUUID.test(e)) { + e = e.replace(n, ''); + } else if (!reLongUUID.test(e)) { + return e; + } + var r = !0 === t ? 2 : 5; + return compressHex(e, r) +} + +const CHARS_BASE64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; +export function compressHex(e: string, r: number) { + var i, n = e.length; + i = void 0 !== r ? r : n % 3; + for (var s = e.slice(0, i), o = []; i < n;) { + var u = parseInt(e[i], 16), + a = parseInt(e[i + 1], 16), + c = parseInt(e[i + 2], 16); + o.push(CHARS_BASE64[u << 2 | a >> 2]); + o.push(CHARS_BASE64[(3 & a) << 4 | c]); + i += 3; + } + return s + o.join('') +} diff --git a/templates/discord_redirect.ejs b/templates/discord_redirect.ejs new file mode 100644 index 0000000..fdd9afc --- /dev/null +++ b/templates/discord_redirect.ejs @@ -0,0 +1,22 @@ + + + + Discord Redirect + + + + + + + diff --git a/templates/error.ejs b/templates/error.ejs new file mode 100644 index 0000000..4b420e6 --- /dev/null +++ b/templates/error.ejs @@ -0,0 +1,2 @@ +

Pay error

+

<%= msg %>

diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..a004782 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,23 @@ +{ + "ts-node": { + "files": true, + "require": ["tsconfig-paths/register"] + }, + "compilerOptions": { + "experimentalDecorators": true, + "emitDecoratorMetadata": true, + "module": "commonjs", + "esModuleInterop": true, + "target": "es2018", + "moduleResolution": "node", + "sourceMap": true, + "outDir": "./dist", + "baseUrl": "./src", + "rootDir": "./src" + }, + "lib": ["es2018"], + "include": [ + "src/**/*.ts", + "typings/extend.d.ts" + ] +} diff --git a/yarn.lock b/yarn.lock new file mode 100644 index 0000000..418b761 --- /dev/null +++ b/yarn.lock @@ -0,0 +1,3248 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@aws-crypto/crc32@3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/crc32/-/crc32-3.0.0.tgz#07300eca214409c33e3ff769cd5697b57fdd38fa" + integrity sha512-IzSgsrxUcsrejQbPVilIKy16kAT52EwB6zSaI+M3xxIhKh5+aldEyvI+z6erM7TCLB2BJsFrtHjp6/4/sr+3dA== + dependencies: + "@aws-crypto/util" "^3.0.0" + "@aws-sdk/types" "^3.222.0" + tslib "^1.11.1" + +"@aws-crypto/ie11-detection@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/ie11-detection/-/ie11-detection-3.0.0.tgz#640ae66b4ec3395cee6a8e94ebcd9f80c24cd688" + integrity sha512-341lBBkiY1DfDNKai/wXM3aujNBkXR7tq1URPQDL9wi3AUbI80NR74uF1TXHMm7po1AcnFk8iu2S2IeU/+/A+Q== + dependencies: + tslib "^1.11.1" + +"@aws-crypto/sha256-browser@3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-browser/-/sha256-browser-3.0.0.tgz#05f160138ab893f1c6ba5be57cfd108f05827766" + integrity sha512-8VLmW2B+gjFbU5uMeqtQM6Nj0/F1bro80xQXCW6CQBWgosFWXTx77aeOF5CAIAmbOK64SdMBJdNr6J41yP5mvQ== + dependencies: + "@aws-crypto/ie11-detection" "^3.0.0" + "@aws-crypto/sha256-js" "^3.0.0" + "@aws-crypto/supports-web-crypto" "^3.0.0" + "@aws-crypto/util" "^3.0.0" + "@aws-sdk/types" "^3.222.0" + "@aws-sdk/util-locate-window" "^3.0.0" + "@aws-sdk/util-utf8-browser" "^3.0.0" + tslib "^1.11.1" + +"@aws-crypto/sha256-js@3.0.0", "@aws-crypto/sha256-js@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-js/-/sha256-js-3.0.0.tgz#f06b84d550d25521e60d2a0e2a90139341e007c2" + integrity sha512-PnNN7os0+yd1XvXAy23CFOmTbMaDxgxXtTKHybrJ39Y8kGzBATgBFibWJKH6BhytLI/Zyszs87xCOBNyBig6vQ== + dependencies: + "@aws-crypto/util" "^3.0.0" + "@aws-sdk/types" "^3.222.0" + tslib "^1.11.1" + +"@aws-crypto/supports-web-crypto@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/supports-web-crypto/-/supports-web-crypto-3.0.0.tgz#5d1bf825afa8072af2717c3e455f35cda0103ec2" + integrity sha512-06hBdMwUAb2WFTuGG73LSC0wfPu93xWwo5vL2et9eymgmu3Id5vFAHBbajVWiGhPO37qcsdCap/FqXvJGJWPIg== + dependencies: + tslib "^1.11.1" + +"@aws-crypto/util@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/util/-/util-3.0.0.tgz#1c7ca90c29293f0883468ad48117937f0fe5bfb0" + integrity sha512-2OJlpeJpCR48CC8r+uKVChzs9Iungj9wkZrl8Z041DWEWvyIHILYKCPNzJghKsivj+S3mLo6BVc7mBNzdxA46w== + dependencies: + "@aws-sdk/types" "^3.222.0" + "@aws-sdk/util-utf8-browser" "^3.0.0" + tslib "^1.11.1" + +"@aws-sdk/abort-controller@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/abort-controller/-/abort-controller-3.342.0.tgz#a84a5fc884d87ae4adfe852aa6a43effc63e7af1" + integrity sha512-W1lAYldbzDjfn8vwnwNe+6qNWfSu1+JrdiVIRSwsiwKvF2ahjKuaLoc8rJM09C6ieNWRi5634urFgfwAJuv6vg== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/client-cognito-identity@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-cognito-identity/-/client-cognito-identity-3.342.0.tgz#627131d572c92a0f026c641f9112928a82212d98" + integrity sha512-WLqqeQpcLUGGqfH0bXhnAXzbX4g0SV1i1lgqJEJivHTZfexpPKEn0UphmP6ucyJ7NgQVOEHJDEowAigXG+HheA== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/client-sts" "3.342.0" + "@aws-sdk/config-resolver" "3.342.0" + "@aws-sdk/credential-provider-node" "3.342.0" + "@aws-sdk/fetch-http-handler" "3.342.0" + "@aws-sdk/hash-node" "3.342.0" + "@aws-sdk/invalid-dependency" "3.342.0" + "@aws-sdk/middleware-content-length" "3.342.0" + "@aws-sdk/middleware-endpoint" "3.342.0" + "@aws-sdk/middleware-host-header" "3.342.0" + "@aws-sdk/middleware-logger" "3.342.0" + "@aws-sdk/middleware-recursion-detection" "3.342.0" + "@aws-sdk/middleware-retry" "3.342.0" + "@aws-sdk/middleware-serde" "3.342.0" + "@aws-sdk/middleware-signing" "3.342.0" + "@aws-sdk/middleware-stack" "3.342.0" + "@aws-sdk/middleware-user-agent" "3.342.0" + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/node-http-handler" "3.342.0" + "@aws-sdk/smithy-client" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/url-parser" "3.342.0" + "@aws-sdk/util-base64" "3.310.0" + "@aws-sdk/util-body-length-browser" "3.310.0" + "@aws-sdk/util-body-length-node" "3.310.0" + "@aws-sdk/util-defaults-mode-browser" "3.342.0" + "@aws-sdk/util-defaults-mode-node" "3.342.0" + "@aws-sdk/util-endpoints" "3.342.0" + "@aws-sdk/util-retry" "3.342.0" + "@aws-sdk/util-user-agent-browser" "3.342.0" + "@aws-sdk/util-user-agent-node" "3.342.0" + "@aws-sdk/util-utf8" "3.310.0" + "@smithy/protocol-http" "^1.0.1" + "@smithy/types" "^1.0.0" + tslib "^2.5.0" + +"@aws-sdk/client-sso-oidc@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-sso-oidc/-/client-sso-oidc-3.342.0.tgz#0d6c54d4a5e000ac515439747d775cd454665aea" + integrity sha512-C1jeKD39pWXlpGRxhWWBw2No1lyZnyIN72M2Qg3BWK6QlsSDtd9kdhpGS9rQU0i1F4w5x178a+qiGWHHMhCwLg== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/config-resolver" "3.342.0" + "@aws-sdk/fetch-http-handler" "3.342.0" + "@aws-sdk/hash-node" "3.342.0" + "@aws-sdk/invalid-dependency" "3.342.0" + "@aws-sdk/middleware-content-length" "3.342.0" + "@aws-sdk/middleware-endpoint" "3.342.0" + "@aws-sdk/middleware-host-header" "3.342.0" + "@aws-sdk/middleware-logger" "3.342.0" + "@aws-sdk/middleware-recursion-detection" "3.342.0" + "@aws-sdk/middleware-retry" "3.342.0" + "@aws-sdk/middleware-serde" "3.342.0" + "@aws-sdk/middleware-stack" "3.342.0" + "@aws-sdk/middleware-user-agent" "3.342.0" + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/node-http-handler" "3.342.0" + "@aws-sdk/smithy-client" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/url-parser" "3.342.0" + "@aws-sdk/util-base64" "3.310.0" + "@aws-sdk/util-body-length-browser" "3.310.0" + "@aws-sdk/util-body-length-node" "3.310.0" + "@aws-sdk/util-defaults-mode-browser" "3.342.0" + "@aws-sdk/util-defaults-mode-node" "3.342.0" + "@aws-sdk/util-endpoints" "3.342.0" + "@aws-sdk/util-retry" "3.342.0" + "@aws-sdk/util-user-agent-browser" "3.342.0" + "@aws-sdk/util-user-agent-node" "3.342.0" + "@aws-sdk/util-utf8" "3.310.0" + "@smithy/protocol-http" "^1.0.1" + "@smithy/types" "^1.0.0" + tslib "^2.5.0" + +"@aws-sdk/client-sso@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-sso/-/client-sso-3.342.0.tgz#8f532e299a0c0e697b737d4bf6603f31a2be7035" + integrity sha512-DbEL+sWBua/04zTlJ6QmUsOpbeIlnPp8eYXQllCwsFzsIT04MjMI4hCZNia/weymwcq3vWTJOk2++SZf0sCGcw== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/config-resolver" "3.342.0" + "@aws-sdk/fetch-http-handler" "3.342.0" + "@aws-sdk/hash-node" "3.342.0" + "@aws-sdk/invalid-dependency" "3.342.0" + "@aws-sdk/middleware-content-length" "3.342.0" + "@aws-sdk/middleware-endpoint" "3.342.0" + "@aws-sdk/middleware-host-header" "3.342.0" + "@aws-sdk/middleware-logger" "3.342.0" + "@aws-sdk/middleware-recursion-detection" "3.342.0" + "@aws-sdk/middleware-retry" "3.342.0" + "@aws-sdk/middleware-serde" "3.342.0" + "@aws-sdk/middleware-stack" "3.342.0" + "@aws-sdk/middleware-user-agent" "3.342.0" + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/node-http-handler" "3.342.0" + "@aws-sdk/smithy-client" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/url-parser" "3.342.0" + "@aws-sdk/util-base64" "3.310.0" + "@aws-sdk/util-body-length-browser" "3.310.0" + "@aws-sdk/util-body-length-node" "3.310.0" + "@aws-sdk/util-defaults-mode-browser" "3.342.0" + "@aws-sdk/util-defaults-mode-node" "3.342.0" + "@aws-sdk/util-endpoints" "3.342.0" + "@aws-sdk/util-retry" "3.342.0" + "@aws-sdk/util-user-agent-browser" "3.342.0" + "@aws-sdk/util-user-agent-node" "3.342.0" + "@aws-sdk/util-utf8" "3.310.0" + "@smithy/protocol-http" "^1.0.1" + "@smithy/types" "^1.0.0" + tslib "^2.5.0" + +"@aws-sdk/client-sts@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-sts/-/client-sts-3.342.0.tgz#21a65e365113418a7816dd4fef16d24b8227d496" + integrity sha512-MUgYm/2ra1Pwoqw9ng75rVsvTLQvLHZLsTjJuKJ4hnHx1GdmQt4/ZlG1q/J2ZK2o6RZXqgavscz/nyrZH0QumA== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/config-resolver" "3.342.0" + "@aws-sdk/credential-provider-node" "3.342.0" + "@aws-sdk/fetch-http-handler" "3.342.0" + "@aws-sdk/hash-node" "3.342.0" + "@aws-sdk/invalid-dependency" "3.342.0" + "@aws-sdk/middleware-content-length" "3.342.0" + "@aws-sdk/middleware-endpoint" "3.342.0" + "@aws-sdk/middleware-host-header" "3.342.0" + "@aws-sdk/middleware-logger" "3.342.0" + "@aws-sdk/middleware-recursion-detection" "3.342.0" + "@aws-sdk/middleware-retry" "3.342.0" + "@aws-sdk/middleware-sdk-sts" "3.342.0" + "@aws-sdk/middleware-serde" "3.342.0" + "@aws-sdk/middleware-signing" "3.342.0" + "@aws-sdk/middleware-stack" "3.342.0" + "@aws-sdk/middleware-user-agent" "3.342.0" + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/node-http-handler" "3.342.0" + "@aws-sdk/smithy-client" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/url-parser" "3.342.0" + "@aws-sdk/util-base64" "3.310.0" + "@aws-sdk/util-body-length-browser" "3.310.0" + "@aws-sdk/util-body-length-node" "3.310.0" + "@aws-sdk/util-defaults-mode-browser" "3.342.0" + "@aws-sdk/util-defaults-mode-node" "3.342.0" + "@aws-sdk/util-endpoints" "3.342.0" + "@aws-sdk/util-retry" "3.342.0" + "@aws-sdk/util-user-agent-browser" "3.342.0" + "@aws-sdk/util-user-agent-node" "3.342.0" + "@aws-sdk/util-utf8" "3.310.0" + "@smithy/protocol-http" "^1.0.1" + "@smithy/types" "^1.0.0" + fast-xml-parser "4.1.2" + tslib "^2.5.0" + +"@aws-sdk/config-resolver@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/config-resolver/-/config-resolver-3.342.0.tgz#186684780ffe74ceb7a384ee8a58f32c45d1c233" + integrity sha512-jUg6DTTrCvG8AOPv5NRJ6PSQSC5fEI2gVv4luzvrGkRJULYbIqpdfUYdW7jB3rWAWC79pQQr5lSqC5DWH91stw== + dependencies: + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-config-provider" "3.310.0" + "@aws-sdk/util-middleware" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-cognito-identity@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-cognito-identity/-/credential-provider-cognito-identity-3.342.0.tgz#0b6c69cded6dec2be33ae4989e4d8f3eafb08d52" + integrity sha512-SIUIgXF73GqEgvGMC4FPUUAFWBR1pQilwgx8aL7cSThWuDgUeEghnamUGdNHSyGPiQ2q3n6RBR0+WEVLIOMa4A== + dependencies: + "@aws-sdk/client-cognito-identity" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-env@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-env/-/credential-provider-env-3.342.0.tgz#1fef895b6460787fdf3b8fef6e67c9d1196fbd4f" + integrity sha512-mufOcoqdXZXkvA7u6hUcJz6wKpVaho8SRWCvJrGO4YkyudUAoI9KSP5R4U+gtneDJ2Y/IEKPuw8ugNfANa1J+A== + dependencies: + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-imds@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-imds/-/credential-provider-imds-3.342.0.tgz#f18345d69e2ebeb2396d16756ed92370cc250120" + integrity sha512-ReaHwFLfcsEYjDFvi95OFd+IU8frPwuAygwL56aiMT7Voc0oy3EqB3MFs3gzFxdLsJ0vw9TZMRbaouepAEVCkA== + dependencies: + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/url-parser" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-ini@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.342.0.tgz#54b7e6d2d968ba86ea40faf21687cf3bada7be3b" + integrity sha512-VJ7+IlI3rx5XfO8AarbKeqNVwfExsWW0S6fqBXIim0s10FJAy7R+wxYyhZhawfRm0ydCggT+Ji6dftS+WXF8fg== + dependencies: + "@aws-sdk/credential-provider-env" "3.342.0" + "@aws-sdk/credential-provider-imds" "3.342.0" + "@aws-sdk/credential-provider-process" "3.342.0" + "@aws-sdk/credential-provider-sso" "3.342.0" + "@aws-sdk/credential-provider-web-identity" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/shared-ini-file-loader" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-node@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-node/-/credential-provider-node-3.342.0.tgz#712d00d7ee34483edaae714e722dbd55e2b738d0" + integrity sha512-u3oUo0UxGEaHLtIx7a38aFLgcTe1OevCNe5exL3ugf5C4ifvUjM8rLWySQ9zrKRgPT2yDRYG/oq4ezjoR9fhHg== + dependencies: + "@aws-sdk/credential-provider-env" "3.342.0" + "@aws-sdk/credential-provider-imds" "3.342.0" + "@aws-sdk/credential-provider-ini" "3.342.0" + "@aws-sdk/credential-provider-process" "3.342.0" + "@aws-sdk/credential-provider-sso" "3.342.0" + "@aws-sdk/credential-provider-web-identity" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/shared-ini-file-loader" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-process@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-process/-/credential-provider-process-3.342.0.tgz#faccc5937f055e2888217140e47499da844c01a6" + integrity sha512-q03yJQPa4jnZtwKFW3yEYNMcpYH7wQzbEOEXjnXG4v8935oOttZjXBvRK7ax+f0D1ZHZFeFSashjw0A/bi1efQ== + dependencies: + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/shared-ini-file-loader" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-sso@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.342.0.tgz#0682696f07c2093548a241c633a5f7db069e4d56" + integrity sha512-ank2703Riz5gwTxC11FDnZtMcq1Z1JjN3Nd53ahyZ+KOJPgWXEw+uolEuzMl4oAovmbTJ6WANo2qMVmLzZEaQg== + dependencies: + "@aws-sdk/client-sso" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/shared-ini-file-loader" "3.342.0" + "@aws-sdk/token-providers" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-provider-web-identity@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.342.0.tgz#d05f0478c897a69a7010643c5aac1bae0f1861ec" + integrity sha512-+an5oGnzoXMmGJql0Qs9MtyQTmz5GFqrWleQ0k9UVhN3uIfCS9AITS7vb+q1+G7A7YXy9+KshgBhcHco0G/JWQ== + dependencies: + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/credential-providers@^3.186.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-providers/-/credential-providers-3.342.0.tgz#460f6e6eb03de5bc8ea681488c8381b212abe692" + integrity sha512-eqtYmWBufLJcZPU0vveIPOBnYUuYpNXTYvABdYhy1EDlrYp3r3kpWpwK+A7DRRUP7T7awjZRZbkz7zoosq2MGg== + dependencies: + "@aws-sdk/client-cognito-identity" "3.342.0" + "@aws-sdk/client-sso" "3.342.0" + "@aws-sdk/client-sts" "3.342.0" + "@aws-sdk/credential-provider-cognito-identity" "3.342.0" + "@aws-sdk/credential-provider-env" "3.342.0" + "@aws-sdk/credential-provider-imds" "3.342.0" + "@aws-sdk/credential-provider-ini" "3.342.0" + "@aws-sdk/credential-provider-node" "3.342.0" + "@aws-sdk/credential-provider-process" "3.342.0" + "@aws-sdk/credential-provider-sso" "3.342.0" + "@aws-sdk/credential-provider-web-identity" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/eventstream-codec@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/eventstream-codec/-/eventstream-codec-3.342.0.tgz#aef9ab3c5fdaa02c6da9836194eada9d35515fa1" + integrity sha512-IwtvSuplioMyiu/pQgpazKkGWDM5M5BOx85zmsB0uNxt6rmje8+WqPmGmuPdmJv4bLC5dJPLovcCp/fuH8XWhA== + dependencies: + "@aws-crypto/crc32" "3.0.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-hex-encoding" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/fetch-http-handler@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/fetch-http-handler/-/fetch-http-handler-3.342.0.tgz#7db371a02a5d7e5db80715d3f14803727fb9e984" + integrity sha512-zsC23VUQMHEu4OKloLCVyWLG0ns6n+HKZ9euGLnNO3l0VSRne9qj/94yR+4jr/h04M7MhGf9mlczGfnZUFxs5w== + dependencies: + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/querystring-builder" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-base64" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/hash-node@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/hash-node/-/hash-node-3.342.0.tgz#5f1d7019e7246997beaa323b6108772da0534262" + integrity sha512-cFgXy9CDNQdYCdJBsG91FF0P0tNkCfi7+vTy7fzAEchxLxhcfLtC0cS6+gv2e3Dy8mv+uqp45Tu24+8Trx9hJQ== + dependencies: + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-buffer-from" "3.310.0" + "@aws-sdk/util-utf8" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/invalid-dependency@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/invalid-dependency/-/invalid-dependency-3.342.0.tgz#90fbfab6f8789962ba7291d1a06d70ca1054b83e" + integrity sha512-3qza2Br1jGKJi8toPYG9u5aGJ3sbGmJLgKDvlga7q3F8JaeB92He6muRJ07eyDvxZ9jiKhLZ2mtYoVcEjI7Mgw== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/is-array-buffer@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/is-array-buffer/-/is-array-buffer-3.310.0.tgz#f87a79f1b858c88744f07e8d8d0a791df204017e" + integrity sha512-urnbcCR+h9NWUnmOtet/s4ghvzsidFmspfhYaHAmSRdy9yDjdjBJMFjjsn85A1ODUktztm+cVncXjQ38WCMjMQ== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/middleware-content-length@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-content-length/-/middleware-content-length-3.342.0.tgz#6b42d8e6d07631b080a3e30065ec3c1efb6ae0bc" + integrity sha512-7LUMZqhihSAptGRFFQvuwt9nCLNzNPkGd1oU1RpVXw6YPQfKP9Ec5tgg4oUlv1t58IYQvdVj5ITKp4X2aUJVPg== + dependencies: + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-endpoint@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-endpoint/-/middleware-endpoint-3.342.0.tgz#fdc6c318bc5a27962538a164e274fe0d126b8a3c" + integrity sha512-/rE+3a2EbNQoylc7vyN+O6GFfcLitboZ8f/Kdkld3Ijcp9whPHdfjiqujlwyiUTgBVP3BqgyB3r7AZDloc7B0g== + dependencies: + "@aws-sdk/middleware-serde" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/url-parser" "3.342.0" + "@aws-sdk/util-middleware" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-host-header@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-host-header/-/middleware-host-header-3.342.0.tgz#7e82300466d458a2726c52de264e013f50bd5898" + integrity sha512-EOoix2D2Mk3NQtv7UVhJttfttGYechQxKuGvCI8+8iEKxqlyXaKqAkLR07BQb6epMYeKP4z1PfJm203Sf0WPUQ== + dependencies: + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-logger@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-logger/-/middleware-logger-3.342.0.tgz#0f89a98a5e771c18ffa9bc9c70176df5f4866323" + integrity sha512-wbkp85T7p9sHLNPMY6HAXHvLOp+vOubFT/XLIGtgRhYu5aRJSlVo9qlwtdZjyhEgIRQ6H/QUnqAN7Zgk5bCLSw== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-recursion-detection@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.342.0.tgz#16568a3bf89e20f978b2145168f62acd8d881847" + integrity sha512-KUDseSAz95kXCqnXEQxNObpviZ6F7eJ5lEgpi+ZehlzGDk/GyOVgjVuAyI7nNxWI5v0ZJ5nIDy+BH273dWbnmQ== + dependencies: + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-retry@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-retry/-/middleware-retry-3.342.0.tgz#63f8e132845f2528f1c653e90a06489a0230716a" + integrity sha512-Bfllrjqs0bXNG7A3ydLjTAE5zPEdigG+/lDuEsCfB35gywZnnxqi6BjTeQ9Ss6gbEWX+WyXP7/oVdNaUDQUr9Q== + dependencies: + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/service-error-classification" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-middleware" "3.342.0" + "@aws-sdk/util-retry" "3.342.0" + tslib "^2.5.0" + uuid "^8.3.2" + +"@aws-sdk/middleware-sdk-sts@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-sdk-sts/-/middleware-sdk-sts-3.342.0.tgz#99bd8ac1f39ea8baa30e5e36d5a874e89595c74f" + integrity sha512-eGcGDC+6UWKC87mex3voBVRcZN3hzFN6GVzWkTS574hDqp/uJG3yPk3Dltw0qf8skikTGi3/ZE+yAxerq/f5rg== + dependencies: + "@aws-sdk/middleware-signing" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-serde@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-serde/-/middleware-serde-3.342.0.tgz#ed051e4e7dfc33e431aa27f260e065b9fbb5ee0f" + integrity sha512-WRD+Cyu6+h1ymfPnAw4fI2q3zXjihJ55HFe1uRF8VPN4uBbJNfN3IqL38y/SMEdZ0gH9zNlRNxZLhR0q6SNZEQ== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-signing@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-signing/-/middleware-signing-3.342.0.tgz#f0964e6c1e6dc7eaf4a90a8a15f1de5f5fb03b7e" + integrity sha512-CFRQyPv4OjRGmFoB3OfKcQ0aHgS9VWC0YwoHnSWIcLt3Xltorug/Amk0obr/MFoIrktdlVtmvLEJ4Z+8cdsz8g== + dependencies: + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/signature-v4" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-middleware" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/middleware-stack@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-stack/-/middleware-stack-3.342.0.tgz#e755815cb22a66f15a964db12e998211f736eda0" + integrity sha512-nDYtLAv9IZq8YFxtbyAiK/U1mtvtJS0DG6HiIPT5jpHcRpuWRHQ170EAW51zYts+21Ffj1VA6ZPkbup83+T6/w== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/middleware-user-agent@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.342.0.tgz#b4983412786b4b42e4c8ada295476bc1f0bdbe63" + integrity sha512-6iiFno+rq7W82mqM4KQKndIkZdGG1XZDlZIb77fcmQGYYlB1J2S/d0pIPdMk5ZQteuKJ5iorANUC0dKWw1mWTg== + dependencies: + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-endpoints" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/node-config-provider@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/node-config-provider/-/node-config-provider-3.342.0.tgz#ef4bb4642e885c7f634af358c9312809373c67ca" + integrity sha512-Mwkj4+zt64w7a8QDrI9q4SrEt7XRO30Vk0a0xENqcOGrKIPfF5aeqlw85NYLoGys+KV1oatqQ+k0GzKx8qTIdQ== + dependencies: + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/shared-ini-file-loader" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/node-http-handler@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/node-http-handler/-/node-http-handler-3.342.0.tgz#6bd98ea8c81a477a87ff65c38bb9560ea6565d0d" + integrity sha512-ieNdrfJJMh46qY6rkV1azJBo3UfS9hc7d8CuHtkgHhCfH3BhxbtFqEiGilOdBmY5Sk69b//lFr4zHpUPYsXKaA== + dependencies: + "@aws-sdk/abort-controller" "3.342.0" + "@aws-sdk/protocol-http" "3.342.0" + "@aws-sdk/querystring-builder" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/property-provider@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/property-provider/-/property-provider-3.342.0.tgz#04acca6ddb0dec6fdc190ef28ef5c19af192629f" + integrity sha512-p4TR9yRakIpwupEH3BUijWMYThGG0q43n1ICcsBOcvWZpE636lIUw6nzFlOuBUwqyPfUyLbXzchvosYxfCl0jw== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/protocol-http@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/protocol-http/-/protocol-http-3.342.0.tgz#2f4852a1ff14491f8785ca094684e7fcd80db4e5" + integrity sha512-zuF2urcTJBZ1tltPdTBQzRasuGB7+4Yfs9i5l0F7lE0luK5Azy6G+2r3WWENUNxFTYuP94GrrqaOhVyj8XXLPQ== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/querystring-builder@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/querystring-builder/-/querystring-builder-3.342.0.tgz#1163c1b9ec901b1264911be504a42638113f1002" + integrity sha512-tb3FbtC36a7XBYeupdKm60LeM0etp73I6/7pDAkzAlw7zJdvY0aQIvj1c0U6nZlwZF8sSSxC7vlamR+wCspdMw== + dependencies: + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-uri-escape" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/querystring-parser@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/querystring-parser/-/querystring-parser-3.342.0.tgz#20b3e13cb727171045625c1fbb87e351f300bb20" + integrity sha512-6svvr/LZW1EPJaARnOpjf92FIiK25wuO7fRq05gLTcTRAfUMDvub+oDg3Ro9EjJERumrYQrYCem5Qi4X9w8K2g== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/service-error-classification@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/service-error-classification/-/service-error-classification-3.342.0.tgz#6ddb08a7976bc93cfafab4584719883baa787f6f" + integrity sha512-MwHO5McbdAVKxfQj1yhleboAXqrzcGoi9ODS+bwCwRfe2lakGzBBhu8zaGDlKYOdv5rS+yAPP/5fZZUiuZY8Bw== + +"@aws-sdk/shared-ini-file-loader@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/shared-ini-file-loader/-/shared-ini-file-loader-3.342.0.tgz#395c3cad50c831979751842e81eefbf1cee55d35" + integrity sha512-kQG7TMQMhNp5+Y8vhGuO/+wU3K/dTx0xC0AKoDFiBf6EpDRmDfr2pPRnfJ9GwgS9haHxJ/3Uwc03swHMlsj20A== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/signature-v4@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/signature-v4/-/signature-v4-3.342.0.tgz#c2249594c53c76891986e3a54a077062a0b55b63" + integrity sha512-OWrGO2UOa1ENpy0kYd2shK4sklQygWUqvWLx9FotDbjIeUIEfAnqoPq/QqcXVrNyT/UvPi4iIrjHJEO8JCNRmA== + dependencies: + "@aws-sdk/eventstream-codec" "3.342.0" + "@aws-sdk/is-array-buffer" "3.310.0" + "@aws-sdk/types" "3.342.0" + "@aws-sdk/util-hex-encoding" "3.310.0" + "@aws-sdk/util-middleware" "3.342.0" + "@aws-sdk/util-uri-escape" "3.310.0" + "@aws-sdk/util-utf8" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/smithy-client@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/smithy-client/-/smithy-client-3.342.0.tgz#976ec7ca4e029145707c33d6300d60efcee53214" + integrity sha512-HQ4JejjHU2X7OAZPwixFG+EyPSjmoZqll7EvWjPSKyclWrM320haWWz1trVzjG/AgPfeDLfRkH/JoMr13lECew== + dependencies: + "@aws-sdk/middleware-stack" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/token-providers@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/token-providers/-/token-providers-3.342.0.tgz#3e8af8ab0ee27b2bd17d17f48c91f88bd4c06590" + integrity sha512-gYShxImNQVx3FYOUKB7nzzowYiiP1joyx43KrduHwBDV7hiqg7QhtJHr6Ek+QLPqcFKP9rRvo7NhGxu+T7dEQg== + dependencies: + "@aws-sdk/client-sso-oidc" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/shared-ini-file-loader" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/types@3.342.0", "@aws-sdk/types@^3.222.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/types/-/types-3.342.0.tgz#0bcba3b5966f28e0725122697a19ece8647afbec" + integrity sha512-5uyXVda/AgUpdZNJ9JPHxwyxr08miPiZ/CKSMcRdQVjcNnrdzY9m/iM9LvnQT44sQO+IEEkF2IoZIWvZcq199A== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/url-parser@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/url-parser/-/url-parser-3.342.0.tgz#c0be80c1d88b0ff8a8224de0ff7de64ccd5ef186" + integrity sha512-r4s/FDK6iywl8l4TqEwIwtNvxWO0kZes03c/yCiRYqxlkjVmbXEOodn5IAAweAeS9yqC3sl/wKbsaoBiGFn45g== + dependencies: + "@aws-sdk/querystring-parser" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/util-base64@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-base64/-/util-base64-3.310.0.tgz#d0fd49aff358c5a6e771d0001c63b1f97acbe34c" + integrity sha512-v3+HBKQvqgdzcbL+pFswlx5HQsd9L6ZTlyPVL2LS9nNXnCcR3XgGz9jRskikRUuUvUXtkSG1J88GAOnJ/apTPg== + dependencies: + "@aws-sdk/util-buffer-from" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/util-body-length-browser@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-body-length-browser/-/util-body-length-browser-3.310.0.tgz#3fca9d2f73c058edf1907e4a1d99a392fdd23eca" + integrity sha512-sxsC3lPBGfpHtNTUoGXMQXLwjmR0zVpx0rSvzTPAuoVILVsp5AU/w5FphNPxD5OVIjNbZv9KsKTuvNTiZjDp9g== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-body-length-node@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-body-length-node/-/util-body-length-node-3.310.0.tgz#4846ae72834ab0636f29f89fc1878520f6543fed" + integrity sha512-2tqGXdyKhyA6w4zz7UPoS8Ip+7sayOg9BwHNidiGm2ikbDxm1YrCfYXvCBdwaJxa4hJfRVz+aL9e+d3GqPI9pQ== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-buffer-from@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-buffer-from/-/util-buffer-from-3.310.0.tgz#7a72cb965984d3c6a7e256ae6cf1621f52e54a57" + integrity sha512-i6LVeXFtGih5Zs8enLrt+ExXY92QV25jtEnTKHsmlFqFAuL3VBeod6boeMXkN2p9lbSVVQ1sAOOYZOHYbYkntw== + dependencies: + "@aws-sdk/is-array-buffer" "3.310.0" + tslib "^2.5.0" + +"@aws-sdk/util-config-provider@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-config-provider/-/util-config-provider-3.310.0.tgz#ff21f73d4774cfd7bd16ae56f905828600dda95f" + integrity sha512-xIBaYo8dwiojCw8vnUcIL4Z5tyfb1v3yjqyJKJWV/dqKUFOOS0U591plmXbM+M/QkXyML3ypon1f8+BoaDExrg== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-defaults-mode-browser@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-defaults-mode-browser/-/util-defaults-mode-browser-3.342.0.tgz#309b8191801f31647b259c8f8cf30de9b47895df" + integrity sha512-N1ZRvCLbrt4Re9MKU3pLYR0iO+H7GU7RsXG4yAq6DtSWT9WCw6xhIUpeV2T5uxWKL92o3WHNiGjwcebq+N73Bg== + dependencies: + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + bowser "^2.11.0" + tslib "^2.5.0" + +"@aws-sdk/util-defaults-mode-node@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-defaults-mode-node/-/util-defaults-mode-node-3.342.0.tgz#ddd7180ff1cf0429be6077a2b67856fa6088eb4c" + integrity sha512-yNa/eX8sELnwM5NONOFR/PCJMHTNrUVklSo/QHy57CT/L3KOqosRNAMnDVMzH1QolGaVN/8jgtDI2xVsvlP+AA== + dependencies: + "@aws-sdk/config-resolver" "3.342.0" + "@aws-sdk/credential-provider-imds" "3.342.0" + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/property-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/util-endpoints@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-endpoints/-/util-endpoints-3.342.0.tgz#19aa3176c6f3d7e35d5a6f02d5808c6129ea24f2" + integrity sha512-ZsYF413hkVwSOjvZG6U0SshRtzSg6MtwzO+j90AjpaqgoHAxE5LjO5eVYFfPXTC2U8NhU7xkzASY6++e5bRRnw== + dependencies: + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/util-hex-encoding@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-hex-encoding/-/util-hex-encoding-3.310.0.tgz#19294c78986c90ae33f04491487863dc1d33bd87" + integrity sha512-sVN7mcCCDSJ67pI1ZMtk84SKGqyix6/0A1Ab163YKn+lFBQRMKexleZzpYzNGxYzmQS6VanP/cfU7NiLQOaSfA== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-locate-window@^3.0.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-locate-window/-/util-locate-window-3.310.0.tgz#b071baf050301adee89051032bd4139bba32cc40" + integrity sha512-qo2t/vBTnoXpjKxlsC2e1gBrRm80M3bId27r0BRB2VniSSe7bL1mmzM+/HFtujm0iAxtPM+aLEflLJlJeDPg0w== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-middleware@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-middleware/-/util-middleware-3.342.0.tgz#db8f50136bcba3d480d5c8e5340aecaa1e1c3a6c" + integrity sha512-P2LYyMP4JUFZBy9DcMvCDxWU34mlShCyrqBZ1ouuGW7UMgRb1PTEvpLAVndIWn9H+1KGDFjMqOWp1FZHr4YZOA== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-retry@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-retry/-/util-retry-3.342.0.tgz#9451a6809a51b9915661fcbea0335c89f24eab4e" + integrity sha512-U1LXXtOMAQjU4H9gjYZng8auRponAH0t3vShHMKT8UQggT6Hwz1obdXUZgcLCtcjp/1aEK4MkDwk2JSjuUTaZw== + dependencies: + "@aws-sdk/service-error-classification" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/util-uri-escape@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-uri-escape/-/util-uri-escape-3.310.0.tgz#9f942f09a715d8278875013a416295746b6085ba" + integrity sha512-drzt+aB2qo2LgtDoiy/3sVG8w63cgLkqFIa2NFlGpUgHFWTXkqtbgf4L5QdjRGKWhmZsnqkbtL7vkSWEcYDJ4Q== + dependencies: + tslib "^2.5.0" + +"@aws-sdk/util-user-agent-browser@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.342.0.tgz#7127e523973b382d98c916ae069285eb48a01d8b" + integrity sha512-FWHiBi1xaebzmq3LJsizgd2LCix/bKHUTOjTeO6hEYny5DyrOl0liwIA0mqgvfgwIoMOF/l6FGg7kTfKtNgkEA== + dependencies: + "@aws-sdk/types" "3.342.0" + bowser "^2.11.0" + tslib "^2.5.0" + +"@aws-sdk/util-user-agent-node@3.342.0": + version "3.342.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.342.0.tgz#5b8e849b83e9fbaae5664e2e0c284892093af783" + integrity sha512-YMAhUar4CAB6hfUR72FH0sRqMBhPajDIhiKrZEOy7+qaWFdfb/t9DYi6p3PYIUZWK2vkESiDoX9Ays2xsp9rOQ== + dependencies: + "@aws-sdk/node-config-provider" "3.342.0" + "@aws-sdk/types" "3.342.0" + tslib "^2.5.0" + +"@aws-sdk/util-utf8-browser@^3.0.0": + version "3.259.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.259.0.tgz#3275a6f5eb334f96ca76635b961d3c50259fd9ff" + integrity sha512-UvFa/vR+e19XookZF8RzFZBrw2EUkQWxiBW0yYQAhvk3C+QVGl0H3ouca8LDBlBfQKXwmW3huo/59H8rwb1wJw== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-utf8@3.310.0": + version "3.310.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-utf8/-/util-utf8-3.310.0.tgz#4a7b9dcebb88e830d3811aeb21e9a6df4273afb4" + integrity sha512-DnLfFT8uCO22uOJc0pt0DsSNau1GTisngBCDw8jQuWT5CqogMJu4b/uXmwEqfj8B3GX6Xsz8zOd6JpRlPftQoA== + dependencies: + "@aws-sdk/util-buffer-from" "3.310.0" + tslib "^2.5.0" + +"@cspotcode/source-map-support@^0.8.0": + version "0.8.1" + resolved "https://registry.yarnpkg.com/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz#00629c35a688e05a88b1cda684fb9d5e73f000a1" + integrity sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw== + dependencies: + "@jridgewell/trace-mapping" "0.3.9" + +"@discordjs/builders@^1.6.3": + version "1.6.3" + resolved "https://registry.yarnpkg.com/@discordjs/builders/-/builders-1.6.3.tgz#994b4fe57e77b47096f74bb5a1f664870a930a43" + integrity sha512-CTCh8NqED3iecTNuiz49mwSsrc2iQb4d0MjMdmS/8pb69Y4IlzJ/DIy/p5GFlgOrFbNO2WzMHkWKQSiJ3VNXaw== + dependencies: + "@discordjs/formatters" "^0.3.1" + "@discordjs/util" "^0.3.1" + "@sapphire/shapeshift" "^3.8.2" + discord-api-types "^0.37.41" + fast-deep-equal "^3.1.3" + ts-mixer "^6.0.3" + tslib "^2.5.0" + +"@discordjs/collection@^1.5.1": + version "1.5.1" + resolved "https://registry.yarnpkg.com/@discordjs/collection/-/collection-1.5.1.tgz#bc7ca557838dc29247bf19860426637f103bc383" + integrity sha512-aWEc9DCf3TMDe9iaJoOnO2+JVAjeRNuRxPZQA6GVvBf+Z3gqUuWYBy2NWh4+5CLYq5uoc3MOvUQ5H5m8CJBqOA== + +"@discordjs/formatters@^0.3.1": + version "0.3.1" + resolved "https://registry.yarnpkg.com/@discordjs/formatters/-/formatters-0.3.1.tgz#81393cf25e6e3223361061629752ea727475e842" + integrity sha512-M7X4IGiSeh4znwcRGcs+49B5tBkNDn4k5bmhxJDAUhRxRHTiFAOTVUNQ6yAKySu5jZTnCbSvTYHW3w0rAzV1MA== + dependencies: + discord-api-types "^0.37.41" + +"@discordjs/rest@^1.7.1": + version "1.7.1" + resolved "https://registry.yarnpkg.com/@discordjs/rest/-/rest-1.7.1.tgz#eeef0e71a37c95fa27962129729b2aa9de8e3752" + integrity sha512-Ofa9UqT0U45G/eX86cURQnX7gzOJLG2oC28VhIk/G6IliYgQF7jFByBJEykPSHE4MxPhqCleYvmsrtfKh1nYmQ== + dependencies: + "@discordjs/collection" "^1.5.1" + "@discordjs/util" "^0.3.0" + "@sapphire/async-queue" "^1.5.0" + "@sapphire/snowflake" "^3.4.2" + discord-api-types "^0.37.41" + file-type "^18.3.0" + tslib "^2.5.0" + undici "^5.22.0" + +"@discordjs/util@^0.3.0", "@discordjs/util@^0.3.1": + version "0.3.1" + resolved "https://registry.yarnpkg.com/@discordjs/util/-/util-0.3.1.tgz#4e8737e1dcff7e9f5eccc3116fb44755b65b1e97" + integrity sha512-HxXKYKg7vohx2/OupUN/4Sd02Ev3PBJ5q0gtjdcvXb0ErCva8jNHWfe/v5sU3UKjIB/uxOhc+TDOnhqffj9pRA== + +"@discordjs/ws@^0.8.3": + version "0.8.3" + resolved "https://registry.yarnpkg.com/@discordjs/ws/-/ws-0.8.3.tgz#77db8d563b731a2198c1b40f63b1ef8d230504f7" + integrity sha512-hcYtppanjHecbdNyCKQNH2I4RP9UrphDgmRgLYrATEQF1oo4sYSve7ZmGsBEXSzH72MO2tBPdWSThunbxUVk0g== + dependencies: + "@discordjs/collection" "^1.5.1" + "@discordjs/rest" "^1.7.1" + "@discordjs/util" "^0.3.1" + "@sapphire/async-queue" "^1.5.0" + "@types/ws" "^8.5.4" + "@vladfrangu/async_event_emitter" "^2.2.1" + discord-api-types "^0.37.41" + tslib "^2.5.0" + ws "^8.13.0" + +"@eslint-community/eslint-utils@^4.2.0": + version "4.4.0" + resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" + integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== + dependencies: + eslint-visitor-keys "^3.3.0" + +"@eslint-community/regexpp@^4.4.0": + version "4.5.1" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.5.1.tgz#cdd35dce4fa1a89a4fd42b1599eb35b3af408884" + integrity sha512-Z5ba73P98O1KUYCCJTUeVpja9RcGoMdncZ6T49FCUl2lN38JtCJ+3WgIDBv0AuY4WChU5PmtJmOCTlN6FZTFKQ== + +"@eslint/eslintrc@^2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-2.0.3.tgz#4910db5505f4d503f27774bf356e3704818a0331" + integrity sha512-+5gy6OQfk+xx3q0d6jGZZC3f3KzAkXc/IanVxd1is/VIIziRqqt3ongQz0FiTUXqTk0c7aDB3OaFuKnuSoJicQ== + dependencies: + ajv "^6.12.4" + debug "^4.3.2" + espree "^9.5.2" + globals "^13.19.0" + ignore "^5.2.0" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.1.2" + strip-json-comments "^3.1.1" + +"@eslint/js@8.41.0": + version "8.41.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-8.41.0.tgz#080321c3b68253522f7646b55b577dd99d2950b3" + integrity sha512-LxcyMGxwmTh2lY9FwHPGWOHmYFCZvbrFCBZL4FzSSsxsRPuhrYUg/49/0KDfW8tnIEaEHtfmn6+NPN+1DqaNmA== + +"@fastify/ajv-compiler@^3.5.0": + version "3.5.0" + resolved "https://registry.yarnpkg.com/@fastify/ajv-compiler/-/ajv-compiler-3.5.0.tgz#459bff00fefbf86c96ec30e62e933d2379e46670" + integrity sha512-ebbEtlI7dxXF5ziNdr05mOY8NnDiPB1XvAlLHctRt/Rc+C3LCOVW5imUVX+mhvUhnNzmPBHewUkOFgGlCxgdAA== + dependencies: + ajv "^8.11.0" + ajv-formats "^2.1.1" + fast-uri "^2.0.0" + +"@fastify/cors@^8.1.0": + version "8.3.0" + resolved "https://registry.yarnpkg.com/@fastify/cors/-/cors-8.3.0.tgz#f03d745731b770793a1a15344da7220ca0d19619" + integrity sha512-oj9xkka2Tg0MrwuKhsSUumcAkfp2YCnKxmFEusi01pjk1YrdDsuSYTHXEelWNW+ilSy/ApZq0c2SvhKrLX0H1g== + dependencies: + fastify-plugin "^4.0.0" + mnemonist "0.39.5" + +"@fastify/deepmerge@^1.0.0": + version "1.3.0" + resolved "https://registry.yarnpkg.com/@fastify/deepmerge/-/deepmerge-1.3.0.tgz#8116858108f0c7d9fd460d05a7d637a13fe3239a" + integrity sha512-J8TOSBq3SoZbDhM9+R/u77hP93gz/rajSA+K2kGyijPpORPWUXHUpTaleoj+92As0S9uPRP7Oi8IqMf0u+ro6A== + +"@fastify/error@^3.0.0": + version "3.2.0" + resolved "https://registry.yarnpkg.com/@fastify/error/-/error-3.2.0.tgz#9010e0acfe07965f5fc7d2b367f58f042d0f4106" + integrity sha512-KAfcLa+CnknwVi5fWogrLXgidLic+GXnLjijXdpl8pvkvbXU5BGa37iZO9FGvsh9ZL4y+oFi5cbHBm5UOG+dmQ== + +"@fastify/fast-json-stringify-compiler@^4.3.0": + version "4.3.0" + resolved "https://registry.yarnpkg.com/@fastify/fast-json-stringify-compiler/-/fast-json-stringify-compiler-4.3.0.tgz#5df89fa4d1592cbb8780f78998355feb471646d5" + integrity sha512-aZAXGYo6m22Fk1zZzEUKBvut/CIIQe/BapEORnxiD5Qr0kPHqqI69NtEMCme74h+at72sPhbkb4ZrLd1W3KRLA== + dependencies: + fast-json-stringify "^5.7.0" + +"@fastify/formbody@^7.3.0": + version "7.4.0" + resolved "https://registry.yarnpkg.com/@fastify/formbody/-/formbody-7.4.0.tgz#5370b16d1ee58b9023008d1e883de60353a132ad" + integrity sha512-H3C6h1GN56/SMrZS8N2vCT2cZr7mIHzBHzOBa5OPpjfB/D6FzP9mMpE02ZzrFX0ANeh0BAJdoXKOF2e7IbV+Og== + dependencies: + fast-querystring "^1.0.0" + fastify-plugin "^4.0.0" + +"@fastify/helmet@^10.0.1": + version "10.1.1" + resolved "https://registry.yarnpkg.com/@fastify/helmet/-/helmet-10.1.1.tgz#3028fa5ab4100214a9dec1fea27ebcd983e58e9b" + integrity sha512-z9abyIlCHPU25llOTyo3uz8F8TJ+uDqtOC4+38dxODPw8Ro9sTZjbm2U7ZIF0IAv3/E0ke6vbUQ4sB376WuKJA== + dependencies: + fastify-plugin "^4.2.1" + helmet "^6.0.0" + +"@fastify/jwt@^6.3.2": + version "6.7.1" + resolved "https://registry.yarnpkg.com/@fastify/jwt/-/jwt-6.7.1.tgz#7ebbb7844eecf5bd4da12a878a8d0b1ccb28413e" + integrity sha512-pvRcGeyF2H1U+HXaxlRBd6s1y99vbSZjhpxTWECIGIhMXKRxBTBSUPRF7LJGONlW1/pZstQ0/Dp/ZxBFlDuEnw== + dependencies: + "@fastify/error" "^3.0.0" + "@lukeed/ms" "^2.0.0" + fast-jwt "^2.0.0" + fastify-plugin "^4.0.0" + steed "^1.1.3" + +"@fastify/view@^7.4.1": + version "7.4.1" + resolved "https://registry.yarnpkg.com/@fastify/view/-/view-7.4.1.tgz#265daba48386a5d3f69dfc446af468d72e0a8757" + integrity sha512-ahmRmSbNVM8bIoz0BAFnY0jNigom+xbPQ9Q1ZjmNOtGVVT3nYXCxw2OMkTr9iXwrJ4Le3EtWDHlFkZ2fCQ2hJA== + dependencies: + fastify-plugin "^4.0.0" + hashlru "^2.3.0" + +"@humanwhocodes/config-array@^0.11.8": + version "0.11.8" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.11.8.tgz#03595ac2075a4dc0f191cc2131de14fbd7d410b9" + integrity sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g== + dependencies: + "@humanwhocodes/object-schema" "^1.2.1" + debug "^4.1.1" + minimatch "^3.0.5" + +"@humanwhocodes/module-importer@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" + integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== + +"@humanwhocodes/object-schema@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz#b520529ec21d8e5945a1851dfd1c32e94e39ff45" + integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== + +"@jridgewell/resolve-uri@^3.0.3": + version "3.1.1" + resolved "https://registry.yarnpkg.com/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz#c08679063f279615a3326583ba3a90d1d82cc721" + integrity sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA== + +"@jridgewell/sourcemap-codec@^1.4.10": + version "1.4.15" + resolved "https://registry.yarnpkg.com/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz#d7c6e6755c78567a951e04ab52ef0fd26de59f32" + integrity sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg== + +"@jridgewell/trace-mapping@0.3.9": + version "0.3.9" + resolved "https://registry.yarnpkg.com/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz#6534fd5933a53ba7cbf3a17615e273a0d1273ff9" + integrity sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ== + dependencies: + "@jridgewell/resolve-uri" "^3.0.3" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@lukeed/ms@^2.0.0": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@lukeed/ms/-/ms-2.0.1.tgz#3c2bbc258affd9cc0e0cc7828477383c73afa6ee" + integrity sha512-Xs/4RZltsAL7pkvaNStUQt7netTkyxrS0K+RILcVr3TRMS/ToOg4I6uNfhB9SlGsnWBym4U+EaXq0f0cEMNkHA== + +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== + +"@nodelib/fs.walk@^1.2.3", "@nodelib/fs.walk@^1.2.8": + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== + dependencies: + "@nodelib/fs.scandir" "2.1.5" + fastq "^1.6.0" + +"@sapphire/async-queue@^1.5.0": + version "1.5.0" + resolved "https://registry.yarnpkg.com/@sapphire/async-queue/-/async-queue-1.5.0.tgz#2f255a3f186635c4fb5a2381e375d3dfbc5312d8" + integrity sha512-JkLdIsP8fPAdh9ZZjrbHWR/+mZj0wvKS5ICibcLrRI1j84UmLMshx5n9QmL8b95d4onJ2xxiyugTgSAX7AalmA== + +"@sapphire/shapeshift@^3.8.2": + version "3.9.2" + resolved "https://registry.yarnpkg.com/@sapphire/shapeshift/-/shapeshift-3.9.2.tgz#a9c12cd51e1bc467619bb56df804450dd14871ac" + integrity sha512-YRbCXWy969oGIdqR/wha62eX8GNHsvyYi0Rfd4rNW6tSVVa8p0ELiMEuOH/k8rgtvRoM+EMV7Csqz77YdwiDpA== + dependencies: + fast-deep-equal "^3.1.3" + lodash "^4.17.21" + +"@sapphire/snowflake@^3.4.2": + version "3.5.1" + resolved "https://registry.yarnpkg.com/@sapphire/snowflake/-/snowflake-3.5.1.tgz#254521c188b49e8b2d4cc048b475fb2b38737fec" + integrity sha512-BxcYGzgEsdlG0dKAyOm0ehLGm2CafIrfQTZGWgkfKYbj+pNNsorZ7EotuZukc2MT70E0UbppVbtpBrqpzVzjNA== + +"@smithy/protocol-http@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@smithy/protocol-http/-/protocol-http-1.0.1.tgz#62fd73d73db285fd8e9a2287ed2904ac66e0d43f" + integrity sha512-9OrEn0WfOVtBNYJUjUAn9AOiJ4lzERCJJ/JeZs8E6yajTGxBaFRxUnNBHiNqoDJVg076hY36UmEnPx7xXrvUSg== + dependencies: + "@smithy/types" "^1.0.0" + tslib "^2.5.0" + +"@smithy/types@^1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@smithy/types/-/types-1.0.0.tgz#87ab6131fe5e19cbd4d383ffb94d2b806d027d38" + integrity sha512-kc1m5wPBHQCTixwuaOh9vnak/iJm21DrSf9UK6yDE5S3mQQ4u11pqAUiKWnlrZnYkeLfAI9UEHj9OaMT1v5Umg== + dependencies: + tslib "^2.5.0" + +"@tokenizer/token@^0.3.0": + version "0.3.0" + resolved "https://registry.yarnpkg.com/@tokenizer/token/-/token-0.3.0.tgz#fe98a93fe789247e998c75e74e9c7c63217aa276" + integrity sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A== + +"@tsconfig/node10@^1.0.7": + version "1.0.9" + resolved "https://registry.yarnpkg.com/@tsconfig/node10/-/node10-1.0.9.tgz#df4907fc07a886922637b15e02d4cebc4c0021b2" + integrity sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA== + +"@tsconfig/node12@^1.0.7": + version "1.0.11" + resolved "https://registry.yarnpkg.com/@tsconfig/node12/-/node12-1.0.11.tgz#ee3def1f27d9ed66dac6e46a295cffb0152e058d" + integrity sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag== + +"@tsconfig/node14@^1.0.0": + version "1.0.3" + resolved "https://registry.yarnpkg.com/@tsconfig/node14/-/node14-1.0.3.tgz#e4386316284f00b98435bf40f72f75a09dabf6c1" + integrity sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow== + +"@tsconfig/node16@^1.0.2": + version "1.0.4" + resolved "https://registry.yarnpkg.com/@tsconfig/node16/-/node16-1.0.4.tgz#0b92dcc0cc1c81f6f306a381f28e31b1a56536e9" + integrity sha512-vxhUy4J8lyeyinH7Azl1pdd43GJhZH/tP2weN8TntQblOY+A0XbT8DJk1/oCPuOOyg/Ja757rG0CgHcWC8OfMA== + +"@typegoose/typegoose@^9.12.1": + version "9.13.2" + resolved "https://registry.yarnpkg.com/@typegoose/typegoose/-/typegoose-9.13.2.tgz#0f066fdcb114decdd390ed0ab63e1f4e8df71315" + integrity sha512-yEP+Ai+xASUnRR2ZSz2cf7QC4QqhkDPyt42Gt5yfn6dOFMGNFew+4L1BDRbexaeKBQYYrgxtD7yM8kzuceeJ9Q== + dependencies: + lodash "^4.17.20" + loglevel "^1.8.1" + reflect-metadata "^0.1.13" + semver "^7.3.8" + tslib "^2.4.1" + +"@types/dotenv@^8.2.0": + version "8.2.0" + resolved "https://registry.yarnpkg.com/@types/dotenv/-/dotenv-8.2.0.tgz#5cd64710c3c98e82d9d15844375a33bf1b45d053" + integrity sha512-ylSC9GhfRH7m1EUXBXofhgx4lUWmFeQDINW5oLuS+gxWdfUeW4zJdeVTYVkexEW+e2VUvlZR2kGnGGipAWR7kw== + dependencies: + dotenv "*" + +"@types/json-schema@^7.0.9": + version "7.0.12" + resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.12.tgz#d70faba7039d5fca54c83c7dbab41051d2b6f6cb" + integrity sha512-Hr5Jfhc9eYOQNPYO5WLDq/n4jqijdHNlDXjuAQkkt+mWdQR+XJToOHrsD4cPaMXpn6KO7y2+wM8AZEs8VpBLVA== + +"@types/node-schedule@^2.1.0": + version "2.1.0" + resolved "https://registry.yarnpkg.com/@types/node-schedule/-/node-schedule-2.1.0.tgz#60375640c0509bab963573def9d1f417f438c290" + integrity sha512-NiTwl8YN3v/1YCKrDFSmCTkVxFDylueEqsOFdgF+vPsm+AlyJKGAo5yzX1FiOxPsZiN6/r8gJitYx2EaSuBmmg== + dependencies: + "@types/node" "*" + +"@types/node@*": + version "20.2.5" + resolved "https://registry.yarnpkg.com/@types/node/-/node-20.2.5.tgz#26d295f3570323b2837d322180dfbf1ba156fefb" + integrity sha512-JJulVEQXmiY9Px5axXHeYGLSjhkZEnD+MDPDGbCbIAbMslkKwmygtZFy1X6s/075Yo94sf8GuSlFfPzysQrWZQ== + +"@types/semver@^7.3.12": + version "7.5.0" + resolved "https://registry.yarnpkg.com/@types/semver/-/semver-7.5.0.tgz#591c1ce3a702c45ee15f47a42ade72c2fd78978a" + integrity sha512-G8hZ6XJiHnuhQKR7ZmysCeJWE08o8T0AXtk5darsCaTVsYZhhgUrq53jizaR2FvsoeCwJhlmwTjkXBY5Pn/ZHw== + +"@types/strip-bom@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/strip-bom/-/strip-bom-3.0.0.tgz#14a8ec3956c2e81edb7520790aecf21c290aebd2" + integrity sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ== + +"@types/strip-json-comments@0.0.30": + version "0.0.30" + resolved "https://registry.yarnpkg.com/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz#9aa30c04db212a9a0649d6ae6fd50accc40748a1" + integrity sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ== + +"@types/webidl-conversions@*": + version "7.0.0" + resolved "https://registry.yarnpkg.com/@types/webidl-conversions/-/webidl-conversions-7.0.0.tgz#2b8e60e33906459219aa587e9d1a612ae994cfe7" + integrity sha512-xTE1E+YF4aWPJJeUzaZI5DRntlkY3+BCVJi0axFptnjGmAoWxkyREIh/XMrfxVLejwQxMCfDXdICo0VLxThrog== + +"@types/whatwg-url@^8.2.1": + version "8.2.2" + resolved "https://registry.yarnpkg.com/@types/whatwg-url/-/whatwg-url-8.2.2.tgz#749d5b3873e845897ada99be4448041d4cc39e63" + integrity sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA== + dependencies: + "@types/node" "*" + "@types/webidl-conversions" "*" + +"@types/ws@^8.5.4": + version "8.5.5" + resolved "https://registry.yarnpkg.com/@types/ws/-/ws-8.5.5.tgz#af587964aa06682702ee6dcbc7be41a80e4b28eb" + integrity sha512-lwhs8hktwxSjf9UaZ9tG5M03PGogvFaH8gUgLNbN9HKIg0dvv6q+gkSuJ8HN4/VbyxkuLzCjlN7GquQ0gUJfIg== + dependencies: + "@types/node" "*" + +"@typescript-eslint/eslint-plugin@^5.40.1": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.59.8.tgz#1e7a3e5318ece22251dfbc5c9c6feeb4793cc509" + integrity sha512-JDMOmhXteJ4WVKOiHXGCoB96ADWg9q7efPWHRViT/f09bA8XOMLAVHHju3l0MkZnG1izaWXYmgvQcUjTRcpShQ== + dependencies: + "@eslint-community/regexpp" "^4.4.0" + "@typescript-eslint/scope-manager" "5.59.8" + "@typescript-eslint/type-utils" "5.59.8" + "@typescript-eslint/utils" "5.59.8" + debug "^4.3.4" + grapheme-splitter "^1.0.4" + ignore "^5.2.0" + natural-compare-lite "^1.4.0" + semver "^7.3.7" + tsutils "^3.21.0" + +"@typescript-eslint/parser@^5.40.1": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.59.8.tgz#60cbb00671d86cf746044ab797900b1448188567" + integrity sha512-AnR19RjJcpjoeGojmwZtCwBX/RidqDZtzcbG3xHrmz0aHHoOcbWnpDllenRDmDvsV0RQ6+tbb09/kyc+UT9Orw== + dependencies: + "@typescript-eslint/scope-manager" "5.59.8" + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/typescript-estree" "5.59.8" + debug "^4.3.4" + +"@typescript-eslint/scope-manager@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.59.8.tgz#ff4ad4fec6433647b817c4a7d4b4165d18ea2fa8" + integrity sha512-/w08ndCYI8gxGf+9zKf1vtx/16y8MHrZs5/tnjHhMLNSixuNcJavSX4wAiPf4aS5x41Es9YPCn44MIe4cxIlig== + dependencies: + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/visitor-keys" "5.59.8" + +"@typescript-eslint/type-utils@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-5.59.8.tgz#aa6c029a9d7706d26bbd25eb4666398781df6ea2" + integrity sha512-+5M518uEIHFBy3FnyqZUF3BMP+AXnYn4oyH8RF012+e7/msMY98FhGL5SrN29NQ9xDgvqCgYnsOiKp1VjZ/fpA== + dependencies: + "@typescript-eslint/typescript-estree" "5.59.8" + "@typescript-eslint/utils" "5.59.8" + debug "^4.3.4" + tsutils "^3.21.0" + +"@typescript-eslint/types@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.59.8.tgz#212e54414733618f5d0fd50b2da2717f630aebf8" + integrity sha512-+uWuOhBTj/L6awoWIg0BlWy0u9TyFpCHrAuQ5bNfxDaZ1Ppb3mx6tUigc74LHcbHpOHuOTOJrBoAnhdHdaea1w== + +"@typescript-eslint/typescript-estree@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.59.8.tgz#801a7b1766481629481b3b0878148bd7a1f345d7" + integrity sha512-Jy/lPSDJGNow14vYu6IrW790p7HIf/SOV1Bb6lZ7NUkLc2iB2Z9elESmsaUtLw8kVqogSbtLH9tut5GCX1RLDg== + dependencies: + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/visitor-keys" "5.59.8" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + semver "^7.3.7" + tsutils "^3.21.0" + +"@typescript-eslint/utils@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-5.59.8.tgz#34d129f35a2134c67fdaf024941e8f96050dca2b" + integrity sha512-Tr65630KysnNn9f9G7ROF3w1b5/7f6QVCJ+WK9nhIocWmx9F+TmCAcglF26Vm7z8KCTwoKcNEBZrhlklla3CKg== + dependencies: + "@eslint-community/eslint-utils" "^4.2.0" + "@types/json-schema" "^7.0.9" + "@types/semver" "^7.3.12" + "@typescript-eslint/scope-manager" "5.59.8" + "@typescript-eslint/types" "5.59.8" + "@typescript-eslint/typescript-estree" "5.59.8" + eslint-scope "^5.1.1" + semver "^7.3.7" + +"@typescript-eslint/visitor-keys@5.59.8": + version "5.59.8" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.59.8.tgz#aa6a7ef862add919401470c09e1609392ef3cc40" + integrity sha512-pJhi2ms0x0xgloT7xYabil3SGGlojNNKjK/q6dB3Ey0uJLMjK2UDGJvHieiyJVW/7C3KI+Z4Q3pEHkm4ejA+xQ== + dependencies: + "@typescript-eslint/types" "5.59.8" + eslint-visitor-keys "^3.3.0" + +"@vladfrangu/async_event_emitter@^2.2.1": + version "2.2.2" + resolved "https://registry.yarnpkg.com/@vladfrangu/async_event_emitter/-/async_event_emitter-2.2.2.tgz#84c5a3f8d648842cec5cc649b88df599af32ed88" + integrity sha512-HIzRG7sy88UZjBJamssEczH5q7t5+axva19UbZLO6u0ySbYPrwzWiXBcC0WuHyhKKoeCyneH+FvYzKQq/zTtkQ== + +abort-controller@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/abort-controller/-/abort-controller-3.0.0.tgz#eaf54d53b62bae4138e809ca225c8439a6efb392" + integrity sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg== + dependencies: + event-target-shim "^5.0.0" + +abstract-logging@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/abstract-logging/-/abstract-logging-2.0.1.tgz#6b0c371df212db7129b57d2e7fcf282b8bf1c839" + integrity sha512-2BjRTZxTPvheOvGbBslFSYOUkr+SjPtOnrLP33f+VIWLzezQpZcqVg7ja3L4dBXmzzgwT+a029jRx5PCi3JuiA== + +acorn-jsx@^5.3.2: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + +acorn-walk@^8.1.1: + version "8.2.0" + resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1" + integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== + +acorn@^8.4.1, acorn@^8.8.0: + version "8.8.2" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.2.tgz#1b2f25db02af965399b9776b0c2c391276d37c4a" + integrity sha512-xjIYgE8HBrkpd/sJqOGNspf8uHG+NOHGOw6a/Urj8taM2EXfdNAH2oFcPeIFfsv3+kz/mJrS5VuMqbNLjCa2vw== + +agent-base@6: + version "6.0.2" + resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77" + integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== + dependencies: + debug "4" + +ajv-formats@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/ajv-formats/-/ajv-formats-2.1.1.tgz#6e669400659eb74973bbf2e33327180a0996b520" + integrity sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA== + dependencies: + ajv "^8.0.0" + +ajv@^6.10.0, ajv@^6.12.4: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + +ajv@^8.0.0, ajv@^8.10.0, ajv@^8.11.0: + version "8.12.0" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1" + integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA== + dependencies: + fast-deep-equal "^3.1.1" + json-schema-traverse "^1.0.0" + require-from-string "^2.0.2" + uri-js "^4.2.2" + +ansi-regex@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== + +ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + +anymatch@~3.1.2: + version "3.1.3" + resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.3.tgz#790c58b19ba1720a84205b57c618d5ad8524973e" + integrity sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw== + dependencies: + normalize-path "^3.0.0" + picomatch "^2.0.4" + +archy@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/archy/-/archy-1.0.0.tgz#f9c8c13757cc1dd7bc379ac77b2c62a5c2868c40" + integrity sha512-Xg+9RwCg/0p32teKdGMPTPnVXKD0w3DfHnFTficozsAgsvq2XenPJq/MYpzzQ/v8zrOyJn6Ds39VA4JIDwFfqw== + +arg@^4.1.0: + version "4.1.3" + resolved "https://registry.yarnpkg.com/arg/-/arg-4.1.3.tgz#269fc7ad5b8e42cb63c896d5666017261c144089" + integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== + +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + +arrify@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/arrify/-/arrify-2.0.1.tgz#c9655e9331e0abcd588d2a7cad7e9956f66701fa" + integrity sha512-3duEwti880xqi4eAMN8AyR4a0ByT90zoYdLlevfrvU43vb0YZwZVfxOgxWrLXXXpyugL0hNZc9G6BiB5B3nUug== + +asn1.js@^5.4.1: + version "5.4.1" + resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-5.4.1.tgz#11a980b84ebb91781ce35b0fdc2ee294e3783f07" + integrity sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA== + dependencies: + bn.js "^4.0.0" + inherits "^2.0.1" + minimalistic-assert "^1.0.0" + safer-buffer "^2.1.0" + +async@^3.2.3: + version "3.2.4" + resolved "https://registry.yarnpkg.com/async/-/async-3.2.4.tgz#2d22e00f8cddeb5fde5dd33522b56d1cf569a81c" + integrity sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ== + +asynckit@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" + integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== + +atomic-sleep@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/atomic-sleep/-/atomic-sleep-1.0.0.tgz#eb85b77a601fc932cfe432c5acd364a9e2c9075b" + integrity sha512-kNOjDqAh7px0XWNI+4QbzoiR/nTkHAWNud2uvnJquD1/x5a7EQZMJT0AczqK0Qn67oY/TTQ1LbUKajZpp3I9tQ== + +avvio@^8.2.0: + version "8.2.1" + resolved "https://registry.yarnpkg.com/avvio/-/avvio-8.2.1.tgz#b5a482729847abb84d5aadce06511c04a0a62f82" + integrity sha512-TAlMYvOuwGyLK3PfBb5WKBXZmXz2fVCgv23d6zZFdle/q3gPjmxBaeuC0pY0Dzs5PWMSgfqqEZkrye19GlDTgw== + dependencies: + archy "^1.0.0" + debug "^4.0.0" + fastq "^1.6.1" + +axios@^1.1.3: + version "1.4.0" + resolved "https://registry.yarnpkg.com/axios/-/axios-1.4.0.tgz#38a7bf1224cd308de271146038b551d725f0be1f" + integrity sha512-S4XCWMEmzvo64T9GfvQDOXgYRDJ/wsSZc7Jvdgx5u1sd0JwsuPLqb3SYmusag+edF6ziyMensPVqLTSc1PiSEA== + dependencies: + follow-redirects "^1.15.0" + form-data "^4.0.0" + proxy-from-env "^1.1.0" + +balanced-match@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== + +base64-js@^1.3.0, base64-js@^1.3.1: + version "1.5.1" + resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.5.1.tgz#1b1b440160a5bf7ad40b650f095963481903930a" + integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== + +bignumber.js@^9.0.0: + version "9.1.1" + resolved "https://registry.yarnpkg.com/bignumber.js/-/bignumber.js-9.1.1.tgz#c4df7dc496bd849d4c9464344c1aa74228b4dac6" + integrity sha512-pHm4LsMJ6lzgNGVfZHjMoO8sdoRhOzOH4MLmY65Jg70bpxCKu5iOHNJyfF6OyvYw7t8Fpf35RuzUyqnQsj8Vig== + +binary-extensions@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.2.0.tgz#75f502eeaf9ffde42fc98829645be4ea76bd9e2d" + integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== + +bn.js@^4.0.0: + version "4.12.0" + resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.12.0.tgz#775b3f278efbb9718eec7361f483fb36fbbfea88" + integrity sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA== + +bowser@^2.11.0: + version "2.11.0" + resolved "https://registry.yarnpkg.com/bowser/-/bowser-2.11.0.tgz#5ca3c35757a7aa5771500c70a73a9f91ef420a8f" + integrity sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA== + +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +brace-expansion@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== + dependencies: + balanced-match "^1.0.0" + +braces@^3.0.2, braces@~3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + +bson@^4.7.2: + version "4.7.2" + resolved "https://registry.yarnpkg.com/bson/-/bson-4.7.2.tgz#320f4ad0eaf5312dd9b45dc369cc48945e2a5f2e" + integrity sha512-Ry9wCtIZ5kGqkJoi6aD8KjxFZEx78guTQDnpXWiNthsxzrxAK/i8E6pCHAIZTbaEFWcOCvbecMukfK7XUvyLpQ== + dependencies: + buffer "^5.6.0" + +buffer-equal-constant-time@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz#f8e71132f7ffe6e01a5c9697a4c6f3e48d5cc819" + integrity sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA== + +buffer-from@^1.0.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" + integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== + +buffer@^5.6.0: + version "5.7.1" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-5.7.1.tgz#ba62e7c13133053582197160851a8f648e99eed0" + integrity sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.1.13" + +buffer@^6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/buffer/-/buffer-6.0.3.tgz#2ace578459cc8fbe2a70aaa8f52ee63b6a74c6c6" + integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.2.1" + +busboy@^1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/busboy/-/busboy-1.6.0.tgz#966ea36a9502e43cdb9146962523b92f531f6893" + integrity sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA== + dependencies: + streamsearch "^1.1.0" + +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +chalk@^4.0.0, chalk@^4.0.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +chokidar@^3.5.1: + version "3.5.3" + resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.5.3.tgz#1cf37c8707b932bd1af1ae22c0432e2acd1903bd" + integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw== + dependencies: + anymatch "~3.1.2" + braces "~3.0.2" + glob-parent "~5.1.2" + is-binary-path "~2.1.0" + is-glob "~4.0.1" + normalize-path "~3.0.0" + readdirp "~3.6.0" + optionalDependencies: + fsevents "~2.3.2" + +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + +color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + +colors@1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/colors/-/colors-1.4.0.tgz#c50491479d4c1bdaed2c9ced32cf7c7dc2360f78" + integrity sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA== + +combined-stream@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" + integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== + dependencies: + delayed-stream "~1.0.0" + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + +cookie@^0.5.0: + version "0.5.0" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.5.0.tgz#d1f5d71adec6558c58f389987c366aa47e994f8b" + integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== + +create-require@^1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/create-require/-/create-require-1.1.1.tgz#c1d7e8f1e5f6cfc9ff65f9cd352d37348756c333" + integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== + +cron-parser@^4.2.0: + version "4.8.1" + resolved "https://registry.yarnpkg.com/cron-parser/-/cron-parser-4.8.1.tgz#47062ea63d21d78c10ddedb08ea4c5b6fc2750fb" + integrity sha512-jbokKWGcyU4gl6jAfX97E1gDpY12DJ1cLJZmoDzaAln/shZ+S3KBFBuA2Q6WeUN4gJf/8klnV1EfvhA2lK5IRQ== + dependencies: + luxon "^3.2.1" + +cross-spawn@^7.0.2: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +dateformat@4.5.1: + version "4.5.1" + resolved "https://registry.yarnpkg.com/dateformat/-/dateformat-4.5.1.tgz#c20e7a9ca77d147906b6dc2261a8be0a5bd2173c" + integrity sha512-OD0TZ+B7yP7ZgpJf5K2DIbj3FZvFvxgFUuaqA/V5zTjAtAAXZ1E8bktHxmAGs4x5b7PflqA9LeQ84Og7wYtF7Q== + +debug@4, debug@4.x, debug@^4.0.0, debug@^4.1.1, debug@^4.3.2, debug@^4.3.4: + version "4.3.4" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + +deep-is@^0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" + integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== + +diff@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/diff/-/diff-4.0.2.tgz#60f3aecb89d5fae520c11aa19efc2bb982aade7d" + integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== + +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + +discord-api-types@^0.37.41: + version "0.37.43" + resolved "https://registry.yarnpkg.com/discord-api-types/-/discord-api-types-0.37.43.tgz#94ae2b949e3aa092f5e93b0f3cf8e6620583749c" + integrity sha512-bBhDWU3TF9KADxR/mHp1K4Bvu/LRtFQdGyBjADu4e66F3ZnD4kp12W/SJCttIaCcMXzPV3sfty6eDGRNRph51Q== + +discord.js@^14.11.0: + version "14.11.0" + resolved "https://registry.yarnpkg.com/discord.js/-/discord.js-14.11.0.tgz#6529d49f30d10fc5a9ff8e6796661aa998769afe" + integrity sha512-CkueWYFQ28U38YPR8HgsBR/QT35oPpMbEsTNM30Fs8loBIhnA4s70AwQEoy6JvLcpWWJO7GY0y2BUzZmuBMepQ== + dependencies: + "@discordjs/builders" "^1.6.3" + "@discordjs/collection" "^1.5.1" + "@discordjs/formatters" "^0.3.1" + "@discordjs/rest" "^1.7.1" + "@discordjs/util" "^0.3.1" + "@discordjs/ws" "^0.8.3" + "@sapphire/snowflake" "^3.4.2" + "@types/ws" "^8.5.4" + discord-api-types "^0.37.41" + fast-deep-equal "^3.1.3" + lodash.snakecase "^4.1.1" + tslib "^2.5.0" + undici "^5.22.0" + ws "^8.13.0" + +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== + dependencies: + esutils "^2.0.2" + +dotenv@*, dotenv@^16.0.3: + version "16.1.3" + resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-16.1.3.tgz#0c67e90d0ddb48d08c570888f709b41844928210" + integrity sha512-FYssxsmCTtKL72fGBSvb1K9dRz0/VZeWqFme/vSb7r7323x4CRaHu4LvQ5JG3+s6yt2YPbBrkpiEODktfyjI9A== + +dynamic-dedupe@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz#06e44c223f5e4e94d78ef9db23a6515ce2f962a1" + integrity sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ== + dependencies: + xtend "^4.0.0" + +ecdsa-sig-formatter@1.0.11, ecdsa-sig-formatter@^1.0.11: + version "1.0.11" + resolved "https://registry.yarnpkg.com/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz#ae0f0fa2d85045ef14a817daa3ce9acd0489e5bf" + integrity sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ== + dependencies: + safe-buffer "^5.0.1" + +ejs@^3.1.9: + version "3.1.9" + resolved "https://registry.yarnpkg.com/ejs/-/ejs-3.1.9.tgz#03c9e8777fe12686a9effcef22303ca3d8eeb361" + integrity sha512-rC+QVNMJWv+MtPgkt0y+0rVEIdbtxVADApW9JXrUVlzHetgcyczP/E7DJmWJ4fJCZF2cPcBk0laWO9ZHMG3DmQ== + dependencies: + jake "^10.8.5" + +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +eslint-config-prettier@^8.5.0: + version "8.8.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-8.8.0.tgz#bfda738d412adc917fd7b038857110efe98c9348" + integrity sha512-wLbQiFre3tdGgpDv67NQKnJuTlcUVYHas3k+DZCc2U2BadthoEY4B7hLPvAxaqdyOGCzuLfii2fqGph10va7oA== + +eslint-plugin-prettier@^4.2.1: + version "4.2.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-prettier/-/eslint-plugin-prettier-4.2.1.tgz#651cbb88b1dab98bfd42f017a12fa6b2d993f94b" + integrity sha512-f/0rXLXUt0oFYs8ra4w49wYZBG5GKZpAYsJSm6rnYL5uVDjd+zowwMwVZHnAjf4edNrKpCDYfXDgmRE/Ak7QyQ== + dependencies: + prettier-linter-helpers "^1.0.0" + +eslint-scope@^5.1.1: + version "5.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-5.1.1.tgz#e786e59a66cb92b3f6c1fb0d508aab174848f48c" + integrity sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw== + dependencies: + esrecurse "^4.3.0" + estraverse "^4.1.1" + +eslint-scope@^7.2.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.2.0.tgz#f21ebdafda02352f103634b96dd47d9f81ca117b" + integrity sha512-DYj5deGlHBfMt15J7rdtyKNq/Nqlv5KfU4iodrQ019XESsRnwXH9KAE0y3cwtUHDo2ob7CypAnCqefh6vioWRw== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.1: + version "3.4.1" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.1.tgz#c22c48f48942d08ca824cc526211ae400478a994" + integrity sha512-pZnmmLwYzf+kWaM/Qgrvpen51upAktaaiI01nsJD/Yr3lMOdNtq0cxkrrg16w64VtisN6okbs7Q8AfGqj4c9fA== + +eslint@^8.25.0: + version "8.41.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.41.0.tgz#3062ca73363b4714b16dbc1e60f035e6134b6f1c" + integrity sha512-WQDQpzGBOP5IrXPo4Hc0814r4/v2rrIsB0rhT7jtunIalgg6gYXWhRMOejVO8yH21T/FGaxjmFjBMNqcIlmH1Q== + dependencies: + "@eslint-community/eslint-utils" "^4.2.0" + "@eslint-community/regexpp" "^4.4.0" + "@eslint/eslintrc" "^2.0.3" + "@eslint/js" "8.41.0" + "@humanwhocodes/config-array" "^0.11.8" + "@humanwhocodes/module-importer" "^1.0.1" + "@nodelib/fs.walk" "^1.2.8" + ajv "^6.10.0" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.3.2" + doctrine "^3.0.0" + escape-string-regexp "^4.0.0" + eslint-scope "^7.2.0" + eslint-visitor-keys "^3.4.1" + espree "^9.5.2" + esquery "^1.4.2" + esutils "^2.0.2" + fast-deep-equal "^3.1.3" + file-entry-cache "^6.0.1" + find-up "^5.0.0" + glob-parent "^6.0.2" + globals "^13.19.0" + graphemer "^1.4.0" + ignore "^5.2.0" + import-fresh "^3.0.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + is-path-inside "^3.0.3" + js-yaml "^4.1.0" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash.merge "^4.6.2" + minimatch "^3.1.2" + natural-compare "^1.4.0" + optionator "^0.9.1" + strip-ansi "^6.0.1" + strip-json-comments "^3.1.0" + text-table "^0.2.0" + +espree@^9.5.2: + version "9.5.2" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.5.2.tgz#e994e7dc33a082a7a82dceaf12883a829353215b" + integrity sha512-7OASN1Wma5fum5SrNhFMAMJxOUAbhyfQ8dQ//PJaJbNw0URTPWqIghHWt1MmAANKhHZIYOHruW4Kw4ruUWOdGw== + dependencies: + acorn "^8.8.0" + acorn-jsx "^5.3.2" + eslint-visitor-keys "^3.4.1" + +esquery@^1.4.2: + version "1.5.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" + integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^4.1.1: + version "4.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d" + integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== + +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +event-target-shim@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/event-target-shim/-/event-target-shim-5.0.1.tgz#5d4d3ebdf9583d63a5333ce2deb7480ab2b05789" + integrity sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ== + +events@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/events/-/events-3.3.0.tgz#31a95ad0a924e2d2c419a813aeb2c4e878ea7400" + integrity sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q== + +extend@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa" + integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g== + +fast-content-type-parse@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fast-content-type-parse/-/fast-content-type-parse-1.0.0.tgz#cddce00df7d7efb3727d375a598e4904bfcb751c" + integrity sha512-Xbc4XcysUXcsP5aHUU7Nq3OwvHq97C+WnbkeIefpeYLX+ryzFJlU6OStFJhs6Ol0LkUGpcK+wL0JwfM+FCU5IA== + +fast-decode-uri-component@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/fast-decode-uri-component/-/fast-decode-uri-component-1.0.1.tgz#46f8b6c22b30ff7a81357d4f59abfae938202543" + integrity sha512-WKgKWg5eUxvRZGwW8FvfbaH7AXSh2cL+3j5fMGzUMCxWBJ3dV3a7Wz8y2f/uQ0e3B6WmodD3oS54jTQ9HVTIIg== + +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-diff@^1.1.2: + version "1.3.0" + resolved "https://registry.yarnpkg.com/fast-diff/-/fast-diff-1.3.0.tgz#ece407fa550a64d638536cd727e129c61616e0f0" + integrity sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw== + +fast-glob@^3.2.9: + version "3.2.12" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.12.tgz#7f39ec99c2e6ab030337142da9e0c18f37afae80" + integrity sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + +fast-json-stable-stringify@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-json-stringify@^5.7.0: + version "5.7.0" + resolved "https://registry.yarnpkg.com/fast-json-stringify/-/fast-json-stringify-5.7.0.tgz#b0a04c848fdeb6ecd83440c71a4db35067023bed" + integrity sha512-sBVPTgnAZseLu1Qgj6lUbQ0HfjFhZWXAmpZ5AaSGkyLh5gAXBga/uPJjQPHpDFjC9adWIpdOcCLSDTgrZ7snoQ== + dependencies: + "@fastify/deepmerge" "^1.0.0" + ajv "^8.10.0" + ajv-formats "^2.1.1" + fast-deep-equal "^3.1.3" + fast-uri "^2.1.0" + rfdc "^1.2.0" + +fast-jwt@^2.0.0: + version "2.2.3" + resolved "https://registry.yarnpkg.com/fast-jwt/-/fast-jwt-2.2.3.tgz#c9bc42387f04368d2d36971eb9db03e5766a706f" + integrity sha512-ziANDWUZpgUyE+A8YAkauVnGa/XXJGEXC1H3qXAYnT8v4Et3EsC8Zuvw8ljiqDgRearw9Wy+Q/Miw5x1XmPJTA== + dependencies: + asn1.js "^5.4.1" + ecdsa-sig-formatter "^1.0.11" + mnemonist "^0.39.5" + +fast-levenshtein@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + +fast-querystring@^1.0.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/fast-querystring/-/fast-querystring-1.1.1.tgz#f4c56ef56b1a954880cfd8c01b83f9e1a3d3fda2" + integrity sha512-qR2r+e3HvhEFmpdHMv//U8FnFlnYjaC6QKDuaXALDkw2kvHO8WDjxH+f/rHGR4Me4pnk8p9JAkRNTjYHAKRn2Q== + dependencies: + fast-decode-uri-component "^1.0.1" + +fast-rbac@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/fast-rbac/-/fast-rbac-2.0.1.tgz#1eb4370d6e2a9e2c49b56dab00c2fce4328cded9" + integrity sha512-mfvwVtEDNvMtJOJcfo71tIvqNtZScu/bCAWUBMcpLpcn+bRuveR4UCeXKl2uKFBUJB2zp7tLnsoMHRx4rFrtww== + +fast-redact@^3.1.1: + version "3.2.0" + resolved "https://registry.yarnpkg.com/fast-redact/-/fast-redact-3.2.0.tgz#b1e2d39bc731376d28bde844454fa23e26919987" + integrity sha512-zaTadChr+NekyzallAMXATXLOR8MNx3zqpZ0MUF2aGf4EathnG0f32VLODNlY8IuGY3HoRO2L6/6fSzNsLaHIw== + +fast-text-encoding@^1.0.0: + version "1.0.6" + resolved "https://registry.yarnpkg.com/fast-text-encoding/-/fast-text-encoding-1.0.6.tgz#0aa25f7f638222e3396d72bf936afcf1d42d6867" + integrity sha512-VhXlQgj9ioXCqGstD37E/HBeqEGV/qOD/kmbVG8h5xKBYvM1L3lR1Zn4555cQ8GkYbJa8aJSipLPndE1k6zK2w== + +fast-uri@^2.0.0, fast-uri@^2.1.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/fast-uri/-/fast-uri-2.2.0.tgz#519a0f849bef714aad10e9753d69d8f758f7445a" + integrity sha512-cIusKBIt/R/oI6z/1nyfe2FvGKVTohVRfvkOhvx0nCEW+xf5NoCXjAHcWp93uOUBchzYcsvPlrapAdX1uW+YGg== + +fast-xml-parser@4.1.2: + version "4.1.2" + resolved "https://registry.yarnpkg.com/fast-xml-parser/-/fast-xml-parser-4.1.2.tgz#5a98c18238d28a57bbdfa9fe4cda01211fff8f4a" + integrity sha512-CDYeykkle1LiA/uqQyNwYpFbyF6Axec6YapmpUP+/RHWIoR1zKjocdvNaTsxCxZzQ6v9MLXaSYm9Qq0thv0DHg== + dependencies: + strnum "^1.0.5" + +fastfall@^1.5.0: + version "1.5.1" + resolved "https://registry.yarnpkg.com/fastfall/-/fastfall-1.5.1.tgz#3fee03331a49d1d39b3cdf7a5e9cd66f475e7b94" + integrity sha512-KH6p+Z8AKPXnmA7+Iz2Lh8ARCMr+8WNPVludm1LGkZoD2MjY6LVnRMtTKhkdzI+jr0RzQWXKzKyBJm1zoHEL4Q== + dependencies: + reusify "^1.0.0" + +fastify-plugin@^4.0.0, fastify-plugin@^4.2.1: + version "4.5.0" + resolved "https://registry.yarnpkg.com/fastify-plugin/-/fastify-plugin-4.5.0.tgz#8b853923a0bba6ab6921bb8f35b81224e6988d91" + integrity sha512-79ak0JxddO0utAXAQ5ccKhvs6vX2MGyHHMMsmZkBANrq3hXc1CHzvNPHOcvTsVMEPl5I+NT+RO4YKMGehOfSIg== + +fastify@^4.8.1: + version "4.17.0" + resolved "https://registry.yarnpkg.com/fastify/-/fastify-4.17.0.tgz#b2c8245e572edef0b02a167d2d411a3c8a46d01a" + integrity sha512-tzuY1tgWJo2Y6qEKwmLhFvACUmr68Io2pqP/sDKU71KRM6A6R3DrCDqLGqANbeLZcKUfdfY58ut35CGqemcTgg== + dependencies: + "@fastify/ajv-compiler" "^3.5.0" + "@fastify/error" "^3.0.0" + "@fastify/fast-json-stringify-compiler" "^4.3.0" + abstract-logging "^2.0.1" + avvio "^8.2.0" + fast-content-type-parse "^1.0.0" + fast-json-stringify "^5.7.0" + find-my-way "^7.6.0" + light-my-request "^5.6.1" + pino "^8.5.0" + process-warning "^2.0.0" + proxy-addr "^2.0.7" + rfdc "^1.3.0" + secure-json-parse "^2.5.0" + semver "^7.3.7" + tiny-lru "^11.0.1" + +fastparallel@^2.2.0: + version "2.4.1" + resolved "https://registry.yarnpkg.com/fastparallel/-/fastparallel-2.4.1.tgz#0d984a5813ffa67f30b4a5cb4cb8cbe61c7ee5a5" + integrity sha512-qUmhxPgNHmvRjZKBFUNI0oZuuH9OlSIOXmJ98lhKPxMZZ7zS/Fi0wRHOihDSz0R1YiIOjxzOY4bq65YTcdBi2Q== + dependencies: + reusify "^1.0.4" + xtend "^4.0.2" + +fastq@^1.3.0, fastq@^1.6.0, fastq@^1.6.1: + version "1.15.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.15.0.tgz#d04d07c6a2a68fe4599fea8d2e103a937fae6b3a" + integrity sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw== + dependencies: + reusify "^1.0.4" + +fastseries@^1.7.0: + version "1.7.2" + resolved "https://registry.yarnpkg.com/fastseries/-/fastseries-1.7.2.tgz#d22ce13b9433dff3388d91dbd6b8bda9b21a0f4b" + integrity sha512-dTPFrPGS8SNSzAt7u/CbMKCJ3s01N04s4JFbORHcmyvVfVKmbhMD1VtRbh5enGHxkaQDqWyLefiKOGGmohGDDQ== + dependencies: + reusify "^1.0.0" + xtend "^4.0.0" + +file-entry-cache@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" + integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg== + dependencies: + flat-cache "^3.0.4" + +file-type@^18.3.0: + version "18.5.0" + resolved "https://registry.yarnpkg.com/file-type/-/file-type-18.5.0.tgz#604a001ba0d32577d4c3fa420ee104d656b914d2" + integrity sha512-yvpl5U868+V6PqXHMmsESpg6unQ5GfnPssl4dxdJudBrr9qy7Fddt7EVX1VLlddFfe8Gj9N7goCZH22FXuSQXQ== + dependencies: + readable-web-to-node-stream "^3.0.2" + strtok3 "^7.0.0" + token-types "^5.0.1" + +filelist@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/filelist/-/filelist-1.0.4.tgz#f78978a1e944775ff9e62e744424f215e58352b5" + integrity sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q== + dependencies: + minimatch "^5.0.1" + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +find-my-way@^7.6.0: + version "7.6.2" + resolved "https://registry.yarnpkg.com/find-my-way/-/find-my-way-7.6.2.tgz#4dd40200d3536aeef5c7342b10028e04cf79146c" + integrity sha512-0OjHn1b1nCX3eVbm9ByeEHiscPYiHLfhei1wOUU9qffQkk98wE0Lo8VrVYfSGMgnSnDh86DxedduAnBf4nwUEw== + dependencies: + fast-deep-equal "^3.1.3" + fast-querystring "^1.0.0" + safe-regex2 "^2.0.0" + +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +flat-cache@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" + integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + dependencies: + flatted "^3.1.0" + rimraf "^3.0.2" + +flatted@^3.1.0: + version "3.2.7" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.7.tgz#609f39207cb614b89d0765b477cb2d437fbf9787" + integrity sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ== + +follow-redirects@^1.15.0: + version "1.15.2" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.15.2.tgz#b460864144ba63f2681096f274c4e57026da2c13" + integrity sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA== + +form-data@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-4.0.0.tgz#93919daeaf361ee529584b9b31664dc12c9fa452" + integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +forwarded@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" + integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== + +fsevents@~2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + +function-bind@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" + integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== + +gaxios@^5.0.0, gaxios@^5.0.1: + version "5.1.0" + resolved "https://registry.yarnpkg.com/gaxios/-/gaxios-5.1.0.tgz#133b77b45532be71eec72012b7e97c2320b6140a" + integrity sha512-aezGIjb+/VfsJtIcHGcBSerNEDdfdHeMros+RbYbGpmonKWQCOVOes0LVZhn1lDtIgq55qq0HaxymIoae3Fl/A== + dependencies: + extend "^3.0.2" + https-proxy-agent "^5.0.0" + is-stream "^2.0.0" + node-fetch "^2.6.7" + +gcp-metadata@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/gcp-metadata/-/gcp-metadata-5.2.0.tgz#b4772e9c5976241f5d3e69c4f446c906d25506ec" + integrity sha512-aFhhvvNycky2QyhG+dcfEdHBF0FRbYcf39s6WNHUDysKSrbJ5vuFbjydxBcmewtXeV248GP8dWT3ByPNxsyHCw== + dependencies: + gaxios "^5.0.0" + json-bigint "^1.0.0" + +glob-parent@^5.1.2, glob-parent@~5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob-parent@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + +glob@^7.1.3: + version "7.2.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" + integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.1.1" + once "^1.3.0" + path-is-absolute "^1.0.0" + +globals@^13.19.0: + version "13.20.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.20.0.tgz#ea276a1e508ffd4f1612888f9d1bad1e2717bf82" + integrity sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ== + dependencies: + type-fest "^0.20.2" + +globby@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + +google-auth-library@^8.5.2: + version "8.8.0" + resolved "https://registry.yarnpkg.com/google-auth-library/-/google-auth-library-8.8.0.tgz#2e17494431cef56b571420d483a4debff6c481cd" + integrity sha512-0iJn7IDqObDG5Tu9Tn2WemmJ31ksEa96IyK0J0OZCpTh6CrC6FrattwKX87h3qKVuprCJpdOGKc1Xi8V0kMh8Q== + dependencies: + arrify "^2.0.0" + base64-js "^1.3.0" + ecdsa-sig-formatter "^1.0.11" + fast-text-encoding "^1.0.0" + gaxios "^5.0.0" + gcp-metadata "^5.2.0" + gtoken "^6.1.0" + jws "^4.0.0" + lru-cache "^6.0.0" + +google-p12-pem@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/google-p12-pem/-/google-p12-pem-4.0.1.tgz#82841798253c65b7dc2a4e5fe9df141db670172a" + integrity sha512-WPkN4yGtz05WZ5EhtlxNDWPhC4JIic6G8ePitwUWy4l+XPVYec+a0j0Ts47PDtW59y3RwAhUd9/h9ZZ63px6RQ== + dependencies: + node-forge "^1.3.1" + +grapheme-splitter@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz#9cf3a665c6247479896834af35cf1dbb4400767e" + integrity sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ== + +graphemer@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6" + integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== + +gtoken@^6.1.0: + version "6.1.2" + resolved "https://registry.yarnpkg.com/gtoken/-/gtoken-6.1.2.tgz#aeb7bdb019ff4c3ba3ac100bbe7b6e74dce0e8bc" + integrity sha512-4ccGpzz7YAr7lxrT2neugmXQ3hP9ho2gcaityLVkiUecAiwiy60Ii8gRbZeOsXV19fYaRjgBSshs8kXw+NKCPQ== + dependencies: + gaxios "^5.0.1" + google-p12-pem "^4.0.0" + jws "^4.0.0" + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +has@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" + integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== + dependencies: + function-bind "^1.1.1" + +hashlru@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/hashlru/-/hashlru-2.3.0.tgz#5dc15928b3f6961a2056416bb3a4910216fdfb51" + integrity sha512-0cMsjjIC8I+D3M44pOQdsy0OHXGLVz6Z0beRuufhKa0KfaD2wGwAev6jILzXsd3/vpnNQJmWyZtIILqM1N+n5A== + +helmet@^6.0.0: + version "6.2.0" + resolved "https://registry.yarnpkg.com/helmet/-/helmet-6.2.0.tgz#c29d62014be4c70b8ef092c9c5e54c8c26b8e16e" + integrity sha512-DWlwuXLLqbrIOltR6tFQXShj/+7Cyp0gLi6uAb8qMdFh/YBBFbKSgQ6nbXmScYd8emMctuthmgIa7tUfo9Rtyg== + +https-proxy-agent@^5.0.0: + version "5.0.1" + resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz#c59ef224a04fe8b754f3db0063a25ea30d0005d6" + integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== + dependencies: + agent-base "6" + debug "4" + +ieee754@^1.1.13, ieee754@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.2.1.tgz#8eb7a10a63fff25d15a57b001586d177d1b0d352" + integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== + +ignore@^5.2.0: + version "5.2.4" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.4.tgz#a291c0c6178ff1b960befe47fcdec301674a6324" + integrity sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ== + +import-fresh@^3.0.0, import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@^2.0.1, inherits@^2.0.3: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +ip@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ip/-/ip-2.0.0.tgz#4cf4ab182fee2314c75ede1276f8c80b479936da" + integrity sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ== + +ipaddr.js@1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +is-binary-path@~2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" + integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== + dependencies: + binary-extensions "^2.0.0" + +is-core-module@^2.11.0: + version "2.12.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.12.1.tgz#0c0b6885b6f80011c71541ce15c8d66cf5a4f9fd" + integrity sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg== + dependencies: + has "^1.0.3" + +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3, is-glob@~4.0.1: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-path-inside@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" + integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== + +is-stream@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" + integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== + +jake@^10.8.5: + version "10.8.7" + resolved "https://registry.yarnpkg.com/jake/-/jake-10.8.7.tgz#63a32821177940c33f356e0ba44ff9d34e1c7d8f" + integrity sha512-ZDi3aP+fG/LchyBzUM804VjddnwfSfsdeYkwt8NcbKRvo4rFkjhs456iLFn3k2ZUWvNe4i48WACDbza8fhq2+w== + dependencies: + async "^3.2.3" + chalk "^4.0.2" + filelist "^1.0.4" + minimatch "^3.1.2" + +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + +json-bigint@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/json-bigint/-/json-bigint-1.0.0.tgz#ae547823ac0cad8398667f8cd9ef4730f5b01ff1" + integrity sha512-SiPv/8VpZuWbvLSMtTDU8hEfrZWg/mH/nV/b4o0CYbSxu1UIQPLdwKOCIyLQX+VIPO5vrLX3i8qtqFyhdPSUSQ== + dependencies: + bignumber.js "^9.0.0" + +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + +json-schema-traverse@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz#ae7bcb3656ab77a73ba5c49bf654f38e6b6860e2" + integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== + +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== + +json5@^2.2.2: + version "2.2.3" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" + integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== + +jwa@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/jwa/-/jwa-2.0.0.tgz#a7e9c3f29dae94027ebcaf49975c9345593410fc" + integrity sha512-jrZ2Qx916EA+fq9cEAeCROWPTfCwi1IVHqT2tapuqLEVVDKFDENFw1oL+MwrTvH6msKxsd1YTDVw6uKEcsrLEA== + dependencies: + buffer-equal-constant-time "1.0.1" + ecdsa-sig-formatter "1.0.11" + safe-buffer "^5.0.1" + +jws@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/jws/-/jws-4.0.0.tgz#2d4e8cf6a318ffaa12615e9dec7e86e6c97310f4" + integrity sha512-KDncfTmOZoOMTFG4mBlG0qUIOlc03fmzH+ru6RgYVZhPkyiy/92Owlt/8UEN+a4TXR1FQetfIpJE8ApdvdVxTg== + dependencies: + jwa "^2.0.0" + safe-buffer "^5.0.1" + +kareem@2.5.1: + version "2.5.1" + resolved "https://registry.yarnpkg.com/kareem/-/kareem-2.5.1.tgz#7b8203e11819a8e77a34b3517d3ead206764d15d" + integrity sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA== + +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + +light-my-request@^5.6.1: + version "5.9.1" + resolved "https://registry.yarnpkg.com/light-my-request/-/light-my-request-5.9.1.tgz#076f8d4cc4639408cc48381d4f2860212d469d4b" + integrity sha512-UT7pUk8jNCR1wR7w3iWfIjx32DiB2f3hFdQSOwy3/EPQ3n3VocyipUxcyRZR0ahoev+fky69uA+GejPa9KuHKg== + dependencies: + cookie "^0.5.0" + process-warning "^2.0.0" + set-cookie-parser "^2.4.1" + +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + +lodash.snakecase@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/lodash.snakecase/-/lodash.snakecase-4.1.1.tgz#39d714a35357147837aefd64b5dcbb16becd8f8d" + integrity sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw== + +lodash@^4.17.20, lodash@^4.17.21: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" + integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== + +loglevel@^1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/loglevel/-/loglevel-1.8.1.tgz#5c621f83d5b48c54ae93b6156353f555963377b4" + integrity sha512-tCRIJM51SHjAayKwC+QAg8hT8vg6z7GSgLJKGvzuPb1Wc+hLzqtuVLxp6/HzSPOozuK+8ErAhy7U/sVzw8Dgfg== + +long-timeout@0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/long-timeout/-/long-timeout-0.1.1.tgz#9721d788b47e0bcb5a24c2e2bee1a0da55dab514" + integrity sha512-BFRuQUqc7x2NWxfJBCyUrN8iYUYznzL9JROmRz1gZ6KlOIgmoD+njPVbb+VNn2nGMKggMsK79iUNErillsrx7w== + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +luxon@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/luxon/-/luxon-3.3.0.tgz#d73ab5b5d2b49a461c47cedbc7e73309b4805b48" + integrity sha512-An0UCfG/rSiqtAIiBPO0Y9/zAnHUZxAMiCpTd5h2smgsj7GGmcenvrvww2cqNA8/4A5ZrD1gJpHN2mIHZQF+Mg== + +make-error@^1.1.1: + version "1.3.6" + resolved "https://registry.yarnpkg.com/make-error/-/make-error-1.3.6.tgz#2eb2e37ea9b67c4891f684a1394799af484cf7a2" + integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== + +memory-pager@^1.0.2: + version "1.5.0" + resolved "https://registry.yarnpkg.com/memory-pager/-/memory-pager-1.5.0.tgz#d8751655d22d384682741c972f2c3d6dfa3e66b5" + integrity sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg== + +merge2@^1.3.0, merge2@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + +micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + +mime-db@1.52.0: + version "1.52.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-types@^2.1.12: + version "2.1.35" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + +minimalistic-assert@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz#2e194de044626d4a10e7f7fbc00ce73e83e4d5c7" + integrity sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A== + +minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +minimatch@^5.0.1: + version "5.1.6" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.6.tgz#1cfcb8cf5522ea69952cd2af95ae09477f122a96" + integrity sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g== + dependencies: + brace-expansion "^2.0.1" + +minimist@^1.2.6: + version "1.2.8" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c" + integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA== + +mkdirp@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-1.0.4.tgz#3eb5ed62622756d79a5f0e2a221dfebad75c2f7e" + integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== + +mnemonist@0.39.5, mnemonist@^0.39.5: + version "0.39.5" + resolved "https://registry.yarnpkg.com/mnemonist/-/mnemonist-0.39.5.tgz#5850d9b30d1b2bc57cc8787e5caa40f6c3420477" + integrity sha512-FPUtkhtJ0efmEFGpU14x7jGbTB+s18LrzRL2KgoWz9YvcY3cPomz8tih01GbHwnGk/OmkOKfqd/RAQoc8Lm7DQ== + dependencies: + obliterator "^2.0.1" + +mongodb-connection-string-url@^2.5.4: + version "2.6.0" + resolved "https://registry.yarnpkg.com/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz#57901bf352372abdde812c81be47b75c6b2ec5cf" + integrity sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ== + dependencies: + "@types/whatwg-url" "^8.2.1" + whatwg-url "^11.0.0" + +mongodb@4.16.0: + version "4.16.0" + resolved "https://registry.yarnpkg.com/mongodb/-/mongodb-4.16.0.tgz#8b0043de7b577c6a7e0ce44a2ca7315b9c0a7927" + integrity sha512-0EB113Fsucaq1wsY0dOhi1fmZOwFtLOtteQkiqOXGklvWMnSH3g2QS53f0KTP+/6qOkuoXE2JksubSZNmxeI+g== + dependencies: + bson "^4.7.2" + mongodb-connection-string-url "^2.5.4" + socks "^2.7.1" + optionalDependencies: + "@aws-sdk/credential-providers" "^3.186.0" + saslprep "^1.0.3" + +mongoose-findorcreate@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/mongoose-findorcreate/-/mongoose-findorcreate-3.0.0.tgz#490acf67c16061de74f7d1b92906538a62554a6d" + integrity sha512-kQhDe5XDj6tMv8kq1wjK+hITGIGUl60rj8oGLupF9poNsqIDkAJBXudZKcCdSyBZ7p6DLK2+0jSBthrb26tSYQ== + +mongoose@^6.6.5: + version "6.11.1" + resolved "https://registry.yarnpkg.com/mongoose/-/mongoose-6.11.1.tgz#4abcfc747ad38b364a90488af781d054a8cbc242" + integrity sha512-AvQ8C5ZGF6GcsQhoRg/i7pbNZpb96qLGU5ICBllckp7qMOxcfUF1nA6JstZw841BqRcE6myZ/mx9CluEESaw5Q== + dependencies: + bson "^4.7.2" + kareem "2.5.1" + mongodb "4.16.0" + mpath "0.9.0" + mquery "4.0.3" + ms "2.1.3" + sift "16.0.1" + +mpath@0.9.0: + version "0.9.0" + resolved "https://registry.yarnpkg.com/mpath/-/mpath-0.9.0.tgz#0c122fe107846e31fc58c75b09c35514b3871904" + integrity sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew== + +mquery@4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/mquery/-/mquery-4.0.3.tgz#4d15f938e6247d773a942c912d9748bd1965f89d" + integrity sha512-J5heI+P08I6VJ2Ky3+33IpCdAvlYGTSUjwTPxkAr8i8EoduPMBX2OY/wa3IKZIQl7MU4SbFk8ndgSKyB/cl1zA== + dependencies: + debug "4.x" + +ms@2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@2.1.3: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +nanoid@^3.1.23: + version "3.3.6" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.6.tgz#443380c856d6e9f9824267d960b4236ad583ea4c" + integrity sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA== + +natural-compare-lite@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz#17b09581988979fddafe0201e931ba933c96cbb4" + integrity sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g== + +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" + integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== + +node-bin-setup@^1.0.0: + version "1.1.3" + resolved "https://registry.yarnpkg.com/node-bin-setup/-/node-bin-setup-1.1.3.tgz#d45d5220e3b2ecc3a94263a56116f727f6c1bb14" + integrity sha512-opgw9iSCAzT2+6wJOETCpeRYAQxSopqQ2z+N6BXwIMsQQ7Zj5M8MaafQY8JMlolRR6R1UXg2WmhKp0p9lSOivg== + +node-fetch@^2.6.7: + version "2.6.11" + resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-2.6.11.tgz#cde7fc71deef3131ef80a738919f999e6edfff25" + integrity sha512-4I6pdBY1EthSqDmJkiNk3JIT8cswwR9nfeW/cPdUagJYEQG7R95WRH74wpz7ma8Gh/9dI9FP+OU+0E4FvtA55w== + dependencies: + whatwg-url "^5.0.0" + +node-forge@^1.3.1: + version "1.3.1" + resolved "https://registry.yarnpkg.com/node-forge/-/node-forge-1.3.1.tgz#be8da2af243b2417d5f646a770663a92b7e9ded3" + integrity sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA== + +node-schedule@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/node-schedule/-/node-schedule-2.1.1.tgz#6958b2c5af8834954f69bb0a7a97c62b97185de3" + integrity sha512-OXdegQq03OmXEjt2hZP33W2YPs/E5BcFQks46+G2gAxs4gHOIVD1u7EqlYLYSKsaIpyKCK9Gbk0ta1/gjRSMRQ== + dependencies: + cron-parser "^4.2.0" + long-timeout "0.1.1" + sorted-array-functions "^1.3.0" + +node@^18.14.0: + version "18.16.0" + resolved "https://registry.yarnpkg.com/node/-/node-18.16.0.tgz#95fa0e48b868d6d8a59d8a86752b02d5fa11414a" + integrity sha512-xi2PRz7qrWfzNXCl7F0Y5wVQFIqsP2VZEOkdghIvyhTg3OBDTTPYX0rmB9vDDJ1f/TUA31ldFMnl0zNd4lhNqA== + dependencies: + node-bin-setup "^1.0.0" + +normalize-path@^3.0.0, normalize-path@~3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" + integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== + +obliterator@^2.0.1: + version "2.0.4" + resolved "https://registry.yarnpkg.com/obliterator/-/obliterator-2.0.4.tgz#fa650e019b2d075d745e44f1effeb13a2adbe816" + integrity sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ== + +on-exit-leak-free@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/on-exit-leak-free/-/on-exit-leak-free-2.1.0.tgz#5c703c968f7e7f851885f6459bf8a8a57edc9cc4" + integrity sha512-VuCaZZAjReZ3vUwgOB8LxAosIurDiAW0s13rI1YwmaP++jvcxP77AWoQvenZebpCA2m8WC1/EosPYPMjnRAp/w== + +once@^1.3.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== + dependencies: + wrappy "1" + +optionator@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" + integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.3" + +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== + +path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== + +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + +peek-readable@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/peek-readable/-/peek-readable-5.0.0.tgz#7ead2aff25dc40458c60347ea76cfdfd63efdfec" + integrity sha512-YtCKvLUOvwtMGmrniQPdO7MwPjgkFBtFIrmfSbYmYuq3tKDV/mcfAhBth1+C3ru7uXIZasc/pHnb+YDYNkkj4A== + +picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + +pino-abstract-transport@v1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/pino-abstract-transport/-/pino-abstract-transport-1.0.0.tgz#cc0d6955fffcadb91b7b49ef220a6cc111d48bb3" + integrity sha512-c7vo5OpW4wIS42hUVcT5REsL8ZljsUfBjqV/e2sFxmFEFZiq1XLUp5EYLtuDH6PEHq9W1egWqRbnLUP5FuZmOA== + dependencies: + readable-stream "^4.0.0" + split2 "^4.0.0" + +pino-std-serializers@^6.0.0: + version "6.2.1" + resolved "https://registry.yarnpkg.com/pino-std-serializers/-/pino-std-serializers-6.2.1.tgz#369f4ae2a19eb6d769ddf2c88a2164b76879a284" + integrity sha512-wHuWB+CvSVb2XqXM0W/WOYUkVSPbiJb9S5fNB7TBhd8s892Xq910bRxwHtC4l71hgztObTjXL6ZheZXFjhDrDQ== + +pino@^8.5.0: + version "8.14.1" + resolved "https://registry.yarnpkg.com/pino/-/pino-8.14.1.tgz#bb38dcda8b500dd90c1193b6c9171eb777a47ac8" + integrity sha512-8LYNv7BKWXSfS+k6oEc6occy5La+q2sPwU3q2ljTX5AZk7v+5kND2o5W794FyRaqha6DJajmkNRsWtPpFyMUdw== + dependencies: + atomic-sleep "^1.0.0" + fast-redact "^3.1.1" + on-exit-leak-free "^2.1.0" + pino-abstract-transport v1.0.0 + pino-std-serializers "^6.0.0" + process-warning "^2.0.0" + quick-format-unescaped "^4.0.3" + real-require "^0.2.0" + safe-stable-stringify "^2.3.1" + sonic-boom "^3.1.0" + thread-stream "^2.0.0" + +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prettier-linter-helpers@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz#d23d41fe1375646de2d0104d3454a3008802cf7b" + integrity sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w== + dependencies: + fast-diff "^1.1.2" + +prettier@^2.7.1: + version "2.8.8" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.8.8.tgz#e8c5d7e98a4305ffe3de2e1fc4aca1a71c28b1da" + integrity sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q== + +process-warning@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/process-warning/-/process-warning-2.2.0.tgz#008ec76b579820a8e5c35d81960525ca64feb626" + integrity sha512-/1WZ8+VQjR6avWOgHeEPd7SDQmFQ1B5mC1eRXsCm5TarlNmx/wCsa5GEaxGm05BORRtyG/Ex/3xq3TuRvq57qg== + +process@^0.11.10: + version "0.11.10" + resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182" + integrity sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A== + +proxy-addr@^2.0.7: + version "2.0.7" + resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" + integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== + dependencies: + forwarded "0.2.0" + ipaddr.js "1.9.1" + +proxy-from-env@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2" + integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== + +punycode@^2.1.0, punycode@^2.1.1: + version "2.3.0" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.3.0.tgz#f67fa67c94da8f4d0cfff981aee4118064199b8f" + integrity sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA== + +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + +quick-format-unescaped@^4.0.3: + version "4.0.4" + resolved "https://registry.yarnpkg.com/quick-format-unescaped/-/quick-format-unescaped-4.0.4.tgz#93ef6dd8d3453cbc7970dd614fad4c5954d6b5a7" + integrity sha512-tYC1Q1hgyRuHgloV/YXs2w15unPVh8qfu/qCTfhTYamaw7fyhumKa2yGpdSo87vY32rIclj+4fWYQXUMs9EHvg== + +readable-stream@^3.6.0: + version "3.6.2" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967" + integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA== + dependencies: + inherits "^2.0.3" + string_decoder "^1.1.1" + util-deprecate "^1.0.1" + +readable-stream@^4.0.0: + version "4.4.0" + resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-4.4.0.tgz#55ce132d60a988c460d75c631e9ccf6a7229b468" + integrity sha512-kDMOq0qLtxV9f/SQv522h8cxZBqNZXuXNyjyezmfAAuribMyVXziljpQ/uQhfE1XLg2/TLTW2DsnoE4VAi/krg== + dependencies: + abort-controller "^3.0.0" + buffer "^6.0.3" + events "^3.3.0" + process "^0.11.10" + +readable-web-to-node-stream@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz#5d52bb5df7b54861fd48d015e93a2cb87b3ee0bb" + integrity sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw== + dependencies: + readable-stream "^3.6.0" + +readdirp@~3.6.0: + version "3.6.0" + resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.6.0.tgz#74a370bd857116e245b29cc97340cd431a02a6c7" + integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== + dependencies: + picomatch "^2.2.1" + +real-require@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/real-require/-/real-require-0.2.0.tgz#209632dea1810be2ae063a6ac084fee7e33fba78" + integrity sha512-57frrGM/OCTLqLOAh0mhVA9VBMHd+9U7Zb2THMGdBUoZVOtGbJzjxsYGDJ3A9AYYCP4hn6y1TVbaOfzWtm5GFg== + +reflect-metadata@^0.1.13: + version "0.1.13" + resolved "https://registry.yarnpkg.com/reflect-metadata/-/reflect-metadata-0.1.13.tgz#67ae3ca57c972a2aa1642b10fe363fe32d49dc08" + integrity sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg== + +require-from-string@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/require-from-string/-/require-from-string-2.0.2.tgz#89a7fdd938261267318eafe14f9c32e598c36909" + integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== + +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + +resolve@^1.0.0: + version "1.22.2" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.2.tgz#0ed0943d4e301867955766c9f3e1ae6d01c6845f" + integrity sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g== + dependencies: + is-core-module "^2.11.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +ret@~0.2.0: + version "0.2.2" + resolved "https://registry.yarnpkg.com/ret/-/ret-0.2.2.tgz#b6861782a1f4762dce43402a71eb7a283f44573c" + integrity sha512-M0b3YWQs7R3Z917WRQy1HHA7Ba7D8hvZg6UE5mLykJxQVE2ju0IXbGlaHPPlkY+WN7wFP+wUMXmBFA0aV6vYGQ== + +reusify@^1.0.0, reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + +rfdc@^1.2.0, rfdc@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/rfdc/-/rfdc-1.3.0.tgz#d0b7c441ab2720d05dc4cf26e01c89631d9da08b" + integrity sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA== + +rimraf@^2.6.1: + version "2.7.1" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" + integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== + dependencies: + glob "^7.1.3" + +rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + +safe-buffer@^5.0.1, safe-buffer@~5.2.0: + version "5.2.1" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" + integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== + +safe-regex2@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/safe-regex2/-/safe-regex2-2.0.0.tgz#b287524c397c7a2994470367e0185e1916b1f5b9" + integrity sha512-PaUSFsUaNNuKwkBijoAPHAK6/eM6VirvyPWlZ7BAQy4D+hCvh4B6lIG+nPdhbFfIbP+gTGBcrdsOaUs0F+ZBOQ== + dependencies: + ret "~0.2.0" + +safe-stable-stringify@^2.3.1: + version "2.4.3" + resolved "https://registry.yarnpkg.com/safe-stable-stringify/-/safe-stable-stringify-2.4.3.tgz#138c84b6f6edb3db5f8ef3ef7115b8f55ccbf886" + integrity sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g== + +safer-buffer@^2.1.0: + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +saslprep@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/saslprep/-/saslprep-1.0.3.tgz#4c02f946b56cf54297e347ba1093e7acac4cf226" + integrity sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag== + dependencies: + sparse-bitfield "^3.0.3" + +secure-json-parse@^2.5.0: + version "2.7.0" + resolved "https://registry.yarnpkg.com/secure-json-parse/-/secure-json-parse-2.7.0.tgz#5a5f9cd6ae47df23dba3151edd06855d47e09862" + integrity sha512-6aU+Rwsezw7VR8/nyvKTx8QpWH9FrcYiXXlqC4z5d5XQBDRqtbfsRjnwGyqbi3gddNtWHuEk9OANUotL26qKUw== + +semver@^7.3.7, semver@^7.3.8: + version "7.5.1" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.5.1.tgz#c90c4d631cf74720e46b21c1d37ea07edfab91ec" + integrity sha512-Wvss5ivl8TMRZXXESstBA4uR5iXgEN/VC5/sOcuXdVLzcdkz4HWetIoRfG5gb5X+ij/G9rw9YoGn3QoQ8OCSpw== + dependencies: + lru-cache "^6.0.0" + +set-cookie-parser@^2.4.1: + version "2.6.0" + resolved "https://registry.yarnpkg.com/set-cookie-parser/-/set-cookie-parser-2.6.0.tgz#131921e50f62ff1a66a461d7d62d7b21d5d15a51" + integrity sha512-RVnVQxTXuerk653XfuliOxBP81Sf0+qfQE73LIYKcyMYHG94AuH0kgrQpRDuTZnSmjpysHmzxJXKNfa6PjFhyQ== + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +sift@16.0.1: + version "16.0.1" + resolved "https://registry.yarnpkg.com/sift/-/sift-16.0.1.tgz#e9c2ccc72191585008cf3e36fc447b2d2633a053" + integrity sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ== + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +smart-buffer@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae" + integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg== + +socks@^2.7.1: + version "2.7.1" + resolved "https://registry.yarnpkg.com/socks/-/socks-2.7.1.tgz#d8e651247178fde79c0663043e07240196857d55" + integrity sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ== + dependencies: + ip "^2.0.0" + smart-buffer "^4.2.0" + +sonic-boom@^3.1.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/sonic-boom/-/sonic-boom-3.3.0.tgz#cffab6dafee3b2bcb88d08d589394198bee1838c" + integrity sha512-LYxp34KlZ1a2Jb8ZQgFCK3niIHzibdwtwNUWKg0qQRzsDoJ3Gfgkf8KdBTFU3SkejDEIlWwnSnpVdOZIhFMl/g== + dependencies: + atomic-sleep "^1.0.0" + +sorted-array-functions@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/sorted-array-functions/-/sorted-array-functions-1.3.0.tgz#8605695563294dffb2c9796d602bd8459f7a0dd5" + integrity sha512-2sqgzeFlid6N4Z2fUQ1cvFmTOLRi/sEDzSQ0OKYchqgoPmQBVyM3959qYx3fpS6Esef80KjmpgPeEr028dP3OA== + +source-map-support@^0.5.12: + version "0.5.21" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" + integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map@^0.6.0: + version "0.6.1" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" + integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== + +sparse-bitfield@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz#ff4ae6e68656056ba4b3e792ab3334d38273ca11" + integrity sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ== + dependencies: + memory-pager "^1.0.2" + +split2@^4.0.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/split2/-/split2-4.2.0.tgz#c9c5920904d148bab0b9f67145f245a86aadbfa4" + integrity sha512-UcjcJOWknrNkF6PLX83qcHM6KHgVKNkV62Y8a5uYDVv9ydGQVwAHMKqHdJje1VTWpljG0WYpCDhrCdAOYH4TWg== + +steed@^1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/steed/-/steed-1.1.3.tgz#f1525dd5adb12eb21bf74749537668d625b9abc5" + integrity sha512-EUkci0FAUiE4IvGTSKcDJIQ/eRUP2JJb56+fvZ4sdnguLTqIdKjSxUe138poW8mkvKWXW2sFPrgTsxqoISnmoA== + dependencies: + fastfall "^1.5.0" + fastparallel "^2.2.0" + fastq "^1.3.0" + fastseries "^1.7.0" + reusify "^1.0.0" + +streamsearch@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/streamsearch/-/streamsearch-1.1.0.tgz#404dd1e2247ca94af554e841a8ef0eaa238da764" + integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg== + +string_decoder@^1.1.1: + version "1.3.0" + resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.3.0.tgz#42f114594a46cf1a8e30b0a84f56c78c3edac21e" + integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== + dependencies: + safe-buffer "~5.2.0" + +strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + +strip-bom@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" + integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== + +strip-json-comments@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" + integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== + +strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +strnum@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/strnum/-/strnum-1.0.5.tgz#5c4e829fe15ad4ff0d20c3db5ac97b73c9b072db" + integrity sha512-J8bbNyKKXl5qYcR36TIO8W3mVGVHrmmxsd5PAItGkmyzwJvybiw2IVq5nqd0i4LSNSkB/sx9VHllbfFdr9k1JA== + +strtok3@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/strtok3/-/strtok3-7.0.0.tgz#868c428b4ade64a8fd8fee7364256001c1a4cbe5" + integrity sha512-pQ+V+nYQdC5H3Q7qBZAz/MO6lwGhoC2gOAjuouGf/VO0m7vQRh8QNMl2Uf6SwAtzZ9bOw3UIeBukEGNJl5dtXQ== + dependencies: + "@tokenizer/token" "^0.3.0" + peek-readable "^5.0.0" + +supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + +thread-stream@^2.0.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/thread-stream/-/thread-stream-2.3.0.tgz#4fc07fb39eff32ae7bad803cb7dd9598349fed33" + integrity sha512-kaDqm1DET9pp3NXwR8382WHbnpXnRkN9xGN9dQt3B2+dmXiW8X1SOwmFOxAErEQ47ObhZ96J6yhZNXuyCOL7KA== + dependencies: + real-require "^0.2.0" + +tiny-lru@^11.0.1: + version "11.0.1" + resolved "https://registry.yarnpkg.com/tiny-lru/-/tiny-lru-11.0.1.tgz#629d6ddd88bd03c0929722680167f1feadf576f2" + integrity sha512-iNgFugVuQgBKrqeO/mpiTTgmBsTP0WL6yeuLfLs/Ctf0pI/ixGqIRm8sDCwMcXGe9WWvt2sGXI5mNqZbValmJg== + +tinytim@0.1.1: + version "0.1.1" + resolved "https://registry.yarnpkg.com/tinytim/-/tinytim-0.1.1.tgz#c968a1e5559ad9553224ef7627bab34e3caef8a8" + integrity sha512-NIpsp9lBIxPNzB++HnMmUd4byzJSVbbO4F+As1Gb1IG/YQT5QvmBDjpx8SpDS8fhGC+t+Qw8ldQgbcAIaU+2cA== + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +token-types@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/token-types/-/token-types-5.0.1.tgz#aa9d9e6b23c420a675e55413b180635b86a093b4" + integrity sha512-Y2fmSnZjQdDb9W4w4r1tswlMHylzWIeOKpx0aZH9BgGtACHhrk3OkT52AzwcuqTRBZtvvnTjDBh8eynMulu8Vg== + dependencies: + "@tokenizer/token" "^0.3.0" + ieee754 "^1.2.1" + +tr46@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-3.0.0.tgz#555c4e297a950617e8eeddef633c87d4d9d6cbf9" + integrity sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA== + dependencies: + punycode "^2.1.1" + +tr46@~0.0.3: + version "0.0.3" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-0.0.3.tgz#8184fd347dac9cdc185992f3a6622e14b9d9ab6a" + integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== + +tracer@^1.1.6: + version "1.1.6" + resolved "https://registry.yarnpkg.com/tracer/-/tracer-1.1.6.tgz#5afc5ea0d7c6026dbafb36bed86e88cafe9bebad" + integrity sha512-VKEIQRNgzSgti18whs+8l7e2y/gWcklw+C/xZtFH/AGvaN6GDlvhkQTFEsy448Gxb5MtbNbzJiG0L1TJEQnqcA== + dependencies: + colors "1.4.0" + dateformat "4.5.1" + mkdirp "^1.0.4" + tinytim "0.1.1" + +tree-kill@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/tree-kill/-/tree-kill-1.2.2.tgz#4ca09a9092c88b73a7cdc5e8a01b507b0790a0cc" + integrity sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A== + +ts-mixer@^6.0.3: + version "6.0.3" + resolved "https://registry.yarnpkg.com/ts-mixer/-/ts-mixer-6.0.3.tgz#69bd50f406ff39daa369885b16c77a6194c7cae6" + integrity sha512-k43M7uCG1AkTyxgnmI5MPwKoUvS/bRvLvUb7+Pgpdlmok8AoqmUaZxUUw8zKM5B1lqZrt41GjYgnvAi0fppqgQ== + +ts-node-dev@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ts-node-dev/-/ts-node-dev-2.0.0.tgz#bdd53e17ab3b5d822ef519928dc6b4a7e0f13065" + integrity sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w== + dependencies: + chokidar "^3.5.1" + dynamic-dedupe "^0.3.0" + minimist "^1.2.6" + mkdirp "^1.0.4" + resolve "^1.0.0" + rimraf "^2.6.1" + source-map-support "^0.5.12" + tree-kill "^1.2.2" + ts-node "^10.4.0" + tsconfig "^7.0.0" + +ts-node@^10.4.0, ts-node@^10.9.1: + version "10.9.1" + resolved "https://registry.yarnpkg.com/ts-node/-/ts-node-10.9.1.tgz#e73de9102958af9e1f0b168a6ff320e25adcff4b" + integrity sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw== + dependencies: + "@cspotcode/source-map-support" "^0.8.0" + "@tsconfig/node10" "^1.0.7" + "@tsconfig/node12" "^1.0.7" + "@tsconfig/node14" "^1.0.0" + "@tsconfig/node16" "^1.0.2" + acorn "^8.4.1" + acorn-walk "^8.1.1" + arg "^4.1.0" + create-require "^1.1.0" + diff "^4.0.1" + make-error "^1.1.1" + v8-compile-cache-lib "^3.0.1" + yn "3.1.1" + +tsconfig-paths@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz#ef78e19039133446d244beac0fd6a1632e2d107c" + integrity sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg== + dependencies: + json5 "^2.2.2" + minimist "^1.2.6" + strip-bom "^3.0.0" + +tsconfig@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/tsconfig/-/tsconfig-7.0.0.tgz#84538875a4dc216e5c4a5432b3a4dec3d54e91b7" + integrity sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw== + dependencies: + "@types/strip-bom" "^3.0.0" + "@types/strip-json-comments" "0.0.30" + strip-bom "^3.0.0" + strip-json-comments "^2.0.0" + +tslib@^1.11.1, tslib@^1.8.1: + version "1.14.1" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tslib@^2.3.1, tslib@^2.4.1, tslib@^2.5.0: + version "2.5.2" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.5.2.tgz#1b6f07185c881557b0ffa84b111a0106989e8338" + integrity sha512-5svOrSA2w3iGFDs1HibEVBGbDrAY82bFQ3HZ3ixB+88nsbsWQoKqDRb5UBYAUPEzbBn6dAp5gRNXglySbx1MlA== + +tsutils@^3.21.0: + version "3.21.0" + resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" + integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== + dependencies: + tslib "^1.8.1" + +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + +type-fest@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" + integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== + +typescript@^4.8.4: + version "4.9.5" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.9.5.tgz#095979f9bcc0d09da324d58d03ce8f8374cbe65a" + integrity sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g== + +undici@^5.22.0: + version "5.22.1" + resolved "https://registry.yarnpkg.com/undici/-/undici-5.22.1.tgz#877d512effef2ac8be65e695f3586922e1a57d7b" + integrity sha512-Ji2IJhFXZY0x/0tVBXeQwgPlLWw13GVzpsWPQ3rV50IFMMof2I55PZZxtm4P6iNq+L5znYN9nSTAq0ZyE6lSJw== + dependencies: + busboy "^1.6.0" + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +util-deprecate@^1.0.1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" + integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== + +uuid@^8.3.2: + version "8.3.2" + resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2" + integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== + +v8-compile-cache-lib@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz#6336e8d71965cb3d35a1bbb7868445a7c05264bf" + integrity sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg== + +webidl-conversions@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-3.0.1.tgz#24534275e2a7bc6be7bc86611cc16ae0a5654871" + integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== + +webidl-conversions@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-7.0.0.tgz#256b4e1882be7debbf01d05f0aa2039778ea080a" + integrity sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g== + +whatwg-url@^11.0.0: + version "11.0.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-11.0.0.tgz#0a849eebb5faf2119b901bb76fd795c2848d4018" + integrity sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ== + dependencies: + tr46 "^3.0.0" + webidl-conversions "^7.0.0" + +whatwg-url@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-5.0.0.tgz#966454e8765462e37644d3626f6742ce8b70965d" + integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== + dependencies: + tr46 "~0.0.3" + webidl-conversions "^3.0.0" + +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +word-wrap@^1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" + integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== + +ws@^8.13.0: + version "8.13.0" + resolved "https://registry.yarnpkg.com/ws/-/ws-8.13.0.tgz#9a9fb92f93cf41512a0735c8f4dd09b8a1211cd0" + integrity sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA== + +xtend@^4.0.0, xtend@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" + integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yn@3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/yn/-/yn-3.1.1.tgz#1e87401a09d767c1d5eab26a6e4c185182d2eb50" + integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==