From fc50c8fa81e32c6b3d0ed144f083f2f32fe279f6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 23 Apr 2022 16:37:16 +0300 Subject: [PATCH 001/238] self commands and /me messages --- util/src/entities/Message.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/util/src/entities/Message.ts b/util/src/entities/Message.ts index b32bbd949..8bd50455a 100644 --- a/util/src/entities/Message.ts +++ b/util/src/entities/Message.ts @@ -39,11 +39,13 @@ export enum MessageType { USER_PREMIUM_GUILD_SUBSCRIPTION_TIER_2 = 10, USER_PREMIUM_GUILD_SUBSCRIPTION_TIER_3 = 11, CHANNEL_FOLLOW_ADD = 12, + ACTION = 13, // /me messages GUILD_DISCOVERY_DISQUALIFIED = 14, GUILD_DISCOVERY_REQUALIFIED = 15, ENCRYPTED = 16, REPLY = 19, - APPLICATION_COMMAND = 20, + APPLICATION_COMMAND = 20, // application command or self command invocation + SELF_COMMAND_SCRIPT = 21, // self command scripts ROUTE_ADDED = 41, // custom message routing: new route affecting that channel ROUTE_DISABLED = 42, // custom message routing: given route no longer affecting that channel ENCRYPTION = 50, From 7835cb9963d21cd4eac6e95a7db89a827deab253 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 23 Apr 2022 16:40:54 +0300 Subject: [PATCH 002/238] Update Message.ts --- util/src/entities/Message.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/src/entities/Message.ts b/util/src/entities/Message.ts index 8bd50455a..e18cf6919 100644 --- a/util/src/entities/Message.ts +++ b/util/src/entities/Message.ts @@ -45,9 +45,9 @@ export enum MessageType { ENCRYPTED = 16, REPLY = 19, APPLICATION_COMMAND = 20, // application command or self command invocation - SELF_COMMAND_SCRIPT = 21, // self command scripts ROUTE_ADDED = 41, // custom message routing: new route affecting that channel ROUTE_DISABLED = 42, // custom message routing: given route no longer affecting that channel + SELF_COMMAND_SCRIPT = 43, // self command scripts ENCRYPTION = 50, CUSTOM_START = 63, UNHANDLED = 255 From fcc104d60ca509dbc2f31ff62987a5daedf1e7d3 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sun, 24 Apr 2022 16:09:38 +1000 Subject: [PATCH 003/238] While backfilling, message ids must now be valid snowflakes, cannot be in the future, and cannot overwrite existing messages --- .../#channel_id/messages/#message_id/index.ts | 24 +++++++++++++++---- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index 6d2bf1851..8d2bd5cbf 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -16,6 +16,8 @@ import multer from "multer"; import { route } from "@fosscord/api"; import { handleMessage, postHandleMessage } from "@fosscord/api"; import { MessageCreateSchema } from "../index"; +import { Snowflake } from "@fosscord/util"; +import { HTTPError } from "lambert-server"; const router = Router(); // TODO: message content/embed string length limit @@ -91,6 +93,22 @@ router.put( var body = req.body as MessageCreateSchema; const attachments: Attachment[] = []; + // regex to check if message contains anything other than numerals ( also no decimals ) + if (!message_id.match(/^\+?\d+$/)) { + throw new HTTPError("Message IDs must be positive integers") + } + + const snowflake = Snowflake.deconstruct(message_id) + if (Date.now() < snowflake.timestamp) { + // message is in the future + throw new HTTPError("You cannot backfill messages in the future", 400); + } + + const exists = await Message.findOne({ where: { id: message_id, channel_id: channel_id }}); + if (exists) { + throw new HTTPError("Cannot backfill to message ID that already exists", 400); + } + if (req.file) { try { const file = await uploadFile(`/attachments/${req.params.channel_id}`, req.file); @@ -100,8 +118,6 @@ router.put( } } const channel = await Channel.findOneOrFail({ where: { id: channel_id }, relations: ["recipients", "recipients.user"] }); - - // TODO: check the ID is not from the future, to prevent future-faking of channel histories const embeds = body.embeds || []; if (body.embed) embeds.push(body.embed); @@ -115,11 +131,9 @@ router.put( channel_id, attachments, edited_timestamp: undefined, - timestamp: undefined, // FIXME: calculate timestamp from snowflake + timestamp: new Date(snowflake.timestamp), }); - channel.last_message_id = message.id; - //Fix for the client bug delete message.member From 755f278e5395207db02af8011f08857abef8be71 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 09:23:52 +0300 Subject: [PATCH 004/238] Backfilling privilege does not imply right to post messages --- .../channels/#channel_id/messages/#message_id/index.ts | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index 8d2bd5cbf..cf25f916a 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -92,10 +92,13 @@ router.put( const { channel_id, message_id } = req.params; var body = req.body as MessageCreateSchema; const attachments: Attachment[] = []; + + const rights = getRights(req.user_id); + rights.hasThrow("SEND_MESSAGES"); // regex to check if message contains anything other than numerals ( also no decimals ) if (!message_id.match(/^\+?\d+$/)) { - throw new HTTPError("Message IDs must be positive integers") + throw new HTTPError("Message IDs must be positive integers", 400); } const snowflake = Snowflake.deconstruct(message_id) @@ -106,7 +109,7 @@ router.put( const exists = await Message.findOne({ where: { id: message_id, channel_id: channel_id }}); if (exists) { - throw new HTTPError("Cannot backfill to message ID that already exists", 400); + throw new HTTPError("Cannot backfill to message ID that already exists", 409); } if (req.file) { From 7d665a83fa76c6acd3a97dad0ad0e314d395481a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 09:48:45 +0300 Subject: [PATCH 005/238] API response codes for backfill errors --- util/src/util/Constants.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/util/src/util/Constants.ts b/util/src/util/Constants.ts index 8d61b9b49..9ceebf302 100644 --- a/util/src/util/Constants.ts +++ b/util/src/util/Constants.ts @@ -742,6 +742,8 @@ export const FosscordApiErrors = { DELETE_MESSAGE_DISABLED: new ApiError("You are not allowed to delete your own messages", 25061), FEATURE_PERMANENTLY_DISABLED: new ApiError("This feature has been disabled server-side", 45006), MISSING_RIGHTS: new ApiError("You lack rights to perform that action ({})", 50013, undefined, [""]), + CANNOT_REPLACE_BY_BACKFILL: new APIError("Cannot backfill to message ID that already exists", 55002), + CANNOT_BACKFILL_TO_THE_FUTURE: new APIError("You cannot backfill messages in the future", 55003), CANNOT_GRANT_PERMISSIONS_EXCEEDING_RIGHTS: new ApiError("You cannot grant permissions exceeding your own rights", 50050), ROUTES_LOOPING: new ApiError("Loops in the route definition ({})", 50060, undefined, [""]), CANNOT_REMOVE_ROUTE: new ApiError("Cannot remove message route while it is in effect and being used", 50061), From 3775c1207ab07dc7c5d4b95901f58fa5fd013d9b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 09:57:00 +0300 Subject: [PATCH 006/238] refine error codes for backfill constraint violations --- util/src/util/Constants.ts | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/util/src/util/Constants.ts b/util/src/util/Constants.ts index 9ceebf302..54287af65 100644 --- a/util/src/util/Constants.ts +++ b/util/src/util/Constants.ts @@ -727,23 +727,23 @@ export const DiscordApiErrors = { * An error encountered while performing an API request (Fosscord only). Here are the potential errors: */ export const FosscordApiErrors = { - MANUALLY_TRIGGERED_ERROR: new ApiError("This is an artificial error", 1), + MANUALLY_TRIGGERED_ERROR: new ApiError("This is an artificial error", 1, 500), PREMIUM_DISABLED_FOR_GUILD: new ApiError("This guild cannot be boosted", 25001), NO_FURTHER_PREMIUM: new ApiError("This guild does not receive further boosts", 25002), - GUILD_PREMIUM_DISABLED_FOR_YOU: new ApiError("This guild cannot be boosted by you", 25003), + GUILD_PREMIUM_DISABLED_FOR_YOU: new ApiError("This guild cannot be boosted by you", 25003, 403), CANNOT_FRIEND_SELF: new ApiError("Cannot friend oneself", 25009), USER_SPECIFIC_INVITE_WRONG_RECIPIENT: new ApiError("This invite is not meant for you", 25010), USER_SPECIFIC_INVITE_FAILED: new ApiError("Failed to invite user", 25011), - CANNOT_MODIFY_USER_GROUP: new ApiError("This user cannot manipulate this group", 25050), + CANNOT_MODIFY_USER_GROUP: new ApiError("This user cannot manipulate this group", 25050, 403), CANNOT_REMOVE_SELF_FROM_GROUP: new ApiError("This user cannot remove oneself from user group", 25051), CANNOT_BAN_OPERATOR: new ApiError("Non-OPERATOR cannot ban OPERATOR from instance", 25052), - CANNOT_LEAVE_GUILD: new ApiError("You are not allowed to leave guilds that you joined by yourself", 25059), - EDITS_DISABLED: new ApiError("You are not allowed to edit your own messages", 25060), - DELETE_MESSAGE_DISABLED: new ApiError("You are not allowed to delete your own messages", 25061), - FEATURE_PERMANENTLY_DISABLED: new ApiError("This feature has been disabled server-side", 45006), + CANNOT_LEAVE_GUILD: new ApiError("You are not allowed to leave guilds that you joined by yourself", 25059, 403), + EDITS_DISABLED: new ApiError("You are not allowed to edit your own messages", 25060, 403), + DELETE_MESSAGE_DISABLED: new ApiError("You are not allowed to delete your own messages", 25061, 403), + FEATURE_PERMANENTLY_DISABLED: new ApiError("This feature has been disabled server-side", 45006, 501), MISSING_RIGHTS: new ApiError("You lack rights to perform that action ({})", 50013, undefined, [""]), - CANNOT_REPLACE_BY_BACKFILL: new APIError("Cannot backfill to message ID that already exists", 55002), - CANNOT_BACKFILL_TO_THE_FUTURE: new APIError("You cannot backfill messages in the future", 55003), + CANNOT_REPLACE_BY_BACKFILL: new ApiError("Cannot backfill to message ID that already exists", 55002, 409), + CANNOT_BACKFILL_TO_THE_FUTURE: new ApiError("You cannot backfill messages in the future", 55003), CANNOT_GRANT_PERMISSIONS_EXCEEDING_RIGHTS: new ApiError("You cannot grant permissions exceeding your own rights", 50050), ROUTES_LOOPING: new ApiError("Loops in the route definition ({})", 50060, undefined, [""]), CANNOT_REMOVE_ROUTE: new ApiError("Cannot remove message route while it is in effect and being used", 50061), From e68e4639ff054c87d1182c58d2686c4f3e6f1b6c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 11:40:24 +0300 Subject: [PATCH 007/238] use return codes to allow for automation --- .../channels/#channel_id/messages/#message_id/index.ts | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index cf25f916a..958954b69 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -2,13 +2,16 @@ import { Attachment, Channel, Embed, + DiscordApiErrors, emitEvent, + FosscordApiErrors, getPermission, getRights, Message, MessageCreateEvent, MessageDeleteEvent, MessageUpdateEvent, + Snowflake, uploadFile } from "@fosscord/util"; import { Router, Response, Request } from "express"; @@ -16,7 +19,6 @@ import multer from "multer"; import { route } from "@fosscord/api"; import { handleMessage, postHandleMessage } from "@fosscord/api"; import { MessageCreateSchema } from "../index"; -import { Snowflake } from "@fosscord/util"; import { HTTPError } from "lambert-server"; const router = Router(); @@ -104,12 +106,12 @@ router.put( const snowflake = Snowflake.deconstruct(message_id) if (Date.now() < snowflake.timestamp) { // message is in the future - throw new HTTPError("You cannot backfill messages in the future", 400); + throw FosscordApiErrors.CANNOT_BACKFILL_TO_THE_FUTURE; } const exists = await Message.findOne({ where: { id: message_id, channel_id: channel_id }}); if (exists) { - throw new HTTPError("Cannot backfill to message ID that already exists", 409); + throw FosscordApiErrors.CANNOT_REPLACE_BY_BACKFILL; } if (req.file) { From c87671d080f79185fce9dd13f6f6e1a3b3aa50a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 14:57:26 +0300 Subject: [PATCH 008/238] Punitive rate limiting --- api/src/middlewares/RateLimit.ts | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index 1a38cfcf2..8368d14ab 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -53,12 +53,12 @@ export default function rateLimit(opts: { if (opts.GET && ["GET", "OPTIONS", "HEAD"].includes(req.method)) max_hits = opts.GET; else if (opts.MODIFY && ["POST", "DELETE", "PATCH", "PUT"].includes(req.method)) max_hits = opts.MODIFY; - const offender = Cache.get(executor_id + bucket_id); + let offender = Cache.get(executor_id + bucket_id); if (offender) { - const reset = offender.expires_at.getTime(); - const resetAfterMs = reset - Date.now(); - const resetAfterSec = resetAfterMs / 1000; + let reset = offender.expires_at.getTime(); + let resetAfterMs = reset - Date.now(); + let resetAfterSec = (resetAfterMs + 999) / 1000; if (resetAfterMs <= 0) { offender.hits = 0; @@ -70,6 +70,10 @@ export default function rateLimit(opts: { if (offender.blocked) { const global = bucket_id === "global"; + reset = reset + opts.window * 1000; // each block violation pushes the expiry one full window further + offender.expires_at += opts.window * 1000; + resetAfterMs = reset - Date.now(); + resetAfterSec = (resetAfterMs + 999) / 1000; console.log("blocked bucket: " + bucket_id, { resetAfterMs }); return ( From 16c10c581c30e54cdb99309272f7940ea5013d4a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 17:35:09 +0300 Subject: [PATCH 009/238] fix the seconds rounding logic --- api/src/middlewares/RateLimit.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index 8368d14ab..b4f321312 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -58,7 +58,7 @@ export default function rateLimit(opts: { if (offender) { let reset = offender.expires_at.getTime(); let resetAfterMs = reset - Date.now(); - let resetAfterSec = (resetAfterMs + 999) / 1000; + let resetAfterSec = Math.ceil(resetAfterMs / 1000); if (resetAfterMs <= 0) { offender.hits = 0; @@ -73,7 +73,7 @@ export default function rateLimit(opts: { reset = reset + opts.window * 1000; // each block violation pushes the expiry one full window further offender.expires_at += opts.window * 1000; resetAfterMs = reset - Date.now(); - resetAfterSec = (resetAfterMs + 999) / 1000; + resetAfterSec = Math.ceil(resetAfterMs / 1000); console.log("blocked bucket: " + bucket_id, { resetAfterMs }); return ( From fb5c79eefa1aa44894fb963e1332b05df77d2663 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 21:49:04 +0300 Subject: [PATCH 010/238] Update RateLimit.ts --- api/src/middlewares/RateLimit.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index b4f321312..f31aa5da2 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -71,7 +71,7 @@ export default function rateLimit(opts: { if (offender.blocked) { const global = bucket_id === "global"; reset = reset + opts.window * 1000; // each block violation pushes the expiry one full window further - offender.expires_at += opts.window * 1000; + offender.expires_at = offender.expires_at + opts.window * 1000; resetAfterMs = reset - Date.now(); resetAfterSec = Math.ceil(resetAfterMs / 1000); From 08097e157f833cd3cd5b43af9e6adc51dc321f72 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 22:40:36 +0300 Subject: [PATCH 011/238] Update Token.ts --- util/src/util/Token.ts | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/util/src/util/Token.ts b/util/src/util/Token.ts index 7c4cc61dd..500ace454 100644 --- a/util/src/util/Token.ts +++ b/util/src/util/Token.ts @@ -6,7 +6,12 @@ export const JWTOptions: VerifyOptions = { algorithms: ["HS256"] }; export function checkToken(token: string, jwtSecret: string): Promise { return new Promise((res, rej) => { - token = token.replace("Bot ", ""); // TODO: proper bot support + token = token.replace("Bot ", ""); + /** + in fosscord, even with instances that have bot distinction; we won't enforce "Bot" prefix, + as we don't really have separate pathways for bots + **/ + jwt.verify(token, jwtSecret, JWTOptions, async (err, decoded: any) => { if (err || !decoded) return rej("Invalid Token"); From 4871513640d49845edb8d22afbb8b8c3ed20a6e2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 23:04:55 +0300 Subject: [PATCH 012/238] Update RateLimit.ts --- api/src/middlewares/RateLimit.ts | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index f31aa5da2..4bbef5203 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -70,8 +70,9 @@ export default function rateLimit(opts: { if (offender.blocked) { const global = bucket_id === "global"; - reset = reset + opts.window * 1000; // each block violation pushes the expiry one full window further - offender.expires_at = offender.expires_at + opts.window * 1000; + // each block violation pushes the expiry one full window further + reset = new Date(reset.getTime() + opts.window * 1000); + offender.expires_at = new Date(offender.expires_at.getTime() + opts.window * 1000); resetAfterMs = reset - Date.now(); resetAfterSec = Math.ceil(resetAfterMs / 1000); From c9c660f7a788dea94f8f5826db96e9a7c7e4e71f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 24 Apr 2022 23:07:25 +0300 Subject: [PATCH 013/238] eventually fix those errors --- api/src/middlewares/RateLimit.ts | 2 +- util/src/util/Constants.ts | 17 ++++++++++------- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index 4bbef5203..81668034d 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -71,7 +71,7 @@ export default function rateLimit(opts: { if (offender.blocked) { const global = bucket_id === "global"; // each block violation pushes the expiry one full window further - reset = new Date(reset.getTime() + opts.window * 1000); + reset += opts.window * 1000; offender.expires_at = new Date(offender.expires_at.getTime() + opts.window * 1000); resetAfterMs = reset - Date.now(); resetAfterSec = Math.ceil(resetAfterMs / 1000); diff --git a/util/src/util/Constants.ts b/util/src/util/Constants.ts index 8d61b9b49..a5d3fcd21 100644 --- a/util/src/util/Constants.ts +++ b/util/src/util/Constants.ts @@ -727,21 +727,23 @@ export const DiscordApiErrors = { * An error encountered while performing an API request (Fosscord only). Here are the potential errors: */ export const FosscordApiErrors = { - MANUALLY_TRIGGERED_ERROR: new ApiError("This is an artificial error", 1), + MANUALLY_TRIGGERED_ERROR: new ApiError("This is an artificial error", 1, 500), PREMIUM_DISABLED_FOR_GUILD: new ApiError("This guild cannot be boosted", 25001), NO_FURTHER_PREMIUM: new ApiError("This guild does not receive further boosts", 25002), - GUILD_PREMIUM_DISABLED_FOR_YOU: new ApiError("This guild cannot be boosted by you", 25003), + GUILD_PREMIUM_DISABLED_FOR_YOU: new ApiError("This guild cannot be boosted by you", 25003, 403), CANNOT_FRIEND_SELF: new ApiError("Cannot friend oneself", 25009), USER_SPECIFIC_INVITE_WRONG_RECIPIENT: new ApiError("This invite is not meant for you", 25010), USER_SPECIFIC_INVITE_FAILED: new ApiError("Failed to invite user", 25011), - CANNOT_MODIFY_USER_GROUP: new ApiError("This user cannot manipulate this group", 25050), + CANNOT_MODIFY_USER_GROUP: new ApiError("This user cannot manipulate this group", 25050, 403), CANNOT_REMOVE_SELF_FROM_GROUP: new ApiError("This user cannot remove oneself from user group", 25051), CANNOT_BAN_OPERATOR: new ApiError("Non-OPERATOR cannot ban OPERATOR from instance", 25052), - CANNOT_LEAVE_GUILD: new ApiError("You are not allowed to leave guilds that you joined by yourself", 25059), - EDITS_DISABLED: new ApiError("You are not allowed to edit your own messages", 25060), - DELETE_MESSAGE_DISABLED: new ApiError("You are not allowed to delete your own messages", 25061), - FEATURE_PERMANENTLY_DISABLED: new ApiError("This feature has been disabled server-side", 45006), + CANNOT_LEAVE_GUILD: new ApiError("You are not allowed to leave guilds that you joined by yourself", 25059, 403), + EDITS_DISABLED: new ApiError("You are not allowed to edit your own messages", 25060, 403), + DELETE_MESSAGE_DISABLED: new ApiError("You are not allowed to delete your own messages", 25061, 403), + FEATURE_PERMANENTLY_DISABLED: new ApiError("This feature has been disabled server-side", 45006, 501), MISSING_RIGHTS: new ApiError("You lack rights to perform that action ({})", 50013, undefined, [""]), + CANNOT_REPLACE_BY_BACKFILL: new ApiError("Cannot backfill to message ID that already exists", 55002, 409), + CANNOT_BACKFILL_TO_THE_FUTURE: new ApiError("You cannot backfill messages in the future", 55003), CANNOT_GRANT_PERMISSIONS_EXCEEDING_RIGHTS: new ApiError("You cannot grant permissions exceeding your own rights", 50050), ROUTES_LOOPING: new ApiError("Loops in the route definition ({})", 50060, undefined, [""]), CANNOT_REMOVE_ROUTE: new ApiError("Cannot remove message route while it is in effect and being used", 50061), @@ -787,3 +789,4 @@ function keyMirror(arr: string[]) { for (const value of arr) tmp[value] = value; return tmp; } + From 80a80cc87314fde283a63f351a91cc97b8464b0f Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Mon, 25 Apr 2022 14:59:48 +0200 Subject: [PATCH 014/238] New translations auth.json (Polish) --- api/locales/pl/auth.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/api/locales/pl/auth.json b/api/locales/pl/auth.json index 3988e9cd0..711cb4d7e 100644 --- a/api/locales/pl/auth.json +++ b/api/locales/pl/auth.json @@ -1,13 +1,13 @@ { "login": { - "INVALID_LOGIN": "E-mail lub telefon nie został znaleziony", + "INVALID_LOGIN": "E-mail lub numer telefonu nie został znaleziony", "INVALID_PASSWORD": "Nieprawidłowe hasło", "ACCOUNT_DISABLED": "To konto jest nieaktywne" }, "register": { "REGISTRATION_DISABLED": "Rejestracja nowych użytkowników jest wyłączona", "INVITE_ONLY": "Aby się zarejestrować, musisz zostać zaproszony", - "EMAIL_INVALID": "Nieprawidłowy email", + "EMAIL_INVALID": "Nieprawidłowy E-mail", "EMAIL_ALREADY_REGISTERED": "E-mail jest już zarejestrowany", "DATE_OF_BIRTH_UNDERAGE": "Musisz mieć {{years}} lat lub więcej", "CONSENT_REQUIRED": "Musisz zaakceptować Regulamin i Politykę Prywatności.", From 44e1ce11d887474921c776ec5d992ad03aeb6fea Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Mon, 25 Apr 2022 14:59:49 +0200 Subject: [PATCH 015/238] New translations common.json (Polish) --- api/locales/pl/common.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/api/locales/pl/common.json b/api/locales/pl/common.json index 3b618c1f9..98c0906b8 100644 --- a/api/locales/pl/common.json +++ b/api/locales/pl/common.json @@ -10,9 +10,9 @@ "BASE_TYPE_OBJECT": "To pole musi być obiektem", "BASE_TYPE_ARRAY": "To pole musi być tablicą", "UNKOWN_FIELD": "Nieznany klucz: {{key}}", - "BASE_TYPE_CONSTANT": "To pole musi być {{value}}", + "BASE_TYPE_CONSTANT": "To pole musi wynosić {{value}}", "EMAIL_TYPE_INVALID_EMAIL": "Źle sformułowany adres e-mail", "DATE_TYPE_PARSE": "Nie można przetworzyć {{date}}. Powinno być ISO8601", - "BASE_TYPE_BAD_LENGTH": "Długość musi wynosić między {{length}}" + "BASE_TYPE_BAD_LENGTH": "Długość musi wynosić pomiędzy {{length}}" } } From 540e643b86295e2c55941fc279e03b69e3f07ed5 Mon Sep 17 00:00:00 2001 From: Thesourtimes Date: Tue, 26 Apr 2022 21:34:15 +0300 Subject: [PATCH 016/238] Do stuff for npm workspace --- api/LICENSE | 14 ------------ api/crowdin.yml | 3 --- api/package.json | 2 +- cdn/CONTRIBUTE.md | 18 --------------- cdn/package.json | 4 ++-- dashboard/LICENSE | 14 ------------ dashboard/package.json | 4 ++-- gateway/LICENSE | 14 ------------ gateway/client.js | 51 ------------------------------------------ gateway/package.json | 2 +- package.json | 17 ++++++++++++++ rtc/LICENSE | 14 ------------ util/LICENSE | 14 ------------ util/package.json | 2 +- webrtc/LICENSE | 14 ------------ webrtc/package.json | 4 ++-- 16 files changed, 26 insertions(+), 165 deletions(-) delete mode 100644 api/LICENSE delete mode 100644 api/crowdin.yml delete mode 100644 cdn/CONTRIBUTE.md delete mode 100644 dashboard/LICENSE delete mode 100644 gateway/LICENSE delete mode 100644 gateway/client.js create mode 100644 package.json delete mode 100644 rtc/LICENSE delete mode 100644 util/LICENSE delete mode 100644 webrtc/LICENSE diff --git a/api/LICENSE b/api/LICENSE deleted file mode 100644 index f19bf5202..000000000 --- a/api/LICENSE +++ /dev/null @@ -1,14 +0,0 @@ -Copyright (C) 2021 Fosscord and contributors - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU Affero General Public License as -published by the Free Software Foundation, either version 3 of the -License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU Affero General Public License for more details. - -You should have received a copy of the GNU Affero General Public License -along with this program. If not, see . \ No newline at end of file diff --git a/api/crowdin.yml b/api/crowdin.yml deleted file mode 100644 index 7228117fd..000000000 --- a/api/crowdin.yml +++ /dev/null @@ -1,3 +0,0 @@ -files: - - source: /locales/en/*.json - translation: /locales/%two_letters_code%/%original_file_name% diff --git a/api/package.json b/api/package.json index c586c9fe7..654725221 100644 --- a/api/package.json +++ b/api/package.json @@ -30,7 +30,7 @@ "discord-open-source" ], "author": "Fosscord", - "license": "GPLV3", + "license": "AGPLV3", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/cdn/CONTRIBUTE.md b/cdn/CONTRIBUTE.md deleted file mode 100644 index 7cc673d9c..000000000 --- a/cdn/CONTRIBUTE.md +++ /dev/null @@ -1,18 +0,0 @@ -# CONTRIBUTE - -### Setup: - -``` -npm i -npm start -``` - -### Run tests: - -``` -npm test -``` - -#### common errors: - -- db not connecting --> start mongod in a seperate terminal window diff --git a/cdn/package.json b/cdn/package.json index 7a1f43c93..f1d12ba5c 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -14,8 +14,8 @@ "url": "git+https://github.com/fosscord/fosscord-server.git" }, "keywords": [], - "author": "", - "license": "GPLV3", + "author": "Fosscord", + "license": "AGPLV3", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/dashboard/LICENSE b/dashboard/LICENSE deleted file mode 100644 index f19bf5202..000000000 --- a/dashboard/LICENSE +++ /dev/null @@ -1,14 +0,0 @@ -Copyright (C) 2021 Fosscord and contributors - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU Affero General Public License as -published by the Free Software Foundation, either version 3 of the -License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU Affero General Public License for more details. - -You should have received a copy of the GNU Affero General Public License -along with this program. If not, see . \ No newline at end of file diff --git a/dashboard/package.json b/dashboard/package.json index 1009d658e..e71de7935 100644 --- a/dashboard/package.json +++ b/dashboard/package.json @@ -14,8 +14,8 @@ "url": "git+https://github.com/fosscord/fosscord-server.git" }, "keywords": [], - "author": "", - "license": "GPLV3", + "author": "Fosscord", + "license": "AGPLV3", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/gateway/LICENSE b/gateway/LICENSE deleted file mode 100644 index f19bf5202..000000000 --- a/gateway/LICENSE +++ /dev/null @@ -1,14 +0,0 @@ -Copyright (C) 2021 Fosscord and contributors - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU Affero General Public License as -published by the Free Software Foundation, either version 3 of the -License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU Affero General Public License for more details. - -You should have received a copy of the GNU Affero General Public License -along with this program. If not, see . \ No newline at end of file diff --git a/gateway/client.js b/gateway/client.js deleted file mode 100644 index c841c6a0f..000000000 --- a/gateway/client.js +++ /dev/null @@ -1,51 +0,0 @@ -require("missing-native-js-functions"); -const WebSocket = require("ws"); -const Constants = require("./dist/util/Constants"); - -// const ws = new WebSocket("ws://127.0.0.1:8080"); -const ws = new WebSocket("wss://dev.fosscord.com"); - -ws.on("open", () => { - // ws.send(JSON.stringify({ req_type: "new_auth" })); - // ws.send(JSON.stringify({ req_type: "check_auth", token: "" })); - // op: 0, - // d: {}, - // s: 42, - // t: "GATEWAY_EVENT_NAME", -}); - -function send(data) { - ws.send(JSON.stringify(data)); -} - -ws.on("message", (buffer) => { - let data = JSON.parse(buffer.toString()); - console.log(data); - - switch (data.op) { - case 10: - setIntervalNow(() => { - send({ op: 1 }); - }, data.d.heartbeat_interval); - - // send({ - // op: 2, - // d: { - // token: - // "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjgxMTY0MjkxNzQzMjA2NjA0OCIsImlhdCI6MTYxMzU4MTE1MX0.7Qj_z2lYIgJ0rc7NfGtpW5DKGqecQfv1mLpoBUQHKDc", - // intents: 0n, - // properties: {}, - // }, - // }); - - send({ - op: 6, - }); - - break; - } -}); - -ws.on("close", (code, reason) => { - console.log(code, reason, Constants.CLOSECODES[code]); -}); diff --git a/gateway/package.json b/gateway/package.json index 6d0d2d1c8..92d812b41 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -13,7 +13,7 @@ }, "keywords": [], "author": "Fosscord", - "license": "GPLV3", + "license": "AGPLV3", "devDependencies": { "@types/amqplib": "^0.8.1", "@types/jsonwebtoken": "^8.5.0", diff --git a/package.json b/package.json new file mode 100644 index 000000000..0fa46c7a9 --- /dev/null +++ b/package.json @@ -0,0 +1,17 @@ +{ + "name": "fosscord-server", + "version": "1.0.0", + "description": "A Fosscord server written in Node.js", + "workspaces": ["api", "bundle", "cdn", "gateway", "webrtc"], + "scripts": {}, + "repository": { + "type": "git", + "url": "git+https://github.com/fosscord/fosscord-server.git" + }, + "author": "Fosscord", + "license": "AGPLV3", + "bugs": { + "url": "https://github.com/fosscord/fosscord-server/issues" + }, + "homepage": "https://fosscord.com" +} diff --git a/rtc/LICENSE b/rtc/LICENSE deleted file mode 100644 index f19bf5202..000000000 --- a/rtc/LICENSE +++ /dev/null @@ -1,14 +0,0 @@ -Copyright (C) 2021 Fosscord and contributors - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU Affero General Public License as -published by the Free Software Foundation, either version 3 of the -License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU Affero General Public License for more details. - -You should have received a copy of the GNU Affero General Public License -along with this program. If not, see . \ No newline at end of file diff --git a/util/LICENSE b/util/LICENSE deleted file mode 100644 index f19bf5202..000000000 --- a/util/LICENSE +++ /dev/null @@ -1,14 +0,0 @@ -Copyright (C) 2021 Fosscord and contributors - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU Affero General Public License as -published by the Free Software Foundation, either version 3 of the -License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU Affero General Public License for more details. - -You should have received a copy of the GNU Affero General Public License -along with this program. If not, see . \ No newline at end of file diff --git a/util/package.json b/util/package.json index d7baed9ae..7251d3e48 100644 --- a/util/package.json +++ b/util/package.json @@ -23,7 +23,7 @@ "discord-open-source" ], "author": "Fosscord", - "license": "GPLV3", + "license": "AGPLV3", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/webrtc/LICENSE b/webrtc/LICENSE deleted file mode 100644 index f19bf5202..000000000 --- a/webrtc/LICENSE +++ /dev/null @@ -1,14 +0,0 @@ -Copyright (C) 2021 Fosscord and contributors - -This program is free software: you can redistribute it and/or modify -it under the terms of the GNU Affero General Public License as -published by the Free Software Foundation, either version 3 of the -License, or (at your option) any later version. - -This program is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -GNU Affero General Public License for more details. - -You should have received a copy of the GNU Affero General Public License -along with this program. If not, see . \ No newline at end of file diff --git a/webrtc/package.json b/webrtc/package.json index 0f700728f..ab9e7486f 100644 --- a/webrtc/package.json +++ b/webrtc/package.json @@ -9,8 +9,8 @@ "start": "npm run build && node dist/start.js" }, "keywords": [], - "author": "", - "license": "ISC", + "author": "Fosscord", + "license": "AGPLV3", "devDependencies": { "@types/node": "^15.6.1", "@types/ws": "^7.4.4", From 2b1e1a3c0256db22371f1834173e96b29e468d51 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Wed, 27 Apr 2022 21:35:36 +0300 Subject: [PATCH 017/238] Forum and guild directory types --- util/src/entities/Channel.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 98766a9d9..69c08be79 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -28,6 +28,8 @@ export enum ChannelType { GUILD_PUBLIC_THREAD = 11, // a temporary sub-channel within a GUILD_TEXT channel GUILD_PRIVATE_THREAD = 12, // a temporary sub-channel within a GUILD_TEXT channel that is only viewable by those invited and those with the MANAGE_THREADS permission GUILD_STAGE_VOICE = 13, // a voice channel for hosting events with an audience + DIRECTORY = 14, // guild directory listing channel + GUILD_FORUM = 15, // forum composed of IM threads TICKET_TRACKER = 33, // ticket tracker, individual ticket items shall have type 12 KANBAN = 34, // confluence like kanban board VOICELESS_WHITEBOARD = 35, // whiteboard but without voice (whiteboard + voice is the same as stage) From a04e34708843425eecb55586dbbc10c5b6f94265 Mon Sep 17 00:00:00 2001 From: Kuna <65683493+kunamech@users.noreply.github.com> Date: Wed, 27 Apr 2022 23:09:01 +0300 Subject: [PATCH 018/238] Hotfix for workspace (#739) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 0fa46c7a9..3395122e3 100644 --- a/package.json +++ b/package.json @@ -2,7 +2,7 @@ "name": "fosscord-server", "version": "1.0.0", "description": "A Fosscord server written in Node.js", - "workspaces": ["api", "bundle", "cdn", "gateway", "webrtc"], + "workspaces": ["api", "cdn", "gateway"], "scripts": {}, "repository": { "type": "git", From 9ecd3d530bc04f068cb624fec2514bef3f63ed4f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Thu, 28 Apr 2022 21:30:41 +0300 Subject: [PATCH 019/238] exempt users logic resolves #396 --- api/src/middlewares/RateLimit.ts | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index 81668034d..7d5c51e2e 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -1,4 +1,4 @@ -import { Config, listenEvent } from "@fosscord/util"; +import { Config, getRights, listenEvent, Rights } from "@fosscord/util"; import { NextFunction, Request, Response, Router } from "express"; import { getIpAdress } from "@fosscord/api"; import { API_PREFIX_TRAILING_SLASH } from "./Authentication"; @@ -9,6 +9,7 @@ import { API_PREFIX_TRAILING_SLASH } from "./Authentication"; /* ? bucket limit? Max actions/sec per bucket? +(ANSWER: a small fosscord instance might not need a complex rate limiting system) TODO: delay database requests to include multiple queries TODO: different for methods (GET/POST) @@ -44,9 +45,12 @@ export default function rateLimit(opts: { onlyIp?: boolean; }): any { return async (req: Request, res: Response, next: NextFunction): Promise => { + // exempt user? if so, immediately short circuit + if (getRights(req.user_id).has("BYPASS_RATE_LIMITS")) return; + const bucket_id = opts.bucket || req.originalUrl.replace(API_PREFIX_TRAILING_SLASH, ""); var executor_id = getIpAdress(req); - if (!opts.onlyIp && req.user_id) executor_id = req.user_id; + if (!opts.onlyIp && req.user_id) executor_id = req.user_id; var max_hits = opts.count; if (opts.bot && req.user_bot) max_hits = opts.bot; From e1399b2875b98c997aa51fc2196a99910248523e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Thu, 28 Apr 2022 21:38:39 +0300 Subject: [PATCH 020/238] needs to be async --- api/src/middlewares/RateLimit.ts | 3 ++- .../#channel_id/messages/#message_id/index.ts | 2 +- bundle/package-lock.json | Bin 595770 -> 595773 bytes 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index 7d5c51e2e..ca6de98fa 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -46,7 +46,8 @@ export default function rateLimit(opts: { }): any { return async (req: Request, res: Response, next: NextFunction): Promise => { // exempt user? if so, immediately short circuit - if (getRights(req.user_id).has("BYPASS_RATE_LIMITS")) return; + const rights = await getRights(req.user_id); + if (rights.has("BYPASS_RATE_LIMITS")) return; const bucket_id = opts.bucket || req.originalUrl.replace(API_PREFIX_TRAILING_SLASH, ""); var executor_id = getIpAdress(req); diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index 958954b69..63fee9b99 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -95,7 +95,7 @@ router.put( var body = req.body as MessageCreateSchema; const attachments: Attachment[] = []; - const rights = getRights(req.user_id); + const rights = await getRights(req.user_id); rights.hasThrow("SEND_MESSAGES"); // regex to check if message contains anything other than numerals ( also no decimals ) diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 4742b4a41a576991b6f81df3d4c826cc158d4745..6fbd6978a8ed59bb88aefbbb9aeca01fc15e086e 100644 GIT binary patch delta 65 zcmdnBPG#>pl?`XPC+ L`*sBh4ypeDIhYj% delta 107 zcmdnHPG#3Rl?`XPCrKzz7C6E-oi~t?efk7>wiVksmDqY2r@z)_Go7BR$)-2mPlt_j z^L)Mv7Ld{ed6vlsa#^M;sIld5=hR^1VA{M()Rn18qD_LaO@gUSg1JqCrA>mhO@ggW Lf_<9=hwXm=bSfZT From f033d1fb2b4c4d38662f7ff71affce911afc8289 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Thu, 28 Apr 2022 21:51:35 +0300 Subject: [PATCH 021/238] Update prune.ts --- api/src/routes/guilds/#guild_id/prune.ts | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/prune.ts b/api/src/routes/guilds/#guild_id/prune.ts index 0dd4d610c..0e587d224 100644 --- a/api/src/routes/guilds/#guild_id/prune.ts +++ b/api/src/routes/guilds/#guild_id/prune.ts @@ -11,6 +11,10 @@ export const inactiveMembers = async (guild_id: string, user_id: string, days: n //Snowflake should have `generateFromTime` method? Or similar? var minId = BigInt(date.valueOf() - Snowflake.EPOCH) << BigInt(22); + /** + idea: ability to customise the cutoff variable + possible candidates: public read receipt, last presence, last VC leave + **/ var members = await Member.find({ where: [ { @@ -47,7 +51,7 @@ export const inactiveMembers = async (guild_id: string, user_id: string, days: n return members; }; -router.get("/", route({ permission: "KICK_MEMBERS" }), async (req: Request, res: Response) => { +router.get("/", route({}), async (req: Request, res: Response) => { const days = parseInt(req.query.days as string); var roles = req.query.include_roles; @@ -65,7 +69,7 @@ export interface PruneSchema { days: number; } -router.post("/", route({ permission: "KICK_MEMBERS" }), async (req: Request, res: Response) => { +router.post("/", route({ permission: "KICK_MEMBERS", right: "KICK_BAN_MEMBERS" }), async (req: Request, res: Response) => { const days = parseInt(req.body.days); var roles = req.query.include_roles; From 63b6ac57d653fda565c1a263492861cd4be6bbca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Thu, 28 Apr 2022 22:31:21 +0300 Subject: [PATCH 022/238] introduce the purge endpoint closes #281 --- .../channels/#channel_id/messages/index.ts | 4 +- api/src/routes/channels/#channel_id/purge.ts | 75 +++++++++++++++++++ 2 files changed, 78 insertions(+), 1 deletion(-) create mode 100644 api/src/routes/channels/#channel_id/purge.ts diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 34cc5ff8b..a77b459ba 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -30,6 +30,8 @@ export function isTextChannel(type: ChannelType): boolean { case ChannelType.GUILD_VOICE: case ChannelType.GUILD_STAGE_VOICE: case ChannelType.GUILD_CATEGORY: + case ChannelType.GUILD_FORUM: + case ChannelType.DIRECTORY: throw new HTTPError("not a text channel", 400); case ChannelType.DM: case ChannelType.GROUP_DM: @@ -155,7 +157,7 @@ const messageUpload = multer({ // https://discord.com/developers/docs/resources/channel#create-message // TODO: text channel slowdown // TODO: trim and replace message content and every embed field -// TODO: check allowed_mentions +// TODO: only dispatch mentions denoted in allowed_mentions // Send message router.post( diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts new file mode 100644 index 000000000..e66034e4f --- /dev/null +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -0,0 +1,75 @@ +import { HTTPError } from "lambert-server"; +import { route } from "@fosscord/api"; +import { isTextChannel } from "./messages"; +import { FindManyOptions, Between } from "typeorm"; +import { + Attachment, + Channel, + Config, + Embed, + DiscordApiErrors, + emitEvent, + FosscordApiErrors, + getPermission, + getRights, + Message, + MessageDeleteBulkEvent, + Snowflake, + uploadFile +} from "@fosscord/util"; +import { Router, Response, Request } from "express"; +import multer from "multer"; +import { handleMessage, postHandleMessage } from "@fosscord/api"; + +const router: Router = Router(); + +export default router; + +export interface PurgeSchema { + before: string; + after: string +} + +// TODO: should users be able to bulk delete messages or only bots? +// TODO: should this request fail, if you provide messages older than 14 days/invalid ids? +// https://discord.com/developers/docs/resources/channel#bulk-delete-messages +router.post("/", route({ body: "PurgeSchema", right: "SELF_DELETE_MESSAGES" }), async (req: Request, res: Response) => { + const { channel_id } = req.params; + const channel = await Channel.findOneOrFail({ id: channel_id }); + + if (!channel.guild_id) throw new HTTPError("Can't purge dm channels", 400); + isTextChannel(channel.type); + + const rights = await getRights(req.user_id); + if (!rights.has("MANAGE_MESSAGES")) { + const permissions = await getPermission(req.user_id, channel.guild_id, channel_id); + permissions.hasThrow("MANAGE_MESSAGES"); + permissions.hasThrow("MANAGE_CHANNELS"); + } + + const { before, after } = req.body as PurgeSchema; + + // TODO: send the deletion event bite-by-bite to prevent client stress + var query: FindManyOptions & { where: { id?: any; }; } = { + order: { id: "ASC" }, + // take: limit, + where: { + channel_id, + id: Between(after, before), // the right way around + }, + relations: ["author", "webhook", "application", "mentions", "mention_roles", "mention_channels", "sticker_items", "attachments"] + }; + + const messages = await Message.find(query); + const endpoint = Config.get().cdn.endpointPublic; + + await Message.delete(messages.map((x) => ({ id: x }))); + + await emitEvent({ + event: "MESSAGE_DELETE_BULK", + channel_id, + data: { ids: messages.map(x => x.id), channel_id, guild_id: channel.guild_id } + } as MessageDeleteBulkEvent); + + res.sendStatus(204); +}); From 9d908e0877d20f2c2814f2c10b13c31558bf5372 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 30 Apr 2022 00:39:44 +0300 Subject: [PATCH 023/238] patch for missing router schema, and also add purge route self-deletion checks --- api/src/routes/channels/#channel_id/purge.ts | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts index e66034e4f..8a87c3793 100644 --- a/api/src/routes/channels/#channel_id/purge.ts +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -1,7 +1,7 @@ import { HTTPError } from "lambert-server"; import { route } from "@fosscord/api"; import { isTextChannel } from "./messages"; -import { FindManyOptions, Between } from "typeorm"; +import { FindManyOptions, Between, Not } from "typeorm"; import { Attachment, Channel, @@ -33,7 +33,7 @@ export interface PurgeSchema { // TODO: should users be able to bulk delete messages or only bots? // TODO: should this request fail, if you provide messages older than 14 days/invalid ids? // https://discord.com/developers/docs/resources/channel#bulk-delete-messages -router.post("/", route({ body: "PurgeSchema", right: "SELF_DELETE_MESSAGES" }), async (req: Request, res: Response) => { +router.post("/", route({ /*body: "PurgeSchema",*/ }), async (req: Request, res: Response) => { const { channel_id } = req.params; const channel = await Channel.findOneOrFail({ id: channel_id }); @@ -50,18 +50,27 @@ router.post("/", route({ body: "PurgeSchema", right: "SELF_DELETE_MESSAGES" }), const { before, after } = req.body as PurgeSchema; // TODO: send the deletion event bite-by-bite to prevent client stress + var query: FindManyOptions & { where: { id?: any; }; } = { order: { id: "ASC" }, // take: limit, where: { channel_id, id: Between(after, before), // the right way around + author_id: rights.has("SELF_DELETE_MESSAGES") ? undefined : Not(req.user_id) + // if you lack the right of self-deletion, you can't delete your own messages, even in purges }, relations: ["author", "webhook", "application", "mentions", "mention_roles", "mention_channels", "sticker_items", "attachments"] }; + const messages = await Message.find(query); const endpoint = Config.get().cdn.endpointPublic; + + if (messages.length == 0) { + res.sendStatus(304); + return; + } await Message.delete(messages.map((x) => ({ id: x }))); From e9ac23c1fe775596f61c192609906b1cd2eafc18 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 30 Apr 2022 07:44:44 +0300 Subject: [PATCH 024/238] messages before/after soundness check --- .../routes/channels/#channel_id/messages/index.ts | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index a77b459ba..9a56106a7 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -11,6 +11,7 @@ import { getRights, Message, MessageCreateEvent, + Snowflake, uploadFile, Member } from "@fosscord/util"; @@ -86,7 +87,7 @@ router.get("/", async (req: Request, res: Response) => { const before = req.query.before ? `${req.query.before}` : undefined; const after = req.query.after ? `${req.query.after}` : undefined; const limit = Number(req.query.limit) || 50; - if (limit < 1 || limit > 100) throw new HTTPError("limit must be between 1 and 100"); + if (limit < 1 || limit > 100) throw new HTTPError("limit must be between 1 and 100", 422); var halfLimit = Math.floor(limit / 2); @@ -100,9 +101,16 @@ router.get("/", async (req: Request, res: Response) => { where: { channel_id }, relations: ["author", "webhook", "application", "mentions", "mention_roles", "mention_channels", "sticker_items", "attachments"] }; + - if (after) query.where.id = MoreThan(after); - else if (before) query.where.id = LessThan(before); + if (after) { + if (after > new Snowflake()) return res.status(422); + query.where.id = MoreThan(after); + } + else if (before) { + if (before < req.params.channel_id) return res.status(422); + query.where.id = LessThan(before); + } else if (around) { query.where.id = [ MoreThan((BigInt(around) - BigInt(halfLimit)).toString()), @@ -243,3 +251,4 @@ router.post( return res.json(message); } ); + From bc76c840b805d52a086f05dd4ea7e996a8abf2a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Fri, 6 May 2022 18:23:52 +0300 Subject: [PATCH 025/238] Remove more WAAO references --- api/client_test/index.html | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/api/client_test/index.html b/api/client_test/index.html index 39ff346dc..b438b4926 100644 --- a/api/client_test/index.html +++ b/api/client_test/index.html @@ -24,20 +24,20 @@ ASSET_ENDPOINT: "", MEDIA_PROXY_ENDPOINT: "https://media.discordapp.net", WIDGET_ENDPOINT: `//${location.host}/widget`, - INVITE_HOST: `${location.host}/invite`, - GUILD_TEMPLATE_HOST: "discord.new", - GIFT_CODE_HOST: "discord.gift", + INVITE_HOST: `${location.hostname}/invite`, + GUILD_TEMPLATE_HOST: "${location.host}", + GIFT_CODE_HOST: "${location.hostname}", RELEASE_CHANNEL: "stable", MARKETING_ENDPOINT: "//discord.com", BRAINTREE_KEY: "production_5st77rrc_49pp2rp4phym7387", STRIPE_KEY: "pk_live_CUQtlpQUF0vufWpnpUmQvcdi", NETWORKING_ENDPOINT: "//router.discordapp.net", - RTC_LATENCY_ENDPOINT: "//latency.discord.media/rtc", + RTC_LATENCY_ENDPOINT: "//${location.hostname}/rtc", PROJECT_ENV: "production", REMOTE_AUTH_ENDPOINT: "//localhost:3020", SENTRY_TAGS: { buildId: "75e36d9", buildType: "normal" }, - MIGRATION_SOURCE_ORIGIN: "https://discordapp.com", - MIGRATION_DESTINATION_ORIGIN: "https://discord.com", + MIGRATION_SOURCE_ORIGIN: "https://${location.hostname}", + MIGRATION_DESTINATION_ORIGIN: "https://${location.hostname}", HTML_TIMESTAMP: Date.now(), ALGOLIA_KEY: "aca0d7082e4e63af5ba5917d5e96bed0" }; From fe06d2b65ba74a69a77976e5304fc5ee2d012cc7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Tue, 10 May 2022 19:43:28 +0300 Subject: [PATCH 026/238] more event types --- util/src/entities/AuditLog.ts | 58 ++++++++++++++++++++++++++++++++--- 1 file changed, 54 insertions(+), 4 deletions(-) diff --git a/util/src/entities/AuditLog.ts b/util/src/entities/AuditLog.ts index 4b81ed6a1..be26374b5 100644 --- a/util/src/entities/AuditLog.ts +++ b/util/src/entities/AuditLog.ts @@ -4,41 +4,91 @@ import { ChannelPermissionOverwrite } from "./Channel"; import { User } from "./User"; export enum AuditLogEvents { - GUILD_UPDATE = 1, - CHANNEL_CREATE = 10, + // guild level + GUILD_UPDATE = 1, + GUILD_IMPORT = 2, + GUILD_EXPORTED = 3, + GUILD_ARCHIVE = 4, + GUILD_UNARCHIVE = 5, + // join-leave + USER_JOIN = 6, + USER_LEAVE = 7, + // channels + CHANNEL_CREATE = 10, CHANNEL_UPDATE = 11, CHANNEL_DELETE = 12, - CHANNEL_OVERWRITE_CREATE = 13, + // permission overrides + CHANNEL_OVERWRITE_CREATE = 13, CHANNEL_OVERWRITE_UPDATE = 14, CHANNEL_OVERWRITE_DELETE = 15, - MEMBER_KICK = 20, + // kick and ban + MEMBER_KICK = 20, MEMBER_PRUNE = 21, MEMBER_BAN_ADD = 22, MEMBER_BAN_REMOVE = 23, + // member updates MEMBER_UPDATE = 24, MEMBER_ROLE_UPDATE = 25, MEMBER_MOVE = 26, MEMBER_DISCONNECT = 27, BOT_ADD = 28, + // roles ROLE_CREATE = 30, ROLE_UPDATE = 31, ROLE_DELETE = 32, + ROLE_SWAP = 33, + // invites INVITE_CREATE = 40, INVITE_UPDATE = 41, INVITE_DELETE = 42, + // webhooks WEBHOOK_CREATE = 50, WEBHOOK_UPDATE = 51, WEBHOOK_DELETE = 52, + WEBHOOK_SWAP = 53, + // custom emojis EMOJI_CREATE = 60, EMOJI_UPDATE = 61, EMOJI_DELETE = 62, + EMOJI_SWAP = 63, + // deletion + MESSAGE_CREATE = 70, // messages sent using non-primary seat of the user only + MESSAGE_EDIT = 71, // non-self edits only MESSAGE_DELETE = 72, MESSAGE_BULK_DELETE = 73, + // pinning MESSAGE_PIN = 74, MESSAGE_UNPIN = 75, + // integrations INTEGRATION_CREATE = 80, INTEGRATION_UPDATE = 81, INTEGRATION_DELETE = 82, + // stage actions + STAGE_INSTANCE_CREATE = 83, + STAGE_INSTANCE_UPDATE = 84, + STAGE_INSTANCE_DELETE = 85, + // stickers + STICKER_CREATE = 90, + STICKER_UPDATE = 91, + STICKER_DELETE = 92, + STICKER_SWAP = 93, + // threads + THREAD_CREATE = 110, + THREAD_UPDATE = 111, + THREAD_DELETE = 112, + // application commands + APPLICATION_COMMAND_PERMISSION_UPDATE = 121, + // automod + POLICY_CREATE = 140, + POLICY_UPDATE = 141, + // instance policies affecting the guild + GUILD_CROPPED_BY_POLICIES = 216, + // message moves + IN_GUILD_MESSAGE_MOVE = 223, + CROSS_GUILD_MESSAGE_MOVE = 224, + // message routing + ROUTE_CREATE = 225, + ROUTE_UPDATE = 226, } @Entity("audit_logs") From ce6556db47df28ce4372206dc32c844893ae7780 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Wed, 11 May 2022 00:40:00 +0300 Subject: [PATCH 027/238] add more message flags --- util/src/util/MessageFlags.ts | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/util/src/util/MessageFlags.ts b/util/src/util/MessageFlags.ts index c76be4c86..d8e7bc4f7 100644 --- a/util/src/util/MessageFlags.ts +++ b/util/src/util/MessageFlags.ts @@ -1,5 +1,5 @@ -// https://github.com/discordjs/discord.js/blob/master/src/util/MessageFlags.js -// Apache License Version 2.0 Copyright 2015 - 2021 Amish Shah +// based on https://github.com/discordjs/discord.js/blob/master/src/util/MessageFlags.js +// Apache License Version 2.0 Copyright 2015 - 2021 Amish Shah, 2022 Erkin Alp Güney import { BitField } from "./BitField"; @@ -8,7 +8,12 @@ export class MessageFlags extends BitField { CROSSPOSTED: BigInt(1) << BigInt(0), IS_CROSSPOST: BigInt(1) << BigInt(1), SUPPRESS_EMBEDS: BigInt(1) << BigInt(2), - SOURCE_MESSAGE_DELETED: BigInt(1) << BigInt(3), + // SOURCE_MESSAGE_DELETED: BigInt(1) << BigInt(3), // fosscord will delete them from destination too, making this redundant URGENT: BigInt(1) << BigInt(4), + // HAS_THREAD: BigInt(1) << BigInt(5) // does not apply to fosscord due to infrastructural differences + PRIVATE_ROUTE: BigInt(1) << BigInt(6), // it that has been routed to only some of the users that can see the channel + INTERACTION_WAIT: BigInt(1) << BigInt(7), // discord.com calls this LOADING + // FAILED_TO_MENTION_SOME_ROLES_IN_THREAD: BigInt(1) << BigInt(8) + SCRIPT_WAIT: BigInt(1) << BigInt(24) // waiting for the self command to complete }; } From 37543ec0fdeb223ffb46a33207c107081d796b63 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Wed, 11 May 2022 00:43:57 +0300 Subject: [PATCH 028/238] Update MessageFlags.ts --- util/src/util/MessageFlags.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/util/src/util/MessageFlags.ts b/util/src/util/MessageFlags.ts index d8e7bc4f7..b8f8c8579 100644 --- a/util/src/util/MessageFlags.ts +++ b/util/src/util/MessageFlags.ts @@ -14,6 +14,7 @@ export class MessageFlags extends BitField { PRIVATE_ROUTE: BigInt(1) << BigInt(6), // it that has been routed to only some of the users that can see the channel INTERACTION_WAIT: BigInt(1) << BigInt(7), // discord.com calls this LOADING // FAILED_TO_MENTION_SOME_ROLES_IN_THREAD: BigInt(1) << BigInt(8) - SCRIPT_WAIT: BigInt(1) << BigInt(24) // waiting for the self command to complete + SCRIPT_WAIT: BigInt(1) << BigInt(24), // waiting for the self command to complete + IMPORT_WAIT: BigInt(1) << BigInt(25), // last message of a channel bulk guild import, waiting for the rest of the channel to be backfilled }; } From 78796c3ce1bca21923e385316956337f0bc8d3fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Wed, 11 May 2022 00:44:19 +0300 Subject: [PATCH 029/238] Update MessageFlags.ts --- util/src/util/MessageFlags.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/src/util/MessageFlags.ts b/util/src/util/MessageFlags.ts index b8f8c8579..b59295c4f 100644 --- a/util/src/util/MessageFlags.ts +++ b/util/src/util/MessageFlags.ts @@ -15,6 +15,6 @@ export class MessageFlags extends BitField { INTERACTION_WAIT: BigInt(1) << BigInt(7), // discord.com calls this LOADING // FAILED_TO_MENTION_SOME_ROLES_IN_THREAD: BigInt(1) << BigInt(8) SCRIPT_WAIT: BigInt(1) << BigInt(24), // waiting for the self command to complete - IMPORT_WAIT: BigInt(1) << BigInt(25), // last message of a channel bulk guild import, waiting for the rest of the channel to be backfilled + IMPORT_WAIT: BigInt(1) << BigInt(25), // latest message of a bulk import, waiting for the rest of the channel to be backfilled }; } From da8d376a6b0319e7f9d04c71876f586231008e01 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 00:16:50 +0300 Subject: [PATCH 030/238] Update purge.ts --- api/src/routes/channels/#channel_id/purge.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts index 8a87c3793..28b52b509 100644 --- a/api/src/routes/channels/#channel_id/purge.ts +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -30,9 +30,9 @@ export interface PurgeSchema { after: string } -// TODO: should users be able to bulk delete messages or only bots? -// TODO: should this request fail, if you provide messages older than 14 days/invalid ids? -// https://discord.com/developers/docs/resources/channel#bulk-delete-messages +/** +TODO: apply the delete bit by bit to prevent client and database stress +**/ router.post("/", route({ /*body: "PurgeSchema",*/ }), async (req: Request, res: Response) => { const { channel_id } = req.params; const channel = await Channel.findOneOrFail({ id: channel_id }); From bce71f5f6a6392a75f2a169faa1db0400484187f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 00:23:17 +0300 Subject: [PATCH 031/238] Update bulk-delete.ts --- .../#channel_id/messages/bulk-delete.ts | 20 ++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts b/api/src/routes/channels/#channel_id/messages/bulk-delete.ts index 7a711cb05..6eacf2497 100644 --- a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts +++ b/api/src/routes/channels/#channel_id/messages/bulk-delete.ts @@ -1,5 +1,5 @@ import { Router, Response, Request } from "express"; -import { Channel, Config, emitEvent, getPermission, MessageDeleteBulkEvent, Message } from "@fosscord/util"; +import { Channel, Config, emitEvent, getPermission, getRights, MessageDeleteBulkEvent, Message } from "@fosscord/util"; import { HTTPError } from "lambert-server"; import { route } from "@fosscord/api"; import { In } from "typeorm"; @@ -12,22 +12,28 @@ export interface BulkDeleteSchema { messages: string[]; } -// TODO: should users be able to bulk delete messages or only bots? -// TODO: should this request fail, if you provide messages older than 14 days/invalid ids? +// should users be able to bulk delete messages or only bots? ANSWER: all users +// should this request fail, if you provide messages older than 14 days/invalid ids? ANSWER: NO // https://discord.com/developers/docs/resources/channel#bulk-delete-messages router.post("/", route({ body: "BulkDeleteSchema" }), async (req: Request, res: Response) => { const { channel_id } = req.params; const channel = await Channel.findOneOrFail({ id: channel_id }); if (!channel.guild_id) throw new HTTPError("Can't bulk delete dm channel messages", 400); + const rights = await getRights(req.user_id); + rights.hasThrow("SELF_DELETE_MESSAGES"); + + let superuser = rights.has("MANAGE_MESSAGES"); const permission = await getPermission(req.user_id, channel?.guild_id, channel_id); - permission.hasThrow("MANAGE_MESSAGES"); - + const { maxBulkDelete } = Config.get().limits.message; const { messages } = req.body as { messages: string[] }; - if (messages.length < 2) throw new HTTPError("You must at least specify 2 messages to bulk delete"); - if (messages.length > maxBulkDelete) throw new HTTPError(`You cannot delete more than ${maxBulkDelete} messages`); + if (messages.length === 0) throw new HTTPError("You must specify messages to bulk delete"); + if (!superuser) { + permission.hasThrow("MANAGE_MESSAGES"); + if (messages.length > maxBulkDelete) throw new HTTPError(`You cannot delete more than ${maxBulkDelete} messages`); + } await Message.delete(messages.map((x) => ({ id: x }))); From 297115f4c5e626f72bd14f5021465204711424e5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 09:12:28 +0300 Subject: [PATCH 032/238] user groups --- util/src/entities/Group.ts | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 util/src/entities/Group.ts diff --git a/util/src/entities/Group.ts b/util/src/entities/Group.ts new file mode 100644 index 000000000..b24d38cf9 --- /dev/null +++ b/util/src/entities/Group.ts @@ -0,0 +1,33 @@ +import { Column, Entity, JoinColumn, ManyToOne, RelationId } from "typeorm"; + +import { BaseClass } from "./BaseClass"; + +@Entity("groups") +export class UserGroup extends BaseClass { + @Column({ nullable: true }) + parent?: BigInt; + + @Column() + color: number; + + @Column() + hoist: boolean; + + @Column() + mentionable: boolean; + + @Column() + name: string; + + @Column() + rights: BigInt; + + @Column() + position: number; + + @Column({ nullable: true }) + icon: BigInt; + + @Column({ nullable: true }) + unicode_emoji: BigInt; +} From 36d69e781c1df8ca826ebe7b481b263a8476754d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 16:28:57 +0300 Subject: [PATCH 033/238] Update AuditLog.ts --- util/src/entities/AuditLog.ts | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/util/src/entities/AuditLog.ts b/util/src/entities/AuditLog.ts index be26374b5..b003e7ba4 100644 --- a/util/src/entities/AuditLog.ts +++ b/util/src/entities/AuditLog.ts @@ -81,8 +81,10 @@ export enum AuditLogEvents { // automod POLICY_CREATE = 140, POLICY_UPDATE = 141, + POLICY_DELETE = 142, + MESSAGE_BLOCKED_BY_POLICIES = 143, // in fosscord, blocked messages are stealth-dropped // instance policies affecting the guild - GUILD_CROPPED_BY_POLICIES = 216, + GUILD_AFFECTED_BY_POLICIES = 216, // message moves IN_GUILD_MESSAGE_MOVE = 223, CROSS_GUILD_MESSAGE_MOVE = 224, From 510ef5aebe95678ca2ad5b45a6a8249eace82f62 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 17:43:30 +0300 Subject: [PATCH 034/238] Update index.ts --- .../channels/#channel_id/messages/index.ts | 32 +++++++++++-------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 9a56106a7..2d6a29771 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -71,7 +71,11 @@ export interface MessageCreateSchema { }; payload_json?: string; file?: any; - attachments?: any[]; //TODO we should create an interface for attachments + /** + TODO: we should create an interface for attachments + TODO: OpenWAAO<-->attachment-style metadata conversion + **/ + attachments?: any[]; sticker_ids?: string[]; } @@ -136,9 +140,12 @@ router.get("/", async (req: Request, res: Response) => { const uri = y.proxy_url.startsWith("http") ? y.proxy_url : `https://example.org${y.proxy_url}`; y.proxy_url = `${endpoint == null ? "" : endpoint}${new URL(uri).pathname}`; }); - - //Some clients ( discord.js ) only check if a property exists within the response, - //which causes erorrs when, say, the `application` property is `null`. + + /** + Some clients ( discord.js ) only check if a property exists within the response, + which causes erorrs when, say, the `application` property is `null`. + **/ + for (var curr in x) { if (x[curr] === null) delete x[curr]; @@ -158,15 +165,14 @@ const messageUpload = multer({ }, storage: multer.memoryStorage() }); // max upload 50 mb +/** + TODO: dynamically change limit of MessageCreateSchema with config -// TODO: dynamically change limit of MessageCreateSchema with config -// TODO: check: sum of all characters in an embed structure must not exceed instance limits - -// https://discord.com/developers/docs/resources/channel#create-message -// TODO: text channel slowdown -// TODO: trim and replace message content and every embed field -// TODO: only dispatch mentions denoted in allowed_mentions - + https://discord.com/developers/docs/resources/channel#create-message + TODO: text channel slowdown (per-user and across-users) + Q: trim and replace message content and every embed field A: NO, given this cannot be implemented in E2EE channels + TODO: only dispatch notifications for mentions denoted in allowed_mentions +**/ // Send message router.post( "/", @@ -233,8 +239,6 @@ router.post( }) ); } - - //Fix for the client bug delete message.member From 2d177a1082baa846617915b3b66b66af9a390f61 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 17:52:17 +0300 Subject: [PATCH 035/238] Extended settings --- util/src/entities/User.ts | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index a5c4c136a..558a4190c 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -163,6 +163,10 @@ export class User extends BaseClass { @Column({ type: "simple-json", select: false }) settings: UserSettings; + + // workaround to prevent fossord-unaware clients from deleting settings not used by them + @Column({ type: "simple-json", select: false }) + extended_settings: UserSettings; @Column({ type: "simple-json" }) notes: { [key: string]: string }; //key is ID of user @@ -273,6 +277,7 @@ export class User extends BaseClass { valid_tokens_since: new Date(), }, settings: { ...defaultSettings, locale: language }, + extended_settings: {}, fingerprints: [], notes: {}, }); From d8d2c28fca31d9426265a51a6713bc4c1757880a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 15 May 2022 17:53:24 +0300 Subject: [PATCH 036/238] Extended settings will not be type checked --- util/src/entities/User.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 558a4190c..9b1c494eb 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -166,7 +166,7 @@ export class User extends BaseClass { // workaround to prevent fossord-unaware clients from deleting settings not used by them @Column({ type: "simple-json", select: false }) - extended_settings: UserSettings; + extended_settings: string; @Column({ type: "simple-json" }) notes: { [key: string]: string }; //key is ID of user From 7e0454c85f411199ea386adb5d8601593cc4cbb0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Thu, 19 May 2022 23:11:46 +0300 Subject: [PATCH 037/238] add guild policies --- util/src/util/Intents.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/util/src/util/Intents.ts b/util/src/util/Intents.ts index d9a60e4a8..1e840b766 100644 --- a/util/src/util/Intents.ts +++ b/util/src/util/Intents.ts @@ -18,6 +18,8 @@ export class Intents extends BitField { DIRECT_MESSAGE_REACTIONS: BigInt(1) << BigInt(13), // DM or orphan channel message reactions DIRECT_MESSAGE_TYPING: BigInt(1) << BigInt(14), // DM typing notifications GUILD_MESSAGES_CONTENT: BigInt(1) << BigInt(15), // guild message content + GUILD_POLICIES: BigInt(1) << BigInt(20), // guild policies + GUILD_POLICY_EXECUTION: BigInt(1) << BigInt(21), // guild policy execution LIVE_MESSAGE_COMPOSITION: BigInt(1) << BigInt(32), // allow composing messages using the gateway GUILD_ROUTES: BigInt(1) << BigInt(41), // message routes affecting the guild DIRECT_MESSAGES_THREADS: BigInt(1) << BigInt(42), // direct message threads From a6c34fa06014143e347a79317609069012dc4f08 Mon Sep 17 00:00:00 2001 From: FlumeZ <35439776+xFlum3@users.noreply.github.com> Date: Thu, 26 May 2022 22:56:51 +0300 Subject: [PATCH 038/238] Fixed Broken Translates and finished the file Enjoy :) --- api/locales/he/common.json | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/api/locales/he/common.json b/api/locales/he/common.json index 9e72e9416..4101eac4a 100644 --- a/api/locales/he/common.json +++ b/api/locales/he/common.json @@ -1,18 +1,18 @@ { "field": { - "BASE_TYPE_REQUIRED": "This field is required", - "BASE_TYPE_STRING": "This field must be a string", - "BASE_TYPE_NUMBER": "This field must be a number", - "BASE_TYPE_BIGINT": "This field must be a bigint", - "BASE_TYPE_BOOLEAN": "This field must be a boolean", - "BASE_TYPE_CHOICES": "This field must be one of ({{types}})", - "BASE_TYPE_CLASS": "This field must be an instance of {{type}}", + "BASE_TYPE_REQUIRED": "שדה זה חובה", + "BASE_TYPE_STRING": "שדה זה חייב להיות כטקסט", + "BASE_TYPE_NUMBER": "שדה זה חייב להיות מספר", + "BASE_TYPE_BIGINT": "השדה הזה חייב להיות ביגינט", + "BASE_TYPE_BOOLEAN": "השדה הזה חייב להיות בוליאני", + "BASE_TYPE_CHOICES": "({{types}}) שדה זה חייב להיות אחד מ", + "BASE_TYPE_CLASS": "{{type}} מסוג instance שדה זה חייב להיות", "BASE_TYPE_OBJECT": "שדה זה חייב להיות אובייקט", "BASE_TYPE_ARRAY": "שדה זה חייב להיות מערך", - "UNKOWN_FIELD": "מפתח לא ידוע: {{key}}", - "BASE_TYPE_CONSTANT": "שדה זה להיות {{value}}", + "UNKOWN_FIELD": "{{key}} :מפתח לא ידוע", + "BASE_TYPE_CONSTANT": "{{value}} שדה זה חייב להיות", "EMAIL_TYPE_INVALID_EMAIL": "כתובת דואר אלקטרוני לא חוקית", - "DATE_TYPE_PARSE": "לא ניתן לנתח {{date}}. צריך להיות ISO8601", - "BASE_TYPE_BAD_LENGTH": "האורך חייב להיות בין {{length}}" + "DATE_TYPE_PARSE": "ISO8601 אמור להיות {{date}} לא ניתן לאתר", + "BASE_TYPE_BAD_LENGTH": "{{length}} האורך חייב להיות בין" } } From 919b4dd03fdc284b2da0c9c5b1f5bcaed721fe0f Mon Sep 17 00:00:00 2001 From: FlumeZ <35439776+xFlum3@users.noreply.github.com> Date: Thu, 26 May 2022 23:02:19 +0300 Subject: [PATCH 039/238] Finished file translation Auth.json :D --- api/locales/he/auth.json | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/api/locales/he/auth.json b/api/locales/he/auth.json index e19547a01..b72968682 100644 --- a/api/locales/he/auth.json +++ b/api/locales/he/auth.json @@ -1,16 +1,16 @@ { "login": { - "INVALID_LOGIN": "E-Mail or Phone not found", - "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "INVALID_LOGIN": "מייל או מספר טלפון לא נמצאים במאגר", + "INVALID_PASSWORD": "סיסמא שגויה", + "ACCOUNT_DISABLED": "משתמש זה חסום / מבוטל" }, "register": { - "REGISTRATION_DISABLED": "New user registration is disabled", - "INVITE_ONLY": "You must be invited to register", - "EMAIL_INVALID": "Invalid Email", - "EMAIL_ALREADY_REGISTERED": "Email is already registered", - "DATE_OF_BIRTH_UNDERAGE": "You need to be {{years}} years or older", - "CONSENT_REQUIRED": "You must agree to the Terms of Service and Privacy Policy.", - "USERNAME_TOO_MANY_USERS": "Too many users have this username, please try another" + "REGISTRATION_DISABLED": "לא ניתן לאפשר רישום משתמשים חדשים", + "INVITE_ONLY": "עליך להיות מוזמן בכדי להרשם", + "EMAIL_INVALID": "מייל שגוי", + "EMAIL_ALREADY_REGISTERED": "מייל זה כבר רשום", + "DATE_OF_BIRTH_UNDERAGE": "{{years}} עלייך להיות מעל גיל", + "CONSENT_REQUIRED": ".עליך להסכים לתנאי השירות ולמדיניות הפרטיות", + "USERNAME_TOO_MANY_USERS": "ליותר מדי משתמשים יש שם משתמש זהה, אנא נסה אחר" } } From ad1aafa7c6e4ef76fc2529efd4c8eef915f4c4ec Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Mon, 30 May 2022 23:28:23 +1000 Subject: [PATCH 040/238] Respect register_dateOfBirth_required = false --- api/src/routes/auth/register.ts | 2 +- util/src/entities/Config.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/api/src/routes/auth/register.ts b/api/src/routes/auth/register.ts index cd1bcb72e..94dd65021 100644 --- a/api/src/routes/auth/register.ts +++ b/api/src/routes/auth/register.ts @@ -128,7 +128,7 @@ router.post("/", route({ body: "RegisterSchema" }), async (req: Request, res: Re throw FieldErrors({ date_of_birth: { code: "BASE_TYPE_REQUIRED", message: req.t("common:field.BASE_TYPE_REQUIRED") } }); - } else if (register.dateOfBirth.minimum) { + } else if (register.dateOfBirth.required && register.dateOfBirth.minimum) { const minimum = new Date(); minimum.setFullYear(minimum.getFullYear() - register.dateOfBirth.minimum); body.date_of_birth = new Date(body.date_of_birth as Date); diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts index 8d29b387a..063a4d4d9 100644 --- a/util/src/entities/Config.ts +++ b/util/src/entities/Config.ts @@ -324,7 +324,7 @@ export const DefaultConfigOptions: ConfigValue = { // domains: fs.readFileSync(__dirname + "/blockedEmailDomains.txt", { encoding: "utf8" }).split("\n"), }, dateOfBirth: { - required: false, + required: true, minimum: 13, }, disabled: false, From 860b5a82ef91d2f73a9502ffbae831e60bf8b26c Mon Sep 17 00:00:00 2001 From: KaKi87 Date: Thu, 2 Jun 2022 17:33:50 +0200 Subject: [PATCH 041/238] Use SPDX license syntax in 'package.json' files --- api/package.json | 2 +- bundle/package.json | 2 +- cdn/package.json | 2 +- dashboard/package.json | 2 +- gateway/package.json | 2 +- package.json | 2 +- util/package.json | 2 +- webrtc/package.json | 2 +- 8 files changed, 8 insertions(+), 8 deletions(-) diff --git a/api/package.json b/api/package.json index 654725221..29fa82a10 100644 --- a/api/package.json +++ b/api/package.json @@ -30,7 +30,7 @@ "discord-open-source" ], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/bundle/package.json b/bundle/package.json index 7d68427fe..d44d257f3 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -18,7 +18,7 @@ }, "keywords": [], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/cdn/package.json b/cdn/package.json index f1d12ba5c..46405b88a 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -15,7 +15,7 @@ }, "keywords": [], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/dashboard/package.json b/dashboard/package.json index e71de7935..9afe20f8c 100644 --- a/dashboard/package.json +++ b/dashboard/package.json @@ -15,7 +15,7 @@ }, "keywords": [], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/gateway/package.json b/gateway/package.json index 92d812b41..7a3b1012e 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -13,7 +13,7 @@ }, "keywords": [], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "devDependencies": { "@types/amqplib": "^0.8.1", "@types/jsonwebtoken": "^8.5.0", diff --git a/package.json b/package.json index 3395122e3..8488ff28b 100644 --- a/package.json +++ b/package.json @@ -9,7 +9,7 @@ "url": "git+https://github.com/fosscord/fosscord-server.git" }, "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/util/package.json b/util/package.json index 7251d3e48..35d2fbbe2 100644 --- a/util/package.json +++ b/util/package.json @@ -23,7 +23,7 @@ "discord-open-source" ], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, diff --git a/webrtc/package.json b/webrtc/package.json index ab9e7486f..d973dd7eb 100644 --- a/webrtc/package.json +++ b/webrtc/package.json @@ -10,7 +10,7 @@ }, "keywords": [], "author": "Fosscord", - "license": "AGPLV3", + "license": "AGPL-3.0-only", "devDependencies": { "@types/node": "^15.6.1", "@types/ws": "^7.4.4", From ffe9bf129980691f4a4aeb5a483c1ada545baa0d Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Wed, 8 Jun 2022 16:57:25 +1000 Subject: [PATCH 042/238] Expose general instance information via api /ping route --- api/src/routes/ping.ts | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/api/src/routes/ping.ts b/api/src/routes/ping.ts index 5cdea7056..3c1da2c38 100644 --- a/api/src/routes/ping.ts +++ b/api/src/routes/ping.ts @@ -1,10 +1,26 @@ import { Router, Response, Request } from "express"; import { route } from "@fosscord/api"; +import { Config } from "@fosscord/util"; const router = Router(); router.get("/", route({}), (req: Request, res: Response) => { - res.send("pong"); + const { general } = Config.get(); + res.send({ + ping: "pong!", + instance: { + id: general.instanceId, + name: general.instanceName, + description: general.instanceDescription, + image: general.image, + + correspondenceEmail: general.correspondenceEmail, + correspondenceUserID: general.correspondenceUserID, + + frontPage: general.frontPage, + tosPage: general.tosPage, + }, + }); }); export default router; From 5fb180ab4386cec98fb81244dd44689d712160cf Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sun, 19 Jun 2022 08:40:50 +0000 Subject: [PATCH 043/238] Bump sqlite3 from 5.0.2 to 5.0.8 in /util Bumps [sqlite3](https://github.com/TryGhost/node-sqlite3) from 5.0.2 to 5.0.8. - [Release notes](https://github.com/TryGhost/node-sqlite3/releases) - [Changelog](https://github.com/TryGhost/node-sqlite3/blob/master/CHANGELOG.md) - [Commits](https://github.com/TryGhost/node-sqlite3/compare/v5.0.2...v5.0.8) --- updated-dependencies: - dependency-name: sqlite3 dependency-type: indirect ... Signed-off-by: dependabot[bot] --- util/package-lock.json | Bin 498021 -> 501775 bytes 1 file changed, 0 insertions(+), 0 deletions(-) diff --git a/util/package-lock.json b/util/package-lock.json index b2fa8bbf7bc938c62960c99604ad83a0c443f9d9..a566836e46504a49e42d7b479d226a8c8356539d 100644 GIT binary patch delta 20933 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 K`@X!s_5T5`(P7>I delta 21146 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 From 652bb40e8c17065698bd5b37718600cc4855b803 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 26 Jun 2022 14:20:34 +0300 Subject: [PATCH 044/238] Update Rights.ts --- util/src/util/Rights.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/util/src/util/Rights.ts b/util/src/util/Rights.ts index 35ad9514f..b28c75b72 100644 --- a/util/src/util/Rights.ts +++ b/util/src/util/Rights.ts @@ -71,6 +71,8 @@ export class Rights extends BitField { INITIATE_INTERACTIONS: BitFlag(40), // can initiate interactions RESPOND_TO_INTERACTIONS: BitFlag(41), // can respond to interactions SEND_BACKDATED_EVENTS: BitFlag(42), // can send backdated events + USE_MASS_INVITES: BitFlag(43), // added per @xnacly's request — can accept mass invites + ACCEPT_INVITES: BitFlag(44) // added per @xnacly's request — can accept user-specific invites and DM requests }; any(permission: RightResolvable, checkOperator = true) { From 84b631e9b614e780caace68ad0e815ecd5ef4919 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 26 Jun 2022 14:26:36 +0300 Subject: [PATCH 045/238] JOIN_GUILDS is not the right flag there --- api/src/routes/invites/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/invites/index.ts b/api/src/routes/invites/index.ts index 21da2d184..eeafb22ab 100644 --- a/api/src/routes/invites/index.ts +++ b/api/src/routes/invites/index.ts @@ -13,7 +13,7 @@ router.get("/:code", route({}), async (req: Request, res: Response) => { res.status(200).send(invite); }); -router.post("/:code", route({right: "JOIN_GUILDS"}), async (req: Request, res: Response) => { +router.post("/:code", route({right: "USE_MASS_INVITES"}), async (req: Request, res: Response) => { const { code } = req.params; const { guild_id } = await Invite.findOneOrFail({ code }) const { features } = await Guild.findOneOrFail({ id: guild_id}); From a034698970f536733c4872157db830bf070531f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 26 Jun 2022 14:41:06 +0300 Subject: [PATCH 046/238] self-leave logic --- .../#guild_id/members/#member_id/index.ts | 22 ++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index 348362923..756b89559 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -1,5 +1,5 @@ import { Request, Response, Router } from "express"; -import { Member, getPermission, Role, GuildMemberUpdateEvent, emitEvent, Sticker, Emoji, Guild } from "@fosscord/util"; +import { Member, getPermission, getRights, Role, GuildMemberUpdateEvent, emitEvent, Sticker, Emoji, Rights, Guild } from "@fosscord/util"; import { HTTPError } from "lambert-server"; import { route } from "@fosscord/api"; @@ -51,9 +51,16 @@ router.patch("/", route({ body: "MemberChangeSchema" }), async (req: Request, re router.put("/", route({}), async (req: Request, res: Response) => { // TODO: Lurker mode + + const rights = await getRights(req.user_id); let { guild_id, member_id } = req.params; - if (member_id === "@me") member_id = req.user_id; + if (member_id === "@me") { + member_id = req.user_id; + rights.hasThrow("JOIN_GUILDS"); + } else { + // TODO: join others by controller + } var guild = await Guild.findOneOrFail({ where: { id: guild_id } }); @@ -71,7 +78,16 @@ router.put("/", route({}), async (req: Request, res: Response) => { res.send({...guild, emojis: emoji, roles: roles, stickers: stickers}); }); -router.delete("/", route({ permission: "KICK_MEMBERS" }), async (req: Request, res: Response) => { +router.delete("/", route(), async (req: Request, res: Response) => { + const permission = await getPermission(req.user_id); + const rights = await getRights(req.user_id); + if (member_id !== "@me" || member_id === req.user_id) { + // TODO: unless force-joined + rights.hasThrow("SELF_LEAVE_GUILDS"); + } else { + rights.hasThrow("KICK_BAN_MEMBERS"); + permission.hasThrow("KICK_MEMBERS"); + } const { guild_id, member_id } = req.params; await Member.removeFromGuild(member_id, guild_id); From cecd9f6e827f71054201a4a7784aaf15b1aa800a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sun, 26 Jun 2022 14:42:06 +0300 Subject: [PATCH 047/238] fix the wrong name --- api/src/routes/guilds/#guild_id/members/#member_id/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index 756b89559..38f2a5294 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -83,7 +83,7 @@ router.delete("/", route(), async (req: Request, res: Response) => { const rights = await getRights(req.user_id); if (member_id !== "@me" || member_id === req.user_id) { // TODO: unless force-joined - rights.hasThrow("SELF_LEAVE_GUILDS"); + rights.hasThrow("SELF_LEAVE_GROUPS"); } else { rights.hasThrow("KICK_BAN_MEMBERS"); permission.hasThrow("KICK_MEMBERS"); From d834b52fc4f9179acaafa7bce788f15b4e2c896e Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sun, 26 Jun 2022 23:33:30 +1000 Subject: [PATCH 048/238] Fix compile errors in latest --- .../#guild_id/members/#member_id/index.ts | 24 +++++++++++-------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index 38f2a5294..c285abb32 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -51,7 +51,7 @@ router.patch("/", route({ body: "MemberChangeSchema" }), async (req: Request, re router.put("/", route({}), async (req: Request, res: Response) => { // TODO: Lurker mode - + const rights = await getRights(req.user_id); let { guild_id, member_id } = req.params; @@ -59,28 +59,33 @@ router.put("/", route({}), async (req: Request, res: Response) => { member_id = req.user_id; rights.hasThrow("JOIN_GUILDS"); } else { - // TODO: join others by controller + // TODO: join others by controller } var guild = await Guild.findOneOrFail({ - where: { id: guild_id } }); + where: { id: guild_id } + }); var emoji = await Emoji.find({ - where: { guild_id: guild_id } }); + where: { guild_id: guild_id } + }); var roles = await Role.find({ - where: { guild_id: guild_id } }); + where: { guild_id: guild_id } + }); var stickers = await Sticker.find({ - where: { guild_id: guild_id } }); - + where: { guild_id: guild_id } + }); + await Member.addToGuild(member_id, guild_id); - res.send({...guild, emojis: emoji, roles: roles, stickers: stickers}); + res.send({ ...guild, emojis: emoji, roles: roles, stickers: stickers }); }); -router.delete("/", route(), async (req: Request, res: Response) => { +router.delete("/", route({}), async (req: Request, res: Response) => { const permission = await getPermission(req.user_id); const rights = await getRights(req.user_id); + const { guild_id, member_id } = req.params; if (member_id !== "@me" || member_id === req.user_id) { // TODO: unless force-joined rights.hasThrow("SELF_LEAVE_GROUPS"); @@ -88,7 +93,6 @@ router.delete("/", route(), async (req: Request, res: Response) => { rights.hasThrow("KICK_BAN_MEMBERS"); permission.hasThrow("KICK_MEMBERS"); } - const { guild_id, member_id } = req.params; await Member.removeFromGuild(member_id, guild_id); res.sendStatus(204); From 11f7d9da78c464f58a347171bed0f93cb8cadcee Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 2 Jul 2022 18:55:18 +1000 Subject: [PATCH 049/238] Skip check for rate limit bypass if no user id is provided --- api/src/middlewares/RateLimit.ts | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index ca6de98fa..13f1602cd 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -46,12 +46,14 @@ export default function rateLimit(opts: { }): any { return async (req: Request, res: Response, next: NextFunction): Promise => { // exempt user? if so, immediately short circuit - const rights = await getRights(req.user_id); - if (rights.has("BYPASS_RATE_LIMITS")) return; - + if (req.user_id) { + const rights = await getRights(req.user_id); + if (rights.has("BYPASS_RATE_LIMITS")) return; + } + const bucket_id = opts.bucket || req.originalUrl.replace(API_PREFIX_TRAILING_SLASH, ""); var executor_id = getIpAdress(req); - if (!opts.onlyIp && req.user_id) executor_id = req.user_id; + if (!opts.onlyIp && req.user_id) executor_id = req.user_id; var max_hits = opts.count; if (opts.bot && req.user_bot) max_hits = opts.bot; @@ -161,7 +163,7 @@ export async function initRateLimits(app: Router) { app.use("/auth/register", rateLimit({ onlyIp: true, success: true, ...routes.auth.register })); } -async function hitRoute(opts: { executor_id: string; bucket_id: string; max_hits: number; window: number }) { +async function hitRoute(opts: { executor_id: string; bucket_id: string; max_hits: number; window: number; }) { const id = opts.executor_id + opts.bucket_id; var limit = Cache.get(id); if (!limit) { From bed535d041b1bf868a4edab83ded25e9a25cf5b7 Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 00:14:26 +1000 Subject: [PATCH 050/238] Create role subdirectory and add GET api route --- .../guilds/#guild_id/roles/#role_id/index.ts | 145 ++++++++++++++++++ .../#guild_id/{roles.ts => roles/index.ts} | 0 2 files changed, 145 insertions(+) create mode 100644 api/src/routes/guilds/#guild_id/roles/#role_id/index.ts rename api/src/routes/guilds/#guild_id/{roles.ts => roles/index.ts} (100%) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts new file mode 100644 index 000000000..69c2143d8 --- /dev/null +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -0,0 +1,145 @@ +import { Router, Request, Response } from "express"; +import { + Role, + getPermission, + Member, + GuildRoleCreateEvent, + GuildRoleUpdateEvent, + GuildRoleDeleteEvent, + emitEvent, + Config, + DiscordApiErrors, + handleFile +} from "@fosscord/util"; +import { route } from "@fosscord/api"; +import {RoleModifySchema, RolePositionUpdateSchema} from '../' + +const router = Router(); + +router.get("/",route({}), async (req: Request, res: Response) => { + const { guild_id, role_id } = req.params + await Member.IsInGuildOrFail(req.user_id, guild_id); + const role = await Role.find({ guild_id: guild_id }).find((r: {id: string}) => r.id === role_id); + return res.json(role); +}); + +// router.post("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { +// const guild_id = req.params.guild_id; +// const body = req.body as RoleModifySchema; + +// const role_count = await Role.count({ guild_id }); +// const { maxRoles } = Config.get().limits.guild; + +// if (role_count > maxRoles) throw DiscordApiErrors.MAXIMUM_ROLES.withParams(maxRoles); + +// const role = new Role({ +// // values before ...body are default and can be overriden +// position: 0, +// hoist: false, +// color: 0, +// mentionable: false, +// ...body, +// guild_id: guild_id, +// managed: false, +// permissions: String(req.permission!.bitfield & BigInt(body.permissions || "0")), +// tags: undefined, +// icon: null, +// unicode_emoji: null +// }); + +// await Promise.all([ +// role.save(), +// emitEvent({ +// event: "GUILD_ROLE_CREATE", +// guild_id, +// data: { +// guild_id, +// role: role +// } +// } as GuildRoleCreateEvent) +// ]); + +// res.json(role); +// }); + +// router.delete("/:role_id", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { +// const guild_id = req.params.guild_id; +// const { role_id } = req.params; +// if (role_id === guild_id) throw new HTTPError("You can't delete the @everyone role"); + +// await Promise.all([ +// Role.delete({ +// id: role_id, +// guild_id: guild_id +// }), +// emitEvent({ +// event: "GUILD_ROLE_DELETE", +// guild_id, +// data: { +// guild_id, +// role_id +// } +// } as GuildRoleDeleteEvent) +// ]); + +// res.sendStatus(204); +// }); + +// // TODO: check role hierarchy + +// router.patch("/:role_id", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { +// const { role_id, guild_id } = req.params; +// const body = req.body as RoleModifySchema; + +// if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); + +// const role = new Role({ +// ...body, +// id: role_id, +// guild_id, +// permissions: String(req.permission!.bitfield & BigInt(body.permissions || "0")) +// }); + +// await Promise.all([ +// role.save(), +// emitEvent({ +// event: "GUILD_ROLE_UPDATE", +// guild_id, +// data: { +// guild_id, +// role +// } +// } as GuildRoleUpdateEvent) +// ]); + +// res.json(role); +// }); + +// router.patch("/", route({ body: "RolePositionUpdateSchema" }), async (req: Request, res: Response) => { +// const { guild_id } = req.params; +// const body = req.body as RolePositionUpdateSchema; + +// const perms = await getPermission(req.user_id, guild_id); +// perms.hasThrow("MANAGE_ROLES"); + +// await Promise.all(body.map(async (x) => Role.update({ guild_id, id: x.id }, { position: x.position }))); + +// const roles = await Role.find({ where: body.map((x) => ({ id: x.id, guild_id })) }); + +// await Promise.all( +// roles.map((x) => +// emitEvent({ +// event: "GUILD_ROLE_UPDATE", +// guild_id, +// data: { +// guild_id, +// role: x +// } +// } as GuildRoleUpdateEvent) +// ) +// ); + +// res.json(roles); +// }); + +export default router; diff --git a/api/src/routes/guilds/#guild_id/roles.ts b/api/src/routes/guilds/#guild_id/roles/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/roles.ts rename to api/src/routes/guilds/#guild_id/roles/index.ts From 04f22cbfd0c522770164be3f27c6dffef595e250 Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 00:19:33 +1000 Subject: [PATCH 051/238] Fix compile error in get request --- .../guilds/#guild_id/roles/#role_id/index.ts | 46 ++----------------- 1 file changed, 4 insertions(+), 42 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 69c2143d8..f01b81c99 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -19,52 +19,14 @@ const router = Router(); router.get("/",route({}), async (req: Request, res: Response) => { const { guild_id, role_id } = req.params await Member.IsInGuildOrFail(req.user_id, guild_id); - const role = await Role.find({ guild_id: guild_id }).find((r: {id: string}) => r.id === role_id); + const roles = await Role.find({ guild_id: guild_id }) + const role = roles.find((r: {id: string}) => r.id === role_id); return res.json(role); }); -// router.post("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { -// const guild_id = req.params.guild_id; -// const body = req.body as RoleModifySchema; -// const role_count = await Role.count({ guild_id }); -// const { maxRoles } = Config.get().limits.guild; - -// if (role_count > maxRoles) throw DiscordApiErrors.MAXIMUM_ROLES.withParams(maxRoles); - -// const role = new Role({ -// // values before ...body are default and can be overriden -// position: 0, -// hoist: false, -// color: 0, -// mentionable: false, -// ...body, -// guild_id: guild_id, -// managed: false, -// permissions: String(req.permission!.bitfield & BigInt(body.permissions || "0")), -// tags: undefined, -// icon: null, -// unicode_emoji: null -// }); - -// await Promise.all([ -// role.save(), -// emitEvent({ -// event: "GUILD_ROLE_CREATE", -// guild_id, -// data: { -// guild_id, -// role: role -// } -// } as GuildRoleCreateEvent) -// ]); - -// res.json(role); -// }); - -// router.delete("/:role_id", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { -// const guild_id = req.params.guild_id; -// const { role_id } = req.params; +// router.delete("/", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { +// const { guild_id, role_id } = req.params; // if (role_id === guild_id) throw new HTTPError("You can't delete the @everyone role"); // await Promise.all([ From 9f8aa049c9da9db0ad7095324d434bbd3a815efe Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 00:42:03 +1000 Subject: [PATCH 052/238] Move role_id specific api routes to correct file --- .../guilds/#guild_id/roles/#role_id/index.ts | 123 +++++++----------- .../routes/guilds/#guild_id/roles/index.ts | 53 -------- 2 files changed, 46 insertions(+), 130 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index f01b81c99..88c1219b0 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -1,18 +1,15 @@ import { Router, Request, Response } from "express"; import { Role, - getPermission, Member, - GuildRoleCreateEvent, GuildRoleUpdateEvent, GuildRoleDeleteEvent, emitEvent, - Config, - DiscordApiErrors, - handleFile + handleFile } from "@fosscord/util"; import { route } from "@fosscord/api"; -import {RoleModifySchema, RolePositionUpdateSchema} from '../' +import { HTTPError } from "lambert-server"; +import {RoleModifySchema} from '../' const router = Router(); @@ -24,84 +21,56 @@ router.get("/",route({}), async (req: Request, res: Response) => { return res.json(role); }); +router.delete("/", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { + const { guild_id, role_id } = req.params; + if (role_id === guild_id) throw new HTTPError("You can't delete the @everyone role"); -// router.delete("/", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { -// const { guild_id, role_id } = req.params; -// if (role_id === guild_id) throw new HTTPError("You can't delete the @everyone role"); + await Promise.all([ + Role.delete({ + id: role_id, + guild_id: guild_id + }), + emitEvent({ + event: "GUILD_ROLE_DELETE", + guild_id, + data: { + guild_id, + role_id + } + } as GuildRoleDeleteEvent) + ]); -// await Promise.all([ -// Role.delete({ -// id: role_id, -// guild_id: guild_id -// }), -// emitEvent({ -// event: "GUILD_ROLE_DELETE", -// guild_id, -// data: { -// guild_id, -// role_id -// } -// } as GuildRoleDeleteEvent) -// ]); + res.sendStatus(204); +}); -// res.sendStatus(204); -// }); +// TODO: check role hierarchy -// // TODO: check role hierarchy +router.patch("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { + const { role_id, guild_id } = req.params; + const body = req.body as RoleModifySchema; -// router.patch("/:role_id", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { -// const { role_id, guild_id } = req.params; -// const body = req.body as RoleModifySchema; + if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); -// if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); + const role = new Role({ + ...body, + id: role_id, + guild_id, + permissions: String(req.permission!.bitfield & BigInt(body.permissions || "0")) + }); -// const role = new Role({ -// ...body, -// id: role_id, -// guild_id, -// permissions: String(req.permission!.bitfield & BigInt(body.permissions || "0")) -// }); + await Promise.all([ + role.save(), + emitEvent({ + event: "GUILD_ROLE_UPDATE", + guild_id, + data: { + guild_id, + role + } + } as GuildRoleUpdateEvent) + ]); -// await Promise.all([ -// role.save(), -// emitEvent({ -// event: "GUILD_ROLE_UPDATE", -// guild_id, -// data: { -// guild_id, -// role -// } -// } as GuildRoleUpdateEvent) -// ]); - -// res.json(role); -// }); - -// router.patch("/", route({ body: "RolePositionUpdateSchema" }), async (req: Request, res: Response) => { -// const { guild_id } = req.params; -// const body = req.body as RolePositionUpdateSchema; - -// const perms = await getPermission(req.user_id, guild_id); -// perms.hasThrow("MANAGE_ROLES"); - -// await Promise.all(body.map(async (x) => Role.update({ guild_id, id: x.id }, { position: x.position }))); - -// const roles = await Role.find({ where: body.map((x) => ({ id: x.id, guild_id })) }); - -// await Promise.all( -// roles.map((x) => -// emitEvent({ -// event: "GUILD_ROLE_UPDATE", -// guild_id, -// data: { -// guild_id, -// role: x -// } -// } as GuildRoleUpdateEvent) -// ) -// ); - -// res.json(roles); -// }); + res.json(role); +}); export default router; diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index b6894e3f2..534651054 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -81,59 +81,6 @@ router.post("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }) res.json(role); }); -router.delete("/:role_id", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { - const guild_id = req.params.guild_id; - const { role_id } = req.params; - if (role_id === guild_id) throw new HTTPError("You can't delete the @everyone role"); - - await Promise.all([ - Role.delete({ - id: role_id, - guild_id: guild_id - }), - emitEvent({ - event: "GUILD_ROLE_DELETE", - guild_id, - data: { - guild_id, - role_id - } - } as GuildRoleDeleteEvent) - ]); - - res.sendStatus(204); -}); - -// TODO: check role hierarchy - -router.patch("/:role_id", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { - const { role_id, guild_id } = req.params; - const body = req.body as RoleModifySchema; - - if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); - - const role = new Role({ - ...body, - id: role_id, - guild_id, - permissions: String(req.permission!.bitfield & BigInt(body.permissions || "0")) - }); - - await Promise.all([ - role.save(), - emitEvent({ - event: "GUILD_ROLE_UPDATE", - guild_id, - data: { - guild_id, - role - } - } as GuildRoleUpdateEvent) - ]); - - res.json(role); -}); - router.patch("/", route({ body: "RolePositionUpdateSchema" }), async (req: Request, res: Response) => { const { guild_id } = req.params; const body = req.body as RolePositionUpdateSchema; From 5dc1479431bb90d91443c3b08b73890fc96b22bc Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 01:03:35 +1000 Subject: [PATCH 053/238] Simplify role query as per code review --- api/src/routes/guilds/#guild_id/roles/#role_id/index.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 88c1219b0..2c1a4c7e5 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -16,8 +16,7 @@ const router = Router(); router.get("/",route({}), async (req: Request, res: Response) => { const { guild_id, role_id } = req.params await Member.IsInGuildOrFail(req.user_id, guild_id); - const roles = await Role.find({ guild_id: guild_id }) - const role = roles.find((r: {id: string}) => r.id === role_id); + const role = await Role.find({ guild_id, id: role_id }) return res.json(role); }); From 73416102a039714a7e16f21692cd6ec37ec9fb89 Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 01:04:16 +1000 Subject: [PATCH 054/238] Add semicolon --- api/src/routes/guilds/#guild_id/roles/#role_id/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 2c1a4c7e5..79cf39cc0 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -16,7 +16,7 @@ const router = Router(); router.get("/",route({}), async (req: Request, res: Response) => { const { guild_id, role_id } = req.params await Member.IsInGuildOrFail(req.user_id, guild_id); - const role = await Role.find({ guild_id, id: role_id }) + const role = await Role.find({ guild_id, id: role_id }); return res.json(role); }); From 078c87ae17c66db5b01bf38c47d573ac298da124 Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 01:08:12 +1000 Subject: [PATCH 055/238] Ensure query fails if role with specified id does not exist --- api/src/routes/guilds/#guild_id/roles/#role_id/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 79cf39cc0..c9a4f662c 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -16,7 +16,7 @@ const router = Router(); router.get("/",route({}), async (req: Request, res: Response) => { const { guild_id, role_id } = req.params await Member.IsInGuildOrFail(req.user_id, guild_id); - const role = await Role.find({ guild_id, id: role_id }); + const role = await Role.findOneOrFail({ guild_id, id: role_id }); return res.json(role); }); From d47c0d6a82ff900c9d9b9a37f726c7cff6fcec9b Mon Sep 17 00:00:00 2001 From: LachlanCourt Date: Tue, 5 Jul 2022 01:23:54 +1000 Subject: [PATCH 056/238] Format changed files --- .../guilds/#guild_id/roles/#role_id/index.ts | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index c9a4f662c..2ad01682c 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -1,21 +1,14 @@ import { Router, Request, Response } from "express"; -import { - Role, - Member, - GuildRoleUpdateEvent, - GuildRoleDeleteEvent, - emitEvent, - handleFile -} from "@fosscord/util"; +import { Role, Member, GuildRoleUpdateEvent, GuildRoleDeleteEvent, emitEvent, handleFile } from "@fosscord/util"; import { route } from "@fosscord/api"; import { HTTPError } from "lambert-server"; -import {RoleModifySchema} from '../' +import { RoleModifySchema } from "../"; const router = Router(); -router.get("/",route({}), async (req: Request, res: Response) => { - const { guild_id, role_id } = req.params - await Member.IsInGuildOrFail(req.user_id, guild_id); +router.get("/", route({}), async (req: Request, res: Response) => { + const { guild_id, role_id } = req.params; + await Member.IsInGuildOrFail(req.user_id, guild_id); const role = await Role.findOneOrFail({ guild_id, id: role_id }); return res.json(role); }); @@ -48,7 +41,7 @@ router.patch("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" } const { role_id, guild_id } = req.params; const body = req.body as RoleModifySchema; - if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); + if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); const role = new Role({ ...body, From 0095318a2508e3e0c64501dadce5fff1c1997631 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 2 Jul 2022 19:28:35 +1000 Subject: [PATCH 057/238] Typescript-json-schema does not crawl extends --- api/src/routes/channels/#channel_id/permissions.ts | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/api/src/routes/channels/#channel_id/permissions.ts index 2eded8530..adf3cc401 100644 --- a/api/src/routes/channels/#channel_id/permissions.ts +++ b/api/src/routes/channels/#channel_id/permissions.ts @@ -16,7 +16,14 @@ const router: Router = Router(); // TODO: Only permissions your bot has in the guild or channel can be allowed/denied (unless your bot has a MANAGE_ROLES overwrite in the channel) -export interface ChannelPermissionOverwriteSchema extends ChannelPermissionOverwrite {} +// export interface ChannelPermissionOverwriteSchema extends ChannelPermissionOverwrite {} +// TODO: typescript-json-schema does not like extending types +export interface ChannelPermissionOverwriteSchema { + allow: string; + deny: string; + id: string; + type: ChannelPermissionOverwriteType; +} router.put( "/:overwrite_id", From 7d98ef972729c551822c290ad768aa5c35707e36 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 2 Jul 2022 20:41:40 +1000 Subject: [PATCH 058/238] Filter out schemas that block generation instead, and also include util in files --- api/assets/schemas.json | 2547 +++++++++++++---- api/scripts/generate_schema.js | 22 +- .../channels/#channel_id/permissions.ts | 9 +- 3 files changed, 2042 insertions(+), 536 deletions(-) diff --git a/api/assets/schemas.json b/api/assets/schemas.json index 7a96be3cc..a930938f4 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -1,181 +1,95 @@ { - "LoginSchema": { + "MessageCreateSchema": { "type": "object", "properties": { - "login": { + "content": { "type": "string" }, - "password": { + "nonce": { "type": "string" }, - "undelete": { + "tts": { "type": "boolean" }, - "captcha_key": { + "flags": { "type": "string" }, - "login_source": { - "type": "string" - }, - "gift_code_sku_id": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "login", - "password" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "RegisterSchema": { - "type": "object", - "properties": { - "username": { - "minLength": 2, - "maxLength": 32, - "type": "string" - }, - "password": { - "minLength": 1, - "maxLength": 72, - "type": "string" - }, - "consent": { - "type": "boolean" - }, - "email": { - "format": "email", - "type": "string" - }, - "fingerprint": { - "type": "string" - }, - "invite": { - "type": "string" - }, - "date_of_birth": { - "type": "string" - }, - "gift_code_sku_id": { - "type": "string" - }, - "captcha_key": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "consent", - "username" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { + "embeds": { "type": "array", "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { + "$ref": "#/definitions/Embed" + } + }, + "embed": { + "$ref": "#/definitions/Embed" + }, + "allowed_mentions": { + "type": "object", + "properties": { + "parse": { + "type": "array", + "items": { "type": "string" } }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] + "roles": { + "type": "array", + "items": { + "type": "string" + } + }, + "users": { + "type": "array", + "items": { + "type": "string" + } + }, + "replied_user": { + "type": "boolean" + } + }, + "additionalProperties": false + }, + "message_reference": { + "type": "object", + "properties": { + "message_id": { + "type": "string" + }, + "channel_id": { + "type": "string" + }, + "guild_id": { + "type": "string" + }, + "fail_if_not_exists": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "channel_id", + "message_id" + ] + }, + "payload_json": { + "type": "string" + }, + "file": {}, + "attachments": { + "description": "TODO: we should create an interface for attachments\nTODO: OpenWAAO<-->attachment-style metadata conversion", + "type": "array", + "items": {} + }, + "sticker_ids": { + "type": "array", + "items": { + "type": "string" } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" } }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -306,6 +220,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -321,6 +247,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -472,104 +400,24 @@ }, "$schema": "http://json-schema.org/draft-07/schema#" }, - "MessageCreateSchema": { + "RouteResponse": { "type": "object", "properties": { - "content": { - "type": "string" + "status": { + "type": "integer" }, - "nonce": { - "type": "string" - }, - "tts": { - "type": "boolean" - }, - "flags": { - "type": "string" - }, - "embeds": { - "type": "array", - "items": { - "$ref": "#/definitions/Embed" - } - }, - "embed": { - "$ref": "#/definitions/Embed" - }, - "allowed_mentions": { - "type": "object", - "properties": { - "parse": { - "type": "array", - "items": { - "type": "string" - } - }, - "roles": { - "type": "array", - "items": { - "type": "string" - } - }, - "users": { - "type": "array", - "items": { - "type": "string" - } - }, - "replied_user": { - "type": "boolean" - } - }, - "additionalProperties": false - }, - "message_reference": { - "type": "object", - "properties": { - "message_id": { - "type": "string" - }, - "channel_id": { - "type": "string" - }, - "guild_id": { - "type": "string" - }, - "fail_if_not_exists": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "channel_id", - "message_id" - ] - }, - "payload_json": { - "type": "string" - }, - "file": {}, - "attachments": { - "type": "array", - "items": {} - }, - "sticker_ids": { + "body": { "type": "array", "items": { "type": "string" } + }, + "headers": { + "$ref": "#/definitions/Record" } }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -700,6 +548,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -715,6 +575,1107 @@ 11, 12, 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "LoginSchema": { + "type": "object", + "properties": { + "login": { + "type": "string" + }, + "password": { + "type": "string" + }, + "undelete": { + "type": "boolean" + }, + "captcha_key": { + "type": "string" + }, + "login_source": { + "type": "string" + }, + "gift_code_sku_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "login", + "password" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "RegisterSchema": { + "type": "object", + "properties": { + "username": { + "minLength": 2, + "maxLength": 32, + "type": "string" + }, + "password": { + "minLength": 1, + "maxLength": 72, + "type": "string" + }, + "consent": { + "type": "boolean" + }, + "email": { + "format": "email", + "type": "string" + }, + "fingerprint": { + "type": "string" + }, + "invite": { + "type": "string" + }, + "date_of_birth": { + "type": "string" + }, + "gift_code_sku_id": { + "type": "string" + }, + "captcha_key": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "consent", + "username" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false, + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, 2, 255, 3, @@ -899,14 +1860,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -1037,6 +1990,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -1052,6 +2017,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -1215,14 +2182,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -1353,6 +2312,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -1368,6 +2339,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -1534,14 +2507,6 @@ "messages" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -1672,6 +2637,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -1687,6 +2664,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -1862,14 +2841,6 @@ "type" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -2000,6 +2971,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -2015,6 +2998,334 @@ 11, 12, 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "PurgeSchema": { + "type": "object", + "properties": { + "before": { + "type": "string" + }, + "after": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "after", + "before" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, 2, 255, 3, @@ -2183,14 +3494,6 @@ "name" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -2321,6 +3624,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -2336,6 +3651,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -2528,14 +3845,6 @@ "url" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -2666,6 +3975,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -2681,6 +4002,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -2844,14 +4167,6 @@ "url" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -2982,6 +4297,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -2997,6 +4324,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -3160,14 +4489,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -3298,6 +4619,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -3313,6 +4646,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -3494,14 +4829,6 @@ "user_id" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -3632,6 +4959,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -3647,6 +4986,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -3825,14 +5166,6 @@ "user_id" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -3963,6 +5296,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -3978,6 +5323,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -4153,14 +5500,6 @@ ] }, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -4291,6 +5630,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -4306,6 +5657,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -4484,14 +5837,6 @@ "image" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -4622,6 +5967,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -4637,6 +5994,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -4803,14 +6162,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -4941,6 +6292,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -4956,6 +6319,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -5144,14 +6509,6 @@ "name" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -5282,6 +6639,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -5297,6 +6666,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -5524,14 +6895,6 @@ "name" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -5662,6 +7025,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -5677,6 +7052,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -5840,14 +7217,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -5978,6 +7347,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -5993,6 +7374,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -6156,14 +7539,6 @@ "nick" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -6294,6 +7669,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -6309,6 +7696,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -6472,14 +7861,6 @@ "days" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -6610,6 +7991,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -6625,6 +8018,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -6806,14 +8201,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -6944,6 +8331,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -6959,6 +8358,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -7129,14 +8530,6 @@ ] }, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -7267,6 +8660,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -7282,6 +8687,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -7456,14 +8863,6 @@ "tags" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -7594,6 +8993,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -7609,6 +9020,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -7775,14 +9188,6 @@ "name" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -7913,6 +9318,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -7928,6 +9345,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -8094,14 +9513,6 @@ "name" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -8232,6 +9643,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -8247,6 +9670,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -8409,14 +9834,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -8547,6 +9964,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -8562,6 +9991,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -8744,14 +10175,6 @@ "channel_id" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -8882,6 +10305,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -8897,6 +10332,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -9086,14 +10523,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -9224,6 +10653,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -9239,6 +10680,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -9406,14 +10849,6 @@ "enabled" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -9544,6 +10979,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -9559,6 +11006,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -9728,14 +11177,6 @@ "name" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -9866,6 +11307,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -9881,6 +11334,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -10056,14 +11511,6 @@ "user" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -10194,6 +11641,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -10209,6 +11668,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -10390,14 +11851,6 @@ "object" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -10528,6 +11981,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -10543,6 +12008,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -10712,14 +12179,6 @@ "recipients" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -10850,6 +12309,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -10865,6 +12336,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -11017,7 +12490,6 @@ "$schema": "http://json-schema.org/draft-07/schema#" }, "UserModifySchema": { - "additionalProperties": false, "type": "object", "properties": { "username": { @@ -11054,15 +12526,8 @@ "type": "string" } }, + "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -11193,6 +12658,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -11208,6 +12685,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -11374,14 +12853,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -11512,6 +12983,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -11527,6 +13010,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -11694,14 +13179,6 @@ "username" ], "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -11832,6 +13309,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -11847,6 +13336,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, @@ -12172,14 +13663,6 @@ }, "additionalProperties": false, "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "Embed": { "type": "object", "properties": { @@ -12310,6 +13793,18 @@ }, "additionalProperties": false }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, "ChannelModifySchema": { "type": "object", "properties": { @@ -12325,6 +13820,8 @@ 11, 12, 13, + 14, + 15, 2, 255, 3, diff --git a/api/scripts/generate_schema.js b/api/scripts/generate_schema.js index 7e742ec11..b56c3fbc5 100644 --- a/api/scripts/generate_schema.js +++ b/api/scripts/generate_schema.js @@ -27,7 +27,16 @@ const Excluded = [ "Response", "e.Response", "request.Response", - "supertest.Response" + "supertest.Response", + + // TODO: Figure out how to exclude schemas from node_modules? + "SomeJSONSchema", + "UncheckedPartialSchema", + "PartialSchema", + "UncheckedPropertiesSchema", + "PropertiesSchema", + "AsyncSchema", + "AnySchema", ]; function modify(obj) { @@ -39,11 +48,18 @@ function modify(obj) { } function main() { - const program = TJS.getProgramFromFiles(walk(path.join(__dirname, "..", "src", "routes")), compilerOptions); + const files = [ + ...walk(path.join(__dirname, "..", "src", "routes")), + ...walk(path.join(__dirname, "..", "..", "util", "src")), + ]; + const program = TJS.getProgramFromFiles( + files, + compilerOptions + ); const generator = TJS.buildGenerator(program, settings); if (!generator || !program) return; - const schemas = generator.getUserSymbols().filter((x) => (x.endsWith("Schema") || x.endsWith("Response")) && !Excluded.includes(x)); + let schemas = generator.getUserSymbols().filter((x) => (x.endsWith("Schema") || x.endsWith("Response")) && !Excluded.includes(x)); console.log(schemas); var definitions = {}; diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/api/src/routes/channels/#channel_id/permissions.ts index adf3cc401..2eded8530 100644 --- a/api/src/routes/channels/#channel_id/permissions.ts +++ b/api/src/routes/channels/#channel_id/permissions.ts @@ -16,14 +16,7 @@ const router: Router = Router(); // TODO: Only permissions your bot has in the guild or channel can be allowed/denied (unless your bot has a MANAGE_ROLES overwrite in the channel) -// export interface ChannelPermissionOverwriteSchema extends ChannelPermissionOverwrite {} -// TODO: typescript-json-schema does not like extending types -export interface ChannelPermissionOverwriteSchema { - allow: string; - deny: string; - id: string; - type: ChannelPermissionOverwriteType; -} +export interface ChannelPermissionOverwriteSchema extends ChannelPermissionOverwrite {} router.put( "/:overwrite_id", From f4368d6aa2be3c90de29db9455e3b0bbdf9cb1dc Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 9 Jul 2022 14:15:15 +1000 Subject: [PATCH 059/238] Allow multiple attachments in messages --- api/assets/schemas.json | 1350 +++++++++++++++++ .../channels/#channel_id/messages/index.ts | 27 +- 2 files changed, 1366 insertions(+), 11 deletions(-) diff --git a/api/assets/schemas.json b/api/assets/schemas.json index 7a96be3cc..7cd2bbbb0 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -1,4 +1,739 @@ { + "MessageCreateSchema": { + "type": "object", + "properties": { + "type": { + "type": "integer" + }, + "content": { + "type": "string" + }, + "nonce": { + "type": "string" + }, + "channel_id": { + "type": "string" + }, + "tts": { + "type": "boolean" + }, + "flags": { + "type": "string" + }, + "embeds": { + "type": "array", + "items": { + "$ref": "#/definitions/Embed" + } + }, + "embed": { + "$ref": "#/definitions/Embed" + }, + "allowed_mentions": { + "type": "object", + "properties": { + "parse": { + "type": "array", + "items": { + "type": "string" + } + }, + "roles": { + "type": "array", + "items": { + "type": "string" + } + }, + "users": { + "type": "array", + "items": { + "type": "string" + } + }, + "replied_user": { + "type": "boolean" + } + }, + "additionalProperties": false + }, + "message_reference": { + "type": "object", + "properties": { + "message_id": { + "type": "string" + }, + "channel_id": { + "type": "string" + }, + "guild_id": { + "type": "string" + }, + "fail_if_not_exists": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "channel_id", + "message_id" + ] + }, + "payload_json": { + "type": "string" + }, + "file": {}, + "attachments": { + "description": "TODO: we should create an interface for attachments\nTODO: OpenWAAO<-->attachment-style metadata conversion", + "type": "array", + "items": {} + }, + "sticker_ids": { + "type": "array", + "items": { + "type": "string" + } + } + }, + "additionalProperties": false, + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "RouteResponse": { + "type": "object", + "properties": { + "status": { + "type": "integer" + }, + "body": { + "type": "array", + "items": { + "type": "string" + } + }, + "headers": { + "$ref": "#/definitions/Record" + } + }, + "additionalProperties": false, + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, "LoginSchema": { "type": "object", "properties": { @@ -26,6 +761,621 @@ "login", "password" ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "RegisterSchema": { + "type": "object", + "properties": { + "username": { + "minLength": 2, + "maxLength": 32, + "type": "string" + }, + "password": { + "minLength": 1, + "maxLength": 72, + "type": "string" + }, + "consent": { + "type": "boolean" + }, + "email": { + "format": "email", + "type": "string" + }, + "fingerprint": { + "type": "string" + }, + "invite": { + "type": "string" + }, + "date_of_birth": { + "type": "string" + }, + "gift_code_sku_id": { + "type": "string" + }, + "captcha_key": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "consent", + "username" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "password": { + "type": "string" + }, + "undelete": { + "type": "boolean" + }, + "captcha_key": { + "type": "string" + }, + "login_source": { + "type": "string" + }, + "gift_code_sku_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "login", + "password" + ], "$schema": "http://json-schema.org/draft-07/schema#" }, "RegisterSchema": { diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 2d6a29771..fc2e4575f 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -17,7 +17,7 @@ import { } from "@fosscord/util"; import { HTTPError } from "lambert-server"; import { handleMessage, postHandleMessage, route } from "@fosscord/api"; -import multer from "multer"; +import multer, { Multer } from "multer"; import { FindManyOptions, LessThan, MoreThan } from "typeorm"; import { URL } from "url"; @@ -50,8 +50,10 @@ export function isTextChannel(type: ChannelType): boolean { } export interface MessageCreateSchema { + type?: number; content?: string; nonce?: string; + channel_id?: string; tts?: boolean; flags?: string; embeds?: Embed[]; @@ -161,7 +163,7 @@ const messageUpload = multer({ limits: { fileSize: 1024 * 1024 * 100, fields: 10, - files: 1 + // files: 1 }, storage: multer.memoryStorage() }); // max upload 50 mb @@ -176,7 +178,7 @@ const messageUpload = multer({ // Send message router.post( "/", - messageUpload.single("file"), + messageUpload.any(), async (req, res, next) => { if (req.body.payload_json) { req.body = JSON.parse(req.body.payload_json); @@ -190,19 +192,22 @@ router.post( var body = req.body as MessageCreateSchema; const attachments: Attachment[] = []; - if (req.file) { - try { - const file = await uploadFile(`/attachments/${req.params.channel_id}`, req.file); - attachments.push({ ...file, proxy_url: file.url }); - } catch (error) { - return res.status(400).json(error); - } - } const channel = await Channel.findOneOrFail({ where: { id: channel_id }, relations: ["recipients", "recipients.user"] }); if (!channel.isWritable()) { throw new HTTPError(`Cannot send messages to channel of type ${channel.type}`, 400) } + const files = req.files as Express.Multer.File[] ?? []; + for (var currFile of files) { + try { + const file = await uploadFile(`/attachments/${channel.id}`, currFile); + attachments.push({ ...file, proxy_url: file.url }); + } + catch (error) { + return res.status(400).json(error); + } + } + const embeds = body.embeds || []; if (body.embed) embeds.push(body.embed); let message = await handleMessage({ From 6a78c6561b933631ade04bad8e199a4f811dc2ea Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 9 Jul 2022 14:58:50 +1000 Subject: [PATCH 060/238] Removed unused import tab autocomplete really loves doing this to me --- api/src/routes/channels/#channel_id/messages/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index fc2e4575f..54e6edcc2 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -17,7 +17,7 @@ import { } from "@fosscord/util"; import { HTTPError } from "lambert-server"; import { handleMessage, postHandleMessage, route } from "@fosscord/api"; -import multer, { Multer } from "multer"; +import multer from "multer"; import { FindManyOptions, LessThan, MoreThan } from "typeorm"; import { URL } from "url"; From 2236cf593ccc2426b5bad5f88d0cd64e7e0e4c17 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 9 Jul 2022 16:01:32 +1000 Subject: [PATCH 061/238] * Make max website preview download size for embeds configurable * Fix Message.update call throwing 'Cannot query across one-to-many for property attachments' --- api/src/util/handlers/Message.ts | 9 ++++++--- util/src/entities/Config.ts | 2 ++ 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index e9f0ac55c..48f87dfe0 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -38,7 +38,7 @@ const DEFAULT_FETCH_OPTIONS: any = { headers: { "user-agent": "Mozilla/5.0 (compatible; Fosscord/1.0; +https://github.com/fosscord/fosscord)" }, - size: 1024 * 1024 * 1, + // size: 1024 * 1024 * 5, // grabbed from config later compress: true, method: "GET" }; @@ -154,7 +154,10 @@ export async function postHandleMessage(message: Message) { for (const link of links) { try { - const request = await fetch(link, DEFAULT_FETCH_OPTIONS); + const request = await fetch(link, { + ...DEFAULT_FETCH_OPTIONS, + size: Config.get().limits.message.maxEmbedDownloadSize, + }); const text = await request.text(); const $ = cheerio.load(text); @@ -191,7 +194,7 @@ export async function postHandleMessage(message: Message) { channel_id: message.channel_id, data } as MessageUpdateEvent), - Message.update({ id: message.id, channel_id: message.channel_id }, data) + Message.update({ id: message.id, channel_id: message.channel_id }, { embeds: data.embeds }) ]); } diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts index 063a4d4d9..75ff4a85f 100644 --- a/util/src/entities/Config.ts +++ b/util/src/entities/Config.ts @@ -85,6 +85,7 @@ export interface ConfigValue { maxReactions: number; maxAttachmentSize: number; maxBulkDelete: number; + maxEmbedDownloadSize: number; }; channel: { maxPins: number; @@ -249,6 +250,7 @@ export const DefaultConfigOptions: ConfigValue = { maxTTSCharacters: 200, maxReactions: 20, maxAttachmentSize: 8388608, + maxEmbedDownloadSize: 1024 * 1024 * 5, maxBulkDelete: 100, }, channel: { From 5b912eed5ddfab0f56327a47bb393fbf6f707b7d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 9 Jul 2022 09:50:02 +0300 Subject: [PATCH 062/238] Relax some of the limits --- util/src/entities/Config.ts | 35 +++++++++++++++++------------------ 1 file changed, 17 insertions(+), 18 deletions(-) diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts index 75ff4a85f..3756d6863 100644 --- a/util/src/entities/Config.ts +++ b/util/src/entities/Config.ts @@ -233,30 +233,30 @@ export const DefaultConfigOptions: ConfigValue = { }, limits: { user: { - maxGuilds: 100, - maxUsername: 32, - maxFriends: 1000, + maxGuilds: 1048576, + maxUsername: 127, + maxFriends: 5000, }, guild: { - maxRoles: 250, - maxEmojis: 50, // TODO: max emojis per guild per nitro level - maxMembers: 250000, - maxChannels: 500, - maxChannelsInCategory: 50, - hideOfflineMember: 1000, + maxRoles: 1000, + maxEmojis: 2000, + maxMembers: 25000000, + maxChannels: 65535, + maxChannelsInCategory: 65535, + hideOfflineMember: 3, }, message: { - maxCharacters: 2000, - maxTTSCharacters: 200, - maxReactions: 20, - maxAttachmentSize: 8388608, + maxCharacters: 1048576, + maxTTSCharacters: 160, + maxReactions: 2048, + maxAttachmentSize: 1024 * 1024 * 1024, maxEmbedDownloadSize: 1024 * 1024 * 5, - maxBulkDelete: 100, + maxBulkDelete: 1000, }, channel: { - maxPins: 50, + maxPins: 500, maxTopic: 1024, - maxWebhooks: 10, + maxWebhooks: 100, }, rate: { disabled: true, @@ -265,9 +265,8 @@ export const DefaultConfigOptions: ConfigValue = { window: 5, }, global: { - count: 20, + count: 250, window: 5, - bot: 250, }, error: { count: 10, From 614cfdc85cfa8903bf7432e770bd4aba41c51b5f Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 16 Jul 2022 18:06:43 +1000 Subject: [PATCH 063/238] Send offline group in LazyRequest (#778) * Send offline member group in LazyRequest * Better implementation of offline member group in lazy request * Always display roles separately to online members --- gateway/src/opcodes/LazyRequest.ts | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 2156070fe..2bff1fd37 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -41,6 +41,9 @@ async function getMembers(guild_id: string, range: [number, number]) { .map((m) => m.roles) .flat() .unique((r: Role) => r.id); + member_roles.push(member_roles.splice(member_roles.findIndex(x => x.id == guild_id))[0]); // move @everyone/online to bottom + + const offlineItems = []; for (const role of member_roles) { // @ts-ignore @@ -63,7 +66,7 @@ async function getMembers(guild_id: string, range: [number, number]) { const session = member.user.sessions.first(); // TODO: properly mock/hide offline/invisible status - items.push({ + const item = { member: { ...member, roles, @@ -74,16 +77,35 @@ async function getMembers(guild_id: string, range: [number, number]) { user: { id: member.user.id }, }, }, - }); + } + + if (!member?.user?.sessions || !member.user.sessions.length) { + offlineItems.push(item); + group.count--; + continue; + } + + items.push(item); } members = other_members; } + if (offlineItems.length) { + const group = { + count: offlineItems.length, + id: "offline", + }; + items.push({ group }); + groups.push(group); + + items.push(...offlineItems); + } + return { items, groups, range, - members: items.map((x) => x.member).filter((x) => x), + members: items.map((x) => 'member' in x ? x.member : undefined).filter(x => !!x), }; } From 0a340853090cad4df87d90d3e38e121d90030de9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 16 Jul 2022 11:23:09 +0300 Subject: [PATCH 064/238] Revert "Send offline group in LazyRequest (#778)" (#787) This reverts commit 614cfdc85cfa8903bf7432e770bd4aba41c51b5f. --- gateway/src/opcodes/LazyRequest.ts | 28 +++------------------------- 1 file changed, 3 insertions(+), 25 deletions(-) diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 2bff1fd37..2156070fe 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -41,9 +41,6 @@ async function getMembers(guild_id: string, range: [number, number]) { .map((m) => m.roles) .flat() .unique((r: Role) => r.id); - member_roles.push(member_roles.splice(member_roles.findIndex(x => x.id == guild_id))[0]); // move @everyone/online to bottom - - const offlineItems = []; for (const role of member_roles) { // @ts-ignore @@ -66,7 +63,7 @@ async function getMembers(guild_id: string, range: [number, number]) { const session = member.user.sessions.first(); // TODO: properly mock/hide offline/invisible status - const item = { + items.push({ member: { ...member, roles, @@ -77,35 +74,16 @@ async function getMembers(guild_id: string, range: [number, number]) { user: { id: member.user.id }, }, }, - } - - if (!member?.user?.sessions || !member.user.sessions.length) { - offlineItems.push(item); - group.count--; - continue; - } - - items.push(item); + }); } members = other_members; } - if (offlineItems.length) { - const group = { - count: offlineItems.length, - id: "offline", - }; - items.push({ group }); - groups.push(group); - - items.push(...offlineItems); - } - return { items, groups, range, - members: items.map((x) => 'member' in x ? x.member : undefined).filter(x => !!x), + members: items.map((x) => x.member).filter((x) => x), }; } From 58c90c57f623fe6720d1097d5fbb8d6e4302289e Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 16 Jul 2022 18:35:44 +1000 Subject: [PATCH 065/238] Display offline members in member list (#788) * Send offline member group in LazyRequest * Better implementation of offline member group in lazy request --- gateway/src/opcodes/LazyRequest.ts | 27 ++++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 2156070fe..7503ee614 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -42,6 +42,8 @@ async function getMembers(guild_id: string, range: [number, number]) { .flat() .unique((r: Role) => r.id); + const offlineItems = []; + for (const role of member_roles) { // @ts-ignore const [role_members, other_members] = partition(members, (m: Member) => @@ -63,7 +65,7 @@ async function getMembers(guild_id: string, range: [number, number]) { const session = member.user.sessions.first(); // TODO: properly mock/hide offline/invisible status - items.push({ + const item = { member: { ...member, roles, @@ -74,16 +76,35 @@ async function getMembers(guild_id: string, range: [number, number]) { user: { id: member.user.id }, }, }, - }); + } + + if (!member?.user?.sessions || !member.user.sessions.length) { + offlineItems.push(item); + group.count--; + continue; + } + + items.push(item); } members = other_members; } + if (offlineItems.length) { + const group = { + count: offlineItems.length, + id: "offline", + }; + items.push({ group }); + groups.push(group); + + items.push(...offlineItems); + } + return { items, groups, range, - members: items.map((x) => x.member).filter((x) => x), + members: items.map((x) => 'member' in x ? x.member : undefined).filter(x => !!x), }; } From cf3873d62ff30da691dae7f7424c6365b5a72edc Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 17 Jul 2022 18:52:41 +0200 Subject: [PATCH 066/238] Add local disk caching for fetched assets --- .gitignore | 3 +- .../autoRegister.js | 0 .../fosscord-login.js | 0 api/client_test/index.html | 1 + api/package.json | 2 +- api/src/middlewares/TestClient.ts | 171 +++++++++++------- api/src/util/entities/AssetCacheItem.ts | 16 ++ api/src/util/index.ts | 1 + bundle/package-lock.json | Bin 595773 -> 595957 bytes fosscord-server.code-workspace | 5 +- package-lock.json | Bin 0 -> 825084 bytes 11 files changed, 131 insertions(+), 68 deletions(-) rename api/assets/{preload-plugins => inline-plugins}/autoRegister.js (100%) rename api/assets/{preload-plugins => inline-plugins}/fosscord-login.js (100%) create mode 100644 api/src/util/entities/AssetCacheItem.ts create mode 100644 package-lock.json diff --git a/.gitignore b/.gitignore index b5a8246e2..cc60b3050 100644 --- a/.gitignore +++ b/.gitignore @@ -9,4 +9,5 @@ files/ config.json .vscode/settings.json -api/assets/plugins/*.js \ No newline at end of file +api/assets/plugins/*.js +.idea/ diff --git a/api/assets/preload-plugins/autoRegister.js b/api/assets/inline-plugins/autoRegister.js similarity index 100% rename from api/assets/preload-plugins/autoRegister.js rename to api/assets/inline-plugins/autoRegister.js diff --git a/api/assets/preload-plugins/fosscord-login.js b/api/assets/inline-plugins/fosscord-login.js similarity index 100% rename from api/assets/preload-plugins/fosscord-login.js rename to api/assets/inline-plugins/fosscord-login.js diff --git a/api/client_test/index.html b/api/client_test/index.html index b438b4926..7a4fe6276 100644 --- a/api/client_test/index.html +++ b/api/client_test/index.html @@ -7,6 +7,7 @@ + diff --git a/api/package.json b/api/package.json index 29fa82a10..051666e94 100644 --- a/api/package.json +++ b/api/package.json @@ -48,7 +48,7 @@ "@types/jsonwebtoken": "^8.5.0", "@types/morgan": "^1.9.3", "@types/multer": "^1.4.5", - "@types/node": "^14.17.9", + "@types/node": "^14.18.22", "@types/node-fetch": "^2.5.5", "@types/supertest": "^2.0.11", "@zerollup/ts-transform-paths": "^1.7.18", diff --git a/api/src/middlewares/TestClient.ts b/api/src/middlewares/TestClient.ts index ecf87681a..e52a5e591 100644 --- a/api/src/middlewares/TestClient.ts +++ b/api/src/middlewares/TestClient.ts @@ -1,54 +1,47 @@ import express, { Request, Response, Application } from "express"; -import fs from "fs"; +import fs, { writeFile } from "fs"; import path from "path"; -import fetch, { Response as FetchResponse } from "node-fetch"; +import fetch, { Response as FetchResponse, Headers } from "node-fetch"; import ProxyAgent from 'proxy-agent'; import { Config } from "@fosscord/util"; +import { AssetCacheItem } from "../util/entities/AssetCacheItem" +import { FileLogger } from "typeorm"; export default function TestClient(app: Application) { const agent = new ProxyAgent(); - const assetCache = new Map(); - const indexHTML = fs.readFileSync(path.join(__dirname, "..", "..", "client_test", "index.html"), { encoding: "utf8" }); - - var html = indexHTML; - const CDN_ENDPOINT = (Config.get().cdn.endpointClient || Config.get()?.cdn.endpointPublic || process.env.CDN || "").replace( - /(https?)?(:\/\/?)/g, - "" - ); - const GATEWAY_ENDPOINT = Config.get().gateway.endpointClient || Config.get()?.gateway.endpointPublic || process.env.GATEWAY || ""; - - if (CDN_ENDPOINT) { - html = html.replace(/CDN_HOST: .+/, `CDN_HOST: \`${CDN_ENDPOINT}\`,`); - } - if (GATEWAY_ENDPOINT) { - html = html.replace(/GATEWAY_ENDPOINT: .+/, `GATEWAY_ENDPOINT: \`${GATEWAY_ENDPOINT}\`,`); - } - // inline plugins - var files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "preload-plugins")); - var plugins = ""; - files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); - html = html.replaceAll("", plugins); - - // plugins - files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "plugins")); - plugins = ""; - files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); - html = html.replaceAll("", plugins); - //preload plugins - files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "preload-plugins")); - plugins = ""; - files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); - html = html.replaceAll("", plugins); - - - app.use("/assets", express.static(path.join(__dirname, "..", "..", "assets"))); + //build client page + let html = fs.readFileSync(path.join(__dirname, "..", "..", "client_test", "index.html"), { encoding: "utf8" }); + html = applyEnv(html); + html = applyInlinePlugins(html); + html = applyPlugins(html); + html = applyPreloadPlugins(html); + + //load asset cache + let newAssetCache: Map = new Map(); + if(!fs.existsSync(path.join(__dirname, "..", "..", "assets", "cache"))) { + fs.mkdirSync(path.join(__dirname, "..", "..", "assets", "cache")); + } + if(fs.existsSync(path.join(__dirname, "..", "..", "assets", "cache", "index.json"))) { + let rawdata = fs.readFileSync(path.join(__dirname, "..", "..", "assets", "cache", "index.json")); + newAssetCache = new Map(Object.entries(JSON.parse(rawdata.toString()))); + } + + //define routes + app.use("/assets", express.static(path.join(__dirname, "..", "..", "assets"))); app.get("/assets/:file", async (req: Request, res: Response) => { delete req.headers.host; - var response: FetchResponse; - var buffer: Buffer; - const cache = assetCache.get(req.params.file); - if (!cache) { + let response: FetchResponse; + let buffer: Buffer; + let assetCacheItem: AssetCacheItem = new AssetCacheItem(req.params.file); + if(newAssetCache.has(req.params.file)){ + assetCacheItem = newAssetCache.get(req.params.file)!; + assetCacheItem.Headers.forEach((value: any, name: any) => { + res.set(name, value); + }); + } + else { + console.log(`CACHE MISS! Asset file: ${req.params.file}`); response = await fetch(`https://discord.com/assets/${req.params.file}`, { agent, // @ts-ignore @@ -56,34 +49,24 @@ export default function TestClient(app: Application) { ...req.headers } }); - buffer = await response.buffer(); - } else { - response = cache.response; - buffer = cache.buffer; + + //set cache info + assetCacheItem.Headers = Object.fromEntries(stripHeaders(response.headers)); + assetCacheItem.FilePath = path.join(__dirname, "..", "..", "assets", "cache", req.params.file); + assetCacheItem.Key = req.params.file; + //add to cache and save + newAssetCache.set(req.params.file, assetCacheItem); + fs.writeFileSync(path.join(__dirname, "..", "..", "assets", "cache", "index.json"), JSON.stringify(Object.fromEntries(newAssetCache), null, 4)); + //download file + fs.writeFileSync(assetCacheItem.FilePath, await response.buffer()); } - - response.headers.forEach((value, name) => { - if ( - [ - "content-length", - "content-security-policy", - "strict-transport-security", - "set-cookie", - "transfer-encoding", - "expect-ct", - "access-control-allow-origin", - "content-encoding" - ].includes(name.toLowerCase()) - ) { - return; - } + + assetCacheItem.Headers.forEach((value: string, name: string) => { res.set(name, value); }); - assetCache.set(req.params.file, { buffer, response }); - - return res.send(buffer); + return res.send(fs.readFileSync(assetCacheItem.FilePath)); }); - app.get("/developers*", (req: Request, res: Response) => { + app.get("/developers*", (_req: Request, res: Response) => { const { useTestClient } = Config.get().client; res.set("Cache-Control", "public, max-age=" + 60 * 60 * 24); res.set("content-type", "text/html"); @@ -104,4 +87,62 @@ export default function TestClient(app: Application) { res.send(html); }); + + +} + +function applyEnv(html: string): string { + const CDN_ENDPOINT = (Config.get().cdn.endpointClient || Config.get()?.cdn.endpointPublic || process.env.CDN || "").replace( + /(https?)?(:\/\/?)/g, + "" + ); + const GATEWAY_ENDPOINT = Config.get().gateway.endpointClient || Config.get()?.gateway.endpointPublic || process.env.GATEWAY || ""; + + if (CDN_ENDPOINT) { + html = html.replace(/CDN_HOST: .+/, `CDN_HOST: \`${CDN_ENDPOINT}\`,`); + } + if (GATEWAY_ENDPOINT) { + html = html.replace(/GATEWAY_ENDPOINT: .+/, `GATEWAY_ENDPOINT: \`${GATEWAY_ENDPOINT}\`,`); + } + return html; +} + +function applyPlugins(html: string): string { + // plugins + let files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "plugins")); + let plugins = ""; + files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); + return html.replaceAll("", plugins); +} + +function applyInlinePlugins(html: string): string{ + // inline plugins + let files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "inline-plugins")); + let plugins = ""; + files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n\n`; }); + return html.replaceAll("", plugins); +} + +function applyPreloadPlugins(html: string): string{ + //preload plugins + let files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "preload-plugins")); + let plugins = ""; + files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); + return html.replaceAll("", plugins); +} + +function stripHeaders(headers: Headers): Headers { + [ + "content-length", + "content-security-policy", + "strict-transport-security", + "set-cookie", + "transfer-encoding", + "expect-ct", + "access-control-allow-origin", + "content-encoding" + ].forEach(headerName => { + headers.delete(headerName); + }); + return headers; } \ No newline at end of file diff --git a/api/src/util/entities/AssetCacheItem.ts b/api/src/util/entities/AssetCacheItem.ts new file mode 100644 index 000000000..7fb4e1e61 --- /dev/null +++ b/api/src/util/entities/AssetCacheItem.ts @@ -0,0 +1,16 @@ +import { Headers } from "node-fetch"; + +export class AssetCacheItem { + public Key: string; + public FilePath: string; + public Headers: any; + + constructor(key: string){ + this.Key = key; + } + /*constructor(key: string, filePath: string, headers: Headers) { + this.Key = key; + this.FilePath = filePath; + this.Headers = headers; + }*/ +} \ No newline at end of file diff --git a/api/src/util/index.ts b/api/src/util/index.ts index ffbcf24e7..ac439371b 100644 --- a/api/src/util/index.ts +++ b/api/src/util/index.ts @@ -6,3 +6,4 @@ export * from "./utility/RandomInviteID"; export * from "./handlers/route"; export * from "./utility/String"; export * from "./handlers/Voice"; +export * from "./entities/AssetCacheItem"; \ No newline at end of file diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 6fbd6978a8ed59bb88aefbbb9aeca01fc15e086e..7a6cc91f0bddea8b94f33a6aa8c7d37983236274 100644 GIT binary patch delta 538 zcmdnHPUY)*l?nSeb&d55bo29aDkpzTRGY4##^$xzfN>!gLVUX7F(#Giyn&4D(GWJpHofV7I&7Sq=ksl4VzJOOGMfJIJCpGA`HE~=lfAikHa`%w zW<(eTvm$>xrv@7b)8<{Go=hmRa?@vPv8hhqsm*qySwV8Uf+XYAwGd+`_A=^EuRqAh zHof5z3opBgo*~$_k5d`tLkp`CBaLvn`pnk5P6yzb>=j^mol{lG7jbv2#wJaFkJ`9jF3`nShuX zh*`GBoM6?BM1;q7V0gSwAn1{Jns}t#)>es&le1QbYw|=+@#!n4G7C@7I?mWPy`hs; Wc>0HB?BeY}-vBZD_IJ%3{*wV8rMo@= delta 327 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 qHMWSI)BPpZnC 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 T$G-+H`3Q9U1L7V3{>Og+6I(FP literal 0 HcmV?d00001 From a0914a126224371a2b3a46664bb027e36a8ed320 Mon Sep 17 00:00:00 2001 From: Nobody Date: Tue, 19 Jul 2022 03:58:01 -0300 Subject: [PATCH 067/238] chore: fix package.json scripts npx should be used to execute local package binaries --- api/package.json | 10 +++++----- bundle/package.json | 4 ++-- cdn/package.json | 2 +- dashboard/package.json | 2 +- gateway/package.json | 2 +- util/package.json | 2 +- 6 files changed, 11 insertions(+), 11 deletions(-) diff --git a/api/package.json b/api/package.json index 29fa82a10..1bb492616 100644 --- a/api/package.json +++ b/api/package.json @@ -5,14 +5,14 @@ "main": "dist/index.js", "types": "src/index.ts", "scripts": { - "test:only": "jest --coverage --verbose --forceExit ./tests", - "test:routes": "jest --coverage --verbose --forceExit ./routes.test.ts", + "test:only": "npx jest --coverage --verbose --forceExit ./tests", + "test:routes": "npx jest --coverage --verbose --forceExit ./routes.test.ts", "test": "npm run build && npm run test:only", - "test:watch": "jest --watch", + "test:watch": "npx jest --watch", "start": "npm run build && node dist/start", "build": "npx tsc -p .", - "dev": "tsnd --respawn src/start.ts", - "patch": "ts-patch install -s && npx patch-package", + "dev": "npx tsnd --respawn src/start.ts", + "patch": "npx ts-patch install -s && npx patch-package", "postinstall": "npm run patch", "generate:docs": "node scripts/generate_openapi", "generate:schema": "node scripts/generate_schema" diff --git a/bundle/package.json b/bundle/package.json index d44d257f3..c050a302b 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -4,7 +4,7 @@ "description": "", "main": "src/start.js", "scripts": { - "setup": "node scripts/install.js && npm install --no-optional && ts-patch install -s && patch-package --patch-dir ../api/patches/ && npm run build", + "setup": "node scripts/install.js && npm install --no-optional && npx ts-patch install -s && npx patch-package --patch-dir ../api/patches/ && npm run build", "build": "node scripts/build.js", "start": "node scripts/build.js && node dist/bundle/src/start.js", "start:bundle": "node dist/bundle/src/start.js", @@ -111,4 +111,4 @@ "typescript-json-schema": "^0.50.1", "ws": "^7.4.2" } -} \ No newline at end of file +} diff --git a/cdn/package.json b/cdn/package.json index 46405b88a..c63713c08 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -5,7 +5,7 @@ "main": "dist/index.js", "types": "src/index.ts", "scripts": { - "test": "npm run build && jest --coverage ./tests", + "test": "npm run build && npx jest --coverage ./tests", "build": "npx tsc -p .", "start": "node dist/start.js" }, diff --git a/dashboard/package.json b/dashboard/package.json index 9afe20f8c..87bc16991 100644 --- a/dashboard/package.json +++ b/dashboard/package.json @@ -5,7 +5,7 @@ "main": "dist/index.js", "types": "src/index.ts", "scripts": { - "test": "npm run build && jest --coverage ./tests", + "test": "npm run build && npx jest --coverage ./tests", "build": "npx tsc -p .", "start": "node dist/start.js" }, diff --git a/gateway/package.json b/gateway/package.json index 7a3b1012e..0524cc400 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -9,7 +9,7 @@ "test": "echo \"Error: no test specified\" && exit 1", "start": "npm run build && node dist/start.js", "build": "npx tsc -p .", - "dev": "tsnd --respawn src/start.ts" + "dev": "npx tsnd --respawn src/start.ts" }, "keywords": [], "author": "Fosscord", diff --git a/util/package.json b/util/package.json index 35d2fbbe2..587e8a14f 100644 --- a/util/package.json +++ b/util/package.json @@ -6,7 +6,7 @@ "types": "src/index.ts", "scripts": { "start": "npm run build && node dist/", - "test": "npm run build && jest", + "test": "npm run build && npx jest", "postinstall": "npm run build", "build": "npx tsc -p .", "typeorm": "node --require ts-node/register ./node_modules/typeorm/cli.js" From db2b94c0a3a0063e1b32e524d4a0cde562f2686b Mon Sep 17 00:00:00 2001 From: Nobody <17956512+n0bodysec@users.noreply.github.com> Date: Wed, 20 Jul 2022 03:43:34 -0300 Subject: [PATCH 068/238] chore!: update docker scripts (#797) BREAKING CHANGE: this new docker image no longer clones this repository. Some manual steps are required * chore!: update docker scripts * chore: fix paths in docker scripts * chore: add config docker compose --- .docker/env | 1 - .dockerignore | 2 -- Dockerfile | 32 +++++++------------------------- docker-compose.cfg.yml | 6 ++++++ docker-compose.yml | 28 +++------------------------- 5 files changed, 16 insertions(+), 53 deletions(-) delete mode 100644 .docker/env delete mode 100644 .dockerignore create mode 100644 docker-compose.cfg.yml diff --git a/.docker/env b/.docker/env deleted file mode 100644 index 595b7ba25..000000000 --- a/.docker/env +++ /dev/null @@ -1 +0,0 @@ -MONGO_URL=mongodb://db:27017/fosscord?readPreference=secondaryPreferred diff --git a/.dockerignore b/.dockerignore deleted file mode 100644 index 7ee311a44..000000000 --- a/.dockerignore +++ /dev/null @@ -1,2 +0,0 @@ -node_modules/ -db/ diff --git a/Dockerfile b/Dockerfile index 3c8a0b317..64130e51c 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,8 +1,6 @@ FROM node:alpine # env vars -ENV WORK_DIR="/srv/fosscord-server" -ENV DEV_MODE=0 ENV HTTP_PORT=3001 ENV WS_PORT=3002 ENV CDN_PORT=3003 @@ -13,28 +11,12 @@ ENV ADMIN_PORT=3005 EXPOSE ${HTTP_PORT}/tcp ${WS_PORT}/tcp ${CDN_PORT}/tcp ${RTC_PORT}/tcp ${ADMIN_PORT}/tcp # install required apps -RUN apk add --no-cache --update git python2 py-pip make build-base +RUN apk add --no-cache --update git python3 py-pip make build-base +RUN ln -s /usr/bin/python3 /usr/bin/python -# optionl: packages for debugging/development -RUN apk add --no-cache sqlite +# Run as non-root user +# RUN adduser -D fosscord +# USER fosscord -# download fosscord-server -WORKDIR $WORK_DIR/src -RUN git clone https://github.com/fosscord/fosscord-server.git . - -# setup and run -WORKDIR $WORK_DIR/src/bundle -RUN npm run setup -RUN npm install @yukikaze-bot/erlpack -# RUN npm install mysql --save - -# create update script -RUN printf '#!/bin/sh\n\ngit -C $WORK_DIR/src/ checkout master\ngit -C $WORK_DIR/src/ reset --hard HEAD\ngit -C $WORK_DIR/src/ pull\ncd $WORK_DIR/src/bundle/\nnpm run setup\n' > $WORK_DIR/update.sh -RUN chmod +x $WORK_DIR/update.sh - -# configure entrypoint file -RUN printf '#!/bin/sh\n\nDEV_MODE=${DEV_MODE:-0}\n\nif [ "$DEV_MODE" -eq 1 ]; then\n tail -f /dev/null\nelse\n cd $WORK_DIR/src/bundle/\n npm run start:bundle\nfi\n' > $WORK_DIR/entrypoint.sh -RUN chmod +x $WORK_DIR/entrypoint.sh - -WORKDIR $WORK_DIR -ENTRYPOINT ["./entrypoint.sh"] +WORKDIR /srv/fosscord-server/bundle +ENTRYPOINT ["npm", "run", "start:bundle"] \ No newline at end of file diff --git a/docker-compose.cfg.yml b/docker-compose.cfg.yml new file mode 100644 index 000000000..18a7031d2 --- /dev/null +++ b/docker-compose.cfg.yml @@ -0,0 +1,6 @@ +version: '3.9' + +services: + + fosscord: + entrypoint: [ "npm", "run", "setup" ] diff --git a/docker-compose.yml b/docker-compose.yml index 13696f6f6..4dc1ee41e 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,46 +1,24 @@ -version: '3.8' +version: '3.9' services: + fosscord: container_name: fosscord image: fosscord restart: on-failure:5 - # depends_on: mariadb build: . ports: - '3001-3005:3001-3005' volumes: - # - ./data/:${WORK_DIR:-/srv/fosscord-server}/data/ - - data:${WORK_DIR:-/srv/fosscord-server}/ + - ./:/srv/fosscord-server/ environment: - WORK_DIR: ${WORK_DIR:-/srv/fosscord-server} - DEV_MODE: ${DEV_MODE:-0} THREADS: ${THREADS:-1} - DATABASE: ${DATABASE:-../../data/database.db} - STORAGE_LOCATION: ${STORAGE_LOCATION:-../../data/files/} HTTP_PORT: 3001 WS_PORT: 3002 CDN_PORT: 3003 RTC_PORT: 3004 ADMIN_PORT: 3005 - # mariadb: - # image: mariadb:latest - # restart: on-failure:5 - # environment: - # MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD:-secr3tpassw0rd} - # MYSQL_DATABASE: ${MYSQL_DATABASE:-fosscord} - # MYSQL_USER: ${MYSQL_USER:-fosscord} - # MYSQL_PASSWORD: ${MYSQL_PASSWORD:-password1} - # networks: - # - default - # volumes: - # - mariadb:/var/lib/mysql - -volumes: - data: - # mariadb: - networks: default: name: fosscord From 1c2cddb7c4be9fa75eabf3ec9424afd6cb032a7c Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Wed, 20 Jul 2022 17:39:16 +1000 Subject: [PATCH 069/238] 2fa --- api/assets/schemas.json | 1313 ++++++++++++++++++ api/locales/en/auth.json | 4 +- api/src/middlewares/Authentication.ts | 1 + api/src/routes/auth/login.ts | 17 +- api/src/routes/auth/mfa/totp.ts | 49 + api/src/routes/users/@me/mfa/codes.ts | 48 + api/src/routes/users/@me/mfa/totp/disable.ts | 45 + api/src/routes/users/@me/mfa/totp/enable.ts | 51 + util/src/entities/BackupCodes.ts | 35 + util/src/entities/User.ts | 8 +- util/src/entities/index.ts | 3 +- 11 files changed, 1570 insertions(+), 4 deletions(-) create mode 100644 api/src/routes/auth/mfa/totp.ts create mode 100644 api/src/routes/users/@me/mfa/codes.ts create mode 100644 api/src/routes/users/@me/mfa/totp/disable.ts create mode 100644 api/src/routes/users/@me/mfa/totp/enable.ts create mode 100644 util/src/entities/BackupCodes.ts diff --git a/api/assets/schemas.json b/api/assets/schemas.json index 2102292bc..4249eb815 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -1072,6 +1072,344 @@ }, "$schema": "http://json-schema.org/draft-07/schema#" }, + "TotpSchema": { + "type": "object", + "properties": { + "code": { + "type": "string" + }, + "ticket": { + "type": "string" + }, + "gift_code_sku_id": { + "type": [ + "null", + "string" + ] + }, + "login_source": { + "type": [ + "null", + "string" + ] + } + }, + "additionalProperties": false, + "required": [ + "code", + "ticket" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, "RegisterSchema": { "type": "object", "properties": { @@ -12844,6 +13182,981 @@ }, "$schema": "http://json-schema.org/draft-07/schema#" }, + "MfaCodesSchema": { + "type": "object", + "properties": { + "password": { + "type": "string" + }, + "regenerate": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "password" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "TotpDisableSchema": { + "type": "object", + "properties": { + "code": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "code" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "TotpEnableSchema": { + "type": "object", + "properties": { + "password": { + "type": "string" + }, + "code": { + "type": "string" + }, + "secret": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "password" + ], + "definitions": { + "Embed": { + "type": "object", + "properties": { + "title": { + "type": "string" + }, + "type": { + "enum": [ + "article", + "gifv", + "image", + "link", + "rich", + "video" + ], + "type": "string" + }, + "description": { + "type": "string" + }, + "url": { + "type": "string" + }, + "timestamp": { + "type": "string", + "format": "date-time" + }, + "color": { + "type": "integer" + }, + "footer": { + "type": "object", + "properties": { + "text": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "text" + ] + }, + "image": { + "$ref": "#/definitions/EmbedImage" + }, + "thumbnail": { + "$ref": "#/definitions/EmbedImage" + }, + "video": { + "$ref": "#/definitions/EmbedImage" + }, + "provider": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "author": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "url": { + "type": "string" + }, + "icon_url": { + "type": "string" + }, + "proxy_icon_url": { + "type": "string" + } + }, + "additionalProperties": false + }, + "fields": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "value": { + "type": "string" + }, + "inline": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "value" + ] + } + } + }, + "additionalProperties": false + }, + "EmbedImage": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "proxy_url": { + "type": "string" + }, + "height": { + "type": "integer" + }, + "width": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "Record": { + "type": "object", + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, "RelationshipPutSchema": { "type": "object", "properties": { diff --git a/api/locales/en/auth.json b/api/locales/en/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/en/auth.json +++ b/api/locales/en/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", diff --git a/api/src/middlewares/Authentication.ts b/api/src/middlewares/Authentication.ts index 5a08caf32..1df7911be 100644 --- a/api/src/middlewares/Authentication.ts +++ b/api/src/middlewares/Authentication.ts @@ -7,6 +7,7 @@ export const NO_AUTHORIZATION_ROUTES = [ "/auth/login", "/auth/register", "/auth/location-metadata", + "/auth/mfa/totp", // Routes with a seperate auth system "/webhooks/", // Public information endpoints diff --git a/api/src/routes/auth/login.ts b/api/src/routes/auth/login.ts index a89721ea6..5df9e2527 100644 --- a/api/src/routes/auth/login.ts +++ b/api/src/routes/auth/login.ts @@ -2,6 +2,7 @@ import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; import { Config, User, generateToken, adjustEmail, FieldErrors } from "@fosscord/util"; +import crypto from "crypto"; const router: Router = Router(); export default router; @@ -37,7 +38,7 @@ router.post("/", route({ body: "LoginSchema" }), async (req: Request, res: Respo const user = await User.findOneOrFail({ where: [{ phone: login }, { email: login }], - select: ["data", "id", "disabled", "deleted", "settings"] + select: ["data", "id", "disabled", "deleted", "settings", "totp_secret", "mfa_enabled"] }).catch((e) => { throw FieldErrors({ login: { message: req.t("auth:login.INVALID_LOGIN"), code: "INVALID_LOGIN" } }); }); @@ -57,6 +58,20 @@ router.post("/", route({ body: "LoginSchema" }), async (req: Request, res: Respo throw FieldErrors({ password: { message: req.t("auth:login.INVALID_PASSWORD"), code: "INVALID_PASSWORD" } }); } + if (user.mfa_enabled) { + // TODO: This is not a discord.com ticket. I'm not sure what it is but I'm lazy + const ticket = crypto.randomBytes(40).toString("hex"); + + await User.update({ id: user.id }, { totp_last_ticket: ticket }); + + return res.json({ + ticket: ticket, + mfa: true, + sms: false, // TODO + token: null, + }) + } + const token = await generateToken(user.id); // Notice this will have a different token structure, than discord diff --git a/api/src/routes/auth/mfa/totp.ts b/api/src/routes/auth/mfa/totp.ts new file mode 100644 index 000000000..cec6e5ee6 --- /dev/null +++ b/api/src/routes/auth/mfa/totp.ts @@ -0,0 +1,49 @@ +import { Router, Request, Response } from "express"; +import { route } from "@fosscord/api"; +import { BackupCode, FieldErrors, generateToken, User } from "@fosscord/util"; +import { verifyToken } from "node-2fa"; +import { HTTPError } from "lambert-server"; +const router = Router(); + +export interface TotpSchema { + code: string, + ticket: string, + gift_code_sku_id?: string | null, + login_source?: string | null, +} + +router.post("/", route({ body: "TotpSchema" }), async (req: Request, res: Response) => { + const { code, ticket, gift_code_sku_id, login_source } = req.body as TotpSchema; + + const user = await User.findOneOrFail({ + where: { + totp_last_ticket: ticket, + }, + select: [ + "id", + "totp_secret", + "settings", + ], + }); + + const backup = await BackupCode.findOne({ code: code, expired: false, consumed: false, user: { id: user.id }}); + + if (!backup) { + const ret = verifyToken(user.totp_secret!, code); + if (!ret || ret.delta != 0) + throw new HTTPError(req.t("auth:login.INVALID_TOTP_CODE"), 60008); + } + else { + backup.consumed = true; + await backup.save(); + } + + await User.update({ id: user.id }, { totp_last_ticket: "" }); + + return res.json({ + token: await generateToken(user.id), + user_settings: user.settings, + }); +}); + +export default router; diff --git a/api/src/routes/users/@me/mfa/codes.ts b/api/src/routes/users/@me/mfa/codes.ts new file mode 100644 index 000000000..2a1fb498c --- /dev/null +++ b/api/src/routes/users/@me/mfa/codes.ts @@ -0,0 +1,48 @@ +import { Router, Request, Response } from "express"; +import { route } from "@fosscord/api"; +import { BackupCode, FieldErrors, generateMfaBackupCodes, User } from "@fosscord/util"; +import bcrypt from "bcrypt"; + +const router = Router(); + +export interface MfaCodesSchema { + password: string; + regenerate?: boolean; +} + +// TODO: This route is replaced with users/@me/mfa/codes-verification in newer clients + +router.post("/", route({ body: "MfaCodesSchema" }), async (req: Request, res: Response) => { + const { password, regenerate } = req.body as MfaCodesSchema; + + const user = await User.findOneOrFail({ id: req.user_id }, { select: ["data"] }); + + if (!await bcrypt.compare(password, user.data.hash || "")) { + throw FieldErrors({ password: { message: req.t("auth:login.INVALID_PASSWORD"), code: "INVALID_PASSWORD" } }); + } + + var codes: BackupCode[]; + if (regenerate) { + await BackupCode.update( + { user: { id: req.user_id } }, + { expired: true } + ); + + codes = generateMfaBackupCodes(req.user_id); + await Promise.all(codes.map(x => x.save())); + } + else { + codes = await BackupCode.find({ + user: { + id: req.user_id, + }, + expired: false, + }); + } + + return res.json({ + backup_codes: codes.map(x => ({ ...x, expired: undefined })), + }) +}); + +export default router; diff --git a/api/src/routes/users/@me/mfa/totp/disable.ts b/api/src/routes/users/@me/mfa/totp/disable.ts new file mode 100644 index 000000000..5e039ea33 --- /dev/null +++ b/api/src/routes/users/@me/mfa/totp/disable.ts @@ -0,0 +1,45 @@ +import { Router, Request, Response } from "express"; +import { route } from "@fosscord/api"; +import { verifyToken } from 'node-2fa'; +import { HTTPError } from "lambert-server"; +import { User, generateToken, BackupCode } from "@fosscord/util"; + +const router = Router(); + +export interface TotpDisableSchema { + code: string; +} + +router.post("/", route({ body: "TotpDisableSchema" }), async (req: Request, res: Response) => { + const body = req.body as TotpDisableSchema; + + const user = await User.findOneOrFail({ id: req.user_id }, { select: ["totp_secret"] }); + + const backup = await BackupCode.findOne({ code: body.code }); + if (!backup) { + const ret = verifyToken(user.totp_secret!, body.code); + if (!ret || ret.delta != 0) + throw new HTTPError(req.t("auth:login.INVALID_TOTP_CODE"), 60008); + } + + await User.update( + { id: req.user_id }, + { + mfa_enabled: false, + totp_secret: "", + }, + ); + + await BackupCode.update( + { user: { id: req.user_id } }, + { + expired: true, + } + ); + + return res.json({ + token: await generateToken(user.id), + }); +}); + +export default router; \ No newline at end of file diff --git a/api/src/routes/users/@me/mfa/totp/enable.ts b/api/src/routes/users/@me/mfa/totp/enable.ts new file mode 100644 index 000000000..bc5f16ad8 --- /dev/null +++ b/api/src/routes/users/@me/mfa/totp/enable.ts @@ -0,0 +1,51 @@ +import { Router, Request, Response } from "express"; +import { User, generateToken, BackupCode, generateMfaBackupCodes } from "@fosscord/util"; +import { route } from "@fosscord/api"; +import bcrypt from "bcrypt"; +import { HTTPError } from "lambert-server"; +import { verifyToken } from 'node-2fa'; +import crypto from "crypto"; + +const router = Router(); + +export interface TotpEnableSchema { + password: string; + code?: string; + secret?: string; +} + +router.post("/", route({ body: "TotpEnableSchema" }), async (req: Request, res: Response) => { + const body = req.body as TotpEnableSchema; + + const user = await User.findOneOrFail({ where: { id: req.user_id }, select: ["data"] }); + + // TODO: Are guests allowed to enable 2fa? + if (user.data.hash) { + if (!await bcrypt.compare(body.password, user.data.hash)) { + throw new HTTPError(req.t("auth:login.INVALID_PASSWORD")); + } + } + + if (!body.secret) + throw new HTTPError(req.t("auth:login.INVALID_TOTP_SECRET"), 60005); + + if (!body.code) + throw new HTTPError(req.t("auth:login.INVALID_TOTP_CODE"), 60008); + + if (verifyToken(body.secret, body.code)?.delta != 0) + throw new HTTPError(req.t("auth:login.INVALID_TOTP_CODE"), 60008); + + let backup_codes = generateMfaBackupCodes(req.user_id); + await Promise.all(backup_codes.map(x => x.save())); + await User.update( + { id: req.user_id }, + { mfa_enabled: true, totp_secret: body.secret } + ); + + res.send({ + token: await generateToken(user.id), + backup_codes: backup_codes.map(x => ({ ...x, expired: undefined })), + }); +}); + +export default router; \ No newline at end of file diff --git a/util/src/entities/BackupCodes.ts b/util/src/entities/BackupCodes.ts new file mode 100644 index 000000000..d532a39ad --- /dev/null +++ b/util/src/entities/BackupCodes.ts @@ -0,0 +1,35 @@ +import { Column, Entity, JoinColumn, ManyToOne, RelationId } from "typeorm"; +import { BaseClass } from "./BaseClass"; +import { User } from "./User"; +import crypto from "crypto"; + +@Entity("backup_codes") +export class BackupCode extends BaseClass { + @JoinColumn({ name: "user_id" }) + @ManyToOne(() => User, { onDelete: "CASCADE" }) + user: User; + + @Column() + code: string; + + @Column() + consumed: boolean; + + @Column() + expired: boolean; +} + +export function generateMfaBackupCodes(user_id: string) { + let backup_codes: BackupCode[] = []; + for (let i = 0; i < 10; i++) { + const code = BackupCode.create({ + user: { id: user_id }, + code: crypto.randomBytes(4).toString("hex"), // 8 characters + consumed: false, + expired: false, + }); + backup_codes.push(code); + } + + return backup_codes; +} \ No newline at end of file diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 9b1c494eb..79d415ca6 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -1,4 +1,4 @@ -import { Column, Entity, FindOneOptions, JoinColumn, ManyToMany, OneToMany, RelationId } from "typeorm"; +import { Column, Entity, FindOneOptions, JoinColumn, OneToMany } from "typeorm"; import { BaseClass } from "./BaseClass"; import { BitField } from "../util/BitField"; import { Relationship } from "./Relationship"; @@ -108,6 +108,12 @@ export class User extends BaseClass { @Column({ select: false }) mfa_enabled: boolean; // if multi factor authentication is enabled + @Column({ select: false, nullable: true }) + totp_secret?: string; + + @Column({ nullable: true, select: false }) + totp_last_ticket?: string; + @Column() created_at: Date; // registration date diff --git a/util/src/entities/index.ts b/util/src/entities/index.ts index f023d5a6b..1b6259aed 100644 --- a/util/src/entities/index.ts +++ b/util/src/entities/index.ts @@ -27,4 +27,5 @@ export * from "./Template"; export * from "./User"; export * from "./VoiceState"; export * from "./Webhook"; -export * from "./ClientRelease"; \ No newline at end of file +export * from "./ClientRelease"; +export * from "./BackupCodes"; \ No newline at end of file From 4fa8b16b4a3e8ebde531088e5a3380b423ae1043 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Wed, 20 Jul 2022 21:17:19 +1000 Subject: [PATCH 070/238] Add node-2fa to package.json --- api/package.json | 1 + bundle/package.json | 5 +++-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/api/package.json b/api/package.json index 1bb492616..07208d60f 100644 --- a/api/package.json +++ b/api/package.json @@ -86,6 +86,7 @@ "missing-native-js-functions": "^1.2.18", "morgan": "^1.10.0", "multer": "^1.4.2", + "node-2fa": "^2.0.3", "node-fetch": "^2.6.2", "patch-package": "^6.4.7", "picocolors": "^1.0.0", diff --git a/bundle/package.json b/bundle/package.json index c050a302b..86e300e1a 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -109,6 +109,7 @@ "typescript": "^4.1.2", "typescript-cached-transpile": "^0.0.6", "typescript-json-schema": "^0.50.1", - "ws": "^7.4.2" + "ws": "^7.4.2", + "node-2fa": "^2.0.3" } -} +} \ No newline at end of file From eb7f2c7b72f545b99949e4290bc38cb448903141 Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Wed, 20 Jul 2022 22:04:19 +1000 Subject: [PATCH 071/238] Add config `security_twoFactor_generateBackupCodes` to control backup code generation --- api/src/routes/users/@me/mfa/codes.ts | 4 ++-- api/src/routes/users/@me/mfa/totp/enable.ts | 11 +++++++---- util/src/entities/Config.ts | 6 ++++++ 3 files changed, 15 insertions(+), 6 deletions(-) diff --git a/api/src/routes/users/@me/mfa/codes.ts b/api/src/routes/users/@me/mfa/codes.ts index 2a1fb498c..6ddf32f06 100644 --- a/api/src/routes/users/@me/mfa/codes.ts +++ b/api/src/routes/users/@me/mfa/codes.ts @@ -1,6 +1,6 @@ import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; -import { BackupCode, FieldErrors, generateMfaBackupCodes, User } from "@fosscord/util"; +import { BackupCode, Config, FieldErrors, generateMfaBackupCodes, User } from "@fosscord/util"; import bcrypt from "bcrypt"; const router = Router(); @@ -22,7 +22,7 @@ router.post("/", route({ body: "MfaCodesSchema" }), async (req: Request, res: Re } var codes: BackupCode[]; - if (regenerate) { + if (regenerate && Config.get().security.twoFactor.generateBackupCodes) { await BackupCode.update( { user: { id: req.user_id } }, { expired: true } diff --git a/api/src/routes/users/@me/mfa/totp/enable.ts b/api/src/routes/users/@me/mfa/totp/enable.ts index bc5f16ad8..87f36d558 100644 --- a/api/src/routes/users/@me/mfa/totp/enable.ts +++ b/api/src/routes/users/@me/mfa/totp/enable.ts @@ -1,10 +1,9 @@ import { Router, Request, Response } from "express"; -import { User, generateToken, BackupCode, generateMfaBackupCodes } from "@fosscord/util"; +import { User, generateToken, BackupCode, generateMfaBackupCodes, Config } from "@fosscord/util"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; import { HTTPError } from "lambert-server"; import { verifyToken } from 'node-2fa'; -import crypto from "crypto"; const router = Router(); @@ -35,8 +34,12 @@ router.post("/", route({ body: "TotpEnableSchema" }), async (req: Request, res: if (verifyToken(body.secret, body.code)?.delta != 0) throw new HTTPError(req.t("auth:login.INVALID_TOTP_CODE"), 60008); - let backup_codes = generateMfaBackupCodes(req.user_id); - await Promise.all(backup_codes.map(x => x.save())); + let backup_codes: BackupCode[] = []; + if (Config.get().security.twoFactor.generateBackupCodes) { + backup_codes = generateMfaBackupCodes(req.user_id); + await Promise.all(backup_codes.map(x => x.save())); + } + await User.update( { id: req.user_id }, { mfa_enabled: true, totp_secret: body.secret } diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts index 3756d6863..c84ea4aa0 100644 --- a/util/src/entities/Config.ts +++ b/util/src/entities/Config.ts @@ -121,6 +121,9 @@ export interface ConfigValue { secret: string | null; }; ipdataApiKey: string | null; + twoFactor: { + generateBackupCodes: boolean; + }; }; login: { requireCaptcha: boolean; @@ -312,6 +315,9 @@ export const DefaultConfigOptions: ConfigValue = { secret: null, }, ipdataApiKey: "eca677b284b3bac29eb72f5e496aa9047f26543605efe99ff2ce35c9", + twoFactor: { + generateBackupCodes: true, + }, }, login: { requireCaptcha: false, From e9a680beaf282588dcf1e789946f61eb10a1d2d3 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Sat, 23 Jul 2022 09:46:55 +0300 Subject: [PATCH 072/238] Bump file-type from 16.5.3 to 16.5.4 in /cdn (#801) Bumps [file-type](https://github.com/sindresorhus/file-type) from 16.5.3 to 16.5.4. - [Release notes](https://github.com/sindresorhus/file-type/releases) - [Commits](https://github.com/sindresorhus/file-type/compare/v16.5.3...v16.5.4) --- updated-dependencies: - dependency-name: file-type dependency-type: direct:production ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- cdn/package-lock.json | Bin 500169 -> 500185 bytes cdn/package.json | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/cdn/package-lock.json b/cdn/package-lock.json index e6e9bb1abccc840399e90968c048b60985fb5720..62c2cdc87e82861859eed9443d77b33ddb76bb34 100644 GIT binary patch delta 332 zcmX?kSnlRwxd~f%9o++bbdB{4bo29aDko2jRoi%9myywAdg4navB~#Xc{dv{r81+c zn!YiHQLcFhYx@pX#_c;;nN;Mb2VG~?pU$nyBt3mnA)`Wwex;j-w?U$NmYZw3i&vJb zcYr}bxN|{Hae!MuMtNmgd1_gjenD78rk_DcuB(ZUrB7~octv<=c8XW9M@qhPPNqp% zdZ15gMwVAed7x8XVQ#Va^u(FWiqrYHm^r7v`o$X2E~CZ-#LPgJ67J!7EGzk5b@~;V;JR{Pq4P1U}fBX zf|W@{e)=J8M*Zp1s!Y<8C;e6kEe$KqG0$|%@Cf#gG)Z#x_w&gK@isBfbo40kD|Yh; z4={~%HL37Qi!v$7i!cv13^XoJPBpNMNG}X_Hh0yp$guEBF4Ip+HO%qLuPi9a3H8vg zFq>RhsxV!Si Date: Sat, 23 Jul 2022 09:47:14 +0300 Subject: [PATCH 073/238] Bump file-type from 16.5.3 to 16.5.4 in /bundle (#802) Bumps [file-type](https://github.com/sindresorhus/file-type) from 16.5.3 to 16.5.4. - [Release notes](https://github.com/sindresorhus/file-type/releases) - [Commits](https://github.com/sindresorhus/file-type/compare/v16.5.3...v16.5.4) --- updated-dependencies: - dependency-name: file-type dependency-type: direct:production ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- bundle/package-lock.json | Bin 595773 -> 595957 bytes bundle/package.json | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 6fbd6978a8ed59bb88aefbbb9aeca01fc15e086e..f94e8d26c17a7e9d6f24b47b34a1ae94d73a54b2 100644 GIT binary patch delta 500 zcmdnHPUY)*l?nSeb&d55bo29aDkpzTRGY4##^$xzfU$~+(PVO=i2ZavWwy!F^)%VI zCs#_SZC=Ns%#P47UGW%`%5>g9M)v6wOyu#dK@8roB%M_-|YqM}p?^kD!m>#u)S#kP;Uo4i>|CKZGwi`@i0%B$$W&vW> i?FQ4>PEHtL7f&y&W|f(KHid(;9q8ok{puX+-U9%E0;xm* delta 325 zcmeymUS;n(l?nTp!i* Date: Sat, 23 Jul 2022 20:52:48 +1000 Subject: [PATCH 074/238] Moved user notes into separate table --- api/src/routes/users/@me/notes.ts | 39 ++++++++++++++++++++++--------- util/src/entities/Note.ts | 18 ++++++++++++++ util/src/entities/User.ts | 4 +--- util/src/entities/index.ts | 3 ++- 4 files changed, 49 insertions(+), 15 deletions(-) create mode 100644 util/src/entities/Note.ts diff --git a/api/src/routes/users/@me/notes.ts b/api/src/routes/users/@me/notes.ts index 4887b1918..e3406d182 100644 --- a/api/src/routes/users/@me/notes.ts +++ b/api/src/routes/users/@me/notes.ts @@ -1,37 +1,54 @@ import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; -import { User, emitEvent } from "@fosscord/util"; +import { User, Note, emitEvent, Snowflake } from "@fosscord/util"; const router: Router = Router(); router.get("/:id", route({}), async (req: Request, res: Response) => { const { id } = req.params; - const user = await User.findOneOrFail({ where: { id: req.user_id }, select: ["notes"] }); - const note = user.notes[id]; + const note = await Note.findOneOrFail({ + where: { + owner: { id: req.user_id }, + target: { id: id }, + } + }); + return res.json({ - note: note, + note: note?.content, note_user_id: id, - user_id: user.id, + user_id: req.user_id, }); }); router.put("/:id", route({}), async (req: Request, res: Response) => { const { id } = req.params; - const user = await User.findOneOrFail({ where: { id: req.user_id } }); - const noteUser = await User.findOneOrFail({ where: { id: id }}); //if noted user does not exist throw + const owner = await User.findOneOrFail({ where: { id: req.user_id } }); + const target = await User.findOneOrFail({ where: { id: id } }); //if noted user does not exist throw const { note } = req.body; - await User.update({ id: req.user_id }, { notes: { ...user.notes, [noteUser.id]: note } }); + // await User.update({ id: req.user_id }, { notes: { ...user.notes, [noteUser.id]: note } }); + + if (await Note.findOne({ owner: { id: owner.id }, target: { id: target.id } })) { + Note.update( + { owner: { id: owner.id }, target: { id: target.id } }, + { owner, target, content: note } + ); + } + else { + Note.insert( + { id: Snowflake.generate(), owner, target, content: note } + ); + } await emitEvent({ event: "USER_NOTE_UPDATE", data: { note: note, - id: noteUser.id + id: target.id }, - user_id: user.id, - }) + user_id: owner.id, + }); return res.status(204); }); diff --git a/util/src/entities/Note.ts b/util/src/entities/Note.ts new file mode 100644 index 000000000..36017c5eb --- /dev/null +++ b/util/src/entities/Note.ts @@ -0,0 +1,18 @@ +import { Column, Entity, JoinColumn, ManyToOne, Unique } from "typeorm"; +import { BaseClass } from "./BaseClass"; +import { User } from "./User"; + +@Entity("notes") +@Unique(["owner", "target"]) +export class Note extends BaseClass { + @JoinColumn({ name: "owner_id" }) + @ManyToOne(() => User, { onDelete: "CASCADE" }) + owner: User; + + @JoinColumn({ name: "target_id" }) + @ManyToOne(() => User, { onDelete: "CASCADE" }) + target: User; + + @Column() + content: string; +} \ No newline at end of file diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 9b1c494eb..8deb7ed5d 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -5,6 +5,7 @@ import { Relationship } from "./Relationship"; import { ConnectedAccount } from "./ConnectedAccount"; import { Config, FieldErrors, Snowflake, trimSpecial } from ".."; import { Member, Session } from "."; +import { Note } from "./Note"; export enum PublicUserEnum { username, @@ -168,9 +169,6 @@ export class User extends BaseClass { @Column({ type: "simple-json", select: false }) extended_settings: string; - @Column({ type: "simple-json" }) - notes: { [key: string]: string }; //key is ID of user - toPublicUser() { const user: any = {}; PublicUserProjection.forEach((x) => { diff --git a/util/src/entities/index.ts b/util/src/entities/index.ts index f023d5a6b..cb0871366 100644 --- a/util/src/entities/index.ts +++ b/util/src/entities/index.ts @@ -27,4 +27,5 @@ export * from "./Template"; export * from "./User"; export * from "./VoiceState"; export * from "./Webhook"; -export * from "./ClientRelease"; \ No newline at end of file +export * from "./ClientRelease"; +export * from "./Note"; \ No newline at end of file From 78acb2a013d109e6a5179f8a9fe28f23819c5f3d Mon Sep 17 00:00:00 2001 From: Madeline <46743919+MaddyUnderStars@users.noreply.github.com> Date: Sat, 23 Jul 2022 21:06:31 +1000 Subject: [PATCH 075/238] Delete Note if no content --- api/src/routes/users/@me/notes.ts | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/api/src/routes/users/@me/notes.ts b/api/src/routes/users/@me/notes.ts index e3406d182..3c503942d 100644 --- a/api/src/routes/users/@me/notes.ts +++ b/api/src/routes/users/@me/notes.ts @@ -27,18 +27,22 @@ router.put("/:id", route({}), async (req: Request, res: Response) => { const target = await User.findOneOrFail({ where: { id: id } }); //if noted user does not exist throw const { note } = req.body; - // await User.update({ id: req.user_id }, { notes: { ...user.notes, [noteUser.id]: note } }); - - if (await Note.findOne({ owner: { id: owner.id }, target: { id: target.id } })) { - Note.update( - { owner: { id: owner.id }, target: { id: target.id } }, - { owner, target, content: note } - ); + if (note && note.length) { + // upsert a note + if (await Note.findOne({ owner: { id: owner.id }, target: { id: target.id } })) { + Note.update( + { owner: { id: owner.id }, target: { id: target.id } }, + { owner, target, content: note } + ); + } + else { + Note.insert( + { id: Snowflake.generate(), owner, target, content: note } + ); + } } else { - Note.insert( - { id: Snowflake.generate(), owner, target, content: note } - ); + await Note.delete({ owner: { id: owner.id }, target: { id: target.id } }); } await emitEvent({ From 9ab01e040495b60d4f29217191d3ae9ee774608c Mon Sep 17 00:00:00 2001 From: Puyodead1 <23562356riley@gmail.com> Date: Mon, 25 Jul 2022 23:02:04 -0400 Subject: [PATCH 076/238] fix: not being able to enable community --- api/assets/schemas.json | 10 +++------- api/src/routes/guilds/#guild_id/index.ts | 3 ++- 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/api/assets/schemas.json b/api/assets/schemas.json index 2102292bc..ca42e6767 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -6828,6 +6828,9 @@ "GuildUpdateSchema": { "type": "object", "properties": { + "name": { + "type": "string" + }, "banner": { "type": [ "null", @@ -6873,10 +6876,6 @@ "preferred_locale": { "type": "string" }, - "name": { - "maxLength": 100, - "type": "string" - }, "region": { "type": "string" }, @@ -6897,9 +6896,6 @@ } }, "additionalProperties": false, - "required": [ - "name" - ], "definitions": { "Embed": { "type": "object", diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index 4ec3df729..be556fb23 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -7,7 +7,8 @@ import { GuildCreateSchema } from "../index"; const router = Router(); -export interface GuildUpdateSchema extends Omit { +export interface GuildUpdateSchema extends Omit { + name?: string; banner?: string | null; splash?: string | null; description?: string; From f3b1e9b02641376177c4c358074e01f201ba0ff8 Mon Sep 17 00:00:00 2001 From: Puyodead1 Date: Sat, 30 Jul 2022 14:33:01 -0400 Subject: [PATCH 077/238] add discriminator to user modify schema --- api/assets/schemas.json | 5 +++++ api/src/routes/users/@me/index.ts | 1 + 2 files changed, 6 insertions(+) diff --git a/api/assets/schemas.json b/api/assets/schemas.json index ca42e6767..f7efb8885 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -12499,6 +12499,11 @@ "maxLength": 100, "type": "string" }, + "discriminator": { + "minLength": 4, + "maxLength": 4, + "type": "string" + }, "avatar": { "type": [ "null", diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 1af413c40..7fc204579 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -11,6 +11,7 @@ export interface UserModifySchema { * @maxLength 100 */ username?: string; + discriminator?: string; avatar?: string | null; /** * @maxLength 1024 From 243417a66728c6494c5718b550ce2f677bba77a7 Mon Sep 17 00:00:00 2001 From: Puyodead1 Date: Sat, 30 Jul 2022 17:34:14 -0400 Subject: [PATCH 078/238] Update schemas.json --- api/assets/schemas.json | 2 -- 1 file changed, 2 deletions(-) diff --git a/api/assets/schemas.json b/api/assets/schemas.json index f7efb8885..9c3121237 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -12500,8 +12500,6 @@ "type": "string" }, "discriminator": { - "minLength": 4, - "maxLength": 4, "type": "string" }, "avatar": { From 6e9bd98711f488dd06d2ce93027f8d9ea4cd3ad5 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 31 Jul 2022 13:27:15 +0200 Subject: [PATCH 079/238] Make requested changes (pr792) --- .gitignore | 2 ++ api/src/middlewares/TestClient.ts | 1 - api/src/util/entities/AssetCacheItem.ts | 15 +-------------- fosscord-server.code-workspace | 6 +----- 4 files changed, 4 insertions(+), 20 deletions(-) diff --git a/.gitignore b/.gitignore index cc60b3050..607b4f5a1 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ config.json .vscode/settings.json api/assets/plugins/*.js .idea/ +*.code-workspace + diff --git a/api/src/middlewares/TestClient.ts b/api/src/middlewares/TestClient.ts index e52a5e591..7292868c9 100644 --- a/api/src/middlewares/TestClient.ts +++ b/api/src/middlewares/TestClient.ts @@ -27,7 +27,6 @@ export default function TestClient(app: Application) { newAssetCache = new Map(Object.entries(JSON.parse(rawdata.toString()))); } - //define routes app.use("/assets", express.static(path.join(__dirname, "..", "..", "assets"))); app.get("/assets/:file", async (req: Request, res: Response) => { delete req.headers.host; diff --git a/api/src/util/entities/AssetCacheItem.ts b/api/src/util/entities/AssetCacheItem.ts index 7fb4e1e61..160dece68 100644 --- a/api/src/util/entities/AssetCacheItem.ts +++ b/api/src/util/entities/AssetCacheItem.ts @@ -1,16 +1,3 @@ -import { Headers } from "node-fetch"; - export class AssetCacheItem { - public Key: string; - public FilePath: string; - public Headers: any; - - constructor(key: string){ - this.Key = key; - } - /*constructor(key: string, filePath: string, headers: Headers) { - this.Key = key; - this.FilePath = filePath; - this.Headers = headers; - }*/ + constructor(public Key: string, public FilePath: string = "", public Headers: any = null as any) {} } \ No newline at end of file diff --git a/fosscord-server.code-workspace b/fosscord-server.code-workspace index fff238f14..7491cb358 100644 --- a/fosscord-server.code-workspace +++ b/fosscord-server.code-workspace @@ -24,9 +24,5 @@ { "path": "webrtc" } - ], - "settings": { - "awooga.originalColorCustomizations": {}, - "workbench.colorCustomizations": {} - } + ] } From e7f89bb71825b6597047995c8164c1bf9d1bd742 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 00:39:50 +0200 Subject: [PATCH 080/238] New translations auth.json (Hebrew) --- api/locales/he/auth.json | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/api/locales/he/auth.json b/api/locales/he/auth.json index b72968682..e19547a01 100644 --- a/api/locales/he/auth.json +++ b/api/locales/he/auth.json @@ -1,16 +1,16 @@ { "login": { - "INVALID_LOGIN": "מייל או מספר טלפון לא נמצאים במאגר", - "INVALID_PASSWORD": "סיסמא שגויה", - "ACCOUNT_DISABLED": "משתמש זה חסום / מבוטל" + "INVALID_LOGIN": "E-Mail or Phone not found", + "INVALID_PASSWORD": "Invalid Password", + "ACCOUNT_DISABLED": "This account is disabled" }, "register": { - "REGISTRATION_DISABLED": "לא ניתן לאפשר רישום משתמשים חדשים", - "INVITE_ONLY": "עליך להיות מוזמן בכדי להרשם", - "EMAIL_INVALID": "מייל שגוי", - "EMAIL_ALREADY_REGISTERED": "מייל זה כבר רשום", - "DATE_OF_BIRTH_UNDERAGE": "{{years}} עלייך להיות מעל גיל", - "CONSENT_REQUIRED": ".עליך להסכים לתנאי השירות ולמדיניות הפרטיות", - "USERNAME_TOO_MANY_USERS": "ליותר מדי משתמשים יש שם משתמש זהה, אנא נסה אחר" + "REGISTRATION_DISABLED": "New user registration is disabled", + "INVITE_ONLY": "You must be invited to register", + "EMAIL_INVALID": "Invalid Email", + "EMAIL_ALREADY_REGISTERED": "Email is already registered", + "DATE_OF_BIRTH_UNDERAGE": "You need to be {{years}} years or older", + "CONSENT_REQUIRED": "You must agree to the Terms of Service and Privacy Policy.", + "USERNAME_TOO_MANY_USERS": "Too many users have this username, please try another" } } From 6aaa92349d9022b84f401a1f36da6c86d27a8b43 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 00:39:52 +0200 Subject: [PATCH 081/238] New translations common.json (Hebrew) --- api/locales/he/common.json | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/api/locales/he/common.json b/api/locales/he/common.json index 4101eac4a..9e72e9416 100644 --- a/api/locales/he/common.json +++ b/api/locales/he/common.json @@ -1,18 +1,18 @@ { "field": { - "BASE_TYPE_REQUIRED": "שדה זה חובה", - "BASE_TYPE_STRING": "שדה זה חייב להיות כטקסט", - "BASE_TYPE_NUMBER": "שדה זה חייב להיות מספר", - "BASE_TYPE_BIGINT": "השדה הזה חייב להיות ביגינט", - "BASE_TYPE_BOOLEAN": "השדה הזה חייב להיות בוליאני", - "BASE_TYPE_CHOICES": "({{types}}) שדה זה חייב להיות אחד מ", - "BASE_TYPE_CLASS": "{{type}} מסוג instance שדה זה חייב להיות", + "BASE_TYPE_REQUIRED": "This field is required", + "BASE_TYPE_STRING": "This field must be a string", + "BASE_TYPE_NUMBER": "This field must be a number", + "BASE_TYPE_BIGINT": "This field must be a bigint", + "BASE_TYPE_BOOLEAN": "This field must be a boolean", + "BASE_TYPE_CHOICES": "This field must be one of ({{types}})", + "BASE_TYPE_CLASS": "This field must be an instance of {{type}}", "BASE_TYPE_OBJECT": "שדה זה חייב להיות אובייקט", "BASE_TYPE_ARRAY": "שדה זה חייב להיות מערך", - "UNKOWN_FIELD": "{{key}} :מפתח לא ידוע", - "BASE_TYPE_CONSTANT": "{{value}} שדה זה חייב להיות", + "UNKOWN_FIELD": "מפתח לא ידוע: {{key}}", + "BASE_TYPE_CONSTANT": "שדה זה להיות {{value}}", "EMAIL_TYPE_INVALID_EMAIL": "כתובת דואר אלקטרוני לא חוקית", - "DATE_TYPE_PARSE": "ISO8601 אמור להיות {{date}} לא ניתן לאתר", - "BASE_TYPE_BAD_LENGTH": "{{length}} האורך חייב להיות בין" + "DATE_TYPE_PARSE": "לא ניתן לנתח {{date}}. צריך להיות ISO8601", + "BASE_TYPE_BAD_LENGTH": "האורך חייב להיות בין {{length}}" } } From 7ecbfa0184dc3554329f1067dc6139ae5a425700 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:15 +0200 Subject: [PATCH 082/238] New translations auth.json (Romanian) --- api/locales/ro/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ro/auth.json b/api/locales/ro/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ro/auth.json +++ b/api/locales/ro/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 867191194c9f8996f1ee82f4cb4f589f3263bbd8 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:16 +0200 Subject: [PATCH 083/238] New translations auth.json (Indonesian) --- api/locales/id/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/id/auth.json b/api/locales/id/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/id/auth.json +++ b/api/locales/id/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 9ac5ebb03b994d49c5969e27f9f956e3654e4412 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:17 +0200 Subject: [PATCH 084/238] New translations auth.json (Serbian (Cyrillic)) --- api/locales/sr/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/sr/auth.json b/api/locales/sr/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/sr/auth.json +++ b/api/locales/sr/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 16017e85ddf75cdae3e41f18ec08c9bcfce0c0c2 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:17 +0200 Subject: [PATCH 085/238] New translations auth.json (Swedish) --- api/locales/sv/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/sv/auth.json b/api/locales/sv/auth.json index 04e557527..573e685d3 100644 --- a/api/locales/sv/auth.json +++ b/api/locales/sv/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-post eller telefon hittades inte", "INVALID_PASSWORD": "Ogiltigt lösenord", - "ACCOUNT_DISABLED": "Detta konto är inaktiverat" + "ACCOUNT_DISABLED": "Detta konto är inaktiverat", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "Registrering av nya användare är inaktiverat", From b418e062f5484afb162a4d9c98cf2dc755aaa7e6 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:18 +0200 Subject: [PATCH 086/238] New translations auth.json (Turkish) --- api/locales/tr/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/tr/auth.json b/api/locales/tr/auth.json index 1b3c4a8f4..670f07e32 100644 --- a/api/locales/tr/auth.json +++ b/api/locales/tr/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-posta veya Telefon Numarası bulunamadı", "INVALID_PASSWORD": "Geçersiz Şifre", - "ACCOUNT_DISABLED": "Bu hesap devre dışı bırakıldı" + "ACCOUNT_DISABLED": "Bu hesap devre dışı bırakıldı", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "Yeni kullanıcı alımı devre dışı bırakıldı", From fe9b3b7dec3336e9ca080fc1d0bbc117cffa703a Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:19 +0200 Subject: [PATCH 087/238] New translations auth.json (Ukrainian) --- api/locales/uk/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/uk/auth.json b/api/locales/uk/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/uk/auth.json +++ b/api/locales/uk/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From cbed0892a19d0ca5348ac363ed3c3a15ca2e72d4 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:20 +0200 Subject: [PATCH 088/238] New translations auth.json (Chinese Simplified) --- api/locales/zh/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/zh/auth.json b/api/locales/zh/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/zh/auth.json +++ b/api/locales/zh/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 9cbcc18779480ab3e4a08282ccb58d625a08fff3 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:22 +0200 Subject: [PATCH 089/238] New translations auth.json (Urdu (Pakistan)) --- api/locales/ur/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ur/auth.json b/api/locales/ur/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ur/auth.json +++ b/api/locales/ur/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 3b228690520565e0034091d471e3c0b60d443c0e Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:23 +0200 Subject: [PATCH 090/238] New translations auth.json (Vietnamese) --- api/locales/vi/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/vi/auth.json b/api/locales/vi/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/vi/auth.json +++ b/api/locales/vi/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 1f8e64b279618920bac781effa2f184c95dbc136 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:23 +0200 Subject: [PATCH 091/238] New translations auth.json (Portuguese, Brazilian) --- api/locales/pt/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/pt/auth.json b/api/locales/pt/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/pt/auth.json +++ b/api/locales/pt/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From af5d79c402300f3965b9f03a027365ae5ab00572 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:24 +0200 Subject: [PATCH 092/238] New translations auth.json (Persian) --- api/locales/fa/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/fa/auth.json b/api/locales/fa/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/fa/auth.json +++ b/api/locales/fa/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From ec6a16f21d9a9f0b851c8d7e8dbfeac6f9274589 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:25 +0200 Subject: [PATCH 093/238] New translations auth.json (Russian) --- api/locales/ru/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ru/auth.json b/api/locales/ru/auth.json index 39a75b611..be7ac8456 100644 --- a/api/locales/ru/auth.json +++ b/api/locales/ru/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "Данный адрес электронной почты или телефона не найден", "INVALID_PASSWORD": "Неверный пароль", - "ACCOUNT_DISABLED": "Этот аккаунт отключён" + "ACCOUNT_DISABLED": "Этот аккаунт отключён", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "Регистрация новых пользователей отключена", From 799b7ab064074086518f7030320b37ed731c4bee Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:26 +0200 Subject: [PATCH 094/238] New translations auth.json (Tamil) --- api/locales/ta/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ta/auth.json b/api/locales/ta/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ta/auth.json +++ b/api/locales/ta/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From c87225652a32eff0ec597fea2d0afe4e8cdd434f Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:27 +0200 Subject: [PATCH 095/238] New translations auth.json (Marathi) --- api/locales/mr/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/mr/auth.json b/api/locales/mr/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/mr/auth.json +++ b/api/locales/mr/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 70e6c052129ac514cfd4d44f8f904bdadaf7a920 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:28 +0200 Subject: [PATCH 096/238] New translations auth.json (Croatian) --- api/locales/hr/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/hr/auth.json b/api/locales/hr/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/hr/auth.json +++ b/api/locales/hr/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 5951aa218266efface50c86fae35550bdc2cd525 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:29 +0200 Subject: [PATCH 097/238] New translations auth.json (Norwegian Nynorsk) --- api/locales/nn/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/nn/auth.json b/api/locales/nn/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/nn/auth.json +++ b/api/locales/nn/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 9f5a579fb147f7664c1f325d610492556eecf240 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:30 +0200 Subject: [PATCH 098/238] New translations auth.json (Kazakh) --- api/locales/kk/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/kk/auth.json b/api/locales/kk/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/kk/auth.json +++ b/api/locales/kk/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 5bae82e40876ca0dccfb2e0bf0ab0512326cca12 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:31 +0200 Subject: [PATCH 099/238] New translations auth.json (Azerbaijani) --- api/locales/az/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/az/auth.json b/api/locales/az/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/az/auth.json +++ b/api/locales/az/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 578522fa73670bcc365f1a582a1073291efa34e7 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:32 +0200 Subject: [PATCH 100/238] New translations auth.json (Hindi) --- api/locales/hi/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/hi/auth.json b/api/locales/hi/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/hi/auth.json +++ b/api/locales/hi/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 1165fd6cf93c9e11460aed8fc346ac7d1e58fcb4 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:32 +0200 Subject: [PATCH 101/238] New translations auth.json (Maori) --- api/locales/mi/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/mi/auth.json b/api/locales/mi/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/mi/auth.json +++ b/api/locales/mi/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 8aa3442bd8024296a480e2c0935c6624e983b8d1 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:33 +0200 Subject: [PATCH 102/238] New translations auth.json (Telugu) --- api/locales/te/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/te/auth.json b/api/locales/te/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/te/auth.json +++ b/api/locales/te/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From a918fd4b2539f53ecadc04ce43119d0690896e06 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:34 +0200 Subject: [PATCH 103/238] New translations auth.json (Tagalog) --- api/locales/tl/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/tl/auth.json b/api/locales/tl/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/tl/auth.json +++ b/api/locales/tl/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 9bdea125a4ababb5add0c1518cbf791f32bbbf11 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:35 +0200 Subject: [PATCH 104/238] New translations auth.json (Slovak) --- api/locales/sk/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/sk/auth.json b/api/locales/sk/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/sk/auth.json +++ b/api/locales/sk/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From d7236bf6c50e0dc4fa306c10aa5a85171bb17610 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:37 +0200 Subject: [PATCH 105/238] New translations auth.json (French) --- api/locales/fr/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/fr/auth.json b/api/locales/fr/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/fr/auth.json +++ b/api/locales/fr/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 2a499261c3549ffcce11a50657295449ba4a4119 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:38 +0200 Subject: [PATCH 106/238] New translations auth.json (Basque) --- api/locales/eu/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/eu/auth.json b/api/locales/eu/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/eu/auth.json +++ b/api/locales/eu/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From b2951c6aff4ab015cc14ff8fd1fc225e454be3e8 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:39 +0200 Subject: [PATCH 107/238] New translations auth.json (Spanish) --- api/locales/es/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/es/auth.json b/api/locales/es/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/es/auth.json +++ b/api/locales/es/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 6afd1885bc03d95d682d0e7783c43cf6012a69d7 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:39 +0200 Subject: [PATCH 108/238] New translations auth.json (Afrikaans) --- api/locales/af/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/af/auth.json b/api/locales/af/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/af/auth.json +++ b/api/locales/af/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From b4a2c4f0f7f8537b451b67e41cbe348185184722 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:40 +0200 Subject: [PATCH 109/238] New translations auth.json (Arabic) --- api/locales/ar/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ar/auth.json b/api/locales/ar/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ar/auth.json +++ b/api/locales/ar/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From ebe1df44c8bdbb3401aa444f572729f1eba1d19d Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:41 +0200 Subject: [PATCH 110/238] New translations auth.json (Belarusian) --- api/locales/be/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/be/auth.json b/api/locales/be/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/be/auth.json +++ b/api/locales/be/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 8a308cfc31a53141a7d60233ce4343e20a7ad4a2 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:42 +0200 Subject: [PATCH 111/238] New translations auth.json (Bulgarian) --- api/locales/bg/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/bg/auth.json b/api/locales/bg/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/bg/auth.json +++ b/api/locales/bg/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 635dd6ca9e05ae776e10e121d5b4f9f19d2ec79d Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:43 +0200 Subject: [PATCH 112/238] New translations auth.json (Catalan) --- api/locales/ca/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ca/auth.json b/api/locales/ca/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ca/auth.json +++ b/api/locales/ca/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From b34a986e843583f88201e0a641572d4254c0e931 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:44 +0200 Subject: [PATCH 113/238] New translations auth.json (Czech) --- api/locales/cs/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/cs/auth.json b/api/locales/cs/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/cs/auth.json +++ b/api/locales/cs/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 5b8e6095d31ed6bdbbbeddd1c0ac52d05811943b Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:45 +0200 Subject: [PATCH 114/238] New translations auth.json (Danish) --- api/locales/da/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/da/auth.json b/api/locales/da/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/da/auth.json +++ b/api/locales/da/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 48c90f173d8295f639b1a6ffa7665f228d05d824 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:45 +0200 Subject: [PATCH 115/238] New translations auth.json (German) --- api/locales/de/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/de/auth.json b/api/locales/de/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/de/auth.json +++ b/api/locales/de/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 394271a46c293a7e0118fb0c82a1b0f3805ef233 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:46 +0200 Subject: [PATCH 116/238] New translations auth.json (Greek) --- api/locales/el/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/el/auth.json b/api/locales/el/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/el/auth.json +++ b/api/locales/el/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From de8c622f264c408195701020c347e793cb37c43b Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:47 +0200 Subject: [PATCH 117/238] New translations auth.json (Finnish) --- api/locales/fi/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/fi/auth.json b/api/locales/fi/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/fi/auth.json +++ b/api/locales/fi/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 5312081828c66b760e4ebabb4fab12507647fba1 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:48 +0200 Subject: [PATCH 118/238] New translations auth.json (Polish) --- api/locales/pl/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/pl/auth.json b/api/locales/pl/auth.json index 711cb4d7e..ff17f2377 100644 --- a/api/locales/pl/auth.json +++ b/api/locales/pl/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-mail lub numer telefonu nie został znaleziony", "INVALID_PASSWORD": "Nieprawidłowe hasło", - "ACCOUNT_DISABLED": "To konto jest nieaktywne" + "ACCOUNT_DISABLED": "To konto jest nieaktywne", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "Rejestracja nowych użytkowników jest wyłączona", From 28933fc7578b15eb1d798557b383822f6a32732c Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:49 +0200 Subject: [PATCH 119/238] New translations auth.json (Hebrew) --- api/locales/he/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/he/auth.json b/api/locales/he/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/he/auth.json +++ b/api/locales/he/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From b025d000d37b8e0b5645af31268ed42edc1c674b Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:50 +0200 Subject: [PATCH 120/238] New translations auth.json (Hungarian) --- api/locales/hu/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/hu/auth.json b/api/locales/hu/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/hu/auth.json +++ b/api/locales/hu/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 080cab1819391d0ddfc75bb725fda588c48bd410 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:51 +0200 Subject: [PATCH 121/238] New translations auth.json (Italian) --- api/locales/it/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/it/auth.json b/api/locales/it/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/it/auth.json +++ b/api/locales/it/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From bf1c6756b459696702cf78201a72f8a826eace22 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:52 +0200 Subject: [PATCH 122/238] New translations auth.json (Japanese) --- api/locales/ja/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ja/auth.json b/api/locales/ja/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ja/auth.json +++ b/api/locales/ja/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 5a7d7cb3daa25f6b78e8a3da80f6b3928a7e117d Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:53 +0200 Subject: [PATCH 123/238] New translations auth.json (Korean) --- api/locales/ko/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ko/auth.json b/api/locales/ko/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ko/auth.json +++ b/api/locales/ko/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From dd3f69ab333595eecb56acfed6bbdf1a26c76bc0 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:54 +0200 Subject: [PATCH 124/238] New translations auth.json (Lithuanian) --- api/locales/lt/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/lt/auth.json b/api/locales/lt/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/lt/auth.json +++ b/api/locales/lt/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 8bc4bdc60fc436df68ec78932c0d0daa2a113592 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:54 +0200 Subject: [PATCH 125/238] New translations auth.json (Mongolian) --- api/locales/mn/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/mn/auth.json b/api/locales/mn/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/mn/auth.json +++ b/api/locales/mn/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From f98af7480a42dbbf68ac102308a39ab930eea691 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:55 +0200 Subject: [PATCH 126/238] New translations auth.json (Dutch) --- api/locales/nl/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/nl/auth.json b/api/locales/nl/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/nl/auth.json +++ b/api/locales/nl/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 7eadac6a82ab62ea1808e4afea27de401d3f0b48 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:56 +0200 Subject: [PATCH 127/238] New translations auth.json (Norwegian) --- api/locales/no/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/no/auth.json b/api/locales/no/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/no/auth.json +++ b/api/locales/no/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 4d66b3e2e579095daaba37eaa4dd68c50f406333 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:57 +0200 Subject: [PATCH 128/238] New translations auth.json (Punjabi) --- api/locales/pa/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/pa/auth.json b/api/locales/pa/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/pa/auth.json +++ b/api/locales/pa/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 019470caeaea746ea7a95697975d73f613802936 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:58 +0200 Subject: [PATCH 129/238] New translations auth.json (Esperanto) --- api/locales/eo/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/eo/auth.json b/api/locales/eo/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/eo/auth.json +++ b/api/locales/eo/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From d6d4af661555784c6bf9d29cfd280a6472b72d10 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:44:59 +0200 Subject: [PATCH 130/238] New translations auth.json (Uyghur) --- api/locales/ug/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ug/auth.json b/api/locales/ug/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ug/auth.json +++ b/api/locales/ug/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 1904cdc872ef4b7b1eca06711e92c9e5d96bf99f Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:01 +0200 Subject: [PATCH 131/238] New translations auth.json (Tibetan) --- api/locales/bo/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/bo/auth.json b/api/locales/bo/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/bo/auth.json +++ b/api/locales/bo/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 2c1365e54490d70034383833ef52d0a159d9f8a0 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:02 +0200 Subject: [PATCH 132/238] New translations auth.json (Latin) --- api/locales/la/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/la/auth.json b/api/locales/la/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/la/auth.json +++ b/api/locales/la/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 35502b2d81636de01f21073d751c876104906de9 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:03 +0200 Subject: [PATCH 133/238] New translations auth.json (Sinhala) --- api/locales/si/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/si/auth.json b/api/locales/si/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/si/auth.json +++ b/api/locales/si/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 26ff03ada2e2f531972f1fa0a05c513beebb3855 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:04 +0200 Subject: [PATCH 134/238] New translations auth.json (Swahili) --- api/locales/sw/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/sw/auth.json b/api/locales/sw/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/sw/auth.json +++ b/api/locales/sw/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From b40cf4d8266d612d880184d93f421142eb1c5030 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:06 +0200 Subject: [PATCH 135/238] New translations auth.json (Kurmanji (Kurdish)) --- api/locales/ku/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ku/auth.json b/api/locales/ku/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ku/auth.json +++ b/api/locales/ku/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 02872e51efff119b52e31f739d4d8d4d1af0a970 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:07 +0200 Subject: [PATCH 136/238] New translations auth.json (Hausa) --- api/locales/ha/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ha/auth.json b/api/locales/ha/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ha/auth.json +++ b/api/locales/ha/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 8983d4a4d42ee72820cae8f24ba55c1b6cf77acf Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:08 +0200 Subject: [PATCH 137/238] New translations auth.json (Berber) --- api/locales/ber/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/ber/auth.json b/api/locales/ber/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/ber/auth.json +++ b/api/locales/ber/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 9a604216224ea19e7f5209c4705fa5e4e1b63401 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:09 +0200 Subject: [PATCH 138/238] New translations auth.json (Serbo-Croatian) --- api/locales/sh/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/sh/auth.json b/api/locales/sh/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/sh/auth.json +++ b/api/locales/sh/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 882da3369e2282632dbc4326d9cb1fb7823475a3 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:10 +0200 Subject: [PATCH 139/238] New translations auth.json (Quechua) --- api/locales/qu/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/qu/auth.json b/api/locales/qu/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/qu/auth.json +++ b/api/locales/qu/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 593547e584b33fa5d54fb5a771b5346583762dd3 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:11 +0200 Subject: [PATCH 140/238] New translations auth.json (Guarani) --- api/locales/gn/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/gn/auth.json b/api/locales/gn/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/gn/auth.json +++ b/api/locales/gn/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From 5748be814a3ec29bf2c58414294c24c737214949 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:12 +0200 Subject: [PATCH 141/238] New translations auth.json (Javanese) --- api/locales/jv/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/jv/auth.json b/api/locales/jv/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/jv/auth.json +++ b/api/locales/jv/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From c0b118906002bfd3646ab325fd67f2310be10887 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 6 Aug 2022 02:45:13 +0200 Subject: [PATCH 142/238] New translations auth.json (Venetian) --- api/locales/vec/auth.json | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/api/locales/vec/auth.json b/api/locales/vec/auth.json index e19547a01..a78d4d60b 100644 --- a/api/locales/vec/auth.json +++ b/api/locales/vec/auth.json @@ -2,7 +2,9 @@ "login": { "INVALID_LOGIN": "E-Mail or Phone not found", "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled" + "ACCOUNT_DISABLED": "This account is disabled", + "INVALID_TOTP_CODE": "Invalid two-factor code.", + "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { "REGISTRATION_DISABLED": "New user registration is disabled", From d8215365720fa77c5e82f361f082e942f7223f10 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 6 Aug 2022 15:08:19 +0200 Subject: [PATCH 143/238] Add utility scripts --- bundle/package.json | 4 ++- bundle/scripts/build.js | 44 +++++++++++++------------- bundle/scripts/depcheck.js | 56 +++++++++++++++++++++++++++++++++ bundle/scripts/depclean.js | 63 ++++++++++++++++++++++++++++++++++++++ bundle/scripts/utils.js | 53 ++++++++++++++++++++++++++++++++ 5 files changed, 196 insertions(+), 24 deletions(-) create mode 100644 bundle/scripts/depcheck.js create mode 100644 bundle/scripts/depclean.js create mode 100644 bundle/scripts/utils.js diff --git a/bundle/package.json b/bundle/package.json index 311fab18c..49aadeb8f 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -4,7 +4,9 @@ "description": "", "main": "src/start.js", "scripts": { - "setup": "node scripts/install.js && npm install --no-optional && npx ts-patch install -s && npx patch-package --patch-dir ../api/patches/ && npm run build", + "setup": "node scripts/install.js && npm install --omit optional && ts-patch install -s && patch-package --patch-dir ../api/patches/ && npm run build", + "depclean": "node scripts/depclean.js", + "depcheck": "node scripts/depcheck.js", "build": "node scripts/build.js", "start": "node scripts/build.js && node dist/bundle/src/start.js", "start:bundle": "node dist/bundle/src/start.js", diff --git a/bundle/scripts/build.js b/bundle/scripts/build.js index f73fb11a2..8a1b3c83b 100644 --- a/bundle/scripts/build.js +++ b/bundle/scripts/build.js @@ -2,39 +2,32 @@ const { execSync } = require("child_process"); const path = require("path"); const fs = require("fs"); const { getSystemErrorMap } = require("util"); -const { argv } = require("process"); +const { argv, stdout, exit } = require("process"); +const {copyRecursiveSync,execIn} = require('./utils'); -var steps = 2, i = 0; +if(argv.includes("help")) { + console.log(`Fosscord build script help: + +Arguments: + clean Cleans up previous builds + copyonly Only copy source files, don't build (useful for updating assets) + verbose Enable verbose logging + logerrors Log build errors to console + pretty-errors Pretty-print build errors`); + exit(0); +} + +let steps = 3, i = 0; if (argv.includes("clean")) steps++; if (argv.includes("copyonly")) steps--; const dirs = ["api", "util", "cdn", "gateway", "bundle"]; const verbose = argv.includes("verbose") || argv.includes("v"); -var copyRecursiveSync = function(src, dest) { - if(verbose) console.log(`cpsync: ${src} -> ${dest}`); - var exists = fs.existsSync(src); - if(!exists){ - console.log(src + " doesn't exist, not copying!"); - return; - } - var stats = exists && fs.statSync(src); - var isDirectory = exists && stats.isDirectory(); - if (isDirectory) { - fs.mkdirSync(dest, {recursive: true}); - fs.readdirSync(src).forEach(function(childItemName) { - copyRecursiveSync(path.join(src, childItemName), - path.join(dest, childItemName)); - }); - } else { - fs.copyFileSync(src, dest); - } - }; - if (argv.includes("clean")) { console.log(`[${++i}/${steps}] Cleaning...`); dirs.forEach((a) => { - var d = "../" + a + "/dist"; + let d = "../" + a + "/dist"; if (fs.existsSync(d)) { fs.rmSync(d, { recursive: true }); if (verbose) console.log(`Deleted ${d}!`); @@ -42,6 +35,11 @@ if (argv.includes("clean")) { }); } +console.log(`[${++i}/${steps}] Checking if dependencies were installed correctly...`); +//exif-be-gone v1.3.0 doesnt build js, known bug +if(!fs.existsSync(path.join(__dirname, "..", "node_modules", "exif-be-gone", "index.js"))) + execIn("npm run build", path.join(__dirname, "..", "node_modules", "exif-be-gone")); + console.log(`[${++i}/${steps}] Copying src files...`); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "assets"), path.join(__dirname, "..", "dist", "api", "assets")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "client_test"), path.join(__dirname, "..", "dist", "api", "client_test")); diff --git a/bundle/scripts/depcheck.js b/bundle/scripts/depcheck.js new file mode 100644 index 000000000..1957f794c --- /dev/null +++ b/bundle/scripts/depcheck.js @@ -0,0 +1,56 @@ +const path = require("path"); +const fs = require("fs"); +const { env } = require("process"); +const { execSync } = require("child_process"); +const { argv, stdout, exit } = require("process"); + +const { execIn, getLines, parts } = require("./utils"); + +let npmi_extra_flags = ""; + +const resolveminor = argv.includes("resolveminor"); +if(argv.includes("nobuild")) npmi_extra_flags += "--ignore-scripts "; + +parts.forEach((part) => { + let partDir = path.join(__dirname, "..", "..", part); + let distDir = path.join(partDir, "dist"); + console.log(`Checking updates for ${part} (${partDir})`); + if(part == "bundle") { + execIn(`npm run syncdeps`, partDir) + } + if(resolveminor) { + fs.rmSync(path.join(partDir, "node_modules"), { + recursive: true, + force: true, + }); + execIn(`npm i --save --no-fund --no-audit --no-package-lock ${npmi_extra_flags}`, partDir) + } + let x = [ + [ + "pkg", + { + current: "1.0", + wanted: "2.0", + latest: "2.0", + dependent: "cdn", + location: "/usr/src/fosscord/bundle/node_packages/pkg", + }, + ], + ]; + x = Object.entries( + JSON.parse(execIn("npm outdated --json", partDir)) + ); + x.forEach((a) => { + let pkgname = a[0]; + let pkginfo = a[1]; + if(!pkginfo.current) + console.log(`MISSING ${pkgname}: ${pkginfo.current} -> ${pkginfo.wanted} (latest: ${pkginfo.latest})`); + else if(pkginfo.latest != pkginfo.wanted){ + if(pkginfo.current != pkginfo.wanted) + console.log(`MINOR ${pkgname}: ${pkginfo.current} -> ${pkginfo.wanted}`); + console.log(`MAJOR ${pkgname}: ${pkginfo.current} -> ${pkginfo.latest}`); + } + else + console.log(`MINOR ${pkgname}: ${pkginfo.current} -> ${pkginfo.wanted}`); + }); +}); diff --git a/bundle/scripts/depclean.js b/bundle/scripts/depclean.js new file mode 100644 index 000000000..6d9a22605 --- /dev/null +++ b/bundle/scripts/depclean.js @@ -0,0 +1,63 @@ +const path = require("path"); +const fs = require("fs"); +const { env } = require("process"); +const { execSync } = require("child_process"); +const { argv, stdout, exit } = require("process"); + +const { execIn, getLines, parts } = require('./utils'); + +const bundleRequired = ["@ovos-media/ts-transform-paths"]; +const removeModules = argv.includes("cleanup"); + +parts.forEach((part) => { + console.log(`Installing all packages for ${part}...`); + execIn("npm i", path.join(__dirname, "..", "..", part)); +}); + +parts.forEach((part) => { + let partDir = path.join(__dirname, "..", "..", part); + let distDir = path.join(partDir, "dist"); + let start = 0; + start = getLines( + execIn("npm ls --parseable --package-lock-only -a", partDir) + ); + if (fs.existsSync(distDir)) + fs.rmSync(distDir, { + recursive: true, + force: true, + }); + let x = { + dependencies: [], + devDependencies: [], + invalidDirs: [], + invalidFiles: [], + missing: [], + using: [], + }; + x = JSON.parse(execIn("npx depcheck --json", partDir).stdout); + + fs.writeFileSync( + path.join(__dirname, "..", `depclean.out.${part}.json`), + JSON.stringify(x, null, "\t"), + { encoding: "utf8" } + ); + + let depsToRemove = x.dependencies.join(" "); + if (depsToRemove) execIn(`npm r --save ${depsToRemove}`, partDir); + + depsToRemove = x.devDependencies.join(" "); + if (depsToRemove) execIn(`npm r --save --dev ${depsToRemove}`, partDir); + + if (removeModules && fs.existsSync(path.join(partDir, "node_modules"))) + fs.rmSync(path.join(partDir, "node_modules"), { + recursive: true, + force: true, + }); + let end = getLines( + execIn("npm ls --parseable --package-lock-only -a", partDir) + ); + console.log(`${part}: ${start} -> ${end} (diff: ${start - end})`); +}); +console.log("Installing required packages for bundle..."); + +execIn(`npm i --save ${bundleRequired.join(" ")}`, path.join(__dirname, "..")); diff --git a/bundle/scripts/utils.js b/bundle/scripts/utils.js new file mode 100644 index 000000000..bf960532f --- /dev/null +++ b/bundle/scripts/utils.js @@ -0,0 +1,53 @@ +const path = require("path"); +const fs = require("fs"); +const { env } = require("process"); +const { execSync } = require("child_process"); +const { argv, stdout, exit } = require("process"); + +const parts = ["api", "util", "cdn", "gateway", "bundle"]; + +function copyRecursiveSync(src, dest) { + //if (verbose) console.log(`cpsync: ${src} -> ${dest}`); + let exists = fs.existsSync(src); + if (!exists) { + console.log(src + " doesn't exist, not copying!"); + return; + } + let stats = exists && fs.statSync(src); + let isDirectory = exists && stats.isDirectory(); + if (isDirectory) { + fs.mkdirSync(dest, { recursive: true }); + fs.readdirSync(src).forEach(function (childItemName) { + copyRecursiveSync( + path.join(src, childItemName), + path.join(dest, childItemName) + ); + }); + } else { + fs.copyFileSync(src, dest); + } +} + +function execIn(cmd, workdir) { + try { + return execSync(cmd, { + cwd: workdir, + shell: true, + env: process.env, + encoding: "utf-8", + }); + } catch (error) { + return error.stdout; + } +} + +function getLines(output) { + return output.split("\n").length; +} + +module.exports = { + //consts + parts, + //functions + copyRecursiveSync, execIn, getLines +}; From fca4480c97124cfbd2352d47f14c27d1f3767cc9 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 6 Aug 2022 15:24:12 +0200 Subject: [PATCH 144/238] Add silent mode --- bundle/scripts/build.js | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/bundle/scripts/build.js b/bundle/scripts/build.js index 8a1b3c83b..99454be6a 100644 --- a/bundle/scripts/build.js +++ b/bundle/scripts/build.js @@ -3,7 +3,7 @@ const path = require("path"); const fs = require("fs"); const { getSystemErrorMap } = require("util"); const { argv, stdout, exit } = require("process"); -const {copyRecursiveSync,execIn} = require('./utils'); +const { copyRecursiveSync, execIn, parts} = require('./utils'); if(argv.includes("help")) { console.log(`Fosscord build script help: @@ -13,20 +13,23 @@ Arguments: copyonly Only copy source files, don't build (useful for updating assets) verbose Enable verbose logging logerrors Log build errors to console - pretty-errors Pretty-print build errors`); + pretty-errors Pretty-print build errors + silent No output, no build log`); exit(0); } let steps = 3, i = 0; if (argv.includes("clean")) steps++; if (argv.includes("copyonly")) steps--; -const dirs = ["api", "util", "cdn", "gateway", "bundle"]; const verbose = argv.includes("verbose") || argv.includes("v"); +const silent = argv.includes("silent"); + +if(silent) console.log = function() {} if (argv.includes("clean")) { console.log(`[${++i}/${steps}] Cleaning...`); - dirs.forEach((a) => { + parts.forEach((a) => { let d = "../" + a + "/dist"; if (fs.existsSync(d)) { fs.rmSync(d, { recursive: true }); @@ -44,7 +47,7 @@ console.log(`[${++i}/${steps}] Copying src files...`); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "assets"), path.join(__dirname, "..", "dist", "api", "assets")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "client_test"), path.join(__dirname, "..", "dist", "api", "client_test")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "locales"), path.join(__dirname, "..", "dist", "api", "locales")); -dirs.forEach((a) => { +parts.forEach((a) => { copyRecursiveSync("../" + a + "/src", "dist/" + a + "/src"); if (verbose) console.log(`Copied ${"../" + a + "/dist"} -> ${"dist/" + a + "/src"}!`); }); From 11227bb2b3810432f77ea94c9eac26b4875397f2 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 6 Aug 2022 15:32:28 +0200 Subject: [PATCH 145/238] Update gitignore, push correct version of build script --- .gitignore | 3 +++ bundle/scripts/build.js | 42 ++++++++++++++++++++++++++++++----------- 2 files changed, 34 insertions(+), 11 deletions(-) diff --git a/.gitignore b/.gitignore index 607b4f5a1..0f1d93323 100644 --- a/.gitignore +++ b/.gitignore @@ -13,3 +13,6 @@ api/assets/plugins/*.js .idea/ *.code-workspace + +*.log +*.log.ansi \ No newline at end of file diff --git a/bundle/scripts/build.js b/bundle/scripts/build.js index 99454be6a..1a12ae73e 100644 --- a/bundle/scripts/build.js +++ b/bundle/scripts/build.js @@ -3,33 +3,35 @@ const path = require("path"); const fs = require("fs"); const { getSystemErrorMap } = require("util"); const { argv, stdout, exit } = require("process"); -const { copyRecursiveSync, execIn, parts} = require('./utils'); +const {copyRecursiveSync,execIn} = require('./utils'); if(argv.includes("help")) { console.log(`Fosscord build script help: - Arguments: clean Cleans up previous builds copyonly Only copy source files, don't build (useful for updating assets) verbose Enable verbose logging logerrors Log build errors to console pretty-errors Pretty-print build errors - silent No output, no build log`); + silent No output to console or files.`); exit(0); } let steps = 3, i = 0; if (argv.includes("clean")) steps++; if (argv.includes("copyonly")) steps--; +const dirs = ["api", "util", "cdn", "gateway", "bundle"]; const verbose = argv.includes("verbose") || argv.includes("v"); +const logerr = argv.includes("logerrors"); +const pretty = argv.includes("pretty-errors"); const silent = argv.includes("silent"); -if(silent) console.log = function() {} +if(silent) console.error = console.log = function(){} if (argv.includes("clean")) { console.log(`[${++i}/${steps}] Cleaning...`); - parts.forEach((a) => { + dirs.forEach((a) => { let d = "../" + a + "/dist"; if (fs.existsSync(d)) { fs.rmSync(d, { recursive: true }); @@ -47,7 +49,7 @@ console.log(`[${++i}/${steps}] Copying src files...`); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "assets"), path.join(__dirname, "..", "dist", "api", "assets")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "client_test"), path.join(__dirname, "..", "dist", "api", "client_test")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "locales"), path.join(__dirname, "..", "dist", "api", "locales")); -parts.forEach((a) => { +dirs.forEach((a) => { copyRecursiveSync("../" + a + "/src", "dist/" + a + "/src"); if (verbose) console.log(`Copied ${"../" + a + "/dist"} -> ${"dist/" + a + "/src"}!`); }); @@ -55,13 +57,16 @@ parts.forEach((a) => { if (!argv.includes("copyonly")) { console.log(`[${++i}/${steps}] Compiling src files ...`); - console.log( + let buildFlags = '' + if(pretty) buildFlags += '--pretty ' + + try { execSync( 'node "' + path.join(__dirname, "..", "node_modules", "typescript", "lib", "tsc.js") + '" -p "' + path.join(__dirname, "..") + - '"', + '" ' + buildFlags, { cwd: path.join(__dirname, ".."), shell: true, @@ -69,6 +74,21 @@ if (!argv.includes("copyonly")) { encoding: "utf8" } ) - ); -} - + } catch (error) { + if(verbose || logerr) { + error.stdout.split(/\r?\n/).forEach((line) => { + let _line = line.replace('dist/','',1); + if(!pretty && _line.includes('.ts(')) { + //reformat file path for easy jumping + _line = _line.replace('(',':',1).replace(',',':',1).replace(')','',1) + } + console.error(_line); + }) + } + console.error(`Build failed! Please check build.log for info!`); + if(!silent){ + if(pretty) fs.writeFileSync("build.log.ansi", error.stdout); + fs.writeFileSync("build.log", error.stdout.replaceAll(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '')); + } + } +} \ No newline at end of file From 8691dbfbaea96f645df190c9cc25d1ece5f2e694 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 6 Aug 2022 15:34:05 +0200 Subject: [PATCH 146/238] Make build script use parts, defined in utils.js --- bundle/scripts/build.js | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/bundle/scripts/build.js b/bundle/scripts/build.js index 1a12ae73e..f53a22233 100644 --- a/bundle/scripts/build.js +++ b/bundle/scripts/build.js @@ -3,7 +3,7 @@ const path = require("path"); const fs = require("fs"); const { getSystemErrorMap } = require("util"); const { argv, stdout, exit } = require("process"); -const {copyRecursiveSync,execIn} = require('./utils'); +const { copyRecursiveSync, execIn, parts } = require('./utils'); if(argv.includes("help")) { console.log(`Fosscord build script help: @@ -20,7 +20,6 @@ Arguments: let steps = 3, i = 0; if (argv.includes("clean")) steps++; if (argv.includes("copyonly")) steps--; -const dirs = ["api", "util", "cdn", "gateway", "bundle"]; const verbose = argv.includes("verbose") || argv.includes("v"); const logerr = argv.includes("logerrors"); @@ -31,7 +30,7 @@ if(silent) console.error = console.log = function(){} if (argv.includes("clean")) { console.log(`[${++i}/${steps}] Cleaning...`); - dirs.forEach((a) => { + parts.forEach((a) => { let d = "../" + a + "/dist"; if (fs.existsSync(d)) { fs.rmSync(d, { recursive: true }); @@ -49,7 +48,7 @@ console.log(`[${++i}/${steps}] Copying src files...`); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "assets"), path.join(__dirname, "..", "dist", "api", "assets")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "client_test"), path.join(__dirname, "..", "dist", "api", "client_test")); copyRecursiveSync(path.join(__dirname, "..", "..", "api", "locales"), path.join(__dirname, "..", "dist", "api", "locales")); -dirs.forEach((a) => { +parts.forEach((a) => { copyRecursiveSync("../" + a + "/src", "dist/" + a + "/src"); if (verbose) console.log(`Copied ${"../" + a + "/dist"} -> ${"dist/" + a + "/src"}!`); }); From df3b658b1e8daa24d9dfea7c9cc2bebd2dbf2960 Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 16:37:13 -0400 Subject: [PATCH 147/238] Fix Missing Directory: preload-plugins --- api/assets/preload-plugins/.gitkeep | 1 + 1 file changed, 1 insertion(+) create mode 100644 api/assets/preload-plugins/.gitkeep diff --git a/api/assets/preload-plugins/.gitkeep b/api/assets/preload-plugins/.gitkeep new file mode 100644 index 000000000..8b1378917 --- /dev/null +++ b/api/assets/preload-plugins/.gitkeep @@ -0,0 +1 @@ + From 2ef49012b862f98f15414d06b4ef6209b01cf766 Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 16:42:55 -0400 Subject: [PATCH 148/238] Remove: console.log(`CACHE MISS! Asset file: x`); --- api/src/middlewares/TestClient.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/api/src/middlewares/TestClient.ts b/api/src/middlewares/TestClient.ts index 7292868c9..466d4bccf 100644 --- a/api/src/middlewares/TestClient.ts +++ b/api/src/middlewares/TestClient.ts @@ -40,7 +40,6 @@ export default function TestClient(app: Application) { }); } else { - console.log(`CACHE MISS! Asset file: ${req.params.file}`); response = await fetch(`https://discord.com/assets/${req.params.file}`, { agent, // @ts-ignore @@ -144,4 +143,4 @@ function stripHeaders(headers: Headers): Headers { headers.delete(headerName); }); return headers; -} \ No newline at end of file +} From 8e7b96864fdfa7ae9de7010103d2d319ee84e948 Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 16:47:27 -0400 Subject: [PATCH 149/238] Add @yukikaze-bot/erlpack for Desktop Client --- api/package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/api/package.json b/api/package.json index 58f35697f..b46e5f3d6 100644 --- a/api/package.json +++ b/api/package.json @@ -67,6 +67,7 @@ "@fosscord/util": "file:../util", "@sentry/node": "^6.16.1", "@sentry/tracing": "^6.16.1", + "@yukikaze-bot/erlpack": "^1.0.1", "ajv": "8.6.2", "ajv-formats": "^2.1.1", "amqplib": "^0.8.0", From 7b87a6a25e21bb22f24ffb1b11d51b5faffccced Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 16:49:14 -0400 Subject: [PATCH 150/238] Add erlpack dependency for bundle as well --- bundle/package.json | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/bundle/package.json b/bundle/package.json index 311fab18c..b1b6fbe97 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -66,6 +66,7 @@ "@fosscord/gateway": "file:../gateway", "@sentry/node": "^6.16.1", "@sentry/tracing": "^6.16.1", + "@yukikaze-bot/erlpack": "^1.0.1", "ajv": "8.6.2", "ajv-formats": "^2.1.1", "amqplib": "^0.8.0", @@ -112,4 +113,4 @@ "ws": "^7.4.2", "node-2fa": "^2.0.3" } -} \ No newline at end of file +} From c60d451296cfd224d7bc95a374c9b1ef5b1d9e0c Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 17:02:25 -0400 Subject: [PATCH 151/238] New logo fix 1 --- gateway/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gateway/README.md b/gateway/README.md index 9ae6a5f1e..959d0d5be 100644 --- a/gateway/README.md +++ b/gateway/README.md @@ -1,5 +1,5 @@

- +

Fosscord WebSocket Gateway Server

From 32394b8c10eda829d4278ebbca9f1825c3cb4603 Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 17:02:47 -0400 Subject: [PATCH 152/238] New logo fix 2 --- util/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/README.md b/util/README.md index fc9ad6383..1934df2a7 100644 --- a/util/README.md +++ b/util/README.md @@ -1,5 +1,5 @@

- +

Fosscord server util

From b3b1ca851f08e4031719571970a443abe59824b8 Mon Sep 17 00:00:00 2001 From: ChrisEric1 CECL Date: Sat, 6 Aug 2022 17:03:04 -0400 Subject: [PATCH 153/238] New logo fix 3 --- api/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/README.md b/api/README.md index 384a96110..62349972b 100644 --- a/api/README.md +++ b/api/README.md @@ -1,5 +1,5 @@

- +

Fosscord HTTP API Server

From afb82deb941efe752c10a530ff3d163734b6d4ea Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Tue, 9 Aug 2022 23:01:40 +0200 Subject: [PATCH 154/238] Update User.ts --- util/src/entities/User.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 470398a5b..bd70780dd 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -322,7 +322,7 @@ export const defaultSettings: UserSettings = { inline_attachment_media: true, inline_embed_media: true, locale: "en-US", - message_display_compact: true, + message_display_compact: false, native_phone_integration_enabled: true, render_embeds: true, render_reactions: true, From e536fb2f72e4883979b451b60b12c44f5f94313c Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 18 Jul 2022 18:30:53 +0200 Subject: [PATCH 155/238] replace all var with let (reduces warnings) --- api/assets/inline-plugins/autoRegister.js | 2 +- api/assets/inline-plugins/fosscord-login.js | 2 +- api/client_test/index.html | 4 ++-- api/scripts/generate_openapi.js | 2 +- api/scripts/generate_schema.js | 10 +++++----- api/scripts/stresstest/index.js | 10 +++++----- api/scripts/stresstest/src/login/index.js | 6 +++--- api/scripts/stresstest/src/message/send.js | 6 +++--- api/scripts/stresstest/src/register/index.js | 10 +++++----- api/src/Server.ts | 2 +- api/src/middlewares/RateLimit.ts | 10 +++++----- api/src/routes/channels/#channel_id/index.ts | 2 +- .../#channel_id/messages/#message_id/index.ts | 4 ++-- .../#channel_id/messages/#message_id/reactions.ts | 2 +- .../routes/channels/#channel_id/messages/index.ts | 10 +++++----- api/src/routes/channels/#channel_id/permissions.ts | 4 ++-- api/src/routes/channels/#channel_id/purge.ts | 2 +- api/src/routes/channels/#channel_id/webhooks.ts | 2 +- api/src/routes/discoverable-guilds.ts | 4 ++-- api/src/routes/discovery.ts | 2 +- api/src/routes/guild-recommendations.ts | 2 +- api/src/routes/guilds/#guild_id/delete.ts | 2 +- api/src/routes/guilds/#guild_id/index.ts | 2 +- .../guilds/#guild_id/members/#member_id/index.ts | 8 ++++---- .../guilds/#guild_id/members/#member_id/nick.ts | 4 ++-- api/src/routes/guilds/#guild_id/prune.ts | 10 +++++----- api/src/routes/guilds/#guild_id/templates.ts | 2 +- .../#guild_id/voice-states/#user_id/index.ts | 2 +- api/src/routes/guilds/#guild_id/widget.json.ts | 2 +- api/src/routes/users/#id/profile.ts | 8 ++++---- api/src/routes/users/#id/relationships.ts | 4 ++-- api/src/routes/users/@me/index.ts | 2 +- api/src/routes/users/@me/relationships.ts | 6 +++--- api/src/start.ts | 4 ++-- api/src/util/handlers/Message.ts | 12 ++++++------ api/src/util/handlers/route.ts | 2 +- api/src/util/utility/passwordStrength.ts | 2 +- api/tests/routes.test.ts | 14 +++++++------- bundle/scripts/benchmark/connections.js | 4 ++-- bundle/src/start.ts | 2 +- bundle/src/stats.ts | 2 +- cdn/src/routes/attachments.ts | 4 ++-- cdn/src/routes/avatars.ts | 6 +++--- cdn/src/routes/role-icons.ts | 6 +++--- cdn/src/util/FileStorage.ts | 2 +- gateway/src/events/Connection.ts | 2 +- gateway/src/events/Message.ts | 4 ++-- gateway/src/opcodes/Identify.ts | 4 ++-- gateway/src/start.ts | 2 +- gateway/src/util/Send.ts | 2 +- util/src/entities/Channel.ts | 2 +- util/src/entities/Guild.ts | 4 ++-- util/src/util/AutoUpdate.ts | 2 +- util/src/util/Config.ts | 6 +++--- util/src/util/Database.ts | 4 ++-- util/src/util/Permissions.ts | 10 +++++----- util/src/util/Rights.ts | 2 +- util/src/util/Snowflake.ts | 8 ++++---- util/tests/setupJest.js | 2 +- webrtc/src/Server.ts | 2 +- 60 files changed, 133 insertions(+), 133 deletions(-) diff --git a/api/assets/inline-plugins/autoRegister.js b/api/assets/inline-plugins/autoRegister.js index bb0b903d8..7bca39f86 100644 --- a/api/assets/inline-plugins/autoRegister.js +++ b/api/assets/inline-plugins/autoRegister.js @@ -44,7 +44,7 @@ function _generateName() { return `${prefix.random()}${suffix.random()}`; } -var token = JSON.parse(localStorage.getItem("token")); +let token = JSON.parse(localStorage.getItem("token")); if (!token && location.pathname !== "/login" && location.pathname !== "/register") { fetch(`${window.GLOBAL_ENV.API_ENDPOINT}/auth/register`, { method: "POST", diff --git a/api/assets/inline-plugins/fosscord-login.js b/api/assets/inline-plugins/fosscord-login.js index 38f822000..9191dad45 100644 --- a/api/assets/inline-plugins/fosscord-login.js +++ b/api/assets/inline-plugins/fosscord-login.js @@ -6,7 +6,7 @@ // fosscord-login.css after login is successful, but not if you reload the page after logging in. This script is to remove fosscord-login.css in // that specific case. -var token = JSON.parse(localStorage.getItem("token")); +let token = JSON.parse(localStorage.getItem("token")); if (!token && location.pathname !== "/login" && location.pathname !== "/register") { document.getElementById("logincss").remove(); } diff --git a/api/client_test/index.html b/api/client_test/index.html index 7a4fe6276..f58a4bca5 100644 --- a/api/client_test/index.html +++ b/api/client_test/index.html @@ -53,9 +53,9 @@ ); setInterval(() => { - var token = JSON.parse(localStorage.getItem("token")); + let token = JSON.parse(localStorage.getItem("token")); if (token) { - var logincss = document.querySelector('#logincss'), + let logincss = document.querySelector('#logincss'), canRemove = logincss ? logincss: ""; if(canRemove !== "") { document.querySelector("#logincss").remove(); diff --git a/api/scripts/generate_openapi.js b/api/scripts/generate_openapi.js index c9de9fa6d..9624a5b91 100644 --- a/api/scripts/generate_openapi.js +++ b/api/scripts/generate_openapi.js @@ -11,7 +11,7 @@ const schemas = JSON.parse(fs.readFileSync(SchemaPath, { encoding: "utf8" })); const specification = JSON.parse(fs.readFileSync(openapiPath, { encoding: "utf8" })); function combineSchemas(schemas) { - var definitions = {}; + let definitions = {}; for (const name in schemas) { definitions = { diff --git a/api/scripts/generate_schema.js b/api/scripts/generate_schema.js index b56c3fbc5..7a498ad67 100644 --- a/api/scripts/generate_schema.js +++ b/api/scripts/generate_schema.js @@ -40,7 +40,7 @@ const Excluded = [ ]; function modify(obj) { - for (var k in obj) { + for (let k in obj) { if (typeof obj[k] === "object" && obj[k] !== null) { modify(obj[k]); } @@ -62,7 +62,7 @@ function main() { let schemas = generator.getUserSymbols().filter((x) => (x.endsWith("Schema") || x.endsWith("Response")) && !Excluded.includes(x)); console.log(schemas); - var definitions = {}; + let definitions = {}; for (const name of schemas) { const part = TJS.generateSchema(program, name, settings, [], generator); @@ -79,11 +79,11 @@ function main() { main(); function walk(dir) { - var results = []; - var list = fs.readdirSync(dir); + let results = []; + let list = fs.readdirSync(dir); list.forEach(function (file) { file = dir + "/" + file; - var stat = fs.statSync(file); + let stat = fs.statSync(file); if (stat && stat.isDirectory()) { /* Recurse into a subdirectory */ results = results.concat(walk(file)); diff --git a/api/scripts/stresstest/index.js b/api/scripts/stresstest/index.js index a9a65097e..740a90119 100644 --- a/api/scripts/stresstest/index.js +++ b/api/scripts/stresstest/index.js @@ -19,19 +19,19 @@ setInterval(() => { getUsers(); }, 60 * 1000); async function generate() { - var accounts = await JSON.parse(fs.readFileSync("accounts.json")); + let accounts = await JSON.parse(fs.readFileSync("accounts.json")); console.log(accounts); - var account = await register(); + let account = await register(); accounts.push(account); fs.writeFileSync("accounts.json", JSON.stringify(accounts)); console.log(accounts.length); - var y = await login(account); + let y = await login(account); sendMessage(y); } async function getUsers() { - var accounts = await JSON.parse(fs.readFileSync("accounts.json")); + let accounts = await JSON.parse(fs.readFileSync("accounts.json")); accounts.forEach(async (x) => { - var y = await login(x); + let y = await login(x); console.log(y); sendMessage(y); }); diff --git a/api/scripts/stresstest/src/login/index.js b/api/scripts/stresstest/src/login/index.js index bd9fea870..ab6c9719e 100644 --- a/api/scripts/stresstest/src/login/index.js +++ b/api/scripts/stresstest/src/login/index.js @@ -1,14 +1,14 @@ const fetch = require("node-fetch"); const fs = require("fs"); -var config = require("./../../config.json"); +let config = require("./../../config.json"); module.exports = login; async function login(account) { - var body = { + let body = { fingerprint: "805826570869932034.wR8vi8lGlFBJerErO9LG5NViJFw", login: account.email, password: account.password }; - var x = await fetch(config.url + "/auth/login", { + let x = await fetch(config.url + "/auth/login", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(body) diff --git a/api/scripts/stresstest/src/message/send.js b/api/scripts/stresstest/src/message/send.js index 1f8af8aaf..d1b869146 100644 --- a/api/scripts/stresstest/src/message/send.js +++ b/api/scripts/stresstest/src/message/send.js @@ -1,14 +1,14 @@ const fetch = require("node-fetch"); const fs = require("fs"); -var config = require("./../../config.json"); +let config = require("./../../config.json"); module.exports = sendMessage; async function sendMessage(account) { - var body = { + let body = { fingerprint: "805826570869932034.wR8vi8lGlFBJerErO9LG5NViJFw", content: "Test", tts: false }; - var x = await fetch(config.url + "/channels/" + config["text-channel"] + "/messages", { + let x = await fetch(config.url + "/channels/" + config["text-channel"] + "/messages", { method: "POST", headers: { "Content-Type": "application/json", diff --git a/api/scripts/stresstest/src/register/index.js b/api/scripts/stresstest/src/register/index.js index bb6f839f5..578b9022b 100644 --- a/api/scripts/stresstest/src/register/index.js +++ b/api/scripts/stresstest/src/register/index.js @@ -1,17 +1,17 @@ const fetch = require("node-fetch"); const fs = require("fs"); -var config = require("./../../config.json"); +let config = require("./../../config.json"); module.exports = generate; async function generate() { - var mail = (Math.random() + 10).toString(36).substring(2); + let mail = (Math.random() + 10).toString(36).substring(2); mail = mail + "." + (Math.random() + 10).toString(36).substring(2) + "@stresstest.com"; - var password = + let password = (Math.random() * 69).toString(36).substring(-7) + (Math.random() * 69).toString(36).substring(-7) + (Math.random() * 69).toString(36).substring(-8); console.log(mail); console.log(password); - var body = { + let body = { fingerprint: "805826570869932034.wR8vi8lGlFBJerErO9LG5NViJFw", email: mail, username: "Fosscord Stress Test", @@ -22,7 +22,7 @@ async function generate() { gift_code_sku_id: null, captcha_key: null }; - var x = await fetch(config.url + "/auth/register", { + let x = await fetch(config.url + "/auth/register", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(body) diff --git a/api/src/Server.ts b/api/src/Server.ts index 4cf0917d6..2b38f4a15 100644 --- a/api/src/Server.ts +++ b/api/src/Server.ts @@ -44,7 +44,7 @@ export class FosscordServer extends Server { this.app.use( morgan("combined", { skip: (req, res) => { - var skip = !(process.env["LOG_REQUESTS"]?.includes(res.statusCode.toString()) ?? false); + let skip = !(process.env["LOG_REQUESTS"]?.includes(res.statusCode.toString()) ?? false); if (process.env["LOG_REQUESTS"]?.charAt(0) == "-") skip = !skip; return skip; } diff --git a/api/src/middlewares/RateLimit.ts b/api/src/middlewares/RateLimit.ts index 13f1602cd..47180b62b 100644 --- a/api/src/middlewares/RateLimit.ts +++ b/api/src/middlewares/RateLimit.ts @@ -28,7 +28,7 @@ type RateLimit = { expires_at: Date; }; -var Cache = new Map(); +let Cache = new Map(); const EventRateLimit = "RATELIMIT"; export default function rateLimit(opts: { @@ -52,10 +52,10 @@ export default function rateLimit(opts: { } const bucket_id = opts.bucket || req.originalUrl.replace(API_PREFIX_TRAILING_SLASH, ""); - var executor_id = getIpAdress(req); + let executor_id = getIpAdress(req); if (!opts.onlyIp && req.user_id) executor_id = req.user_id; - var max_hits = opts.count; + let max_hits = opts.count; if (opts.bot && req.user_bot) max_hits = opts.bot; if (opts.GET && ["GET", "OPTIONS", "HEAD"].includes(req.method)) max_hits = opts.GET; else if (opts.MODIFY && ["POST", "DELETE", "PATCH", "PUT"].includes(req.method)) max_hits = opts.MODIFY; @@ -165,7 +165,7 @@ export async function initRateLimits(app: Router) { async function hitRoute(opts: { executor_id: string; bucket_id: string; max_hits: number; window: number; }) { const id = opts.executor_id + opts.bucket_id; - var limit = Cache.get(id); + let limit = Cache.get(id); if (!limit) { limit = { id: opts.bucket_id, @@ -183,7 +183,7 @@ async function hitRoute(opts: { executor_id: string; bucket_id: string; max_hits } /* - var ratelimit = await RateLimit.findOne({ id: opts.bucket_id, executor_id: opts.executor_id }); + let ratelimit = await RateLimit.findOne({ where: { id: opts.bucket_id, executor_id: opts.executor_id } }); if (!ratelimit) { ratelimit = new RateLimit({ id: opts.bucket_id, diff --git a/api/src/routes/channels/#channel_id/index.ts b/api/src/routes/channels/#channel_id/index.ts index 2fca4fdfd..f6f130173 100644 --- a/api/src/routes/channels/#channel_id/index.ts +++ b/api/src/routes/channels/#channel_id/index.ts @@ -73,7 +73,7 @@ export interface ChannelModifySchema { } router.patch("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANNELS" }), async (req: Request, res: Response) => { - var payload = req.body as ChannelModifySchema; + let payload = req.body as ChannelModifySchema; const { channel_id } = req.params; if (payload.icon) payload.icon = await handleFile(`/channel-icons/${channel_id}`, payload.icon); diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index 63fee9b99..1f5b68c2f 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -35,7 +35,7 @@ const messageUpload = multer({ router.patch("/", route({ body: "MessageCreateSchema", permission: "SEND_MESSAGES", right: "SEND_MESSAGES" }), async (req: Request, res: Response) => { const { message_id, channel_id } = req.params; - var body = req.body as MessageCreateSchema; + let body = req.body as MessageCreateSchema; const message = await Message.findOneOrFail({ where: { id: message_id, channel_id }, relations: ["attachments"] }); @@ -92,7 +92,7 @@ router.put( route({ body: "MessageCreateSchema", permission: "SEND_MESSAGES", right: "SEND_BACKDATED_EVENTS" }), async (req: Request, res: Response) => { const { channel_id, message_id } = req.params; - var body = req.body as MessageCreateSchema; + let body = req.body as MessageCreateSchema; const attachments: Attachment[] = []; const rights = await getRights(req.user_id); diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts b/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts index d93cf70f3..2a387fc1b 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts @@ -145,7 +145,7 @@ router.put("/:emoji/:user_id", route({ permission: "READ_MESSAGE_HISTORY", right }); router.delete("/:emoji/:user_id", route({}), async (req: Request, res: Response) => { - var { message_id, channel_id, user_id } = req.params; + let { message_id, channel_id, user_id } = req.params; const emoji = getEmoji(req.params.emoji); diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 54e6edcc2..1ed6080e5 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -95,13 +95,13 @@ router.get("/", async (req: Request, res: Response) => { const limit = Number(req.query.limit) || 50; if (limit < 1 || limit > 100) throw new HTTPError("limit must be between 1 and 100", 422); - var halfLimit = Math.floor(limit / 2); + let halfLimit = Math.floor(limit / 2); const permissions = await getPermission(req.user_id, channel.guild_id, channel_id); permissions.hasThrow("VIEW_CHANNEL"); if (!permissions.has("READ_MESSAGE_HISTORY")) return res.json([]); - var query: FindManyOptions & { where: { id?: any; }; } = { + let query: FindManyOptions & { where: { id?: any; }; } = { order: { id: "DESC" }, take: limit, where: { channel_id }, @@ -148,7 +148,7 @@ router.get("/", async (req: Request, res: Response) => { which causes erorrs when, say, the `application` property is `null`. **/ - for (var curr in x) { + for (let curr in x) { if (x[curr] === null) delete x[curr]; } @@ -189,7 +189,7 @@ router.post( route({ body: "MessageCreateSchema", permission: "SEND_MESSAGES", right: "SEND_MESSAGES" }), async (req: Request, res: Response) => { const { channel_id } = req.params; - var body = req.body as MessageCreateSchema; + let body = req.body as MessageCreateSchema; const attachments: Attachment[] = []; const channel = await Channel.findOneOrFail({ where: { id: channel_id }, relations: ["recipients", "recipients.user"] }); @@ -198,7 +198,7 @@ router.post( } const files = req.files as Express.Multer.File[] ?? []; - for (var currFile of files) { + for (let currFile of files) { try { const file = await uploadFile(`/attachments/${channel.id}`, currFile); attachments.push({ ...file, proxy_url: file.url }); diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/api/src/routes/channels/#channel_id/permissions.ts index 2eded8530..cdcbde3d4 100644 --- a/api/src/routes/channels/#channel_id/permissions.ts +++ b/api/src/routes/channels/#channel_id/permissions.ts @@ -25,7 +25,7 @@ router.put( const { channel_id, overwrite_id } = req.params; const body = req.body as ChannelPermissionOverwriteSchema; - var channel = await Channel.findOneOrFail({ id: channel_id }); + let channel = await Channel.findOneOrFail({ where: {id: channel_id} }); if (!channel.guild_id) throw new HTTPError("Channel not found", 404); if (body.type === 0) { @@ -35,7 +35,7 @@ router.put( } else throw new HTTPError("type not supported", 501); // @ts-ignore - var overwrite: ChannelPermissionOverwrite = channel.permission_overwrites.find((x) => x.id === overwrite_id); + let overwrite: ChannelPermissionOverwrite = channel.permission_overwrites.find((x) => x.id === overwrite_id); if (!overwrite) { // @ts-ignore overwrite = { diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts index 28b52b509..622e06e5a 100644 --- a/api/src/routes/channels/#channel_id/purge.ts +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -51,7 +51,7 @@ router.post("/", route({ /*body: "PurgeSchema",*/ }), async (req: Request, res: // TODO: send the deletion event bite-by-bite to prevent client stress - var query: FindManyOptions & { where: { id?: any; }; } = { + let query: FindManyOptions & { where: { id?: any; }; } = { order: { id: "ASC" }, // take: limit, where: { diff --git a/api/src/routes/channels/#channel_id/webhooks.ts b/api/src/routes/channels/#channel_id/webhooks.ts index 92895da6a..cfb276ba9 100644 --- a/api/src/routes/channels/#channel_id/webhooks.ts +++ b/api/src/routes/channels/#channel_id/webhooks.ts @@ -31,7 +31,7 @@ router.post("/", route({ body: "WebhookCreateSchema", permission: "MANAGE_WEBHOO const { maxWebhooks } = Config.get().limits.channel; if (webhook_count > maxWebhooks) throw DiscordApiErrors.MAXIMUM_WEBHOOKS.withParams(maxWebhooks); - var { avatar, name } = req.body as { name: string; avatar?: string }; + let { avatar, name } = req.body as { name: string; avatar?: string }; name = trimSpecial(name); if (name === "clyde") throw new HTTPError("Invalid name", 400); diff --git a/api/src/routes/discoverable-guilds.ts b/api/src/routes/discoverable-guilds.ts index 0aa2baa9e..984916f41 100644 --- a/api/src/routes/discoverable-guilds.ts +++ b/api/src/routes/discoverable-guilds.ts @@ -7,8 +7,8 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { offset, limit, categories } = req.query; - var showAllGuilds = Config.get().guild.discovery.showAllGuilds; - var configLimit = Config.get().guild.discovery.limit; + let showAllGuilds = Config.get().guild.discovery.showAllGuilds; + let configLimit = Config.get().guild.discovery.limit; // ! this only works using SQL querys // TODO: implement this with default typeorm query // const guilds = await Guild.find({ where: { features: "DISCOVERABLE" } }); //, take: Math.abs(Number(limit)) }); diff --git a/api/src/routes/discovery.ts b/api/src/routes/discovery.ts index 1991400ef..a7df120e7 100644 --- a/api/src/routes/discovery.ts +++ b/api/src/routes/discovery.ts @@ -10,7 +10,7 @@ router.get("/categories", route({}), async (req: Request, res: Response) => { const { locale, primary_only } = req.query; - const out = primary_only ? await Categories.find() : await Categories.find({ where: `"is_primary" = "true"` }); + const out = primary_only ? await Categories.find() : await Categories.find({ where: {is_primary: true} }); res.send(out); }); diff --git a/api/src/routes/guild-recommendations.ts b/api/src/routes/guild-recommendations.ts index 1432f39c9..069e42218 100644 --- a/api/src/routes/guild-recommendations.ts +++ b/api/src/routes/guild-recommendations.ts @@ -7,7 +7,7 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { limit, personalization_disabled } = req.query; - var showAllGuilds = Config.get().guild.discovery.showAllGuilds; + let showAllGuilds = Config.get().guild.discovery.showAllGuilds; // ! this only works using SQL querys // TODO: implement this with default typeorm query // const guilds = await Guild.find({ where: { features: "DISCOVERABLE" } }); //, take: Math.abs(Number(limit)) }); diff --git a/api/src/routes/guilds/#guild_id/delete.ts b/api/src/routes/guilds/#guild_id/delete.ts index bd158c566..86550005d 100644 --- a/api/src/routes/guilds/#guild_id/delete.ts +++ b/api/src/routes/guilds/#guild_id/delete.ts @@ -8,7 +8,7 @@ const router = Router(); // discord prefixes this route with /delete instead of using the delete method // docs are wrong https://discord.com/developers/docs/resources/guild#delete-guild router.post("/", route({}), async (req: Request, res: Response) => { - var { guild_id } = req.params; + let { guild_id } = req.params; const guild = await Guild.findOneOrFail({ where: { id: guild_id }, select: ["owner_id"] }); if (guild.owner_id !== req.user_id) throw new HTTPError("You are not the owner of this guild", 401); diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index be556fb23..bf77bd5ec 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -55,7 +55,7 @@ router.patch("/", route({ body: "GuildUpdateSchema"}), async (req: Request, res: if (body.banner) body.banner = await handleFile(`/banners/${guild_id}`, body.banner); if (body.splash) body.splash = await handleFile(`/splashes/${guild_id}`, body.splash); - var guild = await Guild.findOneOrFail({ + let guild = await Guild.findOneOrFail({ where: { id: guild_id }, relations: ["emojis", "roles", "stickers"] }); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index c285abb32..5601097e0 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -62,19 +62,19 @@ router.put("/", route({}), async (req: Request, res: Response) => { // TODO: join others by controller } - var guild = await Guild.findOneOrFail({ + let guild = await Guild.findOneOrFail({ where: { id: guild_id } }); - var emoji = await Emoji.find({ + let emoji = await Emoji.find({ where: { guild_id: guild_id } }); - var roles = await Role.find({ + let roles = await Role.find({ where: { guild_id: guild_id } }); - var stickers = await Sticker.find({ + let stickers = await Sticker.find({ where: { guild_id: guild_id } }); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts b/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts index 27f7f65d9..4dfae8dac 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts @@ -9,8 +9,8 @@ export interface MemberNickChangeSchema { } router.patch("/", route({ body: "MemberNickChangeSchema" }), async (req: Request, res: Response) => { - var { guild_id, member_id } = req.params; - var permissionString: PermissionResolvable = "MANAGE_NICKNAMES"; + let { guild_id, member_id } = req.params; + let permissionString: PermissionResolvable = "MANAGE_NICKNAMES"; if (member_id === "@me") { member_id = req.user_id; permissionString = "CHANGE_NICKNAME"; diff --git a/api/src/routes/guilds/#guild_id/prune.ts b/api/src/routes/guilds/#guild_id/prune.ts index 0e587d224..efaad5800 100644 --- a/api/src/routes/guilds/#guild_id/prune.ts +++ b/api/src/routes/guilds/#guild_id/prune.ts @@ -6,16 +6,16 @@ const router = Router(); //Returns all inactive members, respecting role hierarchy export const inactiveMembers = async (guild_id: string, user_id: string, days: number, roles: string[] = []) => { - var date = new Date(); + let date = new Date(); date.setDate(date.getDate() - days); //Snowflake should have `generateFromTime` method? Or similar? - var minId = BigInt(date.valueOf() - Snowflake.EPOCH) << BigInt(22); + let minId = BigInt(date.valueOf() - Snowflake.EPOCH) << BigInt(22); /** idea: ability to customise the cutoff variable possible candidates: public read receipt, last presence, last VC leave **/ - var members = await Member.find({ + let members = await Member.find({ where: [ { guild_id, @@ -54,7 +54,7 @@ export const inactiveMembers = async (guild_id: string, user_id: string, days: n router.get("/", route({}), async (req: Request, res: Response) => { const days = parseInt(req.query.days as string); - var roles = req.query.include_roles; + let roles = req.query.include_roles; if (typeof roles === "string") roles = [roles]; //express will return array otherwise const members = await inactiveMembers(req.params.guild_id, req.user_id, days, roles as string[]); @@ -72,7 +72,7 @@ export interface PruneSchema { router.post("/", route({ permission: "KICK_MEMBERS", right: "KICK_BAN_MEMBERS" }), async (req: Request, res: Response) => { const days = parseInt(req.body.days); - var roles = req.query.include_roles; + let roles = req.query.include_roles; if (typeof roles === "string") roles = [roles]; const { guild_id } = req.params; diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/api/src/routes/guilds/#guild_id/templates.ts index 5179e761b..2989c0d2d 100644 --- a/api/src/routes/guilds/#guild_id/templates.ts +++ b/api/src/routes/guilds/#guild_id/templates.ts @@ -36,7 +36,7 @@ export interface TemplateModifySchema { router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; - var templates = await Template.find({ source_guild_id: guild_id }); + let templates = await Template.find({ where: { source_guild_id: guild_id } }); return res.json(templates); }); diff --git a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts index f9fbea54a..392b002f2 100644 --- a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts +++ b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts @@ -17,7 +17,7 @@ export interface VoiceStateUpdateSchema { router.patch("/", route({ body: "VoiceStateUpdateSchema" }), async (req: Request, res: Response) => { const body = req.body as VoiceStateUpdateSchema; - var { guild_id, user_id } = req.params; + let { guild_id, user_id } = req.params; if (user_id === "@me") user_id = req.user_id; const perms = await getPermission(req.user_id, guild_id, body.channel_id); diff --git a/api/src/routes/guilds/#guild_id/widget.json.ts b/api/src/routes/guilds/#guild_id/widget.json.ts index c31519fad..154b25173 100644 --- a/api/src/routes/guilds/#guild_id/widget.json.ts +++ b/api/src/routes/guilds/#guild_id/widget.json.ts @@ -21,7 +21,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { if (!guild.widget_enabled) throw new HTTPError("Widget Disabled", 404); // Fetch existing widget invite for widget channel - var invite = await Invite.findOne({ channel_id: guild.widget_channel_id }); + let invite = await Invite.findOne({ where: { channel_id: guild.widget_channel_id } }); if (guild.widget_channel_id && !invite) { // Create invite for channel if none exists diff --git a/api/src/routes/users/#id/profile.ts b/api/src/routes/users/#id/profile.ts index 4dbb84cf0..7a995a8ce 100644 --- a/api/src/routes/users/#id/profile.ts +++ b/api/src/routes/users/#id/profile.ts @@ -15,10 +15,10 @@ router.get("/", route({ test: { response: { body: "UserProfileResponse" } } }), if (req.params.id === "@me") req.params.id = req.user_id; const user = await User.getPublicUser(req.params.id, { relations: ["connected_accounts"] }); - var mutual_guilds: object[] = []; - var premium_guild_since; - const requested_member = await Member.find( { id: req.params.id, }) - const self_member = await Member.find( { id: req.user_id, }) + let mutual_guilds: object[] = []; + let premium_guild_since; + const requested_member = await Member.find( { where: { id: req.params.id, } }) + const self_member = await Member.find( { where: { id: req.user_id, } }) for(const rmem of requested_member) { if(rmem.premium_since) { diff --git a/api/src/routes/users/#id/relationships.ts b/api/src/routes/users/#id/relationships.ts index de7cb9d31..61655c25b 100644 --- a/api/src/routes/users/#id/relationships.ts +++ b/api/src/routes/users/#id/relationships.ts @@ -16,7 +16,7 @@ export interface UserRelationsResponse { router.get("/", route({ test: { response: { body: "UserRelationsResponse" } } }), async (req: Request, res: Response) => { - var mutual_relations: object[] = []; + let mutual_relations: object[] = []; const requested_relations = await User.findOneOrFail({ where: { id: req.params.id }, relations: ["relationships"] @@ -29,7 +29,7 @@ router.get("/", route({ test: { response: { body: "UserRelationsResponse" } } }) for(const rmem of requested_relations.relationships) { for(const smem of self_relations.relationships) if (rmem.to_id === smem.to_id && rmem.type === 1 && rmem.to_id !== req.user_id) { - var relation_user = await User.getPublicUser(rmem.to_id) + let relation_user = await User.getPublicUser(rmem.to_id) mutual_relations.push({id: relation_user.id, username: relation_user.username, avatar: relation_user.avatar, discriminator: relation_user.discriminator, public_flags: relation_user.public_flags}) } diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 7fc204579..924996890 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -57,7 +57,7 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: } if(body.username){ - var check_username = body?.username?.replace(/\s/g, ''); + let check_username = body?.username?.replace(/\s/g, ''); if(!check_username) { throw FieldErrors({ username: { code: "BASE_TYPE_REQUIRED", message: req.t("common:field.BASE_TYPE_REQUIRED") } diff --git a/api/src/routes/users/@me/relationships.ts b/api/src/routes/users/@me/relationships.ts index 0c13cdba4..d03014b64 100644 --- a/api/src/routes/users/@me/relationships.ts +++ b/api/src/routes/users/@me/relationships.ts @@ -129,7 +129,7 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ { relations: ["relationships", "relationships.to"], select: userProjection } ); - var relationship = user.relationships.find((x) => x.to_id === id); + let relationship = user.relationships.find((x) => x.to_id === id); const friendRequest = friend.relationships.find((x) => x.to_id === req.user_id); // TODO: you can add infinitely many blocked users (should this be prevented?) @@ -165,8 +165,8 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ const { maxFriends } = Config.get().limits.user; if (user.relationships.length >= maxFriends) throw DiscordApiErrors.MAXIMUM_FRIENDS.withParams(maxFriends); - var incoming_relationship = new Relationship({ nickname: undefined, type: RelationshipType.incoming, to: user, from: friend }); - var outgoing_relationship = new Relationship({ + let incoming_relationship = new Relationship({ nickname: undefined, type: RelationshipType.incoming, to: user, from: friend }); + let outgoing_relationship = new Relationship({ nickname: undefined, type: RelationshipType.outgoing, to: friend, diff --git a/api/src/start.ts b/api/src/start.ts index ccb4d1082..841ad3d5d 100644 --- a/api/src/start.ts +++ b/api/src/start.ts @@ -7,7 +7,7 @@ config(); import { FosscordServer } from "./Server"; import cluster from "cluster"; import os from "os"; -var cores = 1; +let cores = 1; try { cores = Number(process.env.THREADS) || os.cpus().length; } catch { @@ -27,7 +27,7 @@ if (cluster.isMaster && process.env.NODE_ENV == "production") { cluster.fork(); }); } else { - var port = Number(process.env.PORT) || 3001; + let port = Number(process.env.PORT) || 3001; const server = new FosscordServer({ port }); server.start().catch(console.error); diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 48f87dfe0..31ac91080 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -102,11 +102,11 @@ export async function handleMessage(opts: MessageOptions): Promise { throw new HTTPError("Empty messages are not allowed", 50006); } - var content = opts.content; - var mention_channel_ids = [] as string[]; - var mention_role_ids = [] as string[]; - var mention_user_ids = [] as string[]; - var mention_everyone = false; + let content = opts.content; + let mention_channel_ids = [] as string[]; + let mention_role_ids = [] as string[]; + let mention_user_ids = [] as string[]; + let mention_everyone = false; if (content) { // TODO: explicit-only mentions message.content = content.trim(); @@ -144,7 +144,7 @@ export async function handleMessage(opts: MessageOptions): Promise { // TODO: cache link result in db export async function postHandleMessage(message: Message) { - var links = message.content?.match(LINK_REGEX); + let links = message.content?.match(LINK_REGEX); if (!links) return; const data = { ...message }; diff --git a/api/src/util/handlers/route.ts b/api/src/util/handlers/route.ts index 3d3bbc373..eaf7dc91f 100644 --- a/api/src/util/handlers/route.ts +++ b/api/src/util/handlers/route.ts @@ -87,7 +87,7 @@ const normalizeBody = (body: any = {}) => { }; export function route(opts: RouteOptions) { - var validate: AnyValidateFunction | undefined; + let validate: AnyValidateFunction | undefined; if (opts.body) { validate = ajv.getSchema(opts.body); if (!validate) throw new Error(`Body schema ${opts.body} not found`); diff --git a/api/src/util/utility/passwordStrength.ts b/api/src/util/utility/passwordStrength.ts index 439700d04..f8badea78 100644 --- a/api/src/util/utility/passwordStrength.ts +++ b/api/src/util/utility/passwordStrength.ts @@ -19,7 +19,7 @@ const blocklist: string[] = []; // TODO: update ones passwordblocklist is stored */ export function checkPassword(password: string): number { const { minLength, minNumbers, minUpperCase, minSymbols } = Config.get().register.password; - var strength = 0; + let strength = 0; // checks for total password len if (password.length >= minLength - 1) { diff --git a/api/tests/routes.test.ts b/api/tests/routes.test.ts index 35d74a948..c915fab9b 100644 --- a/api/tests/routes.test.ts +++ b/api/tests/routes.test.ts @@ -23,10 +23,10 @@ export const ajv = new Ajv({ }); addFormats(ajv); -var token: string; -var user: User; -var guild: Guild; -var channel: Channel; +let token: string; +let user: User; +let guild: Guild; +let channel: Channel; const request = async (path: string, opts: any = {}): Promise => { const response = await fetch(`http://localhost:3001/api${path}`, { @@ -41,7 +41,7 @@ const request = async (path: string, opts: any = {}): Promise => { }); if (response.status === 204) return; - var data = await response.text(); + let data = await response.text(); try { data = JSON.parse(data); if (response.status >= 400) throw data; @@ -95,13 +95,13 @@ describe("Automatic unit tests with route description middleware", () => { } const urlPath = path.replace(":id", user.id).replace(":guild_id", guild.id).replace(":channel_id", channel.id) || route.test?.path; - var validate: any; + let validate: any; if (route.test.body) { validate = ajv.getSchema(route.test.body); if (!validate) return done(new Error(`Response schema ${route.test.body} not found`)); } - var body = ""; + let body = ""; let eventEmitted = Promise.resolve(); if (route.test.event) { diff --git a/bundle/scripts/benchmark/connections.js b/bundle/scripts/benchmark/connections.js index ffca26283..7e1abc109 100644 --- a/bundle/scripts/benchmark/connections.js +++ b/bundle/scripts/benchmark/connections.js @@ -4,7 +4,7 @@ const WebSocket = require("ws"); const endpoint = process.env.GATEWAY || "ws://localhost:3001"; const connections = Number(process.env.CONNECTIONS) || 50; const token = process.env.TOKEN; -var cores = 1; +let cores = 1; try { cores = Number(process.env.THREADS) || os.cpus().length; } catch { @@ -12,7 +12,7 @@ try { } if (!token) { - console.error("TOKEN env var missing"); + console.error("TOKEN env let missing"); process.exit(); } diff --git a/bundle/src/start.ts b/bundle/src/start.ts index de3b58484..a20581c3f 100644 --- a/bundle/src/start.ts +++ b/bundle/src/start.ts @@ -9,7 +9,7 @@ config(); import { execSync } from "child_process"; // TODO: add socket event transmission -var cores = 1; +let cores = 1; try { cores = Number(process.env.THREADS) || os.cpus().length; } catch { diff --git a/bundle/src/stats.ts b/bundle/src/stats.ts index 0234e0b49..022b2000a 100644 --- a/bundle/src/stats.ts +++ b/bundle/src/stats.ts @@ -29,7 +29,7 @@ export function initStats() { // osu.mem.info(), // osu.netstat.inOut(), // ]); - // var networkUsage = ""; + // let networkUsage = ""; // if (typeof network === "object") { // networkUsage = `| [Network]: in ${network.total.inputMb}mb | out ${network.total.outputMb}mb`; // } diff --git a/cdn/src/routes/attachments.ts b/cdn/src/routes/attachments.ts index ae50bc481..33801932a 100644 --- a/cdn/src/routes/attachments.ts +++ b/cdn/src/routes/attachments.ts @@ -35,8 +35,8 @@ router.post( Config.get()?.cdn.endpointPublic || "http://localhost:3003"; await storage.set(path, buffer); - var width; - var height; + let width; + let height; if (mimetype.includes("image")) { const dimensions = imageSize(buffer); if (dimensions) { diff --git a/cdn/src/routes/avatars.ts b/cdn/src/routes/avatars.ts index 2a4a0ffe2..0b7661444 100644 --- a/cdn/src/routes/avatars.ts +++ b/cdn/src/routes/avatars.ts @@ -33,7 +33,7 @@ router.post( const { buffer, mimetype, size, originalname, fieldname } = req.file; const { user_id } = req.params; - var hash = crypto + let hash = crypto .createHash("md5") .update(Snowflake.generate()) .digest("hex"); @@ -59,7 +59,7 @@ router.post( ); router.get("/:user_id", async (req: Request, res: Response) => { - var { user_id } = req.params; + let { user_id } = req.params; user_id = user_id.split(".")[0]; // remove .file extension const path = `avatars/${user_id}`; @@ -74,7 +74,7 @@ router.get("/:user_id", async (req: Request, res: Response) => { }); router.get("/:user_id/:hash", async (req: Request, res: Response) => { - var { user_id, hash } = req.params; + let { user_id, hash } = req.params; hash = hash.split(".")[0]; // remove .file extension const path = `avatars/${user_id}/${hash}`; diff --git a/cdn/src/routes/role-icons.ts b/cdn/src/routes/role-icons.ts index 12aae8a4e..1d92d6389 100644 --- a/cdn/src/routes/role-icons.ts +++ b/cdn/src/routes/role-icons.ts @@ -33,7 +33,7 @@ router.post( const { buffer, mimetype, size, originalname, fieldname } = req.file; const { role_id } = req.params; - var hash = crypto + let hash = crypto .createHash("md5") .update(Snowflake.generate()) .digest("hex"); @@ -58,7 +58,7 @@ router.post( ); router.get("/:role_id", async (req: Request, res: Response) => { - var { role_id } = req.params; + let { role_id } = req.params; //role_id = role_id.split(".")[0]; // remove .file extension const path = `role-icons/${role_id}`; @@ -73,7 +73,7 @@ router.get("/:role_id", async (req: Request, res: Response) => { }); router.get("/:role_id/:hash", async (req: Request, res: Response) => { - var { role_id, hash } = req.params; + let { role_id, hash } = req.params; //hash = hash.split(".")[0]; // remove .file extension const path = `role-icons/${role_id}/${hash}`; diff --git a/cdn/src/util/FileStorage.ts b/cdn/src/util/FileStorage.ts index 84ecf556d..376ce007c 100644 --- a/cdn/src/util/FileStorage.ts +++ b/cdn/src/util/FileStorage.ts @@ -11,7 +11,7 @@ import ExifTransformer = require("exif-be-gone"); function getPath(path: string) { // STORAGE_LOCATION has a default value in start.ts const root = process.env.STORAGE_LOCATION || "../"; - var filename = join(root, path); + let filename = join(root, path); if (path.indexOf("\0") !== -1 || !filename.startsWith(root)) throw new Error("invalid path"); diff --git a/gateway/src/events/Connection.ts b/gateway/src/events/Connection.ts index 4954cd082..c1bb73b67 100644 --- a/gateway/src/events/Connection.ts +++ b/gateway/src/events/Connection.ts @@ -8,7 +8,7 @@ import { Close } from "./Close"; import { Message } from "./Message"; import { createDeflate } from "zlib"; import { URL } from "url"; -var erlpack: any; +let erlpack: any; try { erlpack = require("@yukikaze-bot/erlpack"); } catch (error) {} diff --git a/gateway/src/events/Message.ts b/gateway/src/events/Message.ts index acc39bb92..83e6fc1b6 100644 --- a/gateway/src/events/Message.ts +++ b/gateway/src/events/Message.ts @@ -1,6 +1,6 @@ import { CLOSECODES, OPCODES } from "../util/Constants"; import { WebSocket, Payload } from "@fosscord/gateway"; -var erlpack: any; +let erlpack: any; try { erlpack = require("@yukikaze-bot/erlpack"); } catch (error) {} @@ -18,7 +18,7 @@ const PayloadSchema = { export async function Message(this: WebSocket, buffer: WS.Data) { // TODO: compression - var data: Payload; + let data: Payload; if (this.encoding === "etf" && buffer instanceof Buffer) data = erlpack.unpack(buffer); diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index 860000da7..31d2ae33a 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -41,7 +41,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { try { const { jwtSecret } = Config.get().security; - var { decoded } = await checkToken(identify.token, jwtSecret); // will throw an error if invalid + let { decoded } = await checkToken(identify.token, jwtSecret); // will throw an error if invalid } catch (error) { console.error("invalid token", error); return this.close(CLOSECODES.Authentication_failed); @@ -117,7 +117,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { return this.close(CLOSECODES.Invalid_shard); } } - var users: PublicUser[] = []; + let users: PublicUser[] = []; const merged_members = members.map((x: Member) => { return [ diff --git a/gateway/src/start.ts b/gateway/src/start.ts index 09a547514..2000522a4 100644 --- a/gateway/src/start.ts +++ b/gateway/src/start.ts @@ -5,7 +5,7 @@ import { Server } from "./Server"; import { config } from "dotenv"; config(); -var port = Number(process.env.PORT); +let port = Number(process.env.PORT); if (isNaN(port)) port = 3002; const server = new Server({ diff --git a/gateway/src/util/Send.ts b/gateway/src/util/Send.ts index c8627b032..dbe2e7899 100644 --- a/gateway/src/util/Send.ts +++ b/gateway/src/util/Send.ts @@ -1,4 +1,4 @@ -var erlpack: any; +let erlpack: any; try { erlpack = require("@yukikaze-bot/erlpack"); } catch (error) { diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 69c08be79..1a20153c6 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -171,7 +171,7 @@ export class Channel extends BaseClass { if (!opts?.skipNameChecks) { const guild = await Guild.findOneOrFail({ id: channel.guild_id }); if (!guild.features.includes("ALLOW_INVALID_CHANNEL_NAMES") && channel.name) { - for (var character of InvisibleCharacters) + for (let character of InvisibleCharacters) if (channel.name.includes(character)) throw new HTTPError("Channel name cannot include invalid characters", 403); diff --git a/util/src/entities/Guild.ts b/util/src/entities/Guild.ts index 70bb41c5d..328c586ef 100644 --- a/util/src/entities/Guild.ts +++ b/util/src/entities/Guild.ts @@ -346,9 +346,9 @@ export class Guild extends BaseClass { }); for (const channel of body.channels?.sort((a, b) => (a.parent_id ? 1 : -1))) { - var id = ids.get(channel.id) || Snowflake.generate(); + let id = ids.get(channel.id) || Snowflake.generate(); - var parent_id = ids.get(channel.parent_id); + let parent_id = ids.get(channel.parent_id); await Channel.createChannel({ ...channel, guild_id, id, parent_id }, body.owner_id, { keepId: true, diff --git a/util/src/util/AutoUpdate.ts b/util/src/util/AutoUpdate.ts index 531bd8b75..6a594fd5b 100644 --- a/util/src/util/AutoUpdate.ts +++ b/util/src/util/AutoUpdate.ts @@ -18,7 +18,7 @@ export function enableAutoUpdate(opts: { downloadType?: "zip"; }) { if (!opts.checkInterval) return; - var interval = 1000 * 60 * 60 * 24; + let interval = 1000 * 60 * 60 * 24; if (typeof opts.checkInterval === "number") opts.checkInterval = 1000 * interval; const i = setInterval(async () => { diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index 31b8d97cc..31b0b35f0 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -6,8 +6,8 @@ import fs from "fs"; // TODO: yaml instead of json // const overridePath = path.join(process.cwd(), "config.json"); -var config: ConfigValue; -var pairs: ConfigEntity[]; +let config: ConfigValue; +let pairs: ConfigEntity[]; // TODO: use events to inform about config updates // Config keys are separated with _ @@ -57,7 +57,7 @@ function applyConfig(val: ConfigValue) { } function pairsToConfig(pairs: ConfigEntity[]) { - var value: any = {}; + let value: any = {}; pairs.forEach((p) => { const keys = p.key.split("_"); diff --git a/util/src/util/Database.ts b/util/src/util/Database.ts index 9ab5d14c2..f0540bdfd 100644 --- a/util/src/util/Database.ts +++ b/util/src/util/Database.ts @@ -8,8 +8,8 @@ import { yellow, green, red } from "picocolors"; // UUID extension option is only supported with postgres // We want to generate all id's with Snowflakes that's why we have our own BaseEntity class -var promise: Promise; -var dbConnection: Connection | undefined; +let promise: Promise; +let dbConnection: Connection | undefined; let dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); export function initDatabase(): Promise { diff --git a/util/src/util/Permissions.ts b/util/src/util/Permissions.ts index e5459ab54..e003bf05e 100644 --- a/util/src/util/Permissions.ts +++ b/util/src/util/Permissions.ts @@ -5,7 +5,7 @@ import { BitField } from "./BitField"; import "missing-native-js-functions"; import { BitFieldResolvable, BitFlag } from "./BitField"; -var HTTPError: any; +let HTTPError: any; try { HTTPError = require("lambert-server").HTTPError; @@ -207,9 +207,9 @@ export async function getPermission( } = {} ) { if (!user_id) throw new HTTPError("User not found"); - var channel: Channel | undefined; - var member: Member | undefined; - var guild: Guild | undefined; + let channel: Channel | undefined; + let member: Member | undefined; + let guild: Guild | undefined; if (channel_id) { channel = await Channel.findOneOrFail({ @@ -257,7 +257,7 @@ export async function getPermission( if (!recipient_ids?.length) recipient_ids = null; // TODO: remove guild.roles and convert recipient_ids to recipients - var permission = Permissions.finalPermission({ + let permission = Permissions.finalPermission({ user: { id: user_id, roles: member?.roles.map((x) => x.id) || [], diff --git a/util/src/util/Rights.ts b/util/src/util/Rights.ts index b28c75b72..b7f458363 100644 --- a/util/src/util/Rights.ts +++ b/util/src/util/Rights.ts @@ -3,7 +3,7 @@ import "missing-native-js-functions"; import { BitFieldResolvable, BitFlag } from "./BitField"; import { User } from "../entities"; -var HTTPError: any; +let HTTPError: any; try { HTTPError = require("lambert-server").HTTPError; diff --git a/util/src/util/Snowflake.ts b/util/src/util/Snowflake.ts index 134d526ed..0ef178fef 100644 --- a/util/src/util/Snowflake.ts +++ b/util/src/util/Snowflake.ts @@ -84,10 +84,10 @@ export class Snowflake { } static generateWorkerProcess() { // worker process - returns a number - var time = BigInt(Date.now() - Snowflake.EPOCH) << BigInt(22); - var worker = Snowflake.workerId << 17n; - var process = Snowflake.processId << 12n; - var increment = Snowflake.INCREMENT++; + let time = BigInt(Date.now() - Snowflake.EPOCH) << BigInt(22); + let worker = Snowflake.workerId << 17n; + let process = Snowflake.processId << 12n; + let increment = Snowflake.INCREMENT++; return BigInt(time | worker | process | increment); } diff --git a/util/tests/setupJest.js b/util/tests/setupJest.js index 35a3cb526..378d72d51 100644 --- a/util/tests/setupJest.js +++ b/util/tests/setupJest.js @@ -7,7 +7,7 @@ const path = require("path"); global.expect.extend({ toBeFasterThan: async (func, target) => { const start = performance.now(); - var error; + let error; try { await func(); } catch (e) { diff --git a/webrtc/src/Server.ts b/webrtc/src/Server.ts index 6591691cb..3199b9c10 100644 --- a/webrtc/src/Server.ts +++ b/webrtc/src/Server.ts @@ -2,7 +2,7 @@ import { Server as WebSocketServer } from "ws"; import { Config, db } from "@fosscord/util"; import mediasoup from "mediasoup"; -var port = Number(process.env.PORT); +let port = Number(process.env.PORT); if (isNaN(port)) port = 3004; export class Server { From 1bb16b76ac61c20c09b60e6641c2c292e5be4c81 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 18 Jul 2022 18:46:45 +0200 Subject: [PATCH 156/238] Update local state, fix a few more errors --- api/package.json | 2 +- gateway/package.json | 2 +- gateway/src/opcodes/Identify.ts | 2 +- package-lock.json | Bin 825084 -> 825110 bytes util/package.json | 2 +- util/src/entities/Member.ts | 4 ++-- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/api/package.json b/api/package.json index b46e5f3d6..b34f1b309 100644 --- a/api/package.json +++ b/api/package.json @@ -93,7 +93,7 @@ "picocolors": "^1.0.0", "proxy-agent": "^5.0.0", "supertest": "^6.1.6", - "typeorm": "^0.2.37" + "typeorm": "^0.2.45" }, "jest": { "setupFiles": [ diff --git a/gateway/package.json b/gateway/package.json index 0524cc400..a062ac9b7 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -34,7 +34,7 @@ "missing-native-js-functions": "^1.2.18", "node-fetch": "^2.6.2", "proxy-agent": "^5.0.0", - "typeorm": "^0.2.37", + "typeorm": "^0.2.45", "ws": "^7.4.2" }, "optionalDependencies": { diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index 31d2ae33a..2559624e0 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -41,7 +41,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { try { const { jwtSecret } = Config.get().security; - let { decoded } = await checkToken(identify.token, jwtSecret); // will throw an error if invalid + var { decoded } = await checkToken(identify.token, jwtSecret); // will throw an error if invalid } catch (error) { console.error("invalid token", error); return this.close(CLOSECODES.Authentication_failed); diff --git a/package-lock.json b/package-lock.json index 9aacf440a5c5dc6b16b8076ce59065ad530dbe62..11edcc9cb64bfb6f04a96c2d21d5ed12f7b26014 100644 GIT binary patch delta 192 zcmeyf)@a%~qYW~wOeUt2>$%k?PxvM{{hu#K%;Xz_YMZaK9_0o~On)ECA=SJ?uziOh zBM>tIF*6Xe05R+K9fEAqhd_!rLOAT&g|Dz}7rw&ISII?yc9=?*iwM5jMk Z!N$@qkjMeVoIuP4#N68j5_#U30sw~RKso>b delta 160 zcmbQX&gjotqYW~wOvdJu>$%k?PxvM{{hu#K%;Xz_YMZaK9_0o~G|v-kpC`xscU z48$xz%({J^Ae-qSCS!}~`w}>UC--vOO)lUGo~|Fmq1*oK3fuN)SJ=(!rq@Mqh)?$o u=C}+r2&B+%dqN0DHz$-Qxt%SJV;d9DkanOP5OV@C7Z7uA-VFm!AI65)_ diff --git a/util/package.json b/util/package.json index 587e8a14f..246ec6b68 100644 --- a/util/package.json +++ b/util/package.json @@ -50,7 +50,7 @@ "picocolors": "^1.0.0", "proxy-agent": "^5.0.0", "reflect-metadata": "^0.1.13", - "typeorm": "^0.2.38", + "typeorm": "^0.2.45", "typescript": "^4.4.2", "typescript-json-schema": "^0.50.1" }, diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index fe2d5590a..0194c9a9b 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -155,7 +155,7 @@ export class Member extends BaseClassWithoutId { Member.findOneOrFail({ where: { id: user_id, guild_id }, relations: ["user", "roles"], // we don't want to load the role objects just the ids - select: ["index", "roles.id"], + select: ["index"], }), Role.findOneOrFail({ where: { id: role_id, guild_id }, select: ["id"] }), ]); @@ -181,7 +181,7 @@ export class Member extends BaseClassWithoutId { Member.findOneOrFail({ where: { id: user_id, guild_id }, relations: ["user", "roles"], // we don't want to load the role objects just the ids - select: ["roles.id", "index"], + select: ["index"], }), await Role.findOneOrFail({ id: role_id, guild_id }), ]); From 450e7d93783b60b3481ae9c6ee2ea05f1315b785 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 18 Jul 2022 19:05:43 +0200 Subject: [PATCH 157/238] Update FindConditions => FindOptionsWhere in BaseClass --- util/src/entities/BaseClass.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/util/src/entities/BaseClass.ts b/util/src/entities/BaseClass.ts index aabca0167..9f23de7cb 100644 --- a/util/src/entities/BaseClass.ts +++ b/util/src/entities/BaseClass.ts @@ -1,5 +1,5 @@ import "reflect-metadata"; -import { BaseEntity, EntityMetadata, FindConditions, ObjectIdColumn, PrimaryColumn } from "typeorm"; +import { BaseEntity, EntityMetadata, ObjectIdColumn, PrimaryColumn, FindOptionsWhere } from "typeorm"; import { Snowflake } from "../util/Snowflake"; import "missing-native-js-functions"; @@ -50,14 +50,14 @@ export class BaseClassWithoutId extends BaseEntity { ); } - static increment(conditions: FindConditions, propertyPath: string, value: number | string) { + static increment(conditions: FindOptionsWhere, propertyPath: string, value: number | string) { const repository = this.getRepository(); - return repository.increment(conditions as T, propertyPath, value); + return repository.increment(conditions, propertyPath, value); } - static decrement(conditions: FindConditions, propertyPath: string, value: number | string) { + static decrement(conditions: FindOptionsWhere, propertyPath: string, value: number | string) { const repository = this.getRepository(); - return repository.decrement(conditions as T, propertyPath, value); + return repository.decrement(conditions, propertyPath, value); } } From 14e0842dfbc7bc67fb50be0b8dbf6443e5413687 Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Mon, 18 Jul 2022 19:22:48 +0200 Subject: [PATCH 158/238] fix ts errors --- api/package-lock.json | Bin 552367 -> 556570 bytes api/package.json | 2 +- .../#channel_id/messages/bulk-delete.ts | 8 +- api/src/routes/channels/#channel_id/purge.ts | 115 ++++++++---------- api/src/routes/discoverable-guilds.ts | 19 +-- bundle/package-lock.json | Bin 596113 -> 596113 bytes util/package-lock.json | Bin 501775 -> 504932 bytes util/package.json | 4 +- util/src/entities/BaseClass.ts | 12 +- util/src/entities/User.ts | 27 ++-- 10 files changed, 94 insertions(+), 93 deletions(-) diff --git a/api/package-lock.json b/api/package-lock.json index de8891880a292180749519b284ec5bc0e9de96cb..4e65e88601c151f3e77576fcf5d8fcc1ecb843e2 100644 GIT binary patch delta 6264 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 { const { channel_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneByOrFail({ id: channel_id }); if (!channel.guild_id) throw new HTTPError("Can't bulk delete dm channel messages", 400); const rights = await getRights(req.user_id); rights.hasThrow("SELF_DELETE_MESSAGES"); - + let superuser = rights.has("MANAGE_MESSAGES"); const permission = await getPermission(req.user_id, channel?.guild_id, channel_id); - + const { maxBulkDelete } = Config.get().limits.message; const { messages } = req.body as { messages: string[] }; @@ -35,7 +35,7 @@ router.post("/", route({ body: "BulkDeleteSchema" }), async (req: Request, res: if (messages.length > maxBulkDelete) throw new HTTPError(`You cannot delete more than ${maxBulkDelete} messages`); } - await Message.delete(messages.map((x) => ({ id: x }))); + await Message.delete({ id: In(messages) }); await emitEvent({ event: "MESSAGE_DELETE_BULK", diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts index 622e06e5a..3a6997b24 100644 --- a/api/src/routes/channels/#channel_id/purge.ts +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -2,24 +2,9 @@ import { HTTPError } from "lambert-server"; import { route } from "@fosscord/api"; import { isTextChannel } from "./messages"; import { FindManyOptions, Between, Not } from "typeorm"; -import { - Attachment, - Channel, - Config, - Embed, - DiscordApiErrors, - emitEvent, - FosscordApiErrors, - getPermission, - getRights, - Message, - MessageDeleteBulkEvent, - Snowflake, - uploadFile -} from "@fosscord/util"; +import { Channel, Config, emitEvent, getPermission, getRights, Message, MessageDeleteBulkEvent } from "@fosscord/util"; import { Router, Response, Request } from "express"; -import multer from "multer"; -import { handleMessage, postHandleMessage } from "@fosscord/api"; +import { In } from "typeorm"; const router: Router = Router(); @@ -27,58 +12,58 @@ export default router; export interface PurgeSchema { before: string; - after: string + after: string; } /** TODO: apply the delete bit by bit to prevent client and database stress **/ -router.post("/", route({ /*body: "PurgeSchema",*/ }), async (req: Request, res: Response) => { - const { channel_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); - - if (!channel.guild_id) throw new HTTPError("Can't purge dm channels", 400); - isTextChannel(channel.type); +router.post("/",route({ /*body: "PurgeSchema",*/ }), async (req: Request, res: Response) => { + const { channel_id } = req.params; + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); - const rights = await getRights(req.user_id); - if (!rights.has("MANAGE_MESSAGES")) { - const permissions = await getPermission(req.user_id, channel.guild_id, channel_id); - permissions.hasThrow("MANAGE_MESSAGES"); - permissions.hasThrow("MANAGE_CHANNELS"); + if (!channel.guild_id) throw new HTTPError("Can't purge dm channels", 400); + isTextChannel(channel.type); + + const rights = await getRights(req.user_id); + if (!rights.has("MANAGE_MESSAGES")) { + const permissions = await getPermission(req.user_id, channel.guild_id, channel_id); + permissions.hasThrow("MANAGE_MESSAGES"); + permissions.hasThrow("MANAGE_CHANNELS"); + } + + const { before, after } = req.body as PurgeSchema; + + // TODO: send the deletion event bite-by-bite to prevent client stress + + let query: FindManyOptions & { where: { id?: any } } = { + order: { id: "ASC" }, + // take: limit, + where: { + channel_id, + id: Between(after, before), // the right way around + author_id: rights.has("SELF_DELETE_MESSAGES") ? undefined : Not(req.user_id) + // if you lack the right of self-deletion, you can't delete your own messages, even in purges + }, + relations: ["author", "webhook", "application", "mentions", "mention_roles", "mention_channels", "sticker_items", "attachments"] + }; + + const messages = await Message.find(query); + const endpoint = Config.get().cdn.endpointPublic; + + if (messages.length == 0) { + res.sendStatus(304); + return; + } + + await Message.delete({ id: In(messages) }); + + await emitEvent({ + event: "MESSAGE_DELETE_BULK", + channel_id, + data: { ids: messages.map((x) => x.id), channel_id, guild_id: channel.guild_id } + } as MessageDeleteBulkEvent); + + res.sendStatus(204); } - - const { before, after } = req.body as PurgeSchema; - - // TODO: send the deletion event bite-by-bite to prevent client stress - - let query: FindManyOptions & { where: { id?: any; }; } = { - order: { id: "ASC" }, - // take: limit, - where: { - channel_id, - id: Between(after, before), // the right way around - author_id: rights.has("SELF_DELETE_MESSAGES") ? undefined : Not(req.user_id) - // if you lack the right of self-deletion, you can't delete your own messages, even in purges - }, - relations: ["author", "webhook", "application", "mentions", "mention_roles", "mention_channels", "sticker_items", "attachments"] - }; - - - const messages = await Message.find(query); - const endpoint = Config.get().cdn.endpointPublic; - - if (messages.length == 0) { - res.sendStatus(304); - return; - } - - await Message.delete(messages.map((x) => ({ id: x }))); - - await emitEvent({ - event: "MESSAGE_DELETE_BULK", - channel_id, - data: { ids: messages.map(x => x.id), channel_id, guild_id: channel.guild_id } - } as MessageDeleteBulkEvent); - - res.sendStatus(204); -}); +); diff --git a/api/src/routes/discoverable-guilds.ts b/api/src/routes/discoverable-guilds.ts index 984916f41..fb7b844f4 100644 --- a/api/src/routes/discoverable-guilds.ts +++ b/api/src/routes/discoverable-guilds.ts @@ -16,19 +16,24 @@ router.get("/", route({}), async (req: Request, res: Response) => { if (categories == undefined) { guilds = showAllGuilds ? await Guild.find({ take: Math.abs(Number(limit || configLimit)) }) - : await Guild.find({ where: `"features" LIKE '%DISCOVERABLE%'`, take: Math.abs(Number(limit || configLimit)) }); + : await Guild.find({ where: { features: Like("%DISCOVERABLE%") }, take: Math.abs(Number(limit || configLimit)) }); } else { guilds = showAllGuilds - ? await Guild.find({ where: `"primary_category_id" = ${categories}`, take: Math.abs(Number(limit || configLimit)) }) - : await Guild.find({ - where: `"primary_category_id" = ${categories} AND "features" LIKE '%DISCOVERABLE%'`, - take: Math.abs(Number(limit || configLimit)) - }); + ? await Guild.find({ where: { primary_category_id: Number(categories) }, take: Math.abs(Number(limit || configLimit)) }) + : await Guild.find({ + where: { primary_category_id: Number(categories), features: Like("%DISCOVERABLE%") }, + take: Math.abs(Number(limit || configLimit)) + }); } const total = guilds ? guilds.length : undefined; - res.send({ total: total, guilds: guilds, offset: Number(offset || Config.get().guild.discovery.offset), limit: Number(limit || configLimit) }); + res.send({ + total: total, + guilds: guilds, + offset: Number(offset || Config.get().guild.discovery.offset), + limit: Number(limit || configLimit) + }); }); export default router; diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 3f2d85ba94eae8263f9b314cbe23d946a755671f..b9277e0b86c145d81a0ccc1e175136f8a11015a3 100644 GIT binary patch delta 116 zcmbQZQDx#rl?}E0OeUtA>-o=e0_o|2&dkD-HQ3ds8|+|Yo6Ik!FnxhGTWzzpRJ*nm zBM>tIF*6Xe05R)!Z7DWx9u^Z*C7tOFHyA~>`>C-xu_O4C=Si`*uh(S*V)pIpbvYir F0sxgxA=3Z= delta 113 zcmbQZQDx#rl?}E0OvdJ$>-o=e0_o|2&dkD-HQ3ds8|+|Yo6Ik!FnxhGTWzzpRJ*nm zBM>tIF*6Xe05R)!Z7DWxp2-W@q$kf8vfAFQ#>UDH<{5BvPmgqF=59Zz%Lc^k+Yjn; HTzCZlRaYTv diff --git a/util/package-lock.json b/util/package-lock.json index a566836e46504a49e42d7b479d226a8c8356539d..2405456ee1f520c44bd7b665e52bd9f6369afeec 100644 GIT binary patch delta 6920 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 diff --git a/util/package.json b/util/package.json index 246ec6b68..e6dc8e2df 100644 --- a/util/package.json +++ b/util/package.json @@ -32,7 +32,7 @@ "@types/amqplib": "^0.8.1", "@types/jsonwebtoken": "^8.5.0", "@types/multer": "^1.4.7", - "@types/node": "^14.17.9", + "@types/node": "^14.18.22", "@types/node-fetch": "^2.5.12", "jest": "^27.0.6", "ts-node": "^10.2.1" @@ -50,7 +50,7 @@ "picocolors": "^1.0.0", "proxy-agent": "^5.0.0", "reflect-metadata": "^0.1.13", - "typeorm": "^0.2.45", + "typeorm": "^0.3.7", "typescript": "^4.4.2", "typescript-json-schema": "^0.50.1" }, diff --git a/util/src/entities/BaseClass.ts b/util/src/entities/BaseClass.ts index 9f23de7cb..7ee27e304 100644 --- a/util/src/entities/BaseClass.ts +++ b/util/src/entities/BaseClass.ts @@ -50,12 +50,20 @@ export class BaseClassWithoutId extends BaseEntity { ); } - static increment(conditions: FindOptionsWhere, propertyPath: string, value: number | string) { + static increment( + conditions: FindOptionsWhere, + propertyPath: string, + value: number | string + ) { const repository = this.getRepository(); return repository.increment(conditions, propertyPath, value); } - static decrement(conditions: FindOptionsWhere, propertyPath: string, value: number | string) { + static decrement( + conditions: FindOptionsWhere, + propertyPath: string, + value: number | string + ) { const repository = this.getRepository(); return repository.decrement(conditions, propertyPath, value); } diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index bd70780dd..7d5dc5a6e 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -1,4 +1,4 @@ -import { Column, Entity, FindOneOptions, JoinColumn, OneToMany } from "typeorm"; +import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, ManyToMany, OneToMany, RelationId } from "typeorm"; import { BaseClass } from "./BaseClass"; import { BitField } from "../util/BitField"; import { Relationship } from "./Relationship"; @@ -90,7 +90,7 @@ export class User extends BaseClass { @Column() premium: boolean; // if user bought individual premium - + @Column() premium_type: number; // individual premium level @@ -105,7 +105,7 @@ export class User extends BaseClass { @Column({ select: false }) nsfw_allowed: boolean; // if the user can do age-restricted actions (NSFW channels/guilds/commands) - + @Column({ select: false }) mfa_enabled: boolean; // if multi factor authentication is enabled @@ -170,11 +170,14 @@ export class User extends BaseClass { @Column({ type: "simple-json", select: false }) settings: UserSettings; - + // workaround to prevent fossord-unaware clients from deleting settings not used by them @Column({ type: "simple-json", select: false }) extended_settings: string; + @Column({ type: "simple-json" }) + notes: { [key: string]: string }; //key is ID of user + toPublicUser() { const user: any = {}; PublicUserProjection.forEach((x) => { @@ -184,19 +187,17 @@ export class User extends BaseClass { } static async getPublicUser(user_id: string, opts?: FindOneOptions) { - return await User.findOneOrFail( - { id: user_id }, - { - ...opts, - select: [...PublicUserProjection, ...(opts?.select || [])], - } - ); + return await User.findOneOrFail({ + where: { id: user_id }, + select: [...PublicUserProjection, ...((opts?.select as FindOptionsSelectByString) || [])], + ...opts, + }); } private static async generateDiscriminator(username: string): Promise { if (Config.get().register.incrementingDiscriminators) { // discriminator will be incrementally generated - + // First we need to figure out the currently highest discrimnator for the given username and then increment it const users = await User.find({ where: { username }, select: ["discriminator"] }); const highestDiscriminator = Math.max(0, ...users.map((u) => Number(u.discriminator))); @@ -268,6 +269,8 @@ export class User extends BaseClass { premium_type: 2, bio: "", mfa_enabled: false, + totp_secret: "", + totp_backup_codes: [], verified: true, disabled: false, deleted: false, From 4ccae56210bfc5e0c0a0b863cac02596674ab5a0 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 18 Jul 2022 21:56:07 +0200 Subject: [PATCH 159/238] Update packages --- api/package-lock.json | Bin 556570 -> 556574 bytes api/package.json | 40 +++++++------- ...ch => typescript-json-schema+0.54.0.patch} | 10 ++-- .../#channel_id/messages/#message_id/index.ts | 2 +- .../channels/#channel_id/messages/index.ts | 2 +- api/src/routes/gifs/search.ts | 2 +- api/src/routes/gifs/trending-gifs.ts | 2 +- api/src/routes/gifs/trending.ts | 4 +- api/src/util/utility/ipAddress.ts | 2 +- api/tsconfig.json | 2 +- bundle/package-lock.json | Bin 596113 -> 679767 bytes bundle/package.json | 49 +++++++++--------- bundle/tsconfig.json | 4 +- cdn/package-lock.json | Bin 500185 -> 500189 bytes cdn/package.json | 14 ++--- cdn/src/routes/attachments.ts | 2 +- cdn/src/routes/avatars.ts | 6 +-- cdn/src/routes/external.ts | 2 +- cdn/src/routes/role-icons.ts | 6 +-- cdn/tsconfig.json | 6 +-- gateway/package-lock.json | Bin 540149 -> 540153 bytes gateway/package.json | 18 +++---- gateway/src/opcodes/Identify.ts | 2 +- gateway/tsconfig.json | 6 +-- package-lock.json | Bin 825110 -> 855275 bytes util/package-lock.json | Bin 504932 -> 494172 bytes util/package.json | 18 +++---- util/src/util/AutoUpdate.ts | 2 +- 28 files changed, 99 insertions(+), 102 deletions(-) rename api/patches/{typescript-json-schema+0.50.1.patch => typescript-json-schema+0.54.0.patch} (71%) diff --git a/api/package-lock.json b/api/package-lock.json index 4e65e88601c151f3e77576fcf5d8fcc1ecb843e2..bb7f725f90e4ca61cb3f7ff15ed1c020e95a3651 100644 GIT binary patch delta 73 zcmbRBM{(XC#SN#~xbn;Li*<8TQ!*2$FHB??<5G$<)HByJw9qwd{>aw;k&O|EnShuX Uh*^M`6^KFN?At%GacGtU02GfK8vp8w@b2fu$BV=nQ9aQ diff --git a/api/package.json b/api/package.json index 48a857b18..8f9d1c8f3 100644 --- a/api/package.json +++ b/api/package.json @@ -36,14 +36,14 @@ }, "homepage": "https://fosscord.com", "devDependencies": { - "@babel/core": "^7.15.5", - "@babel/preset-env": "^7.15.8", + "@babel/core": "^7.18.9", + "@babel/preset-env": "^7.18.9", "@babel/preset-typescript": "^7.15.0", "@types/amqplib": "^0.8.1", "@types/bcrypt": "^5.0.0", "@types/express": "^4.17.9", "@types/i18next-node-fs-backend": "^2.1.0", - "@types/jest": "^27.0.1", + "@types/jest": "^28.1.6", "@types/jest-expect-message": "^1.0.3", "@types/jsonwebtoken": "^8.5.0", "@types/morgan": "^1.9.3", @@ -51,34 +51,32 @@ "@types/node": "^14.18.22", "@types/node-fetch": "^2.5.5", "@types/supertest": "^2.0.11", - "@zerollup/ts-transform-paths": "^1.7.18", - "jest": "^27.2.5", + "@ovos-media/ts-transform-paths": "^1.7.18-1", + "jest": "^28.1.3", "jest-expect-message": "^1.0.2", - "jest-runtime": "^27.2.1", - "ts-node": "^9.1.1", - "ts-node-dev": "^1.1.6", - "ts-patch": "^1.4.4", + "jest-runtime": "^28.1.3", + "ts-node": "^10.9.1", + "ts-node-dev": "^2.0.0", + "ts-patch": "^2.0.1", "typescript": "^4.4.2", - "typescript-json-schema": "0.50.1" + "typescript-json-schema": "^0.54.0" }, "dependencies": { - "@babel/preset-env": "^7.15.8", "@babel/preset-typescript": "^7.15.0", "@fosscord/util": "file:../util", - "@sentry/node": "^6.16.1", - "@sentry/tracing": "^6.16.1", - "@yukikaze-bot/erlpack": "^1.0.1", + "@sentry/node": "^7.7.0", + "@sentry/tracing": "^7.7.0", "ajv": "8.6.2", "ajv-formats": "^2.1.1", - "amqplib": "^0.8.0", - "assert": "^1.5.0", + "amqplib": "^0.10.0", + "assert": "^2.0.0", "bcrypt": "^5.0.1", "body-parser": "^1.19.0", "cheerio": "^1.0.0-rc.10", - "dotenv": "^8.2.0", + "dotenv": "^16.0.1", "express": "^4.17.1", - "form-data": "^3.0.0", - "i18next": "^19.9.2", + "form-data": "^4.0.0", + "i18next": "^21.8.14", "i18next-http-middleware": "^3.1.3", "i18next-node-fs-backend": "^2.1.3", "image-size": "^1.0.0", @@ -86,9 +84,9 @@ "lambert-server": "^1.2.12", "missing-native-js-functions": "^1.2.18", "morgan": "^1.10.0", - "multer": "^1.4.2", + "multer": "^1.4.5-lts.1", "node-2fa": "^2.0.3", - "node-fetch": "^2.6.2", + "node-fetch": "^3.2.9", "patch-package": "^6.4.7", "picocolors": "^1.0.0", "proxy-agent": "^5.0.0", diff --git a/api/patches/typescript-json-schema+0.50.1.patch b/api/patches/typescript-json-schema+0.54.0.patch similarity index 71% rename from api/patches/typescript-json-schema+0.50.1.patch rename to api/patches/typescript-json-schema+0.54.0.patch index a0d479de6..2a319ec48 100644 --- a/api/patches/typescript-json-schema+0.50.1.patch +++ b/api/patches/typescript-json-schema+0.54.0.patch @@ -1,14 +1,14 @@ diff --git a/node_modules/typescript-json-schema/dist/typescript-json-schema.js b/node_modules/typescript-json-schema/dist/typescript-json-schema.js -index 47e1598..8397b9d 100644 +index 78f97ba..790c516 100644 --- a/node_modules/typescript-json-schema/dist/typescript-json-schema.js +++ b/node_modules/typescript-json-schema/dist/typescript-json-schema.js -@@ -432,6 +432,9 @@ var JsonSchemaGenerator = (function () { +@@ -453,6 +453,9 @@ var JsonSchemaGenerator = (function () { else if (flags & ts.TypeFlags.Boolean) { definition.type = "boolean"; } -+ else if (flags & ts.TypeFlags.BigInt) { -+ definition.type = "bigint"; -+ } ++ else if (flags & ts.TypeFlags.BigInt) { ++ definition.type = "bigint"; ++ } else if (flags & ts.TypeFlags.Null) { definition.type = "null"; } diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index 1f5b68c2f..b7f1e1307 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -116,7 +116,7 @@ router.put( if (req.file) { try { - const file = await uploadFile(`/attachments/${req.params.channel_id}`, req.file); + const file: any = await uploadFile(`/attachments/${req.params.channel_id}`, req.file); attachments.push({ ...file, proxy_url: file.url }); } catch (error) { return res.status(400).json(error); diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 1ed6080e5..6d4d57941 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -200,7 +200,7 @@ router.post( const files = req.files as Express.Multer.File[] ?? []; for (let currFile of files) { try { - const file = await uploadFile(`/attachments/${channel.id}`, currFile); + const file: any = await uploadFile(`/attachments/${channel.id}`, currFile); attachments.push({ ...file, proxy_url: file.url }); } catch (error) { diff --git a/api/src/routes/gifs/search.ts b/api/src/routes/gifs/search.ts index 9ad7a5928..1099dc4a7 100644 --- a/api/src/routes/gifs/search.ts +++ b/api/src/routes/gifs/search.ts @@ -20,7 +20,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { headers: { "Content-Type": "application/json" } }); - const { results } = await response.json(); + const { results } = await response.json() as any; res.json(results.map(parseGifResult)).status(200); }); diff --git a/api/src/routes/gifs/trending-gifs.ts b/api/src/routes/gifs/trending-gifs.ts index 6d97bf7cc..2b28d9d2e 100644 --- a/api/src/routes/gifs/trending-gifs.ts +++ b/api/src/routes/gifs/trending-gifs.ts @@ -20,7 +20,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { headers: { "Content-Type": "application/json" } }); - const { results } = await response.json(); + const { results } = await response.json() as any; res.json(results.map(parseGifResult)).status(200); }); diff --git a/api/src/routes/gifs/trending.ts b/api/src/routes/gifs/trending.ts index c81b4c082..bc143f005 100644 --- a/api/src/routes/gifs/trending.ts +++ b/api/src/routes/gifs/trending.ts @@ -50,8 +50,8 @@ router.get("/", route({}), async (req: Request, res: Response) => { }) ]); - const { tags } = await responseSource.json(); - const { results } = await trendGifSource.json(); + const { tags } = await responseSource.json() as any; + const { results } = await trendGifSource.json() as any; res.json({ categories: tags.map((x: any) => ({ name: x.searchterm, src: x.image })), diff --git a/api/src/util/utility/ipAddress.ts b/api/src/util/utility/ipAddress.ts index 13cc9603a..8d986b268 100644 --- a/api/src/util/utility/ipAddress.ts +++ b/api/src/util/utility/ipAddress.ts @@ -65,7 +65,7 @@ export async function IPAnalysis(ip: string): Promise { const { ipdataApiKey } = Config.get().security; if (!ipdataApiKey) return { ...exampleData, ip }; - return (await fetch(`https://api.ipdata.co/${ip}?api-key=${ipdataApiKey}`)).json(); + return (await fetch(`https://api.ipdata.co/${ip}?api-key=${ipdataApiKey}`)).json() as any; } export function isProxy(data: typeof exampleData) { diff --git a/api/tsconfig.json b/api/tsconfig.json index 80d7251ff..91396aa8e 100644 --- a/api/tsconfig.json +++ b/api/tsconfig.json @@ -69,7 +69,7 @@ "paths": { "@fosscord/api": ["src/index"] }, - "plugins": [{ "transform": "@zerollup/ts-transform-paths" }], + "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }], "experimentalDecorators": true } } diff --git a/bundle/package-lock.json b/bundle/package-lock.json index b9277e0b86c145d81a0ccc1e175136f8a11015a3..fd388bd2edf08b5ee0076e08394d2715245b3a22 100644 GIT binary patch delta 120689 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�Y4xB&pKIF(Y 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

Dv9K?)rku`uanghpazfJihCB&2);Qor4`) zTN$l*ptec&D&*Ac6Um8G4)haJRZdEDaHKC14Jq7gVl#?l7be}v_Y#I)(78aoQLKZe ziJ6$N!3I=JhtmLK#Y;kBv3RlVuw zaXq0Jp;WS5syAEGG(~x_64XV~BGfGbUj}BC-?DuRAVXX@v5U`K|HFM~G=da~HN*k4 z(neWT^|uLK_KG~!AEe2$ z)|>`>zIe_nafztNVf7G%>Lp`1su|guJPnA21}}2bTN=9!P zS0XM%Za;aM0M|QU9tCu(WJ zNDqX3pqL~U38LYTGJG`&^pjPIs!IFl_rk7BDBKR(EjCjx^6qOl14ZWtAwec zz}R`DjoWtAO6(Hzxu+m2oRK0Iz@J)=O~vK1g2vi6}WfYuE3We3uOntccIQ1*HZ zU$@Q0y&f#TTfFQnd}M$HxeEP(c7rG`>%~wD)_($CD>zKc-+-NG?e9+owm%X?>-f)X z-?53q-#&ZKMfcWChwMjWWuMqQ{<^(ia-=QSo-NY+aOCOHwBCCp&YxSm5B@x$g!#P& z1Xm5XWv>l0^y-{7(94|%M!7dCvi zt$l0mosp|LKJ?v_+CJBy=`%L}?g8`n~s(bK0Z41JQ z|L#4jy^)IEw>?l-AE6Q|r{f+JZnhr(ZTFdr=QppgYgzAlK?K_F^7Eq7Xxny-q_Rc-Jeir&Om!wHVrW!ew6f_?oR5#A zB>)w5#J=B9s9vTw;DeF6_28$#LjR|qaD8cG_iL|rc{iT?53c@(^`U=Wy3kPZCUB^3 z*8UfK#-$Ve^0#d{+Bdte{if?}8@tj^yJC(9b)^8_gZ%}`1T|(G+y@eYLLu8A79Cm7 z0!we%tKvZRt~EM|QF)fZa?xU@#b(<$>~FaR?d^?nV~XQj>A+%2@lmi!lxZ}fcgjQw z*Qy~kJ~K$!b}kUO@0lY|_j~?7x^CH63m6@B%IEBcpi;pDp&=pB!)9ujR*Z2mI!kub zhT$a!t#GgrsRqh(f3ez^8=;XBZ7Q-E3205)AL=TN)V$cPwkL^Eyylxnf!K&IrKV8H zRhv`+`UY#agO|T?y>ibU3QL6UnK#&_j4<=9$QxX%!p;2(RJ&B@N7rSY-WA{E`raXA zJl$!1{oK~gb`?j8^sjVNob<3`(zH;~554+ytvO{hs#Lmu?HM!n^MXtx% zne9o~(YLo>a6P^$z&$%1>zQ{!GzGMpuCQMIfai`|MCUS8xS=oaogkmf9-)oUJOYw* zL_MDY>llv@C!t}IQA-`RGz+!GWR@&R=~+2Y68ovryf9aQ>uly_ed9qLF#Fk|3|w(> zRqW&^e2dh~)-dchv~t;c&lRp$T_H<@!F&qK4lI+_v+r=9^2~Ksv13n1brv0;2ik-K zcRhVO#F0^uXPegsAVn(Z_Qr91Ds(_?%8s(^=$bMYCB;eLpsY12Nxk*~SZ0Z3Г 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⩔vjhY2Y@<;<`zp{dnGH&&fBXYtTP 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ԛ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 delta 82180 zcmb@udAuW6btnFj-lEst?!|VmcJDS|DBQKE78UtnTPjJVQfVobsmQ*U0 zN>YWvHV`1gW?RHJOjvA&BoGMLn9yOhNd}S(5Zg0J$O70TFk!bz2${(wFjvxh-EGrm zGM~?{KmCVZZTH@D&-y**+%JFT#rHgP{e!!MoAfyx{s+;u(DCixb1cXoi=4yGzI694 z`0uPX8X1mz_GPEf-in{2=Jy020O(b__k!2`b@0GkT6@I?eU3Uug23U8!}H(WyBEB3 zxW0G(X}bHw~hdnX`&MQGOsa}GO4gQqt`=YVxZ=%x1_W9AR;yCFc# zQyaH{1A9ZeH;8jIeBq&u0yz7|jgt?b-n=?+1UrZC%w{rL&V)Hf!lxeCA6cW$QTHA= zJpYZ*o_RjNfbLo-F~9rpZ_dAT;AP9vaByHf^cL`)-Jw(9&V3;g+`TWfF+a6iJiPeE zg;n0-8_uBD8{6~f;gd&pM(Y@()yj$0#6PeZx*2|zfE4?;>vvx_|Nid%8~8c=96b;0 zIRt-^=g9fBdv4pr&QWmA^Skyuv^}v~z*mBy6Z3xw9Qc2y_};ypCB^5zc<`F}yZ7z` zuR0jq1Sbw}gyx^vd&M@1AO6zbJpo8Z^w^PY5*YLr0%W7I5V)8;8NCwn8^-6X)T7xay`r z2!s3p_W<1a*TKUVmYPSkiUVpCv^3SmH&A&MBjTXxlK4}{|n~!v3*Augxgu< zbJ*^MJL8=OnSG(b&tawKC&v8Gud(L0U$=XXp4@o&iWA500N?q_=1G+hqJ66$@pX?w zJ7Tppq{KEWAn{43=eSu(aiVZ8BkI*38eOXe>VJ zSGxAJJ^%Vot^rSdf9?4E!FR=$3sb@>&o)L=uNuo%C$fh$izHqaQ~d!c(iqC}(hTR) zT8f^|!inB6!YQujb`(mcI##Y#F}Z4{LRiWKVNh*IXBuIt2{`oLEuqUfQWSWC6WtzDks<>oEfHD2jTIXl zZIm6{Pa@Go)pJHQjp2(`yr*chPLismTcs4%?PRKIP4bki*^?MI)~pQ-wkfm}jm8R- zq&;k*iTMxT!OpQCgyxTa@)S^&pnTrxiR>fdf225))!=E0qnJK3_twViRVFBJ{4 zfix$LawTI%D~b~9M6%)LIBHVUWFd|9y=0Yf&0I9uFE@r-%4nu~&3G-(Ddf;=CBw05 zub9@Fky&d9?ph0^=QkX<0=(?a0Sx^8cSBdNLo-P)c;V#ysRxMpQxDxfzvUl~&j0O0 z7iPlLEI-+Xf|{PvQN~Ki6Ma0cC#v==HnCa+r(v=u&_02bGqox=EMe)qmeG+h=IgE% zZ`TdIDaLBepBp&htsvD={F1kTJKeDKhUufO)-3zt8@NoDg|fU$v% z)t^tlB5-*1tN+ka6yVO0KoTME?*GWG;C=)Oypqu-lcAkYI8`FmD(ifj=+_i#QtZk& zOBC!J(vLN9C1u7;({*}YzJ-+amNTtzDRM|o(=6Y^=@>7`C>cpd5qZ{b4N%A|t9gF? z&cM|N9iwSX?eUHEfwM9U2FcNhdJq%k!ZHuKbwwUTZjQSvx>)Q$|fgz0Bw)+S;pvri@cRxw5lI=Go+1OkcI zmAu@oY6V(TWR@G4#*%j6(bsKW`|$UF@4f)AU%M*=>>JiR@Z{S9|9#2Mx14_=`01hb zYruiOT0ah+c~hu5|G;~1gtxXJ2ZnceERB;U>J1}EtHBZCpqvp3#S!mtY$6#G6J##w zjv}_1wP%(YwHqVEl!kH`i{{mGopfgoMYq@<%180y)FX!BMy6KQ3+O_+FXil~?+qN7 zzw6T%*r~?i^?Wu<#z#g*;Pd@K6RAb=0$m*$GOLd@BxQS?amh5bq)B85Zu2~ zhR>F|{m*$}{z(4FI&%)+Rz5fy?M;hGmf$SD=BN4`g;OnyEVdnG>e}&sCXvR}St8q1 zvb7vS>(h$Z#K?x&YRgk9(KmWXQH|m}?ox>cIxDm_%rKqHC?8;FH}}tPedL1HD=9N9 zLK#gx+)??G$j<7*w9uCH;n)}rv6NasTq%!@J<5_2v0B^iB2=;~i|sPBANF{rB-o_t zbP~B3=5S_YhV&72+`7!b^RGR42Am5AF6>Qx(9LJNQx1(Ovz&xSdsTu;jbr6(m}ql} zQAQHTSSoI(xm3!+lPZy58e+LDRMO2tvzTm;$(|h zeFPMeW70*9*D<20n(nJm(V^2+GgSx|tg=j|n{)@KhU5foa^|Gwxx@T)Freb1n@M#e zv5`sEDY+(dOwP(AM#!MmZ44uwq+yOdVH&;s;8%iI6*iBoOkCWIno(LZZ9d|XMY?ZK z{EVllwvCO7OxmfBwQPHaS1FpLdYYUTY&6r(@Ip*4h+3s6^u>tV=5qp*%rKdV>ct|> zhFV+rCG)2~5Q27kvC#d`Rbp4jftA7o3w5@=;R>8}Fr!M#n9Y zEv!uzP(kUdV?^p=kt}1@{ZWkNE3x=Oo_@wgp8Dy2@SwVRaHVb0Ff%N0iLi)yUQL_~ zM6#lyZAVBK8iL8C$1RmI#C~pSC*z}hx0%$`=tTDrxjLbZYIDS439?mW97-JWYDOJ2 zhvPP8E)3MRe|7t(&w)>kp%FO#i=nH7J2L4};q0{OWkoc_P3qk=uGgF)-N=bOYtoy^ zxoVc4*_y00DrG*OAnG_;=n~FUmjZe%&7I1 ziOLRR(@Hg?X$ne<+SC+Voe@!X))*z#aXHrUmpTlJI$Iu4%o6d4tfNi)-=vsK!Fp6E=ITY6hJ-6UP6Cs zS1##MlfuWam9QB)v}nyfV=)^?a+PF+S&Pn^Wmtw=Qsbw ziIuG7E0H*57!|TIsXK#GnWS=AZ&1~QaZ*6|f*mEa2;W93sEXF(svwU_3*j`AEJh`< zmaE8|oG1t}QXEQ#<{5HY?S=E8fUHqVr~BqF9=L?OYLyruDYPY*sB)yx5=_OGh1jG= zF|&x|)Lc594VNOx{D2y2PG{6g3GOUK^(s9(3q30u>JpQDX?(K7*tdLQ6MVP62?K*w7*HaqG2Iv@(%}i=^qg6>S~2N1>lCPJHa8}d z8K}3Lqe#1}_gZ73)R6J$FbWwt-HG{@Nfi7RE#@;rF*Qx(SVT$c(QdS~l=}b6M6j>! z0+sOpwjb?}MQY9ff3Foy&#j9$SK2585 zEZIvDE{V9|HWHCqM#HvYl-MS*Xv~Lx{Y6vpmE+*scLw&%&wu5U;H3|*9|Ui0Zr(co z&QD%6fAH&@;CKs02wxhl-#mZ(LtFDlzV-_s>sZi%ct&mid*`j;1wPCrGNR<;!6{7+k4^DZ<(y0n*ZJ3_Q1{f`T?--m)BnaUR+p5 zz|*7k6Wb#k246Y7aTeTSZSDcjyn5Z6Ti<-w%4WvosurHq3;j+J?GJ@Ww9b-twQ8r$ zK_^x6N|iLrAVQoItO}Wi5qzZL;RwkXecc&%ks)rld3#jIP5NfCp5rG-)0OxsG}YGt z=}*@7&VTejeDIdx<}KUXuNbkuJ?gP;uO+o?0mr&3MyFGKr&^gb!$^tdG>K?8MqDLl zn3!gadiHQ8D3t<3mdq|SPBp8Hz%vyIn+d6iP7-3#Ppu;CXWkSjgGax-`O<|6z6w0` zszB)8@10$M3C;Phey_P&Em5PAgiN$`A*a;ouvLY&e#n~%-5QuqN@bI6H(kaHj3#Mf zvelNn;*c&RTr@T)=cqw85#~#?PF)`7az$C!*$jtq#WGy24DP>ga~<6J$Cf5+E&A1cA@p>~?YDEieLmSdb!t4`fcp_jb zsVN;uo0|Z7&t?dQq9?#7zq*+PKl%I3&H01>_~n%#CZ?Tsu38VL;yFsHq^F2J;V6t3 zrl=@t{R)w4H=BJyjaH3@9+ew{)#g-EZnaWo!^Fe}lg?FmdlZYsxV(kvvC=He>)28d zAN;4~YL~mRZ@~}yfCM)8foHz48M^n!Usw&_q@;W_Oz0IUYZYT-Dn3QqH9o`lMN5?G zRJ2`XhGwlfc6^7cHU-~}_fkpS?-z62pa9)=rdr7K3#JxtGmR&--TIIB5U zZ8YghT|83Cj-7;&j%os@n-;}*s-fsBx92h|zWI*L)SY5Bf;c5%Ra8VNWfm^=4NrNw4AJ_x(Zw=6D1ZEd$ zxzg;Yc{jrFWsgo)HOe2tphfapc|Mt^S(%EDM^djTqPR#kN`1~Xno7GoW>qa#bTXNA zI(GT74}d$0!NcG)fxw?E5Hs+=BOAvRH=i0XQM}|Lc_KVaL@Nm2h}lEv4aCE3wj?{{ zCYLsbOgT@dhz3q3#PATu$4-Y*3?dsfM3(7i+d@OOCk?cykm;nJTMqx&?_RwChvvIK zzjp~QERo>Pnc6y1wXaL&?&?~}(^Rsq)YGGrC(fvF% z({uG&vS*b>vu05!G#h!1sVio_%4Ms_Bq2qsty(laZHKM)R7`RTC#tPNWefq*0-p69 zI}g0y9pXlccLXAA%55Jlwh5W+ zdPJpGz++;hUT>r(Mk_1Edi50A8SrJ)^&Qn3&`eWLr+Pm-E(By3mZJ9KO{k@d!K2`| zH*OwT%E?#XytxHV{|6Y*zVD4Y!V(Eb;@t)W0LDl`;q0E~nnNzIoa5*?z;3Pe^_*{R?~DrvIfNu1ZtqVW!+PF!}eO+QaL?*ect*MR3wis!@!@sJ?F28xek{<`x?I0($oxRsG9vg|=hcSnL9S`lHQb;K{e{P=(f} zf{|CLOutGpxM=jFG1e0z0@Y!11)@PyL`$enN;BDPY7o0q?e;J!a^q5ki)V|DiiAr^ z&FqhfIz;GuPFd(Vbd*|oa?jihE#=SJtTPLjCiH9P);G`JbY-ZF?yCdu z4}#opZ5}-TY$e)8j;>O%hePa zi`zn0Xk-XRSlZtU$OUBgW8jup0Qwxy_Ew;ibl+-DPk(oFH#ijzT(_i!(r}06VWV85 za>H09Ec&AoS2hbmI7)?+E@hXYs1pWPQcbs9Yj)~X+>YCWzAhwjq>eE4BHtw@Ijkx& zDL#W5zA5Xr2nwHse#nD22L2Mj(GGzB_`6Hs=%MDu38f#4`etoX)5&;OL1e^I(yIE+4m)5+y5uoRg&LR{GCGC`Q>{Pc22x)@doURP z%*OV3w=jW|JAp{GU*;)ThJv*5o>0m6UGy&$A{5GLDs8LUaLYEk(`zDF^-sCYN{?_ z&HFwI-PJoDhQ1*Q7E!W_S@8tR_C=&yYK5o0I^~Iz7(MArtWh5qJBVN4G_;R-gGA1i zP=97M6f%{9uCq>4lTN3u4;?(Mqm0iMY(_~^Nq17^FSrYrj{JL@E7ntc1HRXfH98oP zjgOLAsudN|ev2{2VubC*9A0Q-*+kS$B?t6WoHaR>ACJoh#tiU5t<)tVjAprIypKh& z$f%HIS*_-Vo6FF3q2yk08TIn!l?Z(M7N{SVL1H`I(FH2p8jHFVkB-ujgjKRUPBe@m zf$LGa8aSOp*WIsAd%}=+ou{s+km;u{~_k{#iOE>~1Lv%sX#Y$<&Fv+Ahgsvz|R*k(# zM~hA}HRz_a^O<7Ob%&x*#?Z+$SB&eOOc!&j3q241_~Xz4_*uoez4AA|X5kbhE`rE$ zS*fySl%eowG8S(UgXyf{l^||jHM|ieWR!Ad1gT%KN2F|^B2V>Awd){CBgHv#ITqn) zR_XbrW|Y;#vc;FJW{%BVjsTx|%__67TEC~~>8^*Ff?vaV+v1_4txqNvk|#OcB65!8 zPhb@Ui=bh%(H;8(ygJO+>XivWBULpWi;!uJ>98|ZF581qB9*C5rs@)pTp@!Ck$fH+ zTm}BC05PH!M9>R|5yKw#h$PAC?TD7DOuY=u19hiqy=Y~{9-F3SsbQ0pGHxS5t93HM zrEtDTD+R9>p^ZTdjoP)!#9}(VC=v^I9qqZh|5O$_$0vWVc^rI6*xCJZH&>aa@KU9u zh?-MQ4z1B30)-ACO5wzSh`<#3*cH0^$f^tkHyWjfV@I{gj-0G!RiV}zC-p&NhA(x?3OGNu@U)&|dP3k= z^MM~gZ5+5WbW&-Oaj7-oBQ4P;V|pp>Rq#=yK4@hl8Xfa&7v>{qq1|r|DW{CgWHs6{ z(5gJP(Q3U+_*@<$Nuxx$)G}S6F8WTQ=7mQKj$dTg7b^DV`GLM5A2&#c4@5!db542{n-{delGvd|iEXx+k#Y!!bg$wP((@NCP@ZM1F>S<&NJn{kQq1=6nsPJz=Er~pWC|Hn5@ zs6CpdCtRtTXDF)|b@`+@OHTS_OQ;mAaJQJkxUeAi)5CJTrkA^ec54=G#9K*=sFk&8 zSs8jUuT@H#=}uNIV1`c)a`pl)wvAz-0vJh45nk}C;Syc`ykxI|40JqpV;6|q;tcxT|k zL}6dUBIuZ}(g~;F(xpV9R_SRGdWv#NqhV3aTBGhD6ki;9SwpePQA%jjHn``801p25 zukYFg&NY_Y{pkB4Knk5J7f1#KhMsBcX#KiJCJD#G`*CvEFs6BaBo``aCtsiG6z4!_ zAjL|eW#H|xGO)I>ip z120+0`!qAIcSp2>mn?py#1OtLQWCT;Jqqc|l{h{gBpXpmDdy>^+s<{|iqa9gmefdA zN*TT+aCI#v~bj<|VSeAi#`|-;UNSh_2aIxALPcdKR;*qwYmIQhNGGXQR_V&HuqHYrMzDN|M=l#}z3PY1*}iCH2|{;khAI!+ zhMhOZGqluAI*4C%hrMy9tZ6XLN;sZ2W153>k&cxojRqa7vVLI}&%`xyN)*GTadVo~ zahecnq=gnyWC^%lPPzQz03!QK#onv~*|aFV(H62-hDO z*;Y538>;vyTI_QpKkOF$sFn(QoLbRYDP^cSi`5i7)<`NAKAom7D^?%+@#fz1_Asz7 zxEi_cCuTu|lhqn_uHBDX;i6aLrZtjCg&DCH6Mfew=_pF6S}tU}eLcqx z;_*}~3(ZW@>+@M6+wAIU+AkJjWD{z=S+h!6+z_f3xN2s8IfU)zg;kG$$Np|Jvat56 zECe|Hjm?)p5xD#Nn@8{c-mdwnXJC@%TM%Vhp-;;^#p3GbJpT_@fbY-XoeS?So`2>? zOU!y};jjrN@Ac2VvcOuwGv9W`tRS$+eCU8k0-1CM?Z+Mu_*Ca`x!di(nj7kuP3&>2{)9Ttf~zihc%%hyi) zVDs!He@YS@vGW7?f#t)G{{h^TMP1-(jOE>>xB2vI;d9HKU4CV8V{L3T0IWtkvsxl_ zzpjU#*OjjhoCSA&0Rk}>Z$bBDdos_4Z!h`a(tyAGnM*0MZChUl2VTzY{@1}Bxww$; zn{bwQd;@aA#cOsu027oyTmr+8W6!Si^=%88UVh@v*F$XR;^R=W9k_(RQ1*{pa(Af; zZg~SFD}48AaQhnqhXdpsf8aRW**o&^(RcsD=8-i5R-wEvlr++oDzI^oBf80C~#A$HbuWX%O7CJuoQx$ywS7Fe8Qs3GFpL{ZOP)UdB zTnpwT8@_F&NIZ+joqo65j1F5hZRnu6SVJ-kG{aaKzo%6O$ROVK@P;wt;%+nA@*{Sb zhz#7uK*!=^2AMWfd`$;Gbf73bz6C4z-^mBBIDgX{18Zw=A&cr(g=OoSYtwp))20qN zN~3XI;hU)c$93!x&Wt1 zI}z0d>}*vuy%dPWgcm>dfUXhTb^g(L;Hls;>GJiLtQ{{(D#8?6!(7KI&*FIu_1Z2h zSRc3SQlw^y_{0`HEz%#)a!D$iHpgEcB-)9t~cvu8~wVIR&ch(kmDE* z?$Nfco!|Yr>ldY8%Yg3FAn?v*!v6f{em(H?8u;M91`nM-_s+nb0k8*MI|vTF8|Hyv zlLB}EfyL1y%k9ZY*2{?lN6vDpn?`26o-k-bE0wg&B+pEH{s@wl?u&^@CD-am`Lr;q zGjR`zs%^LAGPH|`9l=&5)?y=^(E9@7+2I><0ob+zp#T!soEluYBcc5dC=I==x1B$Dt=FodI8cAaL^Hj7u_O6_C!X zo63>pd^qooM{+vbC8wN5WRsb;oh>3{*tF|1L>!$QE>5yh#VjQ%ZIh|jn@O?C&!{-A zlqyOtL0bF}6|-6J^^dR7;FLzd)e9met0@`XzT2)u)k%ol6yYAb!vP5w|*pW zV*BR<*MyE;y40uM2iX+;!d4u%QQ+X2!yy7H)-&%7oZf!u0E==U5A?Oc86=!IuL`_8TF!7*oj4>)x!bQ5^`Z`V#;aVvhgZ2|V{*Ioi1 zwSpVqEw5bL18yFzy#-*O4s32LikeYy*Ldw}@cP%RU2}2U3Jr+R_F0{B1fk0J^mr~& zZ&uk%JVSM1$!NM?acpK9iSnJ)Ku0Ud;RLVIHqz{veGPio<6dD@2-gh)dPr{HLl{%6 z##;-&pPk?Nz1^T)3+(~_>C;=g4~`62;@Yo2n<9%{I{Pfr>6&izZoIUIX|czF2OtjN zzhi3=wcYb*;P_E;r^%%~y0P9~5*acnY>;{M9T)cTYw+iR&Zsf4F5Lup^}21!fBpWg zYhSS3(w(m@H?E_NtajfZE`94cyZ`Un?#pj1+|3t&r=U*Vo<#JI124L)jIB2FBd=fk z|G?=tti_i52<+buoW8hu6;CaPhjd;|A{4}6lU!5RVHpM*6P1ZY=|q;#z&w0M$W;m% zu@G0dA|VliV@r9rfJMsXTAcUwR@5)G@>N$0rwPp&>rmTn~x{M_4+J%UG7CF)tz#H@z$&0KPzg>kpa zqV;CQ8rG-%evKJWl@TLH^M07ei=xnp2&H&$IoDVH=dAv5sGE4w4d=@eK$x^y7qT}@mUzPeO<~7qf z9ix4|r27>!ZW^dz$E6YzZb`T|%!e6iSQO(%zLF(Gq3_T$s|u^BQ;NhaS8?LOXHk6F zuXdr83pOSg^$T5n3yJvolfLm|5W{%ew*v>)7piAvQvB)|)_`huxDd9c1(G65OgI zLedGa|7>W{?e_22#?bJb0tc=O@nG$}ffG;@|Bw$J0{LIr+7G_;x~)Cn)Arh4@Evn) zZ|Ll;u;KAsc=f;+9}ZO4Fu0&gRP-gv_!5D8>irkg0JLPM!QF4zx(as1yyY`%r@^N` z3QfUN9}N&NGP{RcfARmTG6lrPpr?BB18cj%+dmFNf&+iDz78Jz+^((pcd`e;wV&Um z&%gHPHvoHc?d(cu-}>>u!iqrCG1pFBt0avsX|*Y_;0&!^6=M`4oR-^|!PHp2qU7`O z2wg(QMJyqdNr~%uQhZp;&yu~2olCcjB3%%$WUhj9O-t&yX)+N-i7fam0ZVA^{@mgF zz8G8wzx?750*QLt2jL7luMIw*xmZf+fBZNsVL$MJwWI&8#k}yMD2#Qc1F`Q$V_L&v zjbcAbrMVoFz-+xXab*Rm4#22?9IjM(#v5vZIbP=rA=of}t_JJstO28LeGGOx=qNj7&LF zuJzJc*l$=EDKK-Vplzi##?=|RtPO(gz`KH1UtqP{VG-1=53d~uU%YI2~MLMuLVDN0*3YQ zxh-HL>oH5B~XY)|2Od^4|ls0Qm5eP*K3NxV1Ihn}EP9(ZEDei}Ub^}zlYuUhVR+@xDZM&EU2 zD0GwBmeyN1N;?mLNB=r-WT#*Jp?K)nYLa(75jqI4ufhDH{ppPp=O6vczzu=tF6m#n z(C$l?L`uBdq@$)i%ywbI(atb4D{d4}6(3hTEUb&_IN5MVMWv4>Ws_AhMKT@3#IXXg zLes_txfzWjZ5U3+mDQ<(@Q#h$Y~#INwvVh@WIFsfjE!?6Km8s}jQ4F^P zB_>s;)KpJnqilE7_b7qVIlP#TXpSuVLmDaL94RD>I4p&5N?ez2PcP2B_y9PiVC6;fBM&fU8~Waqgmk8_5}d@EvRXFFM!V37rqtv zD)jU2ss>M~QI+XVl2gYhHRyb_QjaEkV$rI>?lf6dv7}eENV1Dp@q#Wg+<>$&ZD{h@ z7Q{3JqhO;c+Nt-De$wh-zS&Ugd}+kSmmRzK`S*P%aBToQ_1WM7aQeG}jq^8rFK`d6 zon82Q#Y8lba@!*%n?*!ToS5YX7alCooZ)EF^ZOM}C~+=>4&Fo-BNZq^om`ghFO)xF$s(I!7Jv!|LxP@&SxMx{8v8;p!2^udl3Be zmqG*Rgr3-$)tULHzI}Z4O!dcs7eZG;dm99|L}H><8kJa^2xCM=ZPZiHWOX=0#WERE ziL)trgf_caj;MG}%SCuJW~Mc=kk?~{n%T-WrftqHg<*{cm4kJ+V^J}betKtG=kNRH z!09W%7ua0~!JoE61AzT7Z~{E_+R#yO=N5$A{$@QG4uA*$Ja}9g`Aj=A^h#_d@XoJM4g%0Xfx0`_(Fjeoz zDzS<%9jS{tDh%B6LD*LRsfX8gLpKQncYk#41bFC2fg8?u_5{J6`4eYPs>uPv4mzE% z*GSazsb+X0v)xfNEBmArE>dPZM!`y&a;=^0&yocJFIS0@>5kdTpi(NiX>%H5Vs_m? z3(BxuEcV^5Pt^JjC=AwKa{iek!9NOubAPkz!2I?XZJfXU+Tgd=;XGC~gG#!f>(;cU z)C{OpiT23n#St~&!ntI>W5C3!y zu|=t(9FaLH1MYft2%aTyVT+*@90V^p17rW&*SFTeYoA^_t}2mgot?NSmC@5PPRq1Y zl5C_ktQ)oKLNm?8`b?POJA$j4Eew`6*lBMZDb$8KJ3_3iCzj~4T98YO2y4vgs@}=M za~hT@)}@=c2@bq2bb29v2LbcC&>0wIo_Tovl*+hC!D=?4DT$S`BUlOvTP6E=3Li_3 z8f)~UvZUCxLEEi{nVQo`%L(6P1e|uWPEQQCjDDD8p_Iu*n1v-Vep9n z=!1=;;ErDkU9nI!YQHeEu>p=+xrVOfaS4_O!Zy&NV>N47RzW))2Q$YLUG4BttCEdg ztTjx#us?_EC-S1-R7!AlwQ?J_?96CblWpjQQfpBpuxe5RH}M;_O$}nE{Tsm@ryzrU z`deG4)mov)Wb$P#Ng2{`Sg(++%-BQqOr=`LnYr?WsAK4?f+{0P7B$OH)fK+b?{S@! z5>`f5H?NiwQZZb2xM^F0iKqk$3x-=T;KjiAezI$8&c$jIQ}nR*;aWk7#8Rwt^*G0!7-TxR_uDGrE_?*oZbTD0UFFM1~%g zXnsOtMZFg3q{cikNnuokPm*>fsaG|t>Xa5MzVGI>Yr);WzH#P!;D%s+6HMO@3r^d0 z7179UcSu%osYvE>ZKNv2vy(1e*G7FYzL{bK{Gjj4L9 ziB{~mA0x3r3dd$6r%N;}aHbVJ15h-0?UlW;p|_pJHg3CssG?|40>|pXt6)kG2Oqi{ z61~_Cz6jj^XX__Jnl-e0ZT#(jdTbzxy2 ztl{*+Ea8!Ty~|eOafsvzNViZO#Ik5uj+HaL#4H_^<9VwUjSfb!PC3dYx?+YdB0Ztz z)}s(Py^=l+KEHd{sXb%2y^M+=NDsdLk@ZvOm79aG`{2VlcnB5~3tke#@*HcIxq91; zwTj~;lM4Gi%rf19*!Fv)iI&6?;b9wbqzs8O6S2$1;ITZ#PDjV`X2pYb8_jY%W|Az^ zYc%C-yG=(bK0@rkqMN|_2s}1uh0I-o<9_zHLN|gpalzvdOv3>7@EUA?;erd3L4eyI zhB?L`aKS~%-_K71EdXj{ZilV}fBDYMtLAr}-Md)eUhr5P8oxKb5E{RayeBlcFBx>f zBj4IOsYa6&<XshuGn5NUk;T^3YUe73SI{KgiNVH%s@Re6PLIx|lr&wDDYdCO zX&oL&(i2Plbe~`wCMevu1lvw5I*be8b+ynj@R=V6w(k1_7{TxV?a&5jTkAgubUVGE z(_!#<266-Y+o2=#vnNifU7_eCa-%fnQ;nQ7qzu`s*Ihx$rK**3K1#-63xBf8`Qc8L zt9y!$Mk$ic2(ZR&z~{21YLigI5eO3+xxuI~5!ggd843&Pq`|A+7h>TFWRHC87`QzX zd@}@WmpR6MyAKnZuvIr&VQWmCO~jEDVe>9-RT>hh4E; zr=+x+Ss;?yv@jB_iC1y+(QaKRlErLnd1~0=bdG0F0SBytda8%&@l9fg$-crB+s~TM8C6~e$2EV|sJs*y= z5~}+@gq{DNrQjR)-nVD{1W5mQ?W9_*GV`Q#R|hzx9GqF<&fU8>2tCZ)mlCZ9Kw zlO|tQ!>n2Ib3(pUZ^pt1ZzJ7yVT`2`rczSTa0v|m^BNA0|3T>38bqpK8A;2^n~4b&jLmt`F*i-oRO%ptykkqaRzp7QFq9u+2T$3pT)S ze?NEx-13R_tvT`@7W`8O24H{m#`Pn6b!RYvXF!g6?U9Ru18;-Xo%PsS81&z^4(o?v zYuBswY%f04GKryC)L=y`lcUlTq&E}F5t>c-3KK??RIdfIQ1uKyC{2qMzi&3pN;Z$x zC=nZA1w!d6l_7$O$x)+UG{T*DsSWP>DFi(iehWO|EqFaR`JG({&;NoIyeG7=5C$AP zL987;f#0Zec01$wn3*&fuSE{~al_4xjAAL71rMEFJGCF4t+mV@FW!P_AaHuV>)7&q z!YOz_TTh+e@`B0W3Sj*3H2669?z=V)f~RJ|$Abh7&g=^wSF3)kKeC(6a*1jgHg2&s zdQ>ZA@-E{!opEGZ9t@JvW{!?Usi8MxBSR?)TLitF>d)+?HfRyH9`<^sugCKdH%2k4 z#Ov-{`{p&^H#))HzBWw%$S+FN2 zFEdEf^I>KYz#F!Qb2$#3QRfm7q%LDhH9f zPHmEDjyp_)rU&hmY4uB!u#(N!FuxRu&$4M7)r>+o-;pVtZRhhw9iF+9%Faq9IXbLN zHM35ndI(h*xoKxvagKr0_Xpw0Hw<|2qp^ z5!i6XFG-FSPm5h&tik|cI*WRRij3xp^uQhao*^&@6N?SQ#ZIh9Sj(Vf6OJ~5hjKk| z9kgr`3uA**#IBJkI+Z>}%%U3(X+TqgKmwMY}fQ2KG>l!^F$o@= z!*$!RI?TYOJ1&aGn0`3 zhW`Q&emMODc(C0~>UszaUjp-M&xF>Y8mEl1QmnurHf`ArLFDAIs5XmSGn&KllU}k^~tsyFmcwLbO&tIEU>=Np$OYgvUnj}jV=#4!lE!T(^oYM zi;U@x3Z1kxSaE-&)wT?GX0J}RBhJBMiRU~pc6#8mH^R-kUxWd{!tDm1*|QECbv_t; zWMhHypPLV_I|8HIr{1-3N-bfw*)pBTXzb7a4|{JO?zmmw3qR-BK6B0_nM{(&J~NpF zNJx~4BwO;5kTAAvOY$nql5MF#B3qW^P1fQaNJ0yAVM{m#6&fJyrIa)&g+tkzTzCtY zHEAhZ0|Z*yvXnq6xuv(z`;~oW<^-lJ_j%qw-sgG$oAL2E`bqjN-{rG#G_FawQC1qv&`ihDlonr1G8gkV`4?-g(|7kGR47k`@Hu*eMk7y^>?jp zUw`C~_o^T7>wwPAm8<6Kfj?Wn*28)m`@HA8C3K+}DcTxDcj10vp%$xJTxR7AT0`XV z97*ZvsD?+0b{uL`F;zFMe9}p!+YT*RMIy>dQmbqBRIXI)a=k<{TFa*5NTizYgSJor zo=N(D?>iq>8SeeyGf@3Gc1!T0ogch={T~9W4f@3U*59$#+I~UjBKXcS__`GCsxCK^ zhT|?+X`U)1dxc1gYGG9b+E?-I2dJaov!A}X<)PbK`;Yo(;_T$>az{>E8Mtl5X&L_8 z2I1Lj1Bmw^``r3PJOA{)^^LVvyV+BIw02m~qf^aFW#^@aj9GE3HD=RQ6ivq& zEE<+8xrnxqW?gI0&Uej4yiQnc7)z3k*M`PmE)U##J4bNI<~EiS<$}Y{40pF@-9xu(jHv2I_Q}x{R`@^!^Jy z{Pk=3a{%(Qys9r2h&w$TNA;xqtfIH8O@_?OO}#wetyp~; zV?lYSkl`}|L^nfCO;~i>oz^?$(NMQC8RM2erVF zosWNL{afo$b;dskg&@}9RN(6L!YSZpQYkuB76yYVLsp0Cz?MrRBEu);^q@{q0s`Fa z+Gx@-?fG<^EGgMB(JUA1y$&8VZ4GM^Lkg>~O4>oaD?h&uq*Pd?JAd}jI&8NPNk#qO z;)p;vO$C_z&14lJ-z5;F-c3f1(9EJy&=lVUk0V@xAWbu5je*d$WH zjX2;6fT>6TQPIhA<9Q2;GzPt@J3anUC`tV0=b^a9-4F^1X>B5QYmP?ea>jfxLwk#; z<@85wbBd2+b%)aNp^_jLk`$lKYF42jjxmBPBn3=0(z4p1$vB#^xB^P{l6V}`DyThH zw;%ai(!2jn!Nkr@f3^Obft@@4di`5#-bFIRd?#KUIvZf>>xaa_01^`yrQ)fqNV7;W zSueG!(y+`+g`&zWx=znj!?hOD6y0u#Y&Kd>JYzVe6e0??R>0>GHqj!qX}DwPqas%U zQMXQI29XWsUHBWprvsw)mfr||$osErL0R(kFN9lu`m=)AR@-gCL87_oNEf5A|pb(7F z+MPsKtjaDqXVLoHOw@XGVj3UjVh+RWQWxG(Y;N0G1!Jd7GNSc!3wb1s^{SEc0iMZ? zWr5-<@9Q;Kz~8+$c&_)|mj^D`-NMfP^T0`r=FgxpVQ3(TJqTX&3-%!IYyN9^+zB2( z{n)*$-xU0hohQD!{*#dR>>q9(@;-RgrsF;KJrLo3;+yMtoho1lz3=?<`kw}Y;NRYU z<72+)#6<&*&Z}q==593(+CMgH9{1yjRYFF151oL_%3rV^EZB2)zWFcf-&$gu4|)CTH~nVNMLYNZ>w0%> zhyKwzv$nJG@9Y1zZ|C;{0cXQUKp*lx^vuoGiT$Jffva|&e<1KkXc?A?c8~4!IZSPV6#49tS(~IWCNP99z>>kwW zrb22yAHWlv!1i+VvYqQM3>;j8O3408PVFiFq9}1<#w;^#WDY9SN*syz$ZSlgrJ8ca z!`~BniubOYfK71I{t)MJmjr@A#dJGf_uZjCUjBC*`TI+}2cHMa``AwdA@9G~&4%|h zD|n^n9|+5Dct5@rKyMG97d$M2nwAnvI0aM$ZQgzZk9CKU2~RIDWueqFGjc@RvQAp% zNC`A(bF~y6Q;W{H(qB+iSraFjzHa1O1IRT9Bt`KP5WktAwD-_wpg;Rxmj${zhmQn~ zuAgPXh6N1iz zJhYC7w<|9>x^vkLfp>0scmCt%W!|wDt%pELx1)$sglaHxYN{zFsx;I27_#9IWVqYJ1+fr!sv1@3%84<=0hsrJc;KF8 z65{V* z+D#`wU@5aeC^AoW#!$hKJK{K+cPI%BQC!qCA$kehTv(Y);F}0y*|I5}zUirPj zbG+v~FNo~K*uafzJ5MVFLV?vLd5^PPsHvTE_`s1huUQLx@e*qYr~Rm-^pCg3?r1nT z-tM;t@QHUD4J@gH-}hI8|D-9Y%_qZ7t<%iQD&mHtVN$0}8U$Kn>8hP}36+acP9ced zGD5x%VT9#k1xqUAKsPB$FrxvN&*5-_N6ZCR%4akAve-GDEO_j*0M54Cbqso?=k4w& zTq4l*&QSvUyhmODa`=z^_2yxC4J2c-RJIF!PM42>USkEcyFjB`saiunnea?y9bye4 z6!gCLg3S}&;Ir^VjJe?O9Rh(-|S!=8+)@sUt6Ocpo$DUcKx>0R=Rc zq475!Q6PR`)Qf|-o@AQw5!0V*=?Dt2tG-@JlC8X&USyJ5)W|G@9@r-s@BSwsasKI1 z(ELXEz=a^_qF4Hfo<`IK3KX8KL6#oodcbTS8%fNQRF@CJc?D zwvvehx`XUvG0B!Wivfl#i-DdupC%RBj}Lrs{uZ2{q<1e3oA7N$fLH-TU2Nh~-*%v|wfV9v_Di!<>;x6JC6T%*mrg7w0Mx-jN4w zS8Qr{R%V*)*lN|au3l~c^;Tkfg-j)CjTiWsNbB9GJrL1!$8~&(X3WbU3hwuQ<99X% z@7B(G+=Gk5nD@%5f6D*t3|i_}uRj0P0KV`iw!GJEu3zE3>??s)y#wpSVsf_NHWOk5 z8mQrLeKBB7y|&PX^VzIfY013Z&qngY{D8{QcEU8W%#iNHvjDjsmBLOYK8+e8Z_2vS z9+}w8>eZUw0~akNY!7>HumXQ@Iw+f@i;G6fs+0(+rPyO+0+_Kz+>)oI(lB2%THsh= zMQuDCuST^I-;3*|dc0+JB2sqN1F;^mJ6lwS;YeZJ$5L!K3-WU26pCXzfv8tl1orQ? zj;{Fq&Fj58oWSPERuTq_Ww~3Y|HIZu$2^35`a(E0iO#rH}9nAs}f{26^GVO8?LDh7dR=pRz z3r76l(S2u~0t-L>^35X~Bf}XgBk%r~t)ssvNPO(QfzW}Lp_qDGJ+5{9LXr3Q=OL3X z{5`CWM=#n9Wd7?5>#qfn&l$eFbrt}DKT`w9$p=sD?mo+y=&=unuJCTCg@E{bhToE| z3*5NcT>taBz`K@T@wUf-%TGV7_Pmf_TTXHY9B9RkI0L1drKXlLQ}`mC!}B>8i5Yz% z-7yG{x)TZUsz{wVKOjjSGb*@zqipcKkee32)TErd()t)Bd zNru=Jo;(d8=lwhd;mTKlJI?XDH?P{A6=#mr_aLCpOnN%+m8Yms&~GHq*)9G58n4c~ zc^*3$0adbjW(eY1moG1)*XR`nGwXdzV-}rB8G%BBvHa8|{*)Qg2&i-gJ`^ zLzc4~=%b(lhZeG~R4MXIthdO46lXNI;(B6>z}34qd*)}hmjNKuIn2>kL=f3PQULlw?hl-<>SD{|4--o|0JD@_AdXuz#bStOxLE< zxzvOBu3WBFBw|#vNkOS7iSVGVQ3iM$-?yFJdShTWwEU zFFnbE^r4MnwxdQ>uGO8kEg|bD3rw1^MGB;E+ud#s%@-2cRF{*Cltol0xRl^jgB|qq zvMq@uNv8TGLI9@)p@n2Ydlm;&i&>k~J?{rE4GhnCvH-|_cO370+1{teh#Y`*a{|_E z00McMAESdkglu&jxUuxftP%$A~VuVPq9F_|tBcD8DyKt*FQERPkP z?6({qpP?YFmplogILVKIwf$7@d-rbocnbd+?pf5o)-ycVHYXitX!?Qjai5;(_h>FU zwS9?|5pR_t!>Q!Q4YQ-vTf=N7oas-w=%@k$Q_L7M`aPhd$1xqtw-)LUBtb|HcY7o< zZI97%ZDEi#A~nLD#<(&vSO9FN3d@_>Loxg5U8jhxKfC1vY3?My&%eb>SH+p#UHLSf z64(g0y>R`%BTt=vQ`g)DJJoe>*}QOdhq>TUVTcz5LU#tS&eW;KHFj7SfdNqyHGuX< zyG+dDa10KzoYjpLJ4C86kCI~|I*2Dg6((HQK>a40tAr6%OLw5ToeV>FWl_uH_(M1LSC2s?WuClLzsY z#<)R@77G)Tt#G7;)|HGfj5Q>Io`j(-D!t2Wiot)o4xJ)iV^_EhQjcE5~!54Zpe`DB^**V;l~{hB@F6YUa@_KawAfu-k@$RHZ0dSM;c3UxByua?D9 zD_b$*v08(Xr}Y-9OVP&E%n!9$ELxe57EnMbr0W8fK*8*zVX6Y?%o2)^Bieg*f=I#& zR=vAh{9hlSwXZ@~L3`Kc`KO+*sOybtVaRE$)M^goxDNG*oE&c=ZLH`{(T=L}1HCsa z$NK4{lc)|@;AgPfBvvygf>|T7w8^p}+g%h9jp3Ox$)_gs{TxE>8@IQf_=RY-_(S6=^1 z_dE6tf$M$r$Id^#0q$>i?X6kR_7n|nk#cDTXY+%&F$2-gk|xjqOLAffSstL@^n^6 z5s=E|K?~nidv0bLGtus(IIG1nr&5x`%fxs0H7_%eFOd5$^Ir4dQrK<}8TET_4&1o= zH9rjj+}nS$p=-S3mjdVW7fF5W#$4O)**vuU?8BR0={=k0oVqtLRqeJltF1=xW@|E` z3E_XmmA&*b4dh0&3SNd8nu@8w`hYl5vw_FgX##h?1{hg7o*}1;#Hdi?3})U* zmju~FXI+`-8A;%5Cn|8f)hshM$&z4+T8gTpRC@;5>n_0t$Xok;EsuT6JE1g`?EX135mrPlx&a<<2LgFJ? zDq|$T-U|3DHB4<;0xg3PQm%$qWxCR9E!q&TCkh-nr+vJ0Z2Q>1K>-j#PVn-*!aMiR zKxGHCvd;GZWqI#-%f7Qc{m<6?+}l^k*pqJo4j&9aR><)!m|5q(J8=8S4SFRd@Tc!S zrO31=a(9)`yKxWd$NrRZ=|Ux7<2$FthmVXDq5~Y1={U47fG^QDr2L5vJ0s! zz618VAJ@B5{3!;jw=ICAO?6B@cS>Q>`Wim$a1QR_7edTW5tdLv)g3vq0e zFojmB-R{oIei5OI&Y4U+HDYsiR~{!oU8m;-ObXJyF+E#2@1L^aK7KxeTVY5;i>8?&ExH6Tni_Oxw zSQ!YEEl3@dbb0vnV42DTC={%VlTxq%NLAQ(ab;?5C(YKsxN`RJ2 z_Kf-9>Dt2;f4TSYXM}Es1Ex+XFB1jRs9IRKlwpWT1~mDt9F}p*b!kFZEJhcL1yi4^ znQAgwWXQUTDlVsm6G%f$S7diFvkE$%>ai?%^ZD!l=eDWuerhx2<0ygq`o92~{! zUo9aR&xZHE9t1@vzp=3M`iBA_@!+??Jn18Ww{O4h>O*gT&PM}l>rfNA@*Dduf)mJo zEwDw$5cRjhG%i-Fqaxy>Gu#=I)tS?e4mgQwrsnV?)DQ=@Qga8ys9BmlOUs~)P|PKw`GbR-wXa&5#sdzu&MM{@Q)}= z=2JM*Q$SpZ9Ej79k&`&wRm#5?c&aMT8Y#yCce?sx;k|!MZMT+~)9&hLpmqk}`IEuO zUU=W`p9SpY$)BDCYI(Q41F${&FA80Dg)tiRkDr7k_;?6SJ6VH(i{jqxC$^sH-S$TS z)V-J9x9<+vPX4>j_Hk1gtT42=|C=YTX--|mTFH`OO7JZ}$?){_-te~w= z2hR42e+%ROyKTT5zvPpFZ|?JM|0+~lt(R|xc0Tbp&?jE@<99yrg}_~FUjNIW4d^3a zz5o5?z}LNxCIW{xh#PPSO1ACnVQ~`fr88|Z)^E3jabHQZ4c;cTZmYq$c&uPR22Z!uWDdNoWPCK~lG#bsOMV%EKVSU2z;W-p zuUtY8^-;TtE~tT)NoLVRqa)UeNk^Xd@MwGqzqtQvfqgsw{%GLaLGSjz4}97CacI-$ z%Midh?^VpX6X_4qy=b8?sbo?TaJxR;Ui;P!=Zpr{l5puy`a^GDso_GusH?bW8)B}|jh3n?>B?~x+;F9I-R-;mQEp+HjXofdj(Pui zPVm}|<@SYp*BuBx$NSP(g69UG0}y=g&ToL|+4uKvJ;f{i5R|%}_{REGJ3l@U+zEI` zwM`!~1p5AHY@~|Jd}=yiFfnOP_y&tNEw1G~ga)tOdEEuU8brkxtY5x^{q@>s*1Ur^ z1VbBId(<*e?}ImnaPN74vwr^Nx+Ek@OxQI`Q(*QNKm!-tWecWkhlkz+Ujjkpy}t%< z>1RS16+Hj4T((51VDvnpC*}lvJeXqECi1m@mGK@@Kt6QuZ*^V=>|2;!{;>N4UW_u} zf;29LdEgE=!zu-y)zf|-+kR+zg*ShFsJQ%P?~*G3vR3-m5+7wmdvv4Z;theO!d$;d z@H9K78g!@Y`Zs&sS!(;vC6-C9 z(5y=(Hh-|*+ZOwddc{k(Ug$meC7{v3XJ>mqxoO{_oyU&_!3px-7$|3+cL|WEoD`lG zvtlV(B4{(wYnQ`$9L#ScB%991=6QxvDTOUgvgO!Zlm-J?YNxvQwPw z@Ia6djc`&KsZ)tTa!g0ICNXP->eU9`81i&8RzU44+aB9VV0=r%Y+{N}IJ`9_!a^BS zpukd^y9S>pgelCL^ovzl9Om?n!vxN$o9n?{k7fnG;aFs+4%NfH`T4~m^O)HDfDYaUssHona z={Mhem3Q7F>(BDez8L_c=X?+3pzgUjcsat}I z_xv{p0ONj6=sfQg_?GH@@)G4gZ(ifQs~mizcULL6;gLmFO2N8U;(|}{zVbl`!T#iyEgy+` zi+6uDc<#=fm7sejk-txP`SXJpo(6XN-#+4f=eL5_?_ALd-nSm`;cuUP6BI8WjISTQ z462BAwX3t`p;SnZ6K2tM&6o%{!-jYFD}W!ksRy6B^P@rVix+uMya?8U9}Mo?`Qo6x zwh9rs-wFOZsFgec^YVLLK(hI>LyXx2!y1`9RxehqnLs*4hE6o==s>FS_}EssY&TqF zCIT`?l`JL=OZpXGh^ zC9uLSuwX63nyS=-dUI5aEC-Ji2r`LUj5=p2r zGadz$MzNg(7PO(4n3*fN0>xAiVmgS_Sf*OV6N`9>!VtYP%osL4?4>2#9iW2L)P`I% zSIEvV+{LQKM2$t}wP?!e6QFgg(S4n7?)!G;&SW=R9s`K}lIz`j$-sEC-78D1o49YXj- zu450RFxeQ{@v5ZBC|RSdj2N*ji(yJhL&fKa+?WkYoQk(6gHj8uv6%(YN!7wV4HJRQ zZIDT{mW!S0W}hmURn7&}$rtVohM^8@^PykZ$$jn{gW1(s0XzRin42S5qi?u#wUBlm zdrR>1TWhX&?@jvntWU5Dtv;V&_+WUOp0|N-0(SK9ur)Y7`AABATX1%8|SK-sFjMS z^|F&j&2f7ylCC;VxfRc5L%RgNqkj79TBkPy!Y`rh|^^Mh2IN@#W zwt^r0FaQp}^LigfJJ~o7+$A4*J22%U89XeuOI1$mI{LH=Ku3H)=3>byDv+cwj+x?I z2EYfE&y-yxtoCLZ2}xVrNM4i)$r+D3K*}xkz-Xs6&rt-jpqf3>T23#puer?o_s;+d z(>M0^;PPAEcOHTzC8mIPOe2rDRtMxWdmwWmahC%aNp0G9n-~fajY^8p(Qh z9{`LTK&=1S+xe^DWgv4N-+riZM8vbvrsNK#&LY}zk>MhSmFi&cWku=4cQl`^Q(XP?ugjQn4L>#rcxiaCFYE!qoY{vFUX;wBMFr% z&NC2Q^(R!VQRarF$R5IX|C7P9wx783kY~Mi?U&d?Ln!Su1&>m-485{X_2-# zAd&Vg%}%-*oyD_N2F)y}Sl=m;LQzF}rMN^5Ck>=qw8n98&~E6^b5<}to~@Mp{u6LQ zJ_&F2c`sPT(_|txXm%TQP`Qj`xG0ae5*Bc8*dC8TV0?*B96r~(;I9G~?RcLGwu37; z@4au^8hQ^u61-=X4}9tE%ad=#RoMCP=Yo%}?|lD@!SVXK02!A*sW`=H29z3#wH`Li>Jukhoz!R1aKF!kCshW7j`JlsOv@BC24Ug;1Qee7 zWY=g~ZM#Jpyp+$DTYf2G6S6%(U;;h*MCl}J;C2L#pwqILFFtqu;P(BW+&B{%dgtax zgC7DZCZLDy=zkwP2aH90^{vO=yZ6ps_)Unayf-0hhsAuoRR+DgN;fLc8?)E~gl=Zl zqR#OBp-Mn~7nH^vt{E@q!E&x;CmU5`5X*$IUZ&V@gALax95u47q=wmra?2tY;2Ym7 z+uj@Rh5@7B4er~iemi(iz`N_vCg{Nd0^X~BFZkx=kao(C2Vb%YTq3a1^jV-Cy{s1a zq=A6|@KBs5!)1%^L<nOo?n%+u7m5YE4{gC_`dJeKvTqy+J+Uf)4ZpPKP5FN=vK*E7yI?jdKthvcY*cB1#D;IgTomh8DT5vt7f zSW*m!op34N(h9j&!%9SrUK-Rh5C9*P0qKq;D~XDsEi|ywEhAK^E`asPx$B5$ULU;J zd-#6_g5FvGy!AZq4_)|g={sAS9wBX=zau;~(0!uh_@CEAv@O*A!Kc}1RlOA z7}|Lk86pGTz0U)N!<~uX5-KkmX{0hAi^(|~cCCfWVkrPZqTO6r*Li~P_L9R0Xh~N` z<2Gj`t(-V*)gjMf(&enm)}`vS#E0VyP8im70M54vhy}G((Ae;0YvB!E<^4w@6!i|? z0df`CmsUC<&pK;Q9nG`X;M2!g5GNWj>L_DXsG`%trGit0eYer-Mw2r`>Yy{dGl~vC zAQ;KOn=%nd{I&SBSQ%#7Ih6m$b~v&~PDia2HbRTtBt`Q$@T_@XN*}x0a+j5f=lCq{ z$SGRBH8$ryp>$abTS{ILK&;?y11a&~wLoY2^y`C%pET4f-Ox?`!aU@i(6=P-YaK{x z?s@u}pFJJ+ZW+PNe&R+5zwZ4{;8^1%Ys4%A9KAVGn%SKc(n*gBLq%8+B{f1KY$rLv zdXT-9^30;4t96?j3ap(;r*nfwt6dopIk^|@*Ek^#j^=&NqSKbOB*;GhrI3w%^aOAf zF+6m1=g)5nks&{A4tk%?0(_0w{MC@=C|C!3s`{lQ4f$T3 zhDC~DGBO_(q=?Ei=@RWE?S#!Tbx}$*7^#mhVpGY~t4^d`ApwHdi4P&|p1I}Hj9qjU z&@k!LQ$v8F-3m4T%q=0^i@ksIqJ7I&IcRz8{B-Mz6@>~0bhUT*nW4MAgBj3Ez2zuq z#h>%8(6Luvy?zh`&Op8bhmT)Fhc4ZDc{cRab%<%;wKXwn1_s^^MZ4*6SnrdmQ8fz& zadRQdg$K=Y4J_V^g6B01?SF;uBLW0v|M3~QP<}b8 zS>s0aaR=+qvC?R0h;D0&hy#V`Bj85$h`jtr2$y z@m;%aARnFWE~%%hi+krC2idI?c<6w4S1Yu!^R;^DJLf|W)wd0=5i`wg0ba4D+jd&x zl-!V<^i-sxqU@*#KB^{TjWq}9gew%2a!Znh&@nMN1d;u?!i{F}SYjNBPq|tY1k2)f zla@POrJwYYe-OH8=gqy)w>G^i?}jvoriL0?O%FRlx{uilZfKS=HG*R1lq+Wdq=gLR zQQzqf)A5POQ?1M*qbXsv&5uFDRgKH0g|@@7cAAe-T|M5_X$LggDR^PK4W-wQLx&*A zfj-#9+h5xX1qs+cya)Wmggt-%SzhuZYnOmF#Gbyw$UW|>ohOLl+-fisXIt6`?8c<^JF% zsEXftYv>XXDsmebi_I0R(k1KNNdlB5=&9S9Xo|M1wC=?23jO|?clH(V*53)fQ6kFm zhNi|9p=3dwz=?(#4)*bILvc%4uuA@HFXpR-L^IoE zfZv?Y(0(U5JD7org(#k!c)P;)hqmFNxgXoQ1n>=OPh9J%+fWxiO^SmgC+PjCw0T&d zdQ>;6cS?~eVkT@y>ZF7Qsn6X}KT|UKI@y)mr2=EMqsq9AR2`;8lQn5N?i%$3Fh8XT zKFHASER_ba003P@6PnO)eSGNU%cITuAqZ+vuL}K9FtluOdFMLoM^-fIMVuqk6VOP` zr{N@qf~FmJ;(evn6QX^jJ4B^+gemviv3>$5pIoA^;Z!F~YV*W|QL$XP?xQ%eiw2wN z=n-&47Gk*yxwHje$}{adaNKf+t+wkzV-5Oh-ofLrWFCHF=)iTSdu>lv7uppa+w*(g zL1+E&t8d#pEGCAe*lw{A+UQxuXxeEw(FE7*v*Y@V%l8rz)@4$>p$=Pecpj57R4Plk z%pjKF;4qr=z>nw}>7LSrib*4_OQQ?2D1?jE21+Btm^`1R7yV8hO$QSAopKG=M2sOhlTCUu zr(wA{^C@UZ#cT5lu(X(5yqwC@w8Le1Y}iY+i)lqMi9rcUoGHFM8?&CW6THxu2MRzx z*;8H^IFrnXYHtZ#*(l&wYcLpSpD|4j;Gg?gY2`1Z^qy`G=n4sKd zyPXyWID+md-K@=kO`OXYT1Y-cfbgo`p+QbMMoDPCWW=3Wb(lzlC4 zuH8fjiAo%bM72aT6VaGlF@_}nvk9@njw7Id zmSnB4h{v2!(~|2Yb5yaHvOEZ6)QY>5DgrAXfWMqAWbOM1Q!kO z-eXXmTuvzZtkE!MdWUh zC&vnoa)3r&)>?k+ouMNa0wBQGyjTSu%Q3^T>z#Mg=Fw|T_1I5;0m7o=&G9LSK?DwB z@GbSH_XU3v^6_YZ0rNfnQpsKsiUz9H8Ns_NoF(Ni{Ikzv447Y>8s6?qe<+9Uy ztRCa|0S_ue0R**RX}w}G7Vjn4&-h+HMiQ87LN;*Ya9VXCE+oI*kK zGG2>oa>nY#BLDzyj3gD)rlOwdg1@qfr@`652+yL`c%>;Pvr57W+chdPmgJH?X=CcD zwu8%1RLx!l_`ch|vTs@D5OIT8^b1v+4Yzm@qY#-~7Vv~roq>IR+~{QywMqAQrQQWs zPC6V-4;Iji6N`>oL!ClIG00z7CoJdpW5@9L|t8{mze zTsRAmU>P<6%rQ}#{bjJ{{}`NlfArzdHQPTq{HC2}JQNz4E5G9~n=}Vze9@eMp+H_T zY%aX)zOdw;a=!1iljcgX9!6vU&klAWY*HkZMw7}77`)q1u# zEA|$+m8VKnmnB9{Se_Au9PqlSLQ-|2`FYYYCB!v{w{Y-2{r009M}>$;CscPfky1rz%1?moPT=)CV-AUY6hjjELoNCNcKxu|aMmu^e*7~B zmp}ClNPWZ6ZSIZ301ik|5KW%V$ayD;5`_hn zHx1bV1B`n%BH-Gv8U*&XOFYaMV|efhczbu|H}-8Gc*nu*_x+JCaJ8r(ik3m@y12o%Wpn42GJ?jIjZA~`+!9T7kN-!RO^j` zmIT@VR5xCX=;NdYp7)g;m`!D+*hniSvye2|3e(n^zMhuLlt9=MBO6Ic{c29p<8#CI zloxMgx1WCSZ12XGK?(n#zO(NFUlTd%PlRi{g94xr(7WM1ocQ4-+dsMQPM(PDwqU;)kwMwCh0Nb@W8l*u)wyEb+ zvTipet)S#fc2%E{oOk7T<3|6DdlhHx%I%XDy4zp9|LW!Z_Kpg$!mtG3E&b{4J^pOa zv0VPkd|Rn9n4m@%Mum)fm>k-AnY0sw z?5L8dO(@>&#BB-`UmZ}1f={>@P!8m z!n2?P{x9$OcW;p0fJyz;tvkH0+`I)0(cj(7dXEd61CI`x>^NempaV6m7uZVGr5!4f$)@rdpc{_dxTO`X`9Mors*7lx%}20gS**8+ z(cB@U257p_NxV9ngzbo0kn7C~ge|)(ea|FEPF_(?;H`48NTl6%fu+mlP)Fo=nT<+r zn@=>y3c^^ELb3vh4I~k3DanFTQ0HSZ!lD{ec7b0X3xv1jUidQ$@7$mHjqSfIUmS$jxVr=4XtF;8^{Fs5 zpydT)QY20q1ESh-gxSbSn}tjc19hyTE)?Yw5^c^Jc^xv|ywTxjWX5dwk*b))X?#Rx zRCHbe38}UQAcvpbfj9xS?jyz1tG_19L2L@tU?W|T22#Vk#m*|wga!9n*TxvJf{eH_ zHlC0JE|ZcwRu3VwJwD&5!wF)I=b$Q;6`gLTl)@ZJi_Z}g5y!^QT^H8cmEH{zU}){$ zE_m&hi#?DIN(u84hbQ~c^k>GYdNC62P#L$tu|$eVTRDnh26$EsXJTr;US}IQ9Rx75 zoiWk3;&ucKMN@2kYWJ$*q+^eM{<3%7yYJOuSR0per|-DiPBLsHce7BWnXofJ zUj59IhC}nv_VYe^Xm!Y?wWOAea+*cQM?^JhTGK^gB8ZlSxz$+CX^oX)XO2r`lpy;G zpJOew&?(StstI}ljVfyb#=Jw9*jTm@E5yY~Dz2-d?ET=6H@KhOvd-qg7wOdIwfvXw z$qgs9FFbzclNw&i3vLA_2ke6={QK_D1&#{nBH?JwWO;;7(sdkac0HoHFaXw8tC5IZ zY<23jXhETIo#?i+PA}chwbkyZMnGqe0MxZ$ierQWS?FR+Yc1SV0`%J9Kpd}5Ww^-c zJ@w(IgCpntBGl3D1qL%nr^oCHm5JoB$wbaihk2qQq8*3LRa91^a$}HY2aH~6W@XcE zxu<6pF*$8c5MG)_+mh~5ScWjFF^A0Cv{(>_I@n!d+6qen;ndA1C*XvP6leMb)Xo@c z+Un(?@9o%8wUqAd==;a+!+if%z4|FeEQUCKo=t++Jm?_8;KRGL`;KfZGOVK zol0+pgI?#Pnky}!x89t$WmA}n2|G1wNCia^&}d$nX?dgThU@cqkB-Z#n-w94=q^^r z-kA@%^Pd!{J?VA81Uk6=+n+r(HgTaWob-^bm1Vglv_TY)lN^xLo(Mde2iu&29tG3T zHbkCtg*Td=rZ&n(H9njNRp~50Vo@{0gO@`>OQ}&Muc!KKO5x75Ywzrr@N6&BPXThu(!jl;K$NBc^C@J< z&2c*o(#e-V5dIZ8^hQoghoa$xu=NF3Tc74FSSOobDhER76{8k>%Z* zzc{sQ0wc4SF%o!+2fxP@k+-?FGHLTUu^%b>N$Qc+#h&@8gL|H;D22fp7d7}AS&vr? zRue3qO-=h`Y#!$vc@)hRBei(8JS0Kjt?L>LJDM|OztOjf5J3%607$i~l$DoVGzua| z7M4Lp1f)d$=x#TtJAcplyEhlv^RhR*@3b~9fe)5}e~lo=QPs}mBGa(bcjl7R(4rj> zMJ7RhW=v!YuvzPFywhv;jd8f9@_5n)%$btwrWOM&Tv-^=e7RufnOUZkK!j{F*-O^^ zZ6NZCN3wnG>(2J9_Q_4p))M1zJzEF*UD2|XLOd4hhSk)l!lv~Bn1FQY9$90H(@0rS z8xu)sn9-<+r?Pz}JOWwqNC$~?MjPb)AS>(;STePMINo1mH~O2u_pLkE&f4C2H0s^) zH(Qr`fBH6PD|T<+y1>J(21?v97lKzT2fYK&1<2|b-voad zKHKLV9&CW7n6@=u1&ZCzfR%CC+{moX#1tXKv zU$f9onb4O`jQR#=SS*h9L@b(POh;-=^$1dnQVJLDs4mqgwKYruRU*rtvqGa1BWhZY z95cEUW9e9f!{)wW7!l4_7tAViKK8^$)!(?T_m5i8J-dBv-z&d+mG{5ix&btDcO$X7 z*RV`x!+f~YWJ^LT8Ug%FwqVm*ra2e_Kub(y!8NjuS7HjMSFwT zCmX_Qz1t{PuqI@FNT{_IUXY3wCB^s}SZfjE9!c8V)M3XtvXYCpqOICEIWWdC79{{J zW?79wRBvc8nORtTEhEaRG~^0Ji~xZ}m}V!lxg-8uJKwu^4jC1U>ews4yS07A_cyl7 z|9ZA}#cbnL!d;BU!;QM*6iU4a$iq_IAtzSq<+%i*LL`+~LVGrq)Q~%$jy-Elp-;jouT=>Vm87|N7qeOOiFFFndDV= z(4jfIkxsc$^1`?)U#;W8W*E z*z)duJ|vHCc;foiAaoM!iX-7>gDVcIsWF+Jp&c2N8O;13&$Y;8M~c~+tdE_ALrFTj z7^VA6wz)8?C9rXWcswRm3T8!9(jY%Iqeg`^t2Wf1pAxHqY~TFv04;z12DQ3&scMHI zEXzsx8qd07ZeE%>H4uJFg<}hVU&gF*madeIR6gfWMw4#onWR0Joq_C5dt48X*NS5Y z)C7_WOEt9t8Jmc0q3Q2>KlcEhdB?_Zbxnyjp{pY&hY4XiH~NJMMb&5N1lF+QvmBvR zb)^xZNs#7F*Aqk`4zUfQR>@YCLu4$9I8-jf(^V%y&x&AUj^VRmD?C!X%A-%Z=811@ zM7>L2wDC0Wir<72{lh=medGGrM63UYy*CYWA=t}5(Al<3- z$$=uJrchL@8$ruq({|G+;}fMmb^tOtZ~I3PK_`1GDA7vOn&U4AWG&K+QV{}7$yuRh z+jRWtcl@5apdbIy7sA1NFWbC+dDZh)wHr)IHGDGHa#|F(^DHZ^WD>yW&v4*F=&t-4kgGkA z?3{kZrsx*m(ET6ZIH`;>af=HQg^@o)QvGPKsiCUj4X4p7s z5Oh?c`UEi^v>ByFrh+wz=X$A@Xyojvf#nrC5!2I%P`4QL@fk$1P~zF%`)S}*Lv_Gi zcv9%V_h8k3?2DWG(4jkkbkh6HO&9+M@&1`NJboEE{i@CVD6`?&y)n@2Yqe%3J|1wo zlVRq1x~j#xW??vQm4oG`7EH`ql-Zg|v9J=B)MmCchDv9a zNI4(_OaaP5`=yzfU&GL^zj`yZdrzv4zmRb(Qq_xTkr-rw!aYu9Aj&o3!ayXcdamVQ zd61c=I}@^`Wr>g!s8)^mwAM^Xp>8#fwJo8DjhumMS}fPl6Y=g-j|m2I?v|kaWD~Z8 z{MvDJ$7?o!eR=c%6^L{U$koSSbP6)&l~KJfPYEumG2ERcXyS z$vO^7y8yIlj2Vo`W#@vRH?*;2iT+7RrdxSEkuQV15eHUatYr>kLTHlZyNT#z+8E5@ zMm`W?dO9Gl0>WHPFPES5wJWHHfdApL%6AHV7QLJ7S) zD2m+y8-$uQ*#OW9|yeCe}xPQPpOwzcKxNSR&+??Pl3VZ?gI zXwkDkm?)W1F;`UE>0BW&t+En1aWJYDmrTYz=jZYmPmL#b zsS)sf$sfsY3$uy&KA5$KLnVNJ>55gYu0j3mj4%WZj4(Oi~e z4!X|;^f*H>E>DYG7GV>d*wu?-(PAtVW7IG9!PbpQ_d_L0a)yO)v7QyFAVbAQj9r9f zfUJcJYJF7H8tp0*u_GY=ri(GcU-fgEPNU6R z{7{!C9H2m~dXf%~p@yXOW?@V2iCEWJ;<*;n$qk5>!+skFuI9TbNVz>})@A|037Mvx zRbiNOaxu#nd$Up_7#nN(K|dp5wL~`~h^6Ud5{Of3)KI~vfoSNM-fM&3SI=Jy=pCRS zhC?H4R_-pgh-avIKeg0->-IfA+(M59VSYcQVzdvv>7mW)awgiK4H>1$0Hw|<1t+No zK&5*E;L};kny9ohQ;3Y*v*U@X*_+JEd{&obMbhfgHbq3$i9lh|Y)&r+g-RJ>MtWX! zy^JAB-;I@)!*TBiHxHn@9){>}X`QU%W+ck)}8FS{Qq0sR-M9ezNOxr-->ko*8j&Tm3wK*lm#75IHn7Zu73cCmWnurGOcwY(`d6nG)GwwbO>opEU4q9NS$eg zH127Sy8PkI!18GASj9;+Q=uv!Avue0M|xtE(V_zp&q19))}>OR&vCKXqz|zsw3)_} zK)VtIcq;@btxPf>8;$ysSj4gEES-<&?PLcZl`ky&Zi9<_>e71_J@OF<1zz_uj}P^t z7Yo3VoKoiNL5?AUu~4K*TC=$^DL}!y48Sr*Oe)3X5Qe*C59wSDlLV$$S33j0V#LFP zTrm^~vpo2j78*fbr*fuHG#hC?`LxT1Bj3Ed?1>JR$rHRTIvOF^rT_u7KAoEW3?0@@ z;I+%nv^%zWKStG!&e*YtazCS0OH-2dm(@flKqo3(o1d$>qHPVM@nm^AQ|pV}W>I-~ zYR-cm{MhCV%j5RD6y>kk{VvF{@p>yziI--RBy?#y;J=$UQ&N{tF!Ol7LCeXJ5oOgX z9SFw>A1$2Y{5Y-t}o_=!=y~48(o&MqGN%RHLT~XZ(r`SoC zW^tlWDkxHAP>g}+i4}k+$xjxjs6_^#*F7GI9erq)EOC?xWT}caOVc4GPj>L8!yAIy zwc--Vnu*jr8!gv6J~y~i((T?rrAa_J|t)3fojuj@OuRd0j)WX>6S4EbFn|z z45C{zaHL<}FTCj0pV*wi66(3zds=DG5wL<00!_)LLwX@HDG@-~v6`tsg$+&Y5wr_f z5xhbA%%JF>=hR>mJl}I;8!K0fq!Z3S;b#~v7MftgSCyPWRGUyh?>pazgZ8((KHj>0 z=+h_NANIM&E~DSh!<1gnUkIs`dP41Wvx6>X)|^zYmgC5<1WwBttJ3TXiF84-Ez_2! z&V&jLq9vmX40i<-ZU-9d>=8vA@UpEY2aRafqWWnd;~PZ|+!NiR;hpu(>kzbVjxE+{ zw;#VaA#~eoJ%`af_03Cxiv}^^CpIgn^O^HEC0CaP!2afYjWEt8L5Ze3Px0AezN7_G zaJlVBLJ8I?M7N)7r=w7CpW}To5ySfWBmwSOR*)X@e0*$*pb?%K81UptmEfY!vFuK| zC-Ic~vb(a$ukf5fXG;q)zWe@OsAIHO# z2qwGzVpY?N9jn!x2aQNGW|CU5GAk<)$h1F$(|o#s z@v)WbhNF_p=YBwpTipow6EsR-DGLgR4rxfh-6TfiDLEVJ1Di?>G&92U#U?)))+Ni* z{RyQpXfXv<#}fUylq*@IZU!tH$MkR{mcwRmWuLz9m7e|g{skaT?)uX1O;yqbu}l;x zQHjXREZb%9bVHH48W@6EBWTt2z&ZyT3uVA>W=Cuxn$=3(N`ReVVFj$CnTBRm2YyD# z4=1UbVitpp*kWz;`s=~B>_HBaHDFwBp_>iQ5qP3Vbof1+&q8ty3OP?0=QGyogpQGe z3DJwteWNzZ2*X^qlo({HbDaqfAhnP4vNRZs=FNO0lr9Q016Re?s69`#itsf0qq-`z z1;3vpO(9OmV?7XI!C&wx0TKE^-Q!;l@hmy6c807%6ii{Lg#1ELVr1Agx{SYdrl{Ly^uh$%oyBf~4C}XB7g)x`4|G66F5Njl&KeivggHoH zJE90Z7pE1}OelWYMyqWMXrnmt#}esKFO+l`6X<81z6iE2Q!`X87AppottDbiGo^HL z0BH&K$syo}1pm`hpu2z5b9!ahBuRaw)znY>jZGKHQL1Tn14|oU6jRO!FUqZ=8koK zlLo3wGD6|?dbl`*`dKRL44~KA@3tpeH{L0!{%{Yldd*HM-B*cWFb~4#AnKlX02@qA z!YZh^%W)9h=5b9SLPkt6iPE*Rvo@!X_^w_q zRYSoPmDDQgKnGto)tKpQQM3k0vz?amcDydm^+uTv1@bvtuLnlaf>?}Gg^|fs=HY>4 zRi74eE!N>*{3h&--})v*B#Y=koi~he!VWW?crDz@O|e;|;Dr6tHi&SS^On?QU~@Ee znM+j+JKgF9!Tn>Rg=ZRA_EDUqg(PR>&}=!(LBVQXplAbEmfg)~h_A2Me*EBmbl*p(ba^L&xYs*tZ4H_nK8qCSUi>&{l!1J?3c=4x4L_B0DbXqAmD~jVc8HsXa9Ed z*)Z4d`N8J#WkDQTCEwlj?be4DErW|?@*m9MFBd+$TfBCQ$UZl+KHmfwPY`#YQ0JoOc~5{jPq&c%m8`uyzMt3MR$+kb~AR5>sFC`=HE>o8J(0=voL zJ8t~}tUm75UC2@nEQj9y0c-{ze;GWgi@$#B2k_)xI1D=V!_9LmzsfQkvHe3xa~5xY z>=STPlmRSci(@SQx(F73^m2IL;?7?9!}{1X5P-a{T3#XqPuD;aeE6lFb7&FGT>KLR z8oMWRao2Zit1Dk z0YU<;hPMd77k}PsJnuyxc_Aoox(DCBaX<9fZt@)2dDD+KZ}-53Ejr6QU#*O6R*#1( zvjII!U=dvr8u2{s&kf03!5|x4D^s!Ad{U4jonB7jospCtMzL6f%{KG3CJ_^&Or3>; zXU)l^M~T#|iLy_C&*>sa`PNT26X%bmHbTLAv_e?I7`kMloFWB(C0?P^U5igPSyPCR zdL$&I6usQ5Qh~|1Taw3NA|ufiu zl!C*oDDY)tl&Ovbp%7tccv2esHH)eeV129uZJ}v&7ppA7-V6%CFnKOTw^1;?;qf_f zzT1D|Vornr!Li%;ylWfcHTNlVPuBfmAL`WBw$LNnkSzT6E#9L$&-vNrBc4Tv)RrcdKyN%x$Cy;2KF+0!sj9zO1zO6O zpD8@mnan#WqgNdy6oPMZ^f*MI*H?VNc6;vvaB*^xoqY^>o{et#cc@RhKuz?i-}Ma8 zagX=ty=&fm+plaL{^M7A|Is}u<_(9AZvP&+qry7%P9 z;%D^jEibYCxo)M3u)0vm*bW{&y^XI4Cju7bTy-WLu`QD(n)YgfJXeVg7} zUFDwbM~>fyZt{BX@Q~ZsiDMh&&8~d&V;k3R-*Qkn^h>nNM-F@-xJ$ zV5UnXu?7oEdmt8r`6{zuaiWj$RiX^7^mCXo2t|0*{xY+kbT60D4P*&w=f49-$Y*#-d-} z?|ms;!~K`j%WFVa`QVH8@7oKf3#y)rQ`z2kbU!+_=DiI0-wbQrZxq3L{2d3pneFz` z>rnC%uLa));*{u-OT5@qPiwofb`;1dVB5P7KJAV+`st>ZeZz^^?uf|;uSK6d=sooR zba1Xay6gh!a|NzrL3-E7O5ga~#Qk%>R3 zwnl{!$Bz6`TeMY~H~Bz#&?A$mPkTWi2W;tfr^`apb|Ll-YPQFAUtCdW1_|)vt`z?U zdho4)Nx`o7ZldoV@vay}6>^-J1@G=oJWUrfRAw?B<`St6JquUJR4m!DQ+Yp4)j@p# zD$Ij4Ax%?3rCx}ZT6L~kZN#K9@IxbnQYb0uC~XRTOiF>O=#_MtN; zywBUE$ioWhI+bjoSH5ih5~Kw-FWKB3kL-W(fx`^c+?|Ek2LoZ)HvwCA*f6jaKhSiaPvCu1et$UL@B1>M~#XqA*e;*S1>6?A0(7n~I zL+hYKi?BPluDBGImt9&Bd>&|S)fT$v#NH$5-dC(2UOn8m-|Rbj`9<@m<@GN(>wO&ar1uxITYkXRin9QQ%{~OVImIc~=}_G(pu_&}RuXre%N6 z%-~9q!1XHUaPclFV5$ZEla4zXrXT6@rSxjjN61EwK5{SGc zwgX}z(sfVlmfdrD?6mi)J+LkVbK(k6%Yr8uL?YgQ;gnar4OSMb#o69<#(UA{MD0~_ z(7NG-l)u)C6%yGY8>vo(vfRV)Nh6Wgan=zEx>Kr0>NTupN8|!WHDzMb&rqD)&r6Y7 zrj#NjP>o{eCa@ogxFUl9f;)oAi++{v2%cV@ALl?>uU1{1^=NT&|9aNDB2Vv>$AG%6 z*i@D>XIYw|3&mJKWZUI^xvoIg9RjmG4sE9f4^2 zS@f|Ff|bIzKIkDKF~92;piN%?f;|V&o;UgcruaD!pn339U_ks2kAiT*m7m_a9ewUU zfiK14abd3ao`K7R2i3KGP-3+XZMGPoHTTVK8Rry|O5{Mtiqm+#q+~LY09(Muc|0l> zX%G&b$dSI50ga8MolZ1sc{VHJv2=+DH%z%bO3=|DMyAlCBv8WS5a2Lhc!SpuBXh?e zf;R4zUxr8aS36BFa{S&i7oX~}4iZA4fnm%vJY?j1DJBt)vDKWGz~B$lhEc-(kw8n6W?V_*Z5datePMyfSR0ZCh`0Hmwj zpTu%tg_BA+)j2icn3|zv`c*DhW|=&numNN~RY(?hg4HBBRI<571(RvenhlSsW#I9` zM?B{jo!2kzBvz))$_}}BR-AL*{pibw_8#8jF76A4vO@CR+$b22mxW+b*D^B-uwJ+$ znMS5T=XHEA1kg@?f(M9zKAGm4LrR%PyBQOLi|$~GPY6xvmlEM%9IKjEqy*w7%`Bjy zw|zH*$Q!^B&;IlNrGwfZTmcc^^6^=uxOd{*uyh_n$!6Cp{9(gOzh%2@qD+ zqlLBAzkkwm5X5=T&-o+h?S%Ifx;(N5BC_sA{;SQQl}({%j#G4D92teRYS~{?Y%nb8 zO@^asu9h0MWvk6;xd0CGd#%~H+e}tkC4XI?1gu)J7$|CB;{?3P>`;N$rh>H;(2!E+ zSQk}Z?4{6SCPeX1+z6Tc_i1l_={Iu{J)iL&-1**fy&v(o(g=IjZ!%iwp^pHK`nJCT znWfu4?**`o55UPk{s-UfXzTC1$5G>Zz9ZhPtrxi-joXjja030e=RtHGxg7w=cYhUT z-KC%2IDy{!)jee&yutnVB9#3O>@**%0{Hnk{~hwdpFhw0QREML&+Kt?Ddf3l4Mz`t z4GJ9gmp%KJuYLOu_FSc^F%c(OIxMSIrkW$1MBJYzRlsegZ44}2U9uB5X z4onB)2Kb$a$s8ugeSa~n_gc2aH#;qH8tL}+{zO!niJQZpLbrb%7Nwg*UhfUd)NVI; zICt9+6mC!@4XA59?@`b>yC?1a zF?vVXd+O=e_Oq~e@5;5&vM_3}!Mfc~b)Z3OC%L&9sbw*h7?&nErAz8KW`Jpt(!*l8 zIm}_xufBx5=tzYS6_pe?s z^4zd-`P0t)=Wun?8kXLM8Q3UyK) zS`(9(tbVZ^^k?mQA=I?Gw8~-L@5V zrlf1>xe^D9TD{sds;N{v0{dg0s*S>+I-up)oaK+iVdZp~s*#_?SurGZFI>p~#-~C_ z{_+$5K+=23#cR8x*rXV`LE-8!!GKqfUK>YEjs!#4yoP{e+XtW*eh&#*Z}tFXU=5!%_qb7W(#ILlyK7|JHMOWsINr zThGzuuUEZcF5^1|^`^u;V>#s69MJ_~iP zg~H$GzY7RO{Beks-kbF%AbxsD8MG~eD%Y9DW`kP6U^Br|H5ltkc~b+XT~1Z;*raUI zbcZMtSzY477H#5{eqBg4A&VDlSsT>P2Gy>=7c<+qQ#aJAP#E%&8an*Q#!Wjv%6Xwj z@U2JJKu8ocY|-_Pdn!90QoQfk<5>h@`Did2AGL-`D&?0d(zISQ!j$EfF8af1*XfnQ zVgX!bF)NoI0CB9@P-rz8N`n|gHwel}lPRb6>U!1a2-&J!&i*0}P z+!6HeFM#?VjViwbQYjKSt(1&Xs6|pZSyGK^9Cn{}xTfOCB&|gFcy5R_I(V8aO$N=8 zU%*23M1{^~bkK3FH&e!}6}Af$;98h8fQ!cx2y^ukivy#3e+rdU_sBb^?(jzUqR;c7 zD*xv#@1KF}`d_Y{RE7@MO7Z37VvcQLJl&H@_9Qc6Lu&mNA=D}pFA5`?@`F_Df`?lE~`1Inxxa1}ih!8ajeBWUMfij`i9#=xm## zAV?OExPE#REJ%2R;LUN+c7k(SH+g;TaQv(SCy~KIE|4=9$c33CddW+@Gy>N;9^JVI z5}B9(X#J$B1jMNwo|uO#$yQv>)e;rF6SS*hBf*7w9K{H2airFpIABNY#AF=E zYJHs_`pwitDzHU0n=5b#*9{678xF?CxJhUPh*jID-ngr z5}Mjjm_$Fn&3n^2SXFI5bj{`H?lMHd@A9snRCp0A2P?)kUz$S+Ps-aS29()7tU4msllYM#MD$PftKO0(Q1pWN%h2FE)UU@?XA;0 zFMYN5Ri1TFm)Ji1-;SYQ{Ih4TyCSK*?A*pJ0yEQwu4D)qAe6vz%@53mhNl#)9S%dc zeyXc&0ajbu=!Tm8#0a=a;a)T&ISr)%7pE0lKv$ZxfI_e7*+LU`kbn1{+FW{TA*iNY zi9YsS-&s}5cDZDxScx$;x!R@hGBi6GwGfr_RCN%ZwPa}fMKJ(HH(i*^jp*@TZ230M-R>%8oO#~HiNo*%SW~&F z!Hae`<%7Y!m!pph8~f2O&TgDlGqM30voK7FvOnnfE5$kxMGu8`14Lbf;c~!`i#p_kZ|$NZJCAZkwtiJ@&%BNeO-a!(!T6FhLY;W?dUn{doNo`e;nQbs_}UN^_}z^ytnK{_DewSH5wT< zDpO}_jeBHR>i{wmFt8JfCnt1I@9?Ea1j=QizmqLnp%g~tLd9e^I!^?1k&M|42CZSJ zT?ApbLv@IY|@TRO*C7AU>3Dw{<*IFHHb5(_F(A=evTNLEU`FR% zy%Hsa2}4hN>|mPz-j^bv2BnR@vt`bf6 zbtxc(^KMNq<#x7b=v6PErP?H0k@Z0cI2UE9Efei7n~p09wv=PkhB`>-Ag9um z3cW;+WH9FgkJm}FAx2{kALU{x-$uuJYRW__t!w$d?8rZYxSVx3k>66iPyL)AC36qBv_0P zX33CgrSEj((p(nHW-CScj_?mn~Rx25e-iBoS}Ok=V$|bwCcr)(S<6 zF~Pk7YzQ(sslz?)vUsC82FZa8aK+O~yrR{!WUMmF4kdFsDUCA0PF2j)`BZ43W%jh= z!%>f-=X?Sxj<@`w_td?AzkX<;#E9<5t}XhBC(sYa0B8sF&dD7tx0VNv(u)9-36sN% z{v-?@a=yK5m+sCG)!|Z&EM?b1(=?N0D&c+z5Uy+s&T*nmVrq8YivpD_;V<#Mcv9ua zc7_7ST#D#c%Y%kLI0OPjpPLOQ3`PaTuv0J-*mSa7$bY7;Ep4V3PZG8BTMv0R_T9S= zyg(8^SwF3p>~xzIB3Z|%7ySdW*z0k#Rz7HON{VVbof#;Q2+F7^jq^YxpMg|w#hC@o zKpUty%jI|f;U?21TU+YkK zd&%kb(<;M@{dl6l6a=FR!KI*)AX3t!r3qDT1@lgkEp?a%KdLhopk_HjEjDckpn%WU z3r zqh3m7aE+003(t~DM=ACFxD*>2y?l*oM+&VVdh|a5O6NnL@Lsc2>wm7fX6@YfN$)@J z*>I;n$k&tWuH~H`wp+;wc(}%D+@wkOdy(2GJ*?#mu@rjp-!`r|WPrTaz`ZW_W6-Zf zXScUbEE?ytotJ*j`)SX@{SUo=w$?&te+bOeEB`C#7kvM%u$_Hte*U#%U+~_rMzZLt zOTg)=?1XwlyU{2Xm}bo;OkQJ$S|OPkag#xN9GDd?D;8{|*-((_Pv(4}F9(4MIRPW2 zxgD!mP14q>Nw@CkkxXC|VmMV6^wA=C+g-mmZhz6o&= zuzE5%&ffsPhHR=nETc!?2#O7hA-m=4-rsc>09R%d-F45}VCSRX@KXENh`=&2C7D8^ z9EK`eTbm{u<2GlotksIw&0b+jDXENxJB2`Go=VuDkO~sJ?Hoh!txTp?1u39-YF;Sh zg8kC0Qm>NnuAj*cM+vY%f&J%3^rqKr9NK{94+zUY_(2%9Lyvp2uByb5cmL_*-Zk`F zmxH_M74KN4gqNb{KYQySdf**v0(y*q)$7m`aH|)}6`y+N+U@8>Z}WzoE1&f4S=-~< zw4%zRp37mL(@SKQP1zHb0|}e?yss-A&}2&|ASG!FWWiKKP?E(5B2Oiqf;=!I38~{q zWr*Kr^WY>~%3cepCfS8I+9ioP>-rqY1Dz;I?3@6eHKP3aU(p$v4CC|ez=Y%mH* zevj@E-AI0v8MV2XG_OLZkoeA?C2swIdzlLi&5PaU8SyvXYnE3Y{M^>Ddq3sb4KpM821SCuvw@l*ldxn z<=RdFLjHO&nkk2X-6`bCo#b=~!VHUN+zXziuD>nnKO3YLpYZNEt(KTtQOTDeTTGa? zAxh!gSW+ALa3h$;Gt+LXAW?H!(x+lkB@|=IgmRTO;7(F41KLrIX~*J&^(^m*ZHBa+ z7*AxWa&WSkF2Yl+d@pE)K1E&FUW(;`7W_pJ)b1O=g?F(+2EaV|GIaRI-p_0-{CBte zS097a@>_2OC#wQ(*PHc0U^sT>vH;znp4q1>@jjpqnyS`g!%e<3kJ$x|SA>XCjG6Ji z+AkRuJ;!C^{h2cWMr;fyys(8eRe{c^xdvk_gs67@^2gBXL%;E#J+5GMB2hAcjy7oG zeJ;|R*wj3kXDWqg%AA5l=#@KP_^G$y*}n1A5%k7?@%|pdJD{v``#Ux+SE*FL4)GP) zO*%#@Uk_-a7R3sFZ9Mmf8WFZmuyic|r6kU1^lT|O2t{fGp=_sURxFpR?Ow-_)2X)H z;e%`;77F;Oywoi%AI8YPc`rp*hxcB#)BHE@``4B$>un$2UC7p9Dc*ib>*!+ZfKbUb z_9<$5usIkyVtF1)20KZr8m{7bKQxX4i{%^r`t^X9#J0EgUhnQ%v-4XPxT(}C=CD>7 zR2QPj5WR!HmAjq22z~z--oJuC8v3uO@?+0QrNK_?b|^Mamo(f4$C0rZ$zxa~5XV_k z%OjNw6$)K#D#_taS(;_R9zc&X(Rr_tF>^LooN^*46eXj%r~*NSRX2EB zs12vZR%T>1>}V#y;BBWR=fJh1CV;qpRs_L&TPLT>&G_AStohbpK_EW5=S)Ey$Oce^ zI%Ej=p5c%X$|xqd$1!=!F#B41L`QQ$En*hwu;K@rcVRSX_4@PaIGC=)#JznH7}SMCqB%EbSjS=QL3dQ^O^GpA9E2N$RpDu;Tn@};1v{Bk z$2iR-g9>gmBbreXm;e^Ft-#YBokGISaaPt?bM#i{FSYfBv590c-ob=kIwAdasoZf3&7d+KSVUZc6d3Oy#S0f?s+3%V?TSu_coM$z2_t{m96~? zpF=e?)6;^GHu2m%SDvUw+!m)3UMxDb6kiH=^~`K)1r_KBW}=)HWvB6^Kb~d4(ZrIW z?G~SylH&}c{bmE0bs(NqBB)BewRpBr?Q-A0?byeCP}c`PA9uwIwG-_&kUQ$BMl-~x zBoKY6!~)}{lU=NM=s8#T{%(;XFVZk=kin;%ZUsUO!IGgS#$11oujR&cEH{ocb^0<+2E{fqdp(j4$JG8lI z#GgaoF2FPS_Pg@2OH1aRkDl`>Yv=2;d(ij4dp@N3$+f;ydw|tn z+rIx>u1ts93DAp~9!V4e!R9EEZ-pYBaVJm1>`u2_0Dp(XC2DVJ*K*R)dXb zCNl+cKIqNTel4tstidoutIfArA`%;6b2mvtPMJN`<@LH zdmM^H?n~MK(|47M&0}#1uL$i}v=K?Pqmqn66~*ojQIX<8S>x@ zAiZ<&DyVj`U`5$$wI#)wz{%fu0m75HYlox3!#z{B2p>YCTL|A9Y%+^ ztqg|w!nhi=hh?Y86#UshcGhflSV^U7lexd&fr8Xj3C-swjLgJnpq~i7Z$JqF1aQwU z2<}Wz%WAZji4Uncs7Y4>U_!#gIHeHMwJ3V%T7VX=BV_BtxM1+ zMBm%d2P7XDb|2nzvJCQA6^x}id;?K+#lEazo#A>KTS`78rUfkdqHZyJ2K)JRODaYEh zF#&PJXhA6JaY!YV3RP@0v~sZs!8WxJ=DG3UZVXo2JunKsWDB&xGd?KQ{s?-GpEg2W+YYGsv2qYq|+7r5Z}Z=^cM2t*{l_f z2eVam+Qf3BOxCK7TLgfZrsH0|tS}rccUZcTo>Yj=bTreJkOdc@gC4&L8a?FA_|DJD zzQ;Dv-GAo;Crz+31d-cTMJ-d|Qaliz)+;@%0+zU9FsMh;go;umnJ53c$4j?xAd1A&@sTM@2?F*|s^`dQ zDHfG7>SEV9i$3#0-*p#P+4OJt#v2RE3iPFyfD-+#l{ym#r<_pkcfrvZtG z<<>6;k(EZa%XjK@Q3-=UlWoQXE71Xt`nWkUxh5yaB(*$ia-fu%HK=Hgq9$&CW%bir|(!neDqD--6ARLH7yJWWBSwPA?&ttylPR%Z@Dm zO5eAT{UTt4ETYr@H7e_`Z`ry5)xYPv93A)+Gz3okrVmF?d;%gmIEhX z$e-tNjp@N1q?m*@a@vHPEfX!xtPNGYPQCX zQ1BMVX|d!`=T!=tb0k@GOtIG}ICX12o9WrAmg{$8lw?U}I3e`;UNaWAgjOI1Algxy z97F?CwyEZNTBBJT_3)Y9Dd^~-qf7bM<7n@1`KlM=n@J?)l&W?%O_!^c{@6bOL{ceW zYtwYvl2Xko*gV*5pNItVY<-mL1RCjLpxSFu<=CtPia1Pr=436BN{+jDNF-yR=hmB+ zmx#!uv%Yt?6LIEuV12!7uY_b1R(n9gcA$!)uAfo;K`y>Q;o>S zNp7l`C34mZig7hQ80uK2Z14%)qA{?vNDv&>>j4HrY}IX$0-(zNWVDv)_%S0=6AU+g zy%`8(&=+=zAr~;CKYE?-)aIx;uqq?;;A^2=;?{8>1*=sn$n!=Y;MgMYk=MRrYcG2I zQ7GYk?I^(i+`0}b^!FS>2fqS5yc1smSi$x&fa`wX7{Jb~uYe!xYu*37?<;FpqI1V# z2mSU})~-d^lYlxnRNm`d2Mu=g+|O;Da@|0|TkH;KWPS8D_+q&Im${myKE!`z?I8Lw zR7vk;d|vbiNB15>KYRB2YJ=uGv*0tzOAan6(@wKFKGZMyD1{L9ertA2aqD7xwOzH_^G{+VOi6@2V7Ge{1{tnZ;&fe|xG7pvbcb?aqD>_QL1AX8j1vIX6-N_I-;7$o+BUS%P(# zSiZsK7^tz9!5VV4J+0YFY*2CV@=Q#HLE^R6ZYMA)$;U!%x!erdbbdmVdD&=+W>?bs zWtCx=P&Z90;25A({V~v5B>=n7E6jz?@_g>P0)h+q?Y`$-csSL#Dg#P0q2PK6Af{7k zjG0`w?DS_jT1YX`rj!|iwF))D^U_FroX zGYrJy06lY&XakSmHRy-;`P|m{;=D;6cA-KoruvY?(6ALGq#2l(0nyn#zq$FM*qgOQ10hw)Fr{VY>( znoNNXjfg>MoERGPEQm}boY59%jmu?`|Hu|$^i8}&#FdX+&E3iP{-j1`v9uYLu)*SQ$=t#|qU z^1}2xnO8azQv+d6Ro5rATCNf2tRFYdhso z6z_}+2}l2`MC4BX@_AYbtNeH*^>gg^A;gV1h*Y2v~NfG{~L^I;PUx0C%bIV#nHRyHm- zg7l=??@nt4Fb!@H{yZP6#SEtx;&Y>xzZMNikx0kP%=uP-K$q%zpJy_iFnHwXrIH*D zx)~X@efs`GOG1h8PTz$o`oQ|>-G}X&cf|9Y+%pK`h0Ff;#tTnyaR)61ZU9Ad)EuoB~kvN02!e7nRAt$a4`5A`FtIna@ZG9V3Py{V6t zK%|$kTkW3IZcK~WK%x&l{9LWv8&L~))g?2!^*-PE+TO|{eE<7=?D-pZO6{j}Sf|PA z4j!3LD3c9@J7j~XCyR{K&1ckfHI{7#xI!teO^a2mQD#fio@CW$9Gjhw97wd2ks>&J zV_@C@9`_0;iPDuKB94I~Kym{tZSQ;4+CBt?=neGIhcCqE&%8UpiCvBo4?xkj{ztxx zqog((rF_zo>tea8n_8d&X=_3Y=>8g>8cwm6VdTt4$I5WsNN~XCO%Z_UVtv9DdK0Br zpkqQ$6jib9r2O@GE}mg>p~*a`FVaJF_XED0c2|h%o7ao**er-f-vSwi-IpQ!i=)@Q ze{~y;w^AW0*^lx$$E>9sEtqSOA%{v^P=cS!cq800=s8V-&8pF^*VChNOlpWEiC4lz zK_*O93k-C-ujz3ulOPzJr*sV*DW8E({;b8LhQ9Kk@5XKUSx3;{y={Gg9^Q|hc*uA2 z?!@=l&@57$vJ)B#6+)EEKywBHjOn@}0L)^*g+M?#JnjxPqC<8>zX_`A{_ac|3^{fJ z*>f_6Ra8T;hKZ0P0jo3}p87)$!J6Iq09wDSs@5#gnAM z6%$Z{?eL+TGbn+rQ=RM8Moc`_&2vDKYGB%QmJHDl{!5@qJ~TSR=#=YW?MZ4@;G&BF zcTt_*9r8sO`(*~&L~nXzp{%#U4*TKnuRmw^ZEh?Jh3TJ(8_z;Fod8nVMQ**jLZO2X z`@Fy@hxR^HN7H}oJ8*H*hw|-O9XvlNLa$CH;ilh@*=c@U>-WNSF0IZ;%X#zBPk$9F}@JiQ!^JXl4}X>GKfZC!WH&T_LfpBp8b{^ur(Wtt3-D znwU&^@T_DMDcA#lHk z=>7a|_R9%9a z1}hQ4Mj%BP=@}1soKVQ6jSw~q2dSI{b_q z)$JefoWCh6aoE1kdahXV1+PXs4?s2!8Qn2-%fp@<;0~;e>PnAhg~Pov^Hv6UWfHCo z@Jcoa%iLAy)(1g-hQ4;M+YSMZBFGE>UsI!S{jpu;1_)*rsf9ce3@~_$3SrIw%s50% z^*&IBS~~D*3xL5B0#Rn_@S|iwZpP=WNLtZ)*bIDcJIx@FK=~|eCwWvs7hnJ{t}-N+==A)BG#k{X4&LpCx+AU9N~C(= zAxpHGkc~BR;;hD(b5txGZSr991K9QgZd7eW(7+-lQ6Tb~knL0**Ug+y%FJAFA(a%c zYxgaV1Ma0~(7_LYXDz4}?RS5&(R<(F-H#d{@VKei(?Wbe=z?v+PdvVRKjGVg*>v#X z^%tLCO_wC%_dk3gXIa^#S7zNa7gScJ+RFUue{lWRmS4a9=!Y&tk9-n}T(A4a*460W zj{|e{iBGyI<9~;71cvGi{hWjb(nrEaNP zSGTU#(Mj+~YN@4G->ufgVw~MT0&F%Wj{Tz`!4tB<>o|CEQvaK6F7nV^2HdL}dFKbn+$NrJG&(A3of?Vhx(zI?i!skHpMc1Z_o%HoSPSAqh`Vh?}`U+Tk0m2~##%Stu5Cc`l`^$z+j@G$f+!l={I0-W2Gv=qzSt zK_*k9Y!-aNR@9s~Z`Oe4zvz4SrfB=YM_{d9+em@;Q)Ar@K&{X0*ywk^;(Og)zkl6P z^p?+V;PYVLRS{0XLS_Z+Qg@O=|zj z8Y;KQqS)4n<>iEh6Yy9J&5Z=PLf2kq{@9VBu7z1H2@R(*X=^5S#q zQ>SeX_pSxL^TL&yZQJQZR$bhuI^yD(1E&23&Oi0#F3N3m<*iZ61pZ;uTd z9j2j20vLfS(Es`w_GjqFUf9uo``AnVd>XD|Pbk3i4=&KkKSk9!?rL23PTGD9SqL!n+w+TwgfM&oO&<}ZEM z$9vGb|H=0y^b@ad1#1rjgL72Y=XOZd=uxzwwxme1RU@s&6j{`P8xD>&bB#q^P21U$ zf8O`Wtu>qseeHXIgZLjW_+~rn7W?uOKk$7V+GL;g_%>G0x*2E{@_N@5joQNPcSgnN zG!3%x04i(bnq48<2M;;Ru1-hYkrXVbMOh*RYarwbN|dV-5l4(m;GNl`8;~m zn?S>V9q>SYdeHNF(B6ZEheS6V0z}i-pYdGcS*>B{j_0xrJ^?oYwwSTP`MO$V(-(gh7W=?TGWJO+oQnf)*QMor;5q{8H z2`r2bz5u!^zxQU(ZRkBe2Ys1I06UA!DA4h~c(bRCp1B?LMnSjf(&cZHSbiJ5_{V_$ z`&sJ3ko;vB`)BXV6aaMYIKb-O_Gau?(UqU_z7~Ci_Z(Y^fnsR+M(lMPpxVuE!rq6@ zKLM@kn{Eb3=QAJQKDzvqn=$sXUkF_|&hFlTzWF!U^{AKyPV!p0>iho_yA+-KG2k42 z+Q$Ou+%^8kmd{tP{uW~DV9NgVhqfW(h;N@f1;wp~q{vy`XccHTp%)!Tj|qTjYIXq@ z_D=%#`6K8@@90rlJOy-6!AMm2Ho!TPoR*Tq0mPvFPgx0E7NY`qYGD@(>PHOm^X!8I; z(wy8-G4ta{byTDC^XgQNM)(F3%uQ>>lqz>S(;{obUZla3b(sk>KGu<1U8rwHg-|{@ zZYX9MZ1SelfRJ_??jSrb6KRF(2iYD^aQY;#n3F*|+ar=hP3@JU)3H{~>w*qsyGRlc zrA9tFq@~e@TYCFvL6zXk|JkEJa+vrnPi^@%9n-ef^!{3%omB{EU>AEipd=1tj-5Fz zr$(`5JUrDx^(hz6LG*`&X0;ChD4kls<(gb3- z+_JEDdhUt9GQWDvgoevm1yG02hQ?aI*ALe6GqtQGhXpo2&J0wC67^EnbSL0C9H`KB zKCbrXByaY^KvPnS&4N-=@nTPpCEdEz1WFO^;4Y-hEAZLj>wVrs7gij*2eaQqN6rET z^DPsYS0{Tg|DQ(}W^{LojlC}?5xCycgNp=zg|X-8^4>eJzx8c_Hv8W~G!py0?bAXfEAflD(Vpb-0id~ghH222 zP;;olV4RF)yCM#Eu`$T)L%Q~=fgoUXR}eL}DFYo$yY)R82?CR7h&@HcjYm&lMt$<_mR=!yG)pAt%wL7~T0OMS(brwZV!NG+0!C8tC!5~;Z{U6_l|(Wdfg-ob;? zXqIl_v{@R93qIVkU3UmvHf{uN9o>133gZi^Gm4m-i2(xB4Rrrs0qo|)r#&5X!~3xt z(QD5_FRRD*qmxlPlI6(=nd>_cL-L7+$uuMJMs(WHdi{JTOD@uk9Z-2X;KuD~sm)pC z0@<$2g!Zh^%k!b6%?(1p$|duiHjQV{dk+CxXC=R~0$?6O<_EBkq2=d1SAuME{H{lu zrvx$+?X(=DHC#l84sI-B0j}ZN!MZv~Q>xEj_>zcg557QgGOABg_F8aZ}SY@ z5v)4HC;A-ghU0{(L6E^OJ%+yVsORYz1V5=!cTy9u+piiWiqu87>BZnzzq13JYSs)_9$9r z=|~#fb8EoXm4>-qsv62gvr|=GBhl4w<$v-u^o`(nKHK_{rt@zVB!kJz6$ChiI~<=nhg+o z3#CiZ3fWDV0IkoCDuLw_AHtNK4OH;_hp{I&@%h*9!^X>Bz8^cZjb8ei=Yz}ZKZ5=G z)^>Y_9(k|l@_ju3@Ow-R$eIf7Oo^GyDAQ2cE>6?HWG>c60V5+%>`Zmim_>uCS^=|~ zG)QCSIWfqH6y<_Yr8)t15;dX>I%d!6Mh2BuKErp{8NCmZrtSc;PITuJu!Q~bgV~HKZ`q9zkcvE_LF39!#dXRvdm z{EAjJlzFL8Ne%*_GieC(WRN$RVYDzQ#Wz%myFZ8h{Qp%ga{2p@VyXu{xC`l&{zdF3 z=zI@imS?{N-|+a;0H@nyXUJJsqSa0u%zTnsw7%f^kvS5LwmvhK_kRU@a%&CKUVi5Z z?6Gb1*i*0tf4L6d^V}itZRn$40|Cty>Ju4X$Np$D=?~9YUd-zK4Cosm{;DcQ)#sS8lOY{Zg6FlYz4e79f7b(>})IvCMF-NvD@ z%L8T=PnHwqL4VN)4@w@VxJC_J3oh9{y?p6=*e%$G@ch1i#{L!E`6LW_Ea2UfI{HMw zTS58g4z~Qef5DWkZQDRwe+c4z086}Dh!31nKr?EknV?_g-tl3RIK-Spw&sOs$(sh;84@)rf}50#D5y$Kf+$v zOu)zA2m$FwB3^6x+`nRnfztmU0DpW(!n0y9yG)S5`VcKm#3c=ERM#?r?)hSmA##u5vFsB-LMdF}9(UX9;u@XLn zyL1Nq?*#18hdN&DRTtHEkhQga1$s6MIu~PB8mG-NRkXWgt6&#lxoUQmXmU1a4T+gN z97i>fmc-L=FLWGo+J1amEE}2Z916#-6$~ws({VQy7!yS$Nih`?$byy5dd0sEeBk#= zIOI*C3yIq`rmN3a#k2LH6)XM0uTZ*)1)-Z(+>2bkm*A`(;3PtejFgXc~AQR#8?4l`4 z4Xb3-vR0a=b6T_8E04oDaTHbSrCJ=UfYp-8&?dxVEBe=8NBu|8b*}I5a_6Vm?VeSt z=Rse}cuopsLW9D_bkPEf#=KUK5`ns!nRUfQy-v)!GC#&^Gor4v+ZAZ(q`Dck4xVV_ z+y;C?89+SLOr^z8m|x@-JCmI2sy6Pc=?zw4yyefKpJzdr{n0J|-8-;9F3)ZIzq*A! z^{d$K?sy~ezs{WD7>U01i1(`cprnptBB-=f%1l2HDh4B=`MA&uNoK*4e2O4bjUwN>ALqG z^wtPqj&D5d|07HSqGo%3c5K{LzU>q`{2relJ^Mr7(b__C<4p(@=$@I+S8zZIHIwzy zxZw^1>O8=Wje+2Fr?{ZC*Fr!~Tc;km#)3aO>e&-{}InsxDg=-7mFsMr1OQ@Ulc? z$0KkS)LGN*+xRe8rr4CjwM?9e2}uJKkK^sqcovT(+)#X4sz*VxCT?{Yaj3M_LD$B}3=Z^)SWGDMw5LVg=X4v1%&@9iIpls+(S<`|Y6A ztGFQBC&fkGBznPEkFLZhMUE>nV}s@{wHkboR9=b6ebDtDg&-YTBv;(^P0Z^F!xN7l zS_RhGO963% z*~6T7cLgS26^=B$A@SYjoFJ0~SxYh%mrOUqN*Zs+5d=<0(bdRz@}S}vP>P?g&T~7M zQxu>!cKk4C{`~M)K#9Tp4CaA*u;%O6@!mvjv7%lcwHNVPCFRa)$wY82rb@=xj<9%R zP>yxz&_EP)X~hNO+hpIRfHADhl8Yi)8FG>AV$znf&04+JcipK-RrVTJPo4GWH(T_h zH~If`{onFc0e^C@{`h^;|L2<*Lm|JjwLBK}zkVA%^j+V{E5V|*O{i2-7>QY335Ezc z1`>muH7%iX7uLl?JK9CGWXpVV3^K#u#+d8W*{4ww*zG*(oiM|U?($E zr#tDl`)O4A9qjVuQwje&w$Q7ug8TCTxLOEAsWRwG@pg?fA=|X0LAC^|XRz6JxD0qZ zlv3kB#SDa@&`rb{j;n(IS|Qp<)kbnLUo9j$8HEMfT|UjMntvH>22^N4xM+^7Rf*5P z$&VxFQS3O(mcS#}FI}XYY`%ZXgY1U?$`vz2phlDum4{rYit7o>ZVgjl`z+6$v6|-e zN+Y6(J+8o-y=dF*;Z>XMGLd>~>MDaq0?16Q5UHgZXO^OYpbFrXXrfN=l9P!qfJw|2cXBO>&=*$^`rnZ+n= zH|=Pm)KRl;V^+$K60Ly3rYZx;=!(I4td*ux8OmX`SfT{W{=5P(Wn}0Gf@ zX)jnA6g$WrSfHQX^&i^Z>)@==4Exl|qXHm8>427r539rCkaI$T)Ud#Z(q^A2h(aw` ztTqV-H)7&^N-xx51EfewP^1TZuq*$;PfMK*;8Q~gLZZ4Yy9WxZ@)`U{#b z4;4XC`qC5xP`5RJ)}+4Qv&xYQA-to2n3NdG4Iwnk)`m(&9Vl`hboExHeRP!aAK9Jl zi5a|s_7mvw&+lAavr^efroaqSWj^zxy0q6!RW4cqH0Us`xFLd#IDh%3o z@{j=`&=}Ps^4uV9&#Fd(1|57|NN)m^KkaQFJFymRfIn+t?hDm*4ccjRMJ!tDfILf% zu2_X}o3DdYQy@!4)HGncG`8j95+v_v@$Ws7)e20s1g@R+|VCwQq%nMs=>(sS%r)H^N#hIUmJ|L~%~gbi&XK;&%4 z-ER~_&;+RXV`cxfQ2hgVJPrc2spO~#3GM=RdWU3)LDC-0_?Z=AVx}Tk<&eApH;Y1m zh%C5~Ifw;%xJnsNM$@%uvO(fRd&u?b;l7@?#JCn_#NJe6K}hc* z8?i>LR4G*YLf)JyV_=4DPI!0Kf1e-yTmjj7P#L`rJ@@yXQ@54M!4eg#By2~W#lyP9 zrNk5ga%Ay(yf3EBQ9J~|$mX~u1^QD#PAgy#s*^OxY7c_5Xf1Dn@y6Q3@v}G;_bkw { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fromBuffer(file); + const type = await FileType.fileTypeFromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000"); @@ -80,7 +80,7 @@ router.get("/:user_id/:hash", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fromBuffer(file); + const type = await FileType.fileTypeFromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000"); diff --git a/cdn/src/routes/external.ts b/cdn/src/routes/external.ts index dc90e3c80..ed44c9054 100644 --- a/cdn/src/routes/external.ts +++ b/cdn/src/routes/external.ts @@ -49,7 +49,7 @@ router.get("/:id", async (req: Request, res: Response) => { const file = await storage.get(`/external/${id}`); if (!file) throw new HTTPError("File not found"); - const result = await FileType.fromBuffer(file); + const result = await FileType.fileTypeFromBuffer(file); res.set("Content-Type", result?.mime); diff --git a/cdn/src/routes/role-icons.ts b/cdn/src/routes/role-icons.ts index 1d92d6389..a850db886 100644 --- a/cdn/src/routes/role-icons.ts +++ b/cdn/src/routes/role-icons.ts @@ -38,7 +38,7 @@ router.post( .update(Snowflake.generate()) .digest("hex"); - const type = await FileType.fromBuffer(buffer); + const type = await FileType.fileTypeFromBuffer(buffer); if (!type || !ALLOWED_MIME_TYPES.includes(type.mime)) throw new HTTPError("Invalid file type"); @@ -64,7 +64,7 @@ router.get("/:role_id", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fromBuffer(file); + const type = await FileType.fileTypeFromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000, must-revalidate"); @@ -79,7 +79,7 @@ router.get("/:role_id/:hash", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fromBuffer(file); + const type = await FileType.fileTypeFromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000, must-revalidate"); diff --git a/cdn/tsconfig.json b/cdn/tsconfig.json index 64ab18f4f..1ad037c60 100644 --- a/cdn/tsconfig.json +++ b/cdn/tsconfig.json @@ -8,7 +8,7 @@ "target": "ES6" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": [ - "ES2015", + "ES2021", "dom" ] /* Specify library files to be included in the compilation. */, "allowJs": true /* Allow javascript files to be compiled. */, @@ -65,7 +65,7 @@ // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ /* Experimental Options */ - // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ + "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ /* Advanced Options */ @@ -76,6 +76,6 @@ "@fosscord/cdn": ["src/index"], "@fosscord/cdn/*": ["src/*"] }, - "plugins": [{ "transform": "@zerollup/ts-transform-paths" }] + "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }] } } diff --git a/gateway/package-lock.json b/gateway/package-lock.json index 38bdab908fc6a1aeff1cbaafc27c1fbfeea0e905..cbad96dc2f057faa4bb38657fbe9b4dd994bc00b 100644 GIT binary patch delta 64 zcmezRTjA$#g$>V{xbn;Li*<8TQ!*1Lzh{zT(lu=6Wp3wXW&~m;AO^8nfS47C*?^dR KJ1;ZG3o8Kck`jLa delta 60 zcmezQTjA?(g$>V{raM}(%W){h8S0tq8Co<8GPesdGXgOa5QEq(K+FonY(UJuU67gM Gg%toq8xM~F diff --git a/gateway/package.json b/gateway/package.json index a062ac9b7..fe59527f4 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -19,23 +19,23 @@ "@types/jsonwebtoken": "^8.5.0", "@types/node": "^14.17.9", "@types/node-fetch": "^2.5.12", - "@types/ws": "^7.4.0", - "@zerollup/ts-transform-paths": "^1.7.18", - "ts-node-dev": "^1.1.6", - "ts-patch": "^1.4.4", + "@types/ws": "^8.5.3", + "@ovos-media/ts-transform-paths": "^1.7.18-1", + "ts-node-dev": "^2.0.0", + "ts-patch": "^2.0.1", "typescript": "^4.2.3" }, "dependencies": { "@fosscord/util": "file:../util", - "amqplib": "^0.8.0", - "dotenv": "^8.2.0", + "amqplib": "^0.10.0", + "dotenv": "^16.0.1", "jsonwebtoken": "^8.5.1", "lambert-server": "^1.2.11", "missing-native-js-functions": "^1.2.18", - "node-fetch": "^2.6.2", + "node-fetch": "^3.2.9", "proxy-agent": "^5.0.0", - "typeorm": "^0.2.45", - "ws": "^7.4.2" + "typeorm": "^0.3.7", + "ws": "^8.8.1" }, "optionalDependencies": { "@yukikaze-bot/erlpack": "^1.0.1" diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index 2559624e0..bfe748f1a 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -231,7 +231,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { const d: ReadyEventData = { v: 8, - application, + application: {id: application?.id??'', flags: application?.flags??''}, //TODO: check this code! user: privateUser, user_settings: user.settings, // @ts-ignore diff --git a/gateway/tsconfig.json b/gateway/tsconfig.json index 5ecb21e14..56b9ca7d0 100644 --- a/gateway/tsconfig.json +++ b/gateway/tsconfig.json @@ -9,7 +9,7 @@ "target": "ES2020" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": [ - "ES2015", + "ES2019", "ES2020.BigInt", "DOM" ] /* Specify library files to be included in the compilation. */, @@ -67,7 +67,7 @@ // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ /* Experimental Options */ - // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ + "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ /* Advanced Options */ @@ -79,6 +79,6 @@ "@fosscord/gateway": ["src/index.ts"], "@fosscord/gateway/*": ["src/*"] }, - "plugins": [{ "transform": "@zerollup/ts-transform-paths" }] + "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }] } } diff --git a/package-lock.json b/package-lock.json index 11edcc9cb64bfb6f04a96c2d21d5ed12f7b26014..6de2acb6e9de69304fa523924dfb0eba14d358c9 100644 GIT binary patch delta 65818 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 delta 57669 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 Tb97#;uDTG0_~LB%vy=Tl;h&0x diff --git a/util/package-lock.json b/util/package-lock.json index 2405456ee1f520c44bd7b665e52bd9f6369afeec..51b6016cb57cc8899e4514fd3b974cbfe3f8bcfd 100644 GIT binary patch delta 51825 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 idBgJo^v0>8Ckw Date: Tue, 19 Jul 2022 00:22:45 +0200 Subject: [PATCH 160/238] update node types to v18, ditch node-fetch --- api/package.json | 6 ++---- bundle/package-lock.json | Bin 679767 -> 673595 bytes bundle/package.json | 6 ++---- bundle/tsconfig.json | 2 +- cdn/package.json | 6 ++---- gateway/package.json | 6 ++---- package-lock.json | Bin 855275 -> 851945 bytes util/package-lock.json | Bin 494172 -> 466540 bytes util/package.json | 9 ++------- util/src/fetch.js | 1 + util/src/index.ts | 1 + util/src/util/AutoUpdate.ts | 2 +- util/src/util/cdn.ts | 3 ++- 13 files changed, 16 insertions(+), 26 deletions(-) create mode 100644 util/src/fetch.js diff --git a/api/package.json b/api/package.json index 8f9d1c8f3..f8d8376eb 100644 --- a/api/package.json +++ b/api/package.json @@ -39,6 +39,7 @@ "@babel/core": "^7.18.9", "@babel/preset-env": "^7.18.9", "@babel/preset-typescript": "^7.15.0", + "@ovos-media/ts-transform-paths": "^1.7.18-1", "@types/amqplib": "^0.8.1", "@types/bcrypt": "^5.0.0", "@types/express": "^4.17.9", @@ -48,10 +49,8 @@ "@types/jsonwebtoken": "^8.5.0", "@types/morgan": "^1.9.3", "@types/multer": "^1.4.5", - "@types/node": "^14.18.22", - "@types/node-fetch": "^2.5.5", + "@types/node": "^18.0.6", "@types/supertest": "^2.0.11", - "@ovos-media/ts-transform-paths": "^1.7.18-1", "jest": "^28.1.3", "jest-expect-message": "^1.0.2", "jest-runtime": "^28.1.3", @@ -86,7 +85,6 @@ "morgan": "^1.10.0", "multer": "^1.4.5-lts.1", "node-2fa": "^2.0.3", - "node-fetch": "^3.2.9", "patch-package": "^6.4.7", "picocolors": "^1.0.0", "proxy-agent": "^5.0.0", diff --git a/bundle/package-lock.json b/bundle/package-lock.json index fd388bd2edf08b5ee0076e08394d2715245b3a22..5078696fd47b825037a4224e64601b52cd8459a1 100644 GIT binary patch delta 555 zcmcbUlCep=3$f=m}_Kam|78HmKhb|o0%3`8SGkO;vQt` z9bu6gSsAJAY~ma27f=|SVVUpe8DL&gW#sPT9g^dgnCX<19_3e&mX;r6>>L*4uAQ8d zRX&~ZIiu9{1tLt`)0b7TubW=*k5Od%V=<=LleX_!#dObZ`^VQz^SIjCelTrk`@#HH zsa-;zWxIqtD_2c>>KxYXsdLzZGY}r%&dbWaf(aBNlWqA!rn9MX@of+0VBZK0o9PX# z>}s3&M0PNO0!MB#54XhjSYCEHSP11xDNjGa$9^0XINML~vu{nu9Uh@H36JTH73`9e z<+-@0>npGbPq!CinlSx+3OoDu=xX-k<=ZvCu)i|go~X`oi(`ASAxFTIb^{5{?FJHD MoZ8#nT(|_K0a~22lmGw# delta 3419 zcmd6pduUtt700<(_g+0}$B7?t^RO+;PMucKy^^k;p-C-EmMu%NuHKK)CRftc`|YbI zDUI15VbFvXQ6EYnjE?=c(ipdhG04_G3hih{^Vi1cprvJlvaSh(HYr&)Nyd$1ybZQ_ z?EZIu=l*`@ch32q^SM92_VjOVK7Hd29G)eG5}YR0q;cz2T!~>CQl*ExDSYg(BEj*o zl~E5tfp+dp~|+gcnNMv3l0 z22$PMwD%}&`;J)NZemZuogX6@{O}&}9DF?}8G@m22`fBL;}U3mOPt?&Y4|;~?`!*l z?ZZQJeQWzBA>87}%1Fap0o5;vsC;Il0;S=zOIC^MnWIT%OItPAvpE%XtAP#je z``)8~kL(Rt4G;cC%zXdqvCh?F$ke@^h)f;<1vgHjLb!QIGPtvf{0x!$%Plq>4Fy{1 zf^Lz?BvT10<%`>*g+NfXSaCKC6{c19tgfVT(dJ63s`fU^xmsq)6{h&8pVtMf%~n#Y z%XwTe7w2_*Y=si9qrp>o774)dBp~zPWRC7>%}J zeHokCC}9I|F^l4RC6`j zv%09Uh6>@JXQ`TLRXjnrO_Nut6YjDnTMsF9W~H4iq#PAZ$}V4O#$&0-8Vf2F_7qIM zhD>(;^b_>c^F&XtiYTm;qVbIfA`Ff{FQAV1Rji2Sicv~IJ$g~lB;0)tmj(1qle=V5 z`<*K-M_Oem*Yss;xWGhNrlF4{tacrfwl&-uCXroYnyby6+MjI5S*n`%7YliNIg@f~ zEQLhWS&N5sMLtwE&}&7v8}4}V?+s+q`Fyj^R`_%w32q-g1!q4)p8&&s?8wm)+bpp; zGS5+uef7H}dKx|98tpEDT!(>QLN;58*{zn>|Il6 zHYU+oU$n~Ams`$S*r7IN;+)$TusOJxmyOs9JmpylW{MHBRqG1slo6etTFQGJ3t5-d zsV}EgjE!ztSNWAF8*ykkcU4t$B-oa#o@paLm_Gcd8vQ9l1N)6Yj;Yk7y1hO>1=2sG z*p=*8XeaxX;7i$e`GCuBXse3Q!q)r06Ww zl~%)&r=HVLoWtW{Omr*}3-Jz9iBY;+j=bMTEms+HB-mWg+rq|3#mU+0Y8O?o+RBW3 zfo1|uBOA^ut+YyQ3R(6mb2*7lz~y_`vnrl_vxeQVx^ zH>)+QvHmclWT=E^g>E$XgwqmMYvg9TFPq3KExA;)K%2dxRfp1B^rX!ZgQwMgB`yVz zTs&rxy`UkLq*8XKe@ofk3Xv*O^PO$4T>3@qZikNo*y)}w7vW429fOB|5zOo!Ae+x% z6a8qfgod$BXc(7VI=olhJ+Y4U6LB$tiQ2`F=j8jfK)2reEw|tL_>`YhI$d-<9tzqk zj;KRvNiG%q0ex^eP^}wX{+dIR$|MU+*2XQ?7QI=$CTX(y(%L1RQn$iKm=bM_#SP0Q zW5C@q+iE6_(NSVnwZO)@Gw0W@V-r^{T*EsTt`ULM4gz|7+)JTt)EUrNXZagqahqn3 zk+ah!r%dqALG~f~Y=UGIOw8W2b})SQVlKTqYzUU}#*tjkuTRy94=?5OEav z_r-63;)ducc;*9f6fRsOhBjP6qVsZExZVK2Ts#i*A7TUh0xobMfHQR-ek#1LBK{q& z`45C^u=%#|pH>s6)7U_ND+xdegIqu9|#xR N-AZ&O&qyXt{2i3lR#pH2 diff --git a/bundle/package.json b/bundle/package.json index 670569e50..002ed7f9d 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -29,6 +29,7 @@ "@babel/core": "^7.18.9", "@babel/preset-env": "^7.18.9", "@babel/preset-typescript": "^7.15.0", + "@ovos-media/ts-transform-paths": "^1.7.18-1", "@types/amqplib": "^0.8.1", "@types/bcrypt": "^5.0.0", "@types/body-parser": "^1.19.0", @@ -42,12 +43,10 @@ "@types/jsonwebtoken": "^8.5.0", "@types/morgan": "^1.9.3", "@types/multer": "^1.4.7", - "@types/node": "^14.17.9", - "@types/node-fetch": "^2.5.12", + "@types/node": "^18.0.6", "@types/node-os-utils": "^1.2.0", "@types/supertest": "^2.0.11", "@types/ws": "^8.5.3", - "@ovos-media/ts-transform-paths": "^1.7.18-1", "jest": "^28.1.3", "jest-expect-message": "^1.0.2", "jest-runtime": "^28.1.3", @@ -98,7 +97,6 @@ "nan": "^2.15.0", "nanocolors": "^0.2.12", "node-2fa": "^2.0.3", - "node-fetch": "^3.2.9", "node-os-utils": "^1.3.5", "patch-package": "^6.4.7", "pg": "^8.7.3", diff --git a/bundle/tsconfig.json b/bundle/tsconfig.json index 5fa811741..87f6578ac 100644 --- a/bundle/tsconfig.json +++ b/bundle/tsconfig.json @@ -8,7 +8,7 @@ "target": "ESNext" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": [ - "ES2021" + "ESNext" ] /* Specify library files to be included in the compilation. */, "allowJs": true /* Allow javascript files to be compiled. */, "checkJs": true /* Report errors in .js files. */, diff --git a/cdn/package.json b/cdn/package.json index b9aaea69e..2b2866cbd 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -21,6 +21,7 @@ }, "homepage": "https://github.com/fosscord/fosscord-server#readme", "devDependencies": { + "@ovos-media/ts-transform-paths": "^1.7.18-1", "@types/amqplib": "^0.8.1", "@types/body-parser": "^1.19.0", "@types/btoa": "^1.2.3", @@ -29,9 +30,7 @@ "@types/fs-extra": "^9.0.12", "@types/jsonwebtoken": "^8.5.0", "@types/multer": "^1.4.7", - "@types/node": "^14.17.0", - "@types/node-fetch": "^2.5.7", - "@ovos-media/ts-transform-paths": "^1.7.18-1", + "@types/node": "^18.0.6", "ts-patch": "^2.0.1" }, "dependencies": { @@ -54,7 +53,6 @@ "missing-native-js-functions": "^1.2.17", "multer": "^1.4.5-lts.1", "nanocolors": "^0.2.12", - "node-fetch": "^3.2.9", "supertest": "^6.1.6", "typescript": "^4.1.2" }, diff --git a/gateway/package.json b/gateway/package.json index fe59527f4..05ef5c558 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -15,12 +15,11 @@ "author": "Fosscord", "license": "AGPL-3.0-only", "devDependencies": { + "@ovos-media/ts-transform-paths": "^1.7.18-1", "@types/amqplib": "^0.8.1", "@types/jsonwebtoken": "^8.5.0", - "@types/node": "^14.17.9", - "@types/node-fetch": "^2.5.12", + "@types/node": "^18.0.6", "@types/ws": "^8.5.3", - "@ovos-media/ts-transform-paths": "^1.7.18-1", "ts-node-dev": "^2.0.0", "ts-patch": "^2.0.1", "typescript": "^4.2.3" @@ -32,7 +31,6 @@ "jsonwebtoken": "^8.5.1", "lambert-server": "^1.2.11", "missing-native-js-functions": "^1.2.18", - "node-fetch": "^3.2.9", "proxy-agent": "^5.0.0", "typeorm": "^0.3.7", "ws": "^8.8.1" diff --git a/package-lock.json b/package-lock.json index 6de2acb6e9de69304fa523924dfb0eba14d358c9..18a82aab57003acae56a179d01cfb82518caf920 100644 GIT binary patch delta 1849 zcmd6nTWAzl7{@u|&dizJ)y=vIUK(RGX>AfGnVFqzqO{0nX*SX9xZO*VUE9!Y%qFYZ zPNIpqyjW<4u&Ns_`A?{oZ;b@>)ZxZ3tMj46?p4sd%igz zpAbqSRfEx9PlJ+pJ*{};j=_j06^{f`$>>n{wLaA!s@~ID+YuXzRru6ESPS-syLRYW zW3Z-gSn)UQiFDT|Qgv^4#Ol?BaGq-ygp%95=LMx6|_s9AUC1T;0PWfPWA`t68?AH5zd!tcp zxV=%8dcuuIbh$ zS+dzOE&Vz4YaDqQX{3By_AJieE$hF#nZP z?cEZ5bxPVIqBgpYa+A)F?ZqA};F@QfdBhur#5>pwR!rRxnPqF{MkUy!sBq^RDFgo{ zW|1_d$>RqU$7T7x_!U|OaeIl4|5;;ypte@yfbeD0lMqF?AvbAnLfoJ>wE2Web2HC& zp`yN(-}4PTl-Br)zmgcru=J(bnb#$n60C>6msmBhI4&({&(kRH3M2}4|joVh=?F5rKwJH^d!NW5@*&$Uf9%EWV7vYMyh=DPW5aqt)^Mek0vPEWNW zG1ZEjt?+#hrl9V{1b(iSf8kZf%c1Udomzhj&kCInb;3`d6$bVM{2IgM@O4IRHhQ%| zODEn8uB`l2Y;UwPmQKcB?aZ{NgRks(S&a@K=+#2L_VBKr{@CvER7ZC-wr6BeJM=<& zyz8a0bYHTgtG9npO=-g|-Osm$_NhDjU-YF0)YPt>ZG*d8e0%CMfUcsTVa@pT{spYV zq=V>?beP5d1-kqjzlF9##VmW~zk(*pPqIZ^9E=gp4rm6pEFu=U35gTS%p`+$maU2p zeqg61(flc!GYLJu73lxNGK0P1%{lhP!@=i+cK{mg)G2J=vbV8uYZAds|0XNkUu2`k z!|;NFsq+z`a2uiU_)BDcc_L#+5`Bm3Qina;+@6r4DGeS!p9pv%@;Rd$56M@o?;aja z3=Qrxs#PVZDr)hdcVw*ZVAA0EF<;hj!YVZ=^-7rE_IbIWR_+c|fRbZvrjQbXGYYNV zFz2WQw;b}Cu$^IL`JX9Rw2oomF0zQkMYh@lGm1>bwOSdq%aKgqp^>4X@dVsC&s>i? bH1GdT14d}7r&qGFjuIW4#7efb>b-vek~@{n diff --git a/util/package-lock.json b/util/package-lock.json index 51b6016cb57cc8899e4514fd3b974cbfe3f8bcfd..e56a5f1bcd7197c46b65533f6d7619eff93be005 100644 GIT binary patch delta 2050 zcmc(g=~Glk5Ws6@-kZn5!tMeBy2}C!qJUWt4XlcY(MS{z!l4lp3uAy_p@QLqCt_79 zMkJsP+C)o$)}sy~?hxCYlF-A(cM5t%;btZewUSvKD7D!CFW{z&%iv+SNGd+Xodh z)Aty@5yWo6(`uH05y5O9>56P>x%3NLryf;3A*wC`mq)RF(fHRi zW)6m7BY3!z2yiqIA6V+4XhrZgKm1@Z(-AmiA{RmZ^u?M$l0&dyDH|RMzr`wTUASS} zw`>d*_ZEiX=v}OU_F#w4;*|;lo>!O`X76Re?7#MbRr5&*9;#;v7Km8}mLR`|1p)=*WesEUd z7Q9m?$1rGZQnT&2pha~gBoTbPTHZnN!CHB}4Hx|=50cCmv3);3*A1x#8V~U6-RXd>2YCy$ zr}0=gEOU3LImGXD2ZPmzc^A#$&{)d7aYX}PM!KS+%JlDKU6?u|+bbm>_#%wm6`fNw zs6EF0Ddbd;Xc%yU*NK^rqT$X7e!n{;-aN?(ajs_r71v&%tB^J5eVRWBM^h(HG&;ex z!F8SN4Nb?W1c{4P>a+FgLXP257tP*Kc!tW*;GuM2vtACMILAxL4@DKWzCX&&=IdxQptHagJH4KTj(zVF@Diyetxs`q{GhOi_KiP5 z_V^!9skJ9)A!ajA^6u9Lqx(2)*#$P-7&OZCa;F%q;@u5dngX1p}INSf$E5q0E zC0F+FpUgjhdszI`{}O`0wfGtK#_w)A`qHBl{7Ax zygRWP9O&ZP=vp!qX)&dysU>h6Xjj3JiQr6UfXf-;Iyt%!(@dQ*(L+cVLz zWKJZlL>zV}C2yAf4Q4jD2Zb5t>Iz!j`@n|AK_j6^H$(zq))6#4(WlNOlFlDN{x|+JT-|@Tc*9TRc%|GZAX4XmhWhQL2i5PtwB#e12QG+EmG-orUkSe+jmNpBpeKyXH|L*tZwo z2oz`WnUK+1%NA?OJYxztdz3a9%{t=+JE<-c1i)I-0ByxC!evh)5s{e=T2gRox?}j8(&x<9NLu> zJo^B$i@p1AOuTF^V1&TxqCq|||$-_|z7T&A|pRk4JsWF#bNFuq)j z$>&Lfr!V*0S3*eqP!9{E}rr2=N2i4RqSQ z2%KO~kyexKM7f{OE7DChtzT|< z{BCnUfh`~1`2HVm1L8C~!9B4V8DGh7stw?s&!C$) z$u8tIHNfM@Mck(n$i36x@@Z@nH{C~$Nd~)$J98L$8Jo(LQ(}H7;!dSrXh5IAi0hRK zsI5Sz!0zu6GI{#rYc%0_f88VCQwS~zQ8rgOk#8y-{e~}H&X)V`l%^9hWg; zO@fXgGWG<%k^BAw2tZbqQt@V7T&)y)aQ*=zM<>DEcOU}rl`r5@-fr-1=T|85eXrCn zXjBv{*qh$Jm`=2qjACQ4C5yB%spd|>ZBWNP`s$G}swh!mW96De|6{}TBQKD6XZ z-$xE1n7Gs6mwO7_@b{=}HEhyp@T)t#V84l75==Y#x_X?fTkN5bzGKm6+y!f_6|BUP zWl^vhu~r#Frc`j*U9M=CYWR%NxFOKX+w}oMTvoPHMoUTEke8{7zFf&x=%7CCRy)Cw z2a(zHI(Xze2*u95z6l)k!RlC=t}U=EzpoHXk_|=*P{*ux_)IK5VhyL!Fn)d4$;w$ zuBb6MTsoy&>&*wF1#8Zq&o$^|H|e9Sk(4vrmDRdkd*A6EI!&(zM?$ z?{=GMmoX|+hzyQkAzdPk#cZ!EHv}SXCmE>tbB374-yixe;JrpLW!eMvpM;zjc#GYc zgpw#0o-KB-1CPfyr`VI@+Yip5_<9+9*UWX-&FrC|&XG$f{`#sbDHW7qr&sJ4=xJ&blJ&5LtSuWH#1_>p;zb zU4l}Bvxe`&GVcBdP~#Sa0S7+BrV#}@_8PgmQe}8^;s1!$5(PMYFFG4?(biPTNOzb> z%q)+0nnhheq^f2d&SFVw&vav2QY3ZjTXlWKmu%7=k6zk0rs#aK=k5DMWHD~EBpTsN z-Csx-Z7OBM$9OV9?O+QE&v`}=Uye?V@E-4+_=bD(36x|<-%N17cnzc1wjGea zLTADI$IEmf|z$_`_?Z}sI8zFfbn&1ib2 zv@(^X3v!1iUG$_=t+YSli)ai1Q=#Yaby_ZI!riAV9Y@=oS1Jne!K|&jK*#YiZ7^$; zgaS|5(1{ylFhp92U6S=mqalWJs8b%)f;K5pF4*?3QAFof;rt!a5HsCoeHcE$@Ipe( zzXL8|GIxH1)x*$j!IOitKgFlOsk7)R@IN`rLa|V2uL` zpJNG>xa?ds*C@st^P$;!{eng@XakERayfYVkFa%97c2<>6poVVg4zT+E3B6If~&yn zAETRAT~Lu7+j(}NKfzDz2*DnDYlJoLvMs7}XxA@>f!sr)L!%comx3)P`C$~2g zUYDg-FO&8V6((I-N*dF2V*RMMTMN}Aj6P90C!H_s+0nh12@p_x37Z6Sc6i=CDZp2- zcZ;VNcT(bj0%Y!eT*+Q0k!_;HRjr=RX>&Sd;%U{HyWUG-n$In2C6Dz3{F`yQreXxVb1aquU=-clviDl!dT(j~zGTsX;Fi+t5!13^DB_&W?ZqG@|jT`yF9da_kb zHBwfmC0uW3_4af!-FLg=ov6`m>-i$~K53(Kmb6;w(U|mJMvm!dA_M!s4rN{|oKM6ZHitY&c>;8`*^j8*MU}Vhlh<^Xro+^v{ds>Y-p{9ggVkDWE7ZwHuq|*Z{EoUM zEGs5-{gOTI@}%8)X)D6iwHl@Zp0-2n^RgCO3rx=;yTIIckc$_;b;sqHWGLL=TbF?Y zmt#}F=O(spkQJO{ku>U>23fCHO;+e`uUl}HJkpwLIK_Lvk8NH2Hd+VIH{PtkH+9%3 zNIrvHOvj>*tUR2R^(k-F6baW!S2duIk+iB5v+8{5DAR5>JrtExQigaqZwbcZshlGw z>d;Nfn{XA4w6d0UnH$Aw%)peg9gjn8&}emlx((4?IGab0P|FbT{I{_Q_Ej0ZxNEOG zfo(@9FxJClpoj=Z;m(w^$aAwHYuBENhHI27X!9lP@^Xhv)*20KCFl;xRBA`DZfsd% zR5)7f8UxKx(-F#g;`UOOqGZxwtYqzWL+O^i=8XhAC3Vx-i#JG5z&4clm!fc&ZO$RY zz|_}vvbkY?FOe%t2RGp4D7I-C??;$gD-LGmf@!e(n1BMugM?s;FXMx-fukARi1`SU zS4FfgWN#;uMTUxH5>znLOgF93Lb+Ja)C19;jp{Y)(M%xW2w4NYM5h)qmJ>!&mSCh*mm2+U1+9-%trk_>k^%4du^IO8kEXbn{{bB#z^!o@5#BwH2!T6H zJPCey9lDj>_0yH$xe0WJQ~Vsg85xEwzkCb*hhfU(*xz8Y;EK25?VWca>$yGepli<6 z`T8mJbs$QkQ{3O4Mjt`gkzY-5Pri$ep@W9pnSVjw#y(2BfK&g9E(e}7=n>F+1=|34 zYa5mo-$&mXM6LrNb>HJ3pa}TlUGTO4`XPF$6r4STTneuK1C#>QKY)pg_}$3(x<)+B zh#Sp#qR9WL=gOH}x+j*MGk`)=A4ms9&3eVCO&WC?C2cHQV^qCrH7H3BnV}d}xM;D` zhQ2f-vIj)ku)~=bMLOna&#wt3>M^&bSkziWRijRqN=20#mnGK#WE6UvZ+siw$ZZf~ zTW7#6C_grt z4hOCT_k4=j%tw+zsmq-$QPn(5oaX38HJ|VK4RxPRN9olnP14`DhBWfHt>#v?eKnsc zEOTdiJ*az=nO4qkbGcNCVuP{8Y)p~Kl&v1Csilq@!2ty}%X(iBPM(*!9-Q~Q2-U*0 z{j^{Y479XhY%@A-{D=(9Z|Pw~0k!c*QuAYtai}36dmz~l&<#NUS!@!&UIFKp+>K1a zggVsL8?gC2o1gJj7tAc{dwhbu`Gs|aNSA!hF|8&hOgM*@Lslz#R;-I13hYK_zg{ zMaTr)=NJKw8DU=NhR4z8ha0W(EEZ+&__FCEQ@e2BVD){N7*Vk&6(sP!M&RK1+r$*S zfBN!STAPbY^I@yal&C1Q)^xt^w4@!0SfCZIXmdeVC*lzq;_|A$5vV2_u0&ETwS_cp zN6HYR{eFEsO?xfnik&e#)vB0Br_(5G+O#PH&fbUJ_EC2(9LLG8VdG%`kFZJZ%vZ3V zA%nefK@ASpxB}sBJ&Zj!GN3TrXCKCxWowxP@6ecdsj-l>)xC{Qv%7av;?BQ+$e$)3 zS1gtf(~u15^2j@>NZ3(#CY+=(V=0Gdb=XR`I$BSt?Nns*nX@T0HchAyv_(Ayrpi zxt06u9XR+TNChdzQa~#B>EY}_)VUiv5B30omK2(&hHQiovee?zLZ zf!GKv5_BAqag^aX?WIx!-C8N+XN~G-d*s}Vf0(53_Sl!qyWe- z!}H|LTLn9@l?%oW)%eK|aLAKjE`hz~2U2j|KEXHsW8xKB3gXoP{0yImyyBCBb=;2q z0v*ELbU^SI^zR3t;s>elOS* zw{nK~G6t4?4OtC-bOt+T7{3{f$}J6zS}?CA zoOlVIlMrT2f-@^1UxyHB<>#*z>>7Y1n1p`%XZR&cg_5YQV46F;jo82bcZZMQ2Dtzq zjh>H>Boue)Rm7ve88_PW>$#B+9_ue&O~^+$sgwA;;P;FP!KwKFOz0z;yNC&my@hRM z9}!4y=v!5(CZMpz?aqv*R!|oTn%o=1=H*|ckTfz-XNyILjs%t8}7$PzFmQ{IT7SNVi3q>8i{Q*PQT)=-(!iOgR9;zlGnENTTTRt%j zUJeke!O0lDRrZM}X3@BYjFo@iMTi>II*{S<3$@(H+Q(KPZX8qB^4 zodwjhE5WOO1y^N2TLwO0X=n@d0YE$@q=0fc{$ucWap;xSzam)0zA0M)+$-?q2Pr~` z^IKrhF&?c9*LNPY4Az%k64El<<>1{XVRHPn$B60W3$)~Sk5jmZeMC&a=eWi>YnV8J zfUBd#>%b8s25GDjkoz?8?#M!%Qq722-DlVHKf#lOS3W}=9LDbumwW+KA48S{`yOI$ zm@!N2B~Bw;GEPik;82QqVqTxm{xgK6Uu1}%aCfH(=(71_8GvA95@ID{`6F54%=X`$ zkkCs)NHW};cM$Fk!#JY)b>b=nta^i(;Eo^13&TtBDoJbuGiH30d-g#hx9xXGK=`0- z{NE7}iHzHHf>?)1S}0@mIb_*}Y3c zDuxjpJSe~k6Ee%KCWMzEJZ%tySJU|4fi*uT{&e}m5`)tbd>V)FMgoq!Pf+Lc1wcJR zY>O@pVBmf9J@*RU;_z>ap?-09JaDVx4#9rZVnG!^oh7#~Pa~cs+8@X#X2}h9s E2P$m Date: Tue, 19 Jul 2022 07:21:26 +0200 Subject: [PATCH 161/238] State update, havent tested --- .gitignore | 3 +- api/package.json | 17 +-- api/src/Server.ts | 8 +- api/src/middlewares/Authentication.ts | 2 +- api/src/middlewares/BodyParser.ts | 2 +- api/src/middlewares/ErrorHandler.ts | 2 +- api/src/middlewares/TestClient.ts | 3 +- api/src/routes/auth/register.ts | 3 +- .../routes/channels/#channel_id/invites.ts | 2 +- .../#channel_id/messages/#message_id/index.ts | 2 +- .../messages/#message_id/reactions.ts | 2 +- .../#channel_id/messages/bulk-delete.ts | 2 +- .../channels/#channel_id/messages/index.ts | 2 +- .../channels/#channel_id/permissions.ts | 2 +- api/src/routes/channels/#channel_id/pins.ts | 2 +- api/src/routes/channels/#channel_id/purge.ts | 2 +- .../routes/channels/#channel_id/webhooks.ts | 2 +- api/src/routes/discoverable-guilds.ts | 3 +- api/src/routes/discovery.ts | 2 +- api/src/routes/downloads.ts | 2 +- api/src/routes/experiments.ts | 2 +- api/src/routes/gifs/trending.ts | 2 +- api/src/routes/guild-recommendations.ts | 3 +- api/src/routes/guilds/#guild_id/audit-logs.ts | 2 +- api/src/routes/guilds/#guild_id/bans.ts | 2 +- api/src/routes/guilds/#guild_id/channels.ts | 2 +- api/src/routes/guilds/#guild_id/delete.ts | 2 +- api/src/routes/guilds/#guild_id/index.ts | 3 +- .../routes/guilds/#guild_id/integrations.ts | 2 +- .../#guild_id/members/#member_id/index.ts | 2 +- .../routes/guilds/#guild_id/members/index.ts | 2 +- .../guilds/#guild_id/roles/#role_id/index.ts | 2 +- .../routes/guilds/#guild_id/roles/index.ts | 2 +- api/src/routes/guilds/#guild_id/stickers.ts | 2 +- api/src/routes/guilds/#guild_id/templates.ts | 2 +- api/src/routes/guilds/#guild_id/vanity-url.ts | 2 +- api/src/routes/guilds/#guild_id/webhooks.ts | 2 +- .../routes/guilds/#guild_id/welcome_screen.ts | 2 +- .../routes/guilds/#guild_id/widget.json.ts | 2 +- api/src/routes/guilds/#guild_id/widget.png.ts | 2 +- api/src/routes/invites/index.ts | 2 +- api/src/routes/users/@me/delete.ts | 2 +- api/src/routes/users/@me/guilds.ts | 2 +- api/src/routes/users/@me/relationships.ts | 2 +- api/src/start.ts | 1 - api/src/util/handlers/Message.ts | 2 +- api/src/util/utility/passwordStrength.ts | 1 - api/tsconfig.json | 2 +- bundle/package-lock.json | Bin 673595 -> 378759 bytes bundle/package.json | 67 +--------- cdn/package.json | 19 +-- cdn/src/routes/attachments.ts | 2 +- cdn/src/routes/avatars.ts | 2 +- cdn/src/routes/external.ts | 5 +- cdn/src/routes/role-icons.ts | 2 +- cdn/src/util/FileStorage.ts | 6 +- cdn/src/util/Storage.ts | 6 +- cdn/tsconfig.json | 2 +- gateway/package.json | 6 - gateway/src/Server.ts | 1 - gateway/src/events/Message.ts | 5 +- gateway/src/listener/listener.ts | 1 - gateway/src/opcodes/LazyRequest.ts | 2 - gateway/src/opcodes/instanceOf.ts | 2 +- gateway/tsconfig.json | 2 +- package-lock.json | Bin 851945 -> 792479 bytes util/package-lock.json | Bin 466540 -> 467541 bytes util/package.json | 2 + util/src/entities/BaseClass.ts | 1 - util/src/entities/Channel.ts | 2 +- util/src/entities/Encryption.ts | 2 +- util/src/entities/Member.ts | 2 +- util/src/fetch.js | 1 - util/src/index.ts | 1 - util/src/util/AutoUpdate.ts | 3 +- util/src/util/Config.ts | 1 - util/src/util/Event.ts | 4 +- util/src/util/FieldError.ts | 2 - util/src/util/Permissions.ts | 13 +- util/src/util/Rights.ts | 13 +- util/src/util/cdn.ts | 4 +- util/src/util/imports/Checks.ts | 125 ++++++++++++++++++ util/src/util/imports/HTTPError.ts | 5 + util/src/util/imports/index.ts | 2 + util/src/util/index.ts | 4 +- util/tsconfig.json | 2 +- 86 files changed, 229 insertions(+), 211 deletions(-) delete mode 100644 util/src/fetch.js create mode 100644 util/src/util/imports/Checks.ts create mode 100644 util/src/util/imports/HTTPError.ts create mode 100644 util/src/util/imports/index.ts diff --git a/.gitignore b/.gitignore index 0f1d93323..c4d703d25 100644 --- a/.gitignore +++ b/.gitignore @@ -15,4 +15,5 @@ api/assets/plugins/*.js *.log -*.log.ansi \ No newline at end of file +*.log.ansi +bundle/depclean.* \ No newline at end of file diff --git a/api/package.json b/api/package.json index f8d8376eb..1fa85884b 100644 --- a/api/package.json +++ b/api/package.json @@ -39,52 +39,39 @@ "@babel/core": "^7.18.9", "@babel/preset-env": "^7.18.9", "@babel/preset-typescript": "^7.15.0", - "@ovos-media/ts-transform-paths": "^1.7.18-1", - "@types/amqplib": "^0.8.1", "@types/bcrypt": "^5.0.0", "@types/express": "^4.17.9", "@types/i18next-node-fs-backend": "^2.1.0", - "@types/jest": "^28.1.6", - "@types/jest-expect-message": "^1.0.3", - "@types/jsonwebtoken": "^8.5.0", "@types/morgan": "^1.9.3", "@types/multer": "^1.4.5", "@types/node": "^18.0.6", - "@types/supertest": "^2.0.11", "jest": "^28.1.3", "jest-expect-message": "^1.0.2", - "jest-runtime": "^28.1.3", - "ts-node": "^10.9.1", "ts-node-dev": "^2.0.0", - "ts-patch": "^2.0.1", "typescript": "^4.4.2", "typescript-json-schema": "^0.54.0" }, "dependencies": { "@babel/preset-typescript": "^7.15.0", "@fosscord/util": "file:../util", - "@sentry/node": "^7.7.0", - "@sentry/tracing": "^7.7.0", "ajv": "8.6.2", "ajv-formats": "^2.1.1", - "amqplib": "^0.10.0", - "assert": "^2.0.0", "bcrypt": "^5.0.1", "body-parser": "^1.19.0", + "canvas": "^2.9.3", "cheerio": "^1.0.0-rc.10", "dotenv": "^16.0.1", "express": "^4.17.1", - "form-data": "^4.0.0", "i18next": "^21.8.14", "i18next-http-middleware": "^3.1.3", "i18next-node-fs-backend": "^2.1.3", "image-size": "^1.0.0", - "jsonwebtoken": "^8.5.1", "lambert-server": "^1.2.12", "missing-native-js-functions": "^1.2.18", "morgan": "^1.10.0", "multer": "^1.4.5-lts.1", "node-2fa": "^2.0.3", + "node-fetch": "^2.6.7", "patch-package": "^6.4.7", "picocolors": "^1.0.0", "proxy-agent": "^5.0.0", diff --git a/api/src/Server.ts b/api/src/Server.ts index 2b38f4a15..f309834b2 100644 --- a/api/src/Server.ts +++ b/api/src/Server.ts @@ -1,7 +1,6 @@ -import "missing-native-js-functions"; import { Server, ServerOptions } from "lambert-server"; import { Authentication, CORS } from "./middlewares/"; -import { Config, initDatabase, initEvent } from "@fosscord/util"; +import { Config, initDatabase, initEvent, registerRoutes } from "@fosscord/util"; import { ErrorHandler } from "./middlewares/ErrorHandler"; import { BodyParser } from "./middlewares/BodyParser"; import { Router, Request, Response, NextFunction } from "express"; @@ -11,7 +10,6 @@ import TestClient from "./middlewares/TestClient"; import { initTranslation } from "./middlewares/Translation"; import morgan from "morgan"; import { initInstance } from "./util/handlers/Instance"; -import { registerRoutes } from "@fosscord/util"; import { red } from "picocolors" export interface FosscordServerOptions extends ServerOptions {} @@ -50,7 +48,7 @@ export class FosscordServer extends Server { } }) ); - }; + } this.app.use(CORS); this.app.use(BodyParser({ inflate: true, limit: "10mb" })); @@ -91,4 +89,4 @@ export class FosscordServer extends Server { return super.start(); } -}; \ No newline at end of file +} \ No newline at end of file diff --git a/api/src/middlewares/Authentication.ts b/api/src/middlewares/Authentication.ts index 1df7911be..2d9ccf571 100644 --- a/api/src/middlewares/Authentication.ts +++ b/api/src/middlewares/Authentication.ts @@ -1,5 +1,5 @@ import { NextFunction, Request, Response } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { checkToken, Config, Rights } from "@fosscord/util"; export const NO_AUTHORIZATION_ROUTES = [ diff --git a/api/src/middlewares/BodyParser.ts b/api/src/middlewares/BodyParser.ts index 4cb376bc2..35db3c6fb 100644 --- a/api/src/middlewares/BodyParser.ts +++ b/api/src/middlewares/BodyParser.ts @@ -1,6 +1,6 @@ import bodyParser, { OptionsJson } from "body-parser"; import { NextFunction, Request, Response } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; export function BodyParser(opts?: OptionsJson) { const jsonParser = bodyParser.json(opts); diff --git a/api/src/middlewares/ErrorHandler.ts b/api/src/middlewares/ErrorHandler.ts index 2012b91c3..8a046e06f 100644 --- a/api/src/middlewares/ErrorHandler.ts +++ b/api/src/middlewares/ErrorHandler.ts @@ -1,5 +1,5 @@ import { NextFunction, Request, Response } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { ApiError, FieldError } from "@fosscord/util"; const EntityNotFoundErrorRegex = /"(\w+)"/; diff --git a/api/src/middlewares/TestClient.ts b/api/src/middlewares/TestClient.ts index 466d4bccf..167b4c47c 100644 --- a/api/src/middlewares/TestClient.ts +++ b/api/src/middlewares/TestClient.ts @@ -1,11 +1,10 @@ import express, { Request, Response, Application } from "express"; -import fs, { writeFile } from "fs"; +import fs from "fs"; import path from "path"; import fetch, { Response as FetchResponse, Headers } from "node-fetch"; import ProxyAgent from 'proxy-agent'; import { Config } from "@fosscord/util"; import { AssetCacheItem } from "../util/entities/AssetCacheItem" -import { FileLogger } from "typeorm"; export default function TestClient(app: Application) { const agent = new ProxyAgent(); diff --git a/api/src/routes/auth/register.ts b/api/src/routes/auth/register.ts index 94dd65021..9816c5fd1 100644 --- a/api/src/routes/auth/register.ts +++ b/api/src/routes/auth/register.ts @@ -1,9 +1,8 @@ import { Request, Response, Router } from "express"; import { Config, generateToken, Invite, FieldErrors, User, adjustEmail, trimSpecial } from "@fosscord/util"; import { route, getIpAdress, IPAnalysis, isProxy } from "@fosscord/api"; -import "missing-native-js-functions"; import bcrypt from "bcrypt"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router: Router = Router(); diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index 9c3611647..788f7d6de 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -1,5 +1,5 @@ import { Router, Request, Response } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { random } from "@fosscord/api"; import { Channel, Invite, InviteCreateEvent, emitEvent, User, Guild, PublicInviteRelation } from "@fosscord/util"; diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index b7f1e1307..0b228ed66 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -19,7 +19,7 @@ import multer from "multer"; import { route } from "@fosscord/api"; import { handleMessage, postHandleMessage } from "@fosscord/api"; import { MessageCreateSchema } from "../index"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router = Router(); // TODO: message content/embed string length limit diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts b/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts index 2a387fc1b..f56f18d30 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts @@ -15,7 +15,7 @@ import { } from "@fosscord/util"; import { route } from "@fosscord/api"; import { Router, Response, Request } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { In } from "typeorm"; const router = Router(); diff --git a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts b/api/src/routes/channels/#channel_id/messages/bulk-delete.ts index 9e8cad235..2e40f110d 100644 --- a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts +++ b/api/src/routes/channels/#channel_id/messages/bulk-delete.ts @@ -1,6 +1,6 @@ import { Router, Response, Request } from "express"; import { Channel, Config, emitEvent, getPermission, getRights, MessageDeleteBulkEvent, Message } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { In } from "typeorm"; diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 6d4d57941..f8e62d8ce 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -15,7 +15,7 @@ import { uploadFile, Member } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { handleMessage, postHandleMessage, route } from "@fosscord/api"; import multer from "multer"; import { FindManyOptions, LessThan, MoreThan } from "typeorm"; diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/api/src/routes/channels/#channel_id/permissions.ts index cdcbde3d4..798f7c8da 100644 --- a/api/src/routes/channels/#channel_id/permissions.ts +++ b/api/src/routes/channels/#channel_id/permissions.ts @@ -9,7 +9,7 @@ import { Role } from "@fosscord/util"; import { Router, Response, Request } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); diff --git a/api/src/routes/channels/#channel_id/pins.ts b/api/src/routes/channels/#channel_id/pins.ts index e71e659fb..5c314f092 100644 --- a/api/src/routes/channels/#channel_id/pins.ts +++ b/api/src/routes/channels/#channel_id/pins.ts @@ -9,7 +9,7 @@ import { DiscordApiErrors } from "@fosscord/util"; import { Router, Request, Response } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts index 3a6997b24..7ab4ad9a4 100644 --- a/api/src/routes/channels/#channel_id/purge.ts +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -1,4 +1,4 @@ -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { isTextChannel } from "./messages"; import { FindManyOptions, Between, Not } from "typeorm"; diff --git a/api/src/routes/channels/#channel_id/webhooks.ts b/api/src/routes/channels/#channel_id/webhooks.ts index cfb276ba9..52f7ef7d5 100644 --- a/api/src/routes/channels/#channel_id/webhooks.ts +++ b/api/src/routes/channels/#channel_id/webhooks.ts @@ -1,7 +1,7 @@ import { Router, Response, Request } from "express"; import { route } from "@fosscord/api"; import { Channel, Config, getPermission, trimSpecial, Webhook } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { isTextChannel } from "./messages/index"; import { DiscordApiErrors } from "@fosscord/util"; diff --git a/api/src/routes/discoverable-guilds.ts b/api/src/routes/discoverable-guilds.ts index fb7b844f4..2d1e60b61 100644 --- a/api/src/routes/discoverable-guilds.ts +++ b/api/src/routes/discoverable-guilds.ts @@ -1,7 +1,8 @@ import { Guild, Config } from "@fosscord/util"; import { Router, Request, Response } from "express"; -import { route } from "@fosscord/api"; +import { route } from ".."; +import { Like } from "typeorm"; const router = Router(); diff --git a/api/src/routes/discovery.ts b/api/src/routes/discovery.ts index a7df120e7..30c418c62 100644 --- a/api/src/routes/discovery.ts +++ b/api/src/routes/discovery.ts @@ -1,6 +1,6 @@ import { Categories } from "@fosscord/util"; import { Router, Response, Request } from "express"; -import { route } from "@fosscord/api"; +import { route } from ".."; const router = Router(); diff --git a/api/src/routes/downloads.ts b/api/src/routes/downloads.ts index ddfc080cf..03c73f440 100644 --- a/api/src/routes/downloads.ts +++ b/api/src/routes/downloads.ts @@ -1,5 +1,5 @@ import { Router, Response, Request } from "express"; -import { route } from "@fosscord/api"; +import { route } from ".."; import { Release, Config } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/experiments.ts b/api/src/routes/experiments.ts index 7be86fb89..fcbd9271d 100644 --- a/api/src/routes/experiments.ts +++ b/api/src/routes/experiments.ts @@ -1,5 +1,5 @@ import { Router, Response, Request } from "express"; -import { route } from "@fosscord/api"; +import { route } from ".."; const router = Router(); diff --git a/api/src/routes/gifs/trending.ts b/api/src/routes/gifs/trending.ts index bc143f005..61eb76c4c 100644 --- a/api/src/routes/gifs/trending.ts +++ b/api/src/routes/gifs/trending.ts @@ -3,7 +3,7 @@ import fetch from "node-fetch"; import ProxyAgent from 'proxy-agent'; import { route } from "@fosscord/api"; import { Config } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/guild-recommendations.ts b/api/src/routes/guild-recommendations.ts index 069e42218..ee2c26f1b 100644 --- a/api/src/routes/guild-recommendations.ts +++ b/api/src/routes/guild-recommendations.ts @@ -1,7 +1,8 @@ import { Guild, Config } from "@fosscord/util"; import { Router, Request, Response } from "express"; -import { route } from "@fosscord/api"; +import { route } from ".."; +import {Like} from "typeorm" const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/audit-logs.ts b/api/src/routes/guilds/#guild_id/audit-logs.ts index a4f2f800b..7b1d00628 100644 --- a/api/src/routes/guilds/#guild_id/audit-logs.ts +++ b/api/src/routes/guilds/#guild_id/audit-logs.ts @@ -1,6 +1,6 @@ import { Router, Response, Request } from "express"; import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/bans.ts b/api/src/routes/guilds/#guild_id/bans.ts index 1ce41936a..eb38de0db 100644 --- a/api/src/routes/guilds/#guild_id/bans.ts +++ b/api/src/routes/guilds/#guild_id/bans.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { DiscordApiErrors, emitEvent, getPermission, GuildBanAddEvent, GuildBanRemoveEvent, Guild, Ban, User, Member } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { getIpAdress, route } from "@fosscord/api"; export interface BanCreateSchema { diff --git a/api/src/routes/guilds/#guild_id/channels.ts b/api/src/routes/guilds/#guild_id/channels.ts index a921fa214..e3c6b8bd7 100644 --- a/api/src/routes/guilds/#guild_id/channels.ts +++ b/api/src/routes/guilds/#guild_id/channels.ts @@ -1,6 +1,6 @@ import { Router, Response, Request } from "express"; import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/delete.ts b/api/src/routes/guilds/#guild_id/delete.ts index 86550005d..e26246511 100644 --- a/api/src/routes/guilds/#guild_id/delete.ts +++ b/api/src/routes/guilds/#guild_id/delete.ts @@ -1,6 +1,6 @@ import { Channel, emitEvent, GuildDeleteEvent, Guild, Member, Message, Role, Invite, Emoji } from "@fosscord/util"; import { Router, Request, Response } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index bf77bd5ec..d9c8f13ba 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -1,8 +1,7 @@ import { Request, Response, Router } from "express"; import { DiscordApiErrors, emitEvent, getPermission, getRights, Guild, GuildUpdateEvent, handleFile, Member } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; -import "missing-native-js-functions"; import { GuildCreateSchema } from "../index"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/integrations.ts b/api/src/routes/guilds/#guild_id/integrations.ts index abf997c9d..19f685635 100644 --- a/api/src/routes/guilds/#guild_id/integrations.ts +++ b/api/src/routes/guilds/#guild_id/integrations.ts @@ -1,6 +1,6 @@ import { Router, Response, Request } from "express"; import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index 5601097e0..e4a060d66 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { Member, getPermission, getRights, Role, GuildMemberUpdateEvent, emitEvent, Sticker, Emoji, Rights, Guild } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/members/index.ts b/api/src/routes/guilds/#guild_id/members/index.ts index b730a4e77..2ed28bda5 100644 --- a/api/src/routes/guilds/#guild_id/members/index.ts +++ b/api/src/routes/guilds/#guild_id/members/index.ts @@ -2,7 +2,7 @@ import { Request, Response, Router } from "express"; import { Guild, Member, PublicMemberProjection } from "@fosscord/util"; import { route } from "@fosscord/api"; import { MoreThan } from "typeorm"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 2ad01682c..7efc53823 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -1,7 +1,7 @@ import { Router, Request, Response } from "express"; import { Role, Member, GuildRoleUpdateEvent, GuildRoleDeleteEvent, emitEvent, handleFile } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { RoleModifySchema } from "../"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index 534651054..2f5141b84 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -11,7 +11,7 @@ import { DiscordApiErrors, handleFile } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); diff --git a/api/src/routes/guilds/#guild_id/stickers.ts b/api/src/routes/guilds/#guild_id/stickers.ts index 4ea1dce1c..bfc462915 100644 --- a/api/src/routes/guilds/#guild_id/stickers.ts +++ b/api/src/routes/guilds/#guild_id/stickers.ts @@ -12,7 +12,7 @@ import { import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; import multer from "multer"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/api/src/routes/guilds/#guild_id/templates.ts index 2989c0d2d..7e4119076 100644 --- a/api/src/routes/guilds/#guild_id/templates.ts +++ b/api/src/routes/guilds/#guild_id/templates.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { Guild, Template } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { generateCode } from "@fosscord/api"; diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/api/src/routes/guilds/#guild_id/vanity-url.ts index 29cd25e23..e841b8b39 100644 --- a/api/src/routes/guilds/#guild_id/vanity-url.ts +++ b/api/src/routes/guilds/#guild_id/vanity-url.ts @@ -1,7 +1,7 @@ import { Channel, ChannelType, getPermission, Guild, Invite, trimSpecial } from "@fosscord/util"; import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/webhooks.ts b/api/src/routes/guilds/#guild_id/webhooks.ts index 8b2febeac..7f5b95928 100644 --- a/api/src/routes/guilds/#guild_id/webhooks.ts +++ b/api/src/routes/guilds/#guild_id/webhooks.ts @@ -1,6 +1,6 @@ import { Router, Response, Request } from "express"; import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/welcome_screen.ts b/api/src/routes/guilds/#guild_id/welcome_screen.ts index 7141f17ee..ab1251311 100644 --- a/api/src/routes/guilds/#guild_id/welcome_screen.ts +++ b/api/src/routes/guilds/#guild_id/welcome_screen.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { Guild, getPermission, Snowflake, Member } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); diff --git a/api/src/routes/guilds/#guild_id/widget.json.ts b/api/src/routes/guilds/#guild_id/widget.json.ts index 154b25173..97f3c3034 100644 --- a/api/src/routes/guilds/#guild_id/widget.json.ts +++ b/api/src/routes/guilds/#guild_id/widget.json.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { Config, Permissions, Guild, Invite, Channel, Member } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { random, route } from "@fosscord/api"; const router: Router = Router(); diff --git a/api/src/routes/guilds/#guild_id/widget.png.ts b/api/src/routes/guilds/#guild_id/widget.png.ts index 4c82b7407..4298d0fe4 100644 --- a/api/src/routes/guilds/#guild_id/widget.png.ts +++ b/api/src/routes/guilds/#guild_id/widget.png.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { Guild } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import fs from "fs"; import path from "path"; diff --git a/api/src/routes/invites/index.ts b/api/src/routes/invites/index.ts index eeafb22ab..b0a349393 100644 --- a/api/src/routes/invites/index.ts +++ b/api/src/routes/invites/index.ts @@ -1,7 +1,7 @@ import { Router, Request, Response } from "express"; import { emitEvent, getPermission, Guild, Invite, InviteDeleteEvent, User, PublicInviteRelation } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router: Router = Router(); diff --git a/api/src/routes/users/@me/delete.ts b/api/src/routes/users/@me/delete.ts index c24c3f1ec..1d81c2b98 100644 --- a/api/src/routes/users/@me/delete.ts +++ b/api/src/routes/users/@me/delete.ts @@ -2,7 +2,7 @@ import { Router, Request, Response } from "express"; import { Guild, Member, User } from "@fosscord/util"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/users/@me/guilds.ts b/api/src/routes/users/@me/guilds.ts index 754a240e3..4d4fccd4a 100644 --- a/api/src/routes/users/@me/guilds.ts +++ b/api/src/routes/users/@me/guilds.ts @@ -1,6 +1,6 @@ import { Router, Request, Response } from "express"; import { Guild, Member, User, GuildDeleteEvent, GuildMemberRemoveEvent, emitEvent, Config } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); diff --git a/api/src/routes/users/@me/relationships.ts b/api/src/routes/users/@me/relationships.ts index d03014b64..b2e39d52d 100644 --- a/api/src/routes/users/@me/relationships.ts +++ b/api/src/routes/users/@me/relationships.ts @@ -9,7 +9,7 @@ import { Config } from "@fosscord/util"; import { Router, Response, Request } from "express"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { DiscordApiErrors } from "@fosscord/util"; import { route } from "@fosscord/api"; diff --git a/api/src/start.ts b/api/src/start.ts index 841ad3d5d..9ba198e72 100644 --- a/api/src/start.ts +++ b/api/src/start.ts @@ -1,7 +1,6 @@ process.on("uncaughtException", console.error); process.on("unhandledRejection", console.error); -import "missing-native-js-functions"; import { config } from "dotenv"; config(); import { FosscordServer } from "./Server"; diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 31ac91080..0a74312ef 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -22,7 +22,7 @@ import { Attachment, Config, } from "@fosscord/util"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import fetch from "node-fetch"; import cheerio from "cheerio"; import { MessageCreateSchema } from "../../routes/channels/#channel_id/messages"; diff --git a/api/src/util/utility/passwordStrength.ts b/api/src/util/utility/passwordStrength.ts index f8badea78..8eca63b8a 100644 --- a/api/src/util/utility/passwordStrength.ts +++ b/api/src/util/utility/passwordStrength.ts @@ -1,5 +1,4 @@ import { Config } from "@fosscord/util"; -import "missing-native-js-functions"; const reNUMBER = /[0-9]/g; const reUPPERCASELETTER = /[A-Z]/g; diff --git a/api/tsconfig.json b/api/tsconfig.json index 91396aa8e..80fca16df 100644 --- a/api/tsconfig.json +++ b/api/tsconfig.json @@ -5,7 +5,7 @@ /* Visit https://aka.ms/tsconfig.json to read more about this file */ /* Basic Options */ - "incremental": true /* Enable incremental compilation */, + "incremental": false /* Enable incremental compilation */, "target": "ESNext" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": ["ES2021"] /* Specify library files to be included in the compilation. */, diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 5078696fd47b825037a4224e64601b52cd8459a1..7a409df31c788ca17f64cd94ae3b3d483797fc58 100644 GIT binary patch delta 13900 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 delta 167581 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

3)GsB`4`fnXD_x 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 z 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�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 diff --git a/bundle/package.json b/bundle/package.json index 002ed7f9d..a2c2f5300 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -26,82 +26,27 @@ }, "homepage": "https://fosscord.com", "devDependencies": { - "@babel/core": "^7.18.9", - "@babel/preset-env": "^7.18.9", - "@babel/preset-typescript": "^7.15.0", - "@ovos-media/ts-transform-paths": "^1.7.18-1", - "@types/amqplib": "^0.8.1", - "@types/bcrypt": "^5.0.0", - "@types/body-parser": "^1.19.0", - "@types/btoa": "^1.2.3", "@types/dotenv": "^8.2.0", "@types/express": "^4.17.12", - "@types/fs-extra": "^9.0.12", - "@types/i18next-node-fs-backend": "^2.1.0", - "@types/jest": "^28.1.6", - "@types/jest-expect-message": "^1.0.3", - "@types/jsonwebtoken": "^8.5.0", - "@types/morgan": "^1.9.3", - "@types/multer": "^1.4.7", "@types/node": "^18.0.6", - "@types/node-os-utils": "^1.2.0", - "@types/supertest": "^2.0.11", - "@types/ws": "^8.5.3", - "jest": "^28.1.3", - "jest-expect-message": "^1.0.2", - "jest-runtime": "^28.1.3", + "@types/node-os-utils": "^1.3.0", "ts-node": "^10.2.1", - "ts-node-dev": "^2.0.0", "ts-patch": "^2.0.1", - "tsconfig-paths": "^3.12.0", - "typescript": "^4.2.3", - "typescript-json-schema": "^0.54.0" + "typescript": "^4.7.4" }, "dependencies": { - "@aws-sdk/client-s3": "^3.36.1", - "@aws-sdk/node-http-handler": "^3.36.0", - "@babel/preset-env": "^7.15.8", - "@babel/preset-typescript": "^7.15.0", "@fosscord/api": "file:../api", "@fosscord/cdn": "file:../cdn", "@fosscord/gateway": "file:../gateway", + "@ovos-media/ts-transform-paths": "^1.7.18-1", "@sentry/node": "^7.7.0", "@sentry/tracing": "^7.7.0", - "ajv": "8.6.2", - "ajv-formats": "^2.1.1", - "amqplib": "^0.10.0", - "assert": "^2.0.0", - "async-exit-hook": "^2.0.1", - "bcrypt": "^5.0.1", - "body-parser": "^1.19.0", - "btoa": "^1.2.1", - "cheerio": "^1.0.0-rc.10", "dotenv": "^16.0.1", - "exif-be-gone": "^1.2.0", - "express": "^4.17.1", - "express-async-errors": "^3.1.1", - "file-type": "^17.1.2", - "form-data": "^4.0.0", - "fs-extra": "^10.0.0", - "i18next": "^21.8.14", - "i18next-http-middleware": "^3.1.3", - "i18next-node-fs-backend": "^2.1.3", - "image-size": "^1.0.0", - "jest": "^28.1.3", - "jsonwebtoken": "^8.5.1", - "lambert-db": "^1.2.3", - "lambert-server": "^1.2.11", - "missing-native-js-functions": "^1.2.18", - "morgan": "^1.10.0", - "multer": "^1.4.5-lts.1", - "nan": "^2.15.0", - "nanocolors": "^0.2.12", - "node-2fa": "^2.0.3", - "node-os-utils": "^1.3.5", + "express": "^4.18.1", + "node-fetch": "^2.6.7", + "node-os-utils": "^1.3.7", "patch-package": "^6.4.7", - "pg": "^8.7.3", "picocolors": "^1.0.0", - "proxy-agent": "^5.0.0", "reflect-metadata": "^0.1.13", "sqlite3": "^4.2.0", "supertest": "^6.1.6", diff --git a/cdn/package.json b/cdn/package.json index 2b2866cbd..f7438109c 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -21,38 +21,27 @@ }, "homepage": "https://github.com/fosscord/fosscord-server#readme", "devDependencies": { - "@ovos-media/ts-transform-paths": "^1.7.18-1", - "@types/amqplib": "^0.8.1", "@types/body-parser": "^1.19.0", - "@types/btoa": "^1.2.3", "@types/dotenv": "^8.2.0", "@types/express": "^4.17.12", - "@types/fs-extra": "^9.0.12", - "@types/jsonwebtoken": "^8.5.0", "@types/multer": "^1.4.7", - "@types/node": "^18.0.6", - "ts-patch": "^2.0.1" + "@types/node": "^18.0.6" }, "dependencies": { "@aws-sdk/client-s3": "^3.36.1", - "@aws-sdk/node-http-handler": "^3.36.0", "@fosscord/util": "file:../util", + "@types/node-fetch": "^2.6.2", "body-parser": "^1.19.0", - "btoa": "^1.2.1", "dotenv": "^16.0.1", "exif-be-gone": "^1.2.0", "express": "^4.17.1", - "express-async-errors": "^3.1.1", "file-type": "^17.1.2", - "form-data": "^4.0.0", - "fs-extra": "^10.0.0", "image-size": "^1.0.0", "jest": "^28.1.3", - "lambert-db": "^1.2.3", "lambert-server": "^1.2.12", - "missing-native-js-functions": "^1.2.17", "multer": "^1.4.5-lts.1", - "nanocolors": "^0.2.12", + "node-fetch": "^2.6.7", + "picocolors": "^1.0.0", "supertest": "^6.1.6", "typescript": "^4.1.2" }, diff --git a/cdn/src/routes/attachments.ts b/cdn/src/routes/attachments.ts index 2aed752eb..3e04fe76a 100644 --- a/cdn/src/routes/attachments.ts +++ b/cdn/src/routes/attachments.ts @@ -2,7 +2,7 @@ import { Router, Response, Request } from "express"; import { Config, Snowflake } from "@fosscord/util"; import { storage } from "../util/Storage"; import FileType from "file-type"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import { multer } from "../util/multer"; import imageSize from "image-size"; diff --git a/cdn/src/routes/avatars.ts b/cdn/src/routes/avatars.ts index 3b521cc3b..bbdf42cc7 100644 --- a/cdn/src/routes/avatars.ts +++ b/cdn/src/routes/avatars.ts @@ -2,7 +2,7 @@ import { Router, Response, Request } from "express"; import { Config, Snowflake } from "@fosscord/util"; import { storage } from "../util/Storage"; import FileType from "file-type"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import crypto from "crypto"; import { multer } from "../util/multer"; diff --git a/cdn/src/routes/external.ts b/cdn/src/routes/external.ts index ed44c9054..cf02f645b 100644 --- a/cdn/src/routes/external.ts +++ b/cdn/src/routes/external.ts @@ -1,10 +1,9 @@ import { Router, Response, Request } from "express"; import fetch from "node-fetch"; -import { HTTPError } from "lambert-server"; -import { Snowflake } from "@fosscord/util"; +import { HTTPError } from "@fosscord/util"; +import { Snowflake, Config } from "@fosscord/util"; import { storage } from "../util/Storage"; import FileType from "file-type"; -import { Config } from "@fosscord/util"; // TODO: somehow handle the deletion of images posted to the /external route diff --git a/cdn/src/routes/role-icons.ts b/cdn/src/routes/role-icons.ts index a850db886..dd96c90e6 100644 --- a/cdn/src/routes/role-icons.ts +++ b/cdn/src/routes/role-icons.ts @@ -2,7 +2,7 @@ import { Router, Response, Request } from "express"; import { Config, Snowflake } from "@fosscord/util"; import { storage } from "../util/Storage"; import FileType from "file-type"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from "@fosscord/util"; import crypto from "crypto"; import { multer } from "../util/multer"; diff --git a/cdn/src/util/FileStorage.ts b/cdn/src/util/FileStorage.ts index 376ce007c..ed007abbf 100644 --- a/cdn/src/util/FileStorage.ts +++ b/cdn/src/util/FileStorage.ts @@ -1,8 +1,7 @@ import { Storage } from "./Storage"; import fs from "fs"; -import fse from "fs-extra"; +//import fse from "fs-extra"; import { join, relative, dirname } from "path"; -import "missing-native-js-functions"; import { Readable } from "stream"; import ExifTransformer = require("exif-be-gone"); @@ -36,7 +35,8 @@ export class FileStorage implements Storage { async set(path: string, value: any) { path = getPath(path); - fse.ensureDirSync(dirname(path)); + //fse.ensureDirSync(dirname(path)); + fs.mkdirSync(dirname(path), {recursive: true}); value = Readable.from(value); const cleaned_file = fs.createWriteStream(path); diff --git a/cdn/src/util/Storage.ts b/cdn/src/util/Storage.ts index 89dd5634b..728804a0c 100644 --- a/cdn/src/util/Storage.ts +++ b/cdn/src/util/Storage.ts @@ -1,6 +1,7 @@ import { FileStorage } from "./FileStorage"; import path from "path"; -import fse from "fs-extra"; +//import fse from "fs-extra"; +import fs from "fs"; import { bgCyan, black } from "picocolors"; import { S3 } from "@aws-sdk/client-s3"; import { S3Storage } from "./S3Storage"; @@ -22,7 +23,8 @@ if (process.env.STORAGE_PROVIDER === "file" || !process.env.STORAGE_PROVIDER) { location = path.join(process.cwd(), "files"); } console.log(`[CDN] storage location: ${bgCyan(`${black(location)}`)}`); - fse.ensureDirSync(location); + //fse.ensureDirSync(location); + fs.mkdirSync(location, {recursive: true}); process.env.STORAGE_LOCATION = location; storage = new FileStorage(); diff --git a/cdn/tsconfig.json b/cdn/tsconfig.json index 1ad037c60..94cc7b586 100644 --- a/cdn/tsconfig.json +++ b/cdn/tsconfig.json @@ -4,7 +4,7 @@ /* Visit https://aka.ms/tsconfig.json to read more about this file */ /* Basic Options */ - "incremental": true /* Enable incremental compilation */, + "incremental": false /* Enable incremental compilation */, "target": "ES6" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": [ diff --git a/gateway/package.json b/gateway/package.json index 05ef5c558..19d44eba7 100644 --- a/gateway/package.json +++ b/gateway/package.json @@ -15,9 +15,7 @@ "author": "Fosscord", "license": "AGPL-3.0-only", "devDependencies": { - "@ovos-media/ts-transform-paths": "^1.7.18-1", "@types/amqplib": "^0.8.1", - "@types/jsonwebtoken": "^8.5.0", "@types/node": "^18.0.6", "@types/ws": "^8.5.3", "ts-node-dev": "^2.0.0", @@ -28,10 +26,6 @@ "@fosscord/util": "file:../util", "amqplib": "^0.10.0", "dotenv": "^16.0.1", - "jsonwebtoken": "^8.5.1", - "lambert-server": "^1.2.11", - "missing-native-js-functions": "^1.2.18", - "proxy-agent": "^5.0.0", "typeorm": "^0.3.7", "ws": "^8.8.1" }, diff --git a/gateway/src/Server.ts b/gateway/src/Server.ts index 7e1489bee..254820c9b 100644 --- a/gateway/src/Server.ts +++ b/gateway/src/Server.ts @@ -1,4 +1,3 @@ -import "missing-native-js-functions"; import dotenv from "dotenv"; dotenv.config(); import { closeDatabase, Config, initDatabase, initEvent } from "@fosscord/util"; diff --git a/gateway/src/events/Message.ts b/gateway/src/events/Message.ts index 83e6fc1b6..313287841 100644 --- a/gateway/src/events/Message.ts +++ b/gateway/src/events/Message.ts @@ -1,17 +1,16 @@ -import { CLOSECODES, OPCODES } from "../util/Constants"; +import { CLOSECODES } from "../util/Constants"; import { WebSocket, Payload } from "@fosscord/gateway"; let erlpack: any; try { erlpack = require("@yukikaze-bot/erlpack"); } catch (error) {} import OPCodeHandlers from "../opcodes"; -import { Tuple } from "lambert-server"; import { check } from "../opcodes/instanceOf"; import WS from "ws"; const PayloadSchema = { op: Number, - $d: new Tuple(Object, Number), // or number for heartbeat sequence + $d: Object || Number, // or number for heartbeat sequence $s: Number, $t: String, }; diff --git a/gateway/src/listener/listener.ts b/gateway/src/listener/listener.ts index 060de65bb..0cf2b82b9 100644 --- a/gateway/src/listener/listener.ts +++ b/gateway/src/listener/listener.ts @@ -13,7 +13,6 @@ import { import { OPCODES } from "../util/Constants"; import { Send } from "../util/Send"; import { WebSocket } from "@fosscord/gateway"; -import "missing-native-js-functions"; import { Channel as AMQChannel } from "amqplib"; import { Recipient } from "@fosscord/util"; diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 7503ee614..dd96d6d7b 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -4,9 +4,7 @@ import { Send } from "../util/Send"; import { OPCODES } from "../util/Constants"; import { WebSocket, Payload, handlePresenceUpdate } from "@fosscord/gateway"; import { check } from "./instanceOf"; -import "missing-native-js-functions"; import { getRepository } from "typeorm"; -import "missing-native-js-functions"; // TODO: only show roles/members that have access to this channel // TODO: config: to list all members (even those who are offline) sorted by role, or just those who are online diff --git a/gateway/src/opcodes/instanceOf.ts b/gateway/src/opcodes/instanceOf.ts index 6fd508527..eb6f6ea18 100644 --- a/gateway/src/opcodes/instanceOf.ts +++ b/gateway/src/opcodes/instanceOf.ts @@ -1,4 +1,4 @@ -import { instanceOf } from "lambert-server"; +import { instanceOf } from "@fosscord/util"; import { WebSocket } from "@fosscord/gateway"; import { CLOSECODES } from "../util/Constants"; diff --git a/gateway/tsconfig.json b/gateway/tsconfig.json index 56b9ca7d0..70407c6b0 100644 --- a/gateway/tsconfig.json +++ b/gateway/tsconfig.json @@ -5,7 +5,7 @@ /* Visit https://aka.ms/tsconfig.json to read more about this file */ /* Basic Options */ - "incremental": true /* Enable incremental compilation */, + "incremental": false /* Enable incremental compilation */, "target": "ES2020" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": [ diff --git a/package-lock.json b/package-lock.json index 18a82aab57003acae56a179d01cfb82518caf920..abc8be0ddacd667a875b5c9afbe70a9fb9fb8846 100644 GIT binary patch delta 6191 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 F{{p$Ynz{f0 diff --git a/util/package-lock.json b/util/package-lock.json index e56a5f1bcd7197c46b65533f6d7619eff93be005..472f1b95f0c62965ea4c9d6bc17e3a24b8ca5e16 100644 GIT binary patch delta 953 zcmci9+b^4O7{KwoZ-0GXY^p^ohUjX{oQl?AGufzP)v5HbUZB&`*0~2oBC$z`EDQ28 zk4&=7W^NeUBztWkM8skj2ytZ>?zWj-SQbkbvK5*CV7qy4eoykt^Zo4225v0{_8sA( zH5#}*2zf_W8SRxO(KVr{EIuYNCSDZP|8p6VwI~q2|DgEO8^rztxW7dDL&XA#V5*%Z zhSW%k3kMa*3(s%yAyALXK>m_Uh3!zv2Uhin1KqF5i0SfS2R;33%zOo;d_sU1mT0^P zBKRs}i7|JEhTd}5C(_?YsLIG`GSxOESd5t^iq^QRrMFB9eT_UesiweDr`1?0GYl3MdAMx}Ndl1iGC zxy>?Ner9u8enYmZF;=UJv>A)dI-|uBD=Tc1D03wyO_9_lYnD{&G#Z6PUTR3PW;-iw zSqa8GUAEaAYZaSrSHm42A{bH%*=h)%ByJoB=^R>ThSmx0NBkZ>!SEwefOm)Xfcuto zW5y@QyPNpn>E=m3CaQxqmx{wjk4|fLKHr0Tde{E=SON2Sj#V-O-y*1hGbNgttw2Mr z$Zj+T_Ue%v6IY8S!#q9Q-P@yFLv+*L+KA^N^#6JAc3j?5y@&^W(IkBW(zQ$QK-f$P z+^ZU_bupCcWKR9qq6JAtCw4Y!W!Mpv!~XBp-9f%3*jD OdAo4a7$HF`g8l%9t6ReW delta 429 zcmW-dUr1AN9L2f!_r1TL&WHuMdFO(8U6Wdyik30*Aqav7(H|n}VRUJ>{MR3yiZAXV zBdsaZH z;PeV>w-2ei1B9vx|29>DVz`n^mJ$Nwva+%j%bS-{=P1*NA3PvHwA4=NuN!mqH_k64CvqWaY-k7d{m95!hP?^NN#g?WAu zmvnIwKi1d~>buTxY~6`0CY<40_lP6=nhV$5T{AtGip)$+;Ic_Rth6zK@HZ#ZNume6 zJ=}}yBofd~I*LGw{OwH+BNi|g`l5Z&0po process.setMaxListeners(process.getMaxListeners() - 1); }; - const listener = (msg: ProcessEvent) => { - msg.type === "event" && msg.id === event && callback({ ...msg.event, cancel }); + const listener = (message: any) => { + message.type === "event" && message.id === event && callback({ ...message.event, cancel }); }; process.addListener("message", listener); diff --git a/util/src/util/FieldError.ts b/util/src/util/FieldError.ts index 406b33e82..49968e1a2 100644 --- a/util/src/util/FieldError.ts +++ b/util/src/util/FieldError.ts @@ -1,5 +1,3 @@ -import "missing-native-js-functions"; - export function FieldErrors(fields: Record) { return new FieldError( 50035, diff --git a/util/src/util/Permissions.ts b/util/src/util/Permissions.ts index e003bf05e..d3efb70c1 100644 --- a/util/src/util/Permissions.ts +++ b/util/src/util/Permissions.ts @@ -1,17 +1,8 @@ // https://github.com/discordjs/discord.js/blob/master/src/util/Permissions.js // Apache License Version 2.0 Copyright 2015 - 2021 Amish Shah import { Channel, ChannelPermissionOverwrite, Guild, Member, Role } from "../entities"; -import { BitField } from "./BitField"; -import "missing-native-js-functions"; -import { BitFieldResolvable, BitFlag } from "./BitField"; - -let HTTPError: any; - -try { - HTTPError = require("lambert-server").HTTPError; -} catch (e) { - HTTPError = Error; -} +import { BitField, BitFieldResolvable, BitFlag } from "./BitField"; +import { HTTPError } from ".."; export type PermissionResolvable = bigint | number | Permissions | PermissionResolvable[] | PermissionString; diff --git a/util/src/util/Rights.ts b/util/src/util/Rights.ts index b7f458363..1c3906fb4 100644 --- a/util/src/util/Rights.ts +++ b/util/src/util/Rights.ts @@ -1,15 +1,6 @@ -import { BitField } from "./BitField"; -import "missing-native-js-functions"; -import { BitFieldResolvable, BitFlag } from "./BitField"; +import { BitField, BitFieldResolvable, BitFlag } from "./BitField"; import { User } from "../entities"; - -let HTTPError: any; - -try { - HTTPError = require("lambert-server").HTTPError; -} catch (e) { - HTTPError = Error; -} +import { HTTPError } from ".."; export type RightResolvable = bigint | number | Rights | RightResolvable[] | RightString; diff --git a/util/src/util/cdn.ts b/util/src/util/cdn.ts index ef4ac47d6..9cfe4896c 100644 --- a/util/src/util/cdn.ts +++ b/util/src/util/cdn.ts @@ -1,8 +1,8 @@ import FormData from "form-data"; -import { HTTPError } from "lambert-server"; +import { HTTPError } from ".."; import { Config } from "./Config"; import multer from "multer"; -import fetch from "../fetch" +import fetch from "node-fetch" import { nodeModuleNameResolver } from "typescript"; export async function uploadFile(path: string, file?: Express.Multer.File) { diff --git a/util/src/util/imports/Checks.ts b/util/src/util/imports/Checks.ts new file mode 100644 index 000000000..19a841713 --- /dev/null +++ b/util/src/util/imports/Checks.ts @@ -0,0 +1,125 @@ +//source: https://github.com/Flam3rboy/-server/blob/master/src/check.ts +import { NextFunction, Request, Response } from "express"; +import { HTTPError } from "."; + +const OPTIONAL_PREFIX = "$"; +const EMAIL_REGEX = + /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/; + +export function check(schema: any) { + return (req: Request, res: Response, next: NextFunction) => { + try { + const result = instanceOf(schema, req.body, { path: "body" }); + if (result === true) return next(); + throw result; + } catch (error) { + next(new HTTPError((error as any).toString(), 400)); + } + }; +} +export class Tuple { + public types: any[]; + constructor(...types: any[]) { + this.types = types; + } +} + +export class Email { + constructor(public email: string) {} + check() { + return !!this.email.match(EMAIL_REGEX); + } +} +export function instanceOf( + type: any, + value: any, + { path = "", optional = false }: { path?: string; optional?: boolean } = {} +): boolean { + if (!type) return true; // no type was specified + + if (value == null) { + if (optional) return true; + throw `${path} is required`; + } + + switch (type) { + case String: + if (typeof value === "string") return true; + throw `${path} must be a string`; + case Number: + value = Number(value); + if (typeof value === "number" && !isNaN(value)) return true; + throw `${path} must be a number`; + case BigInt: + try { + value = BigInt(value); + if (typeof value === "bigint") return true; + } catch (error) {} + throw `${path} must be a bigint`; + case Boolean: + if (value == "true") value = true; + if (value == "false") value = false; + if (typeof value === "boolean") return true; + throw `${path} must be a boolean`; + case Object: + if (typeof value === "object" && value !== null) return true; + throw `${path} must be a object`; + } + + if (typeof type === "object") { + if (Array.isArray(type)) { + if (!Array.isArray(value)) throw `${path} must be an array`; + if (!type.length) return true; // type array didn't specify any type + + return value.every((val, i) => instanceOf(type[0], val, { path: `${path}[${i}]`, optional })); + } + if (type?.constructor?.name != "Object") { + if (type instanceof Tuple) { + if ( + (type).types.some((x) => { + try { + return instanceOf(x, value, { path, optional }); + } catch (error) { + return false; + } + }) + ) { + return true; + } + throw `${path} must be one of ${type.types}`; + } + if (type instanceof Email) { + if ((type).check()) return true; + throw `${path} is not a valid E-Mail`; + } + if (value instanceof type) return true; + throw `${path} must be an instance of ${type}`; + } + if (typeof value !== "object") throw `${path} must be a object`; + + const diff = Object.keys(value).missing( + Object.keys(type).map((x) => (x.startsWith(OPTIONAL_PREFIX) ? x.slice(OPTIONAL_PREFIX.length) : x)) + ); + + if (diff.length) throw `Unkown key ${diff}`; + + return Object.keys(type).every((key) => { + let newKey = key; + const OPTIONAL = key.startsWith(OPTIONAL_PREFIX); + if (OPTIONAL) newKey = newKey.slice(OPTIONAL_PREFIX.length); + + return instanceOf(type[key], value[newKey], { + path: `${path}.${newKey}`, + optional: OPTIONAL, + }); + }); + } else if (typeof type === "number" || typeof type === "string" || typeof type === "boolean") { + if (value === type) return true; + throw `${path} must be ${value}`; + } else if (typeof type === "bigint") { + if (BigInt(value) === type) return true; + throw `${path} must be ${value}`; + } + + return type == value; +} diff --git a/util/src/util/imports/HTTPError.ts b/util/src/util/imports/HTTPError.ts new file mode 100644 index 000000000..56a7dd553 --- /dev/null +++ b/util/src/util/imports/HTTPError.ts @@ -0,0 +1,5 @@ +export class HTTPError extends Error { + constructor(message: string, public code: number = 400) { + super(message); + } +} \ No newline at end of file diff --git a/util/src/util/imports/index.ts b/util/src/util/imports/index.ts new file mode 100644 index 000000000..4a4448ba8 --- /dev/null +++ b/util/src/util/imports/index.ts @@ -0,0 +1,2 @@ +export * from './Checks'; +export * from './HTTPError'; diff --git a/util/src/util/index.ts b/util/src/util/index.ts index f7a273cb3..cfad53f3b 100644 --- a/util/src/util/index.ts +++ b/util/src/util/index.ts @@ -19,4 +19,6 @@ export * from "./Snowflake"; export * from "./String"; export * from "./Array"; export * from "./TraverseDirectory"; -export * from "./InvisibleCharacters"; \ No newline at end of file +export * from "./InvisibleCharacters"; + +export * from "./imports/index" diff --git a/util/tsconfig.json b/util/tsconfig.json index 0398ce9a7..a5d5ae05f 100644 --- a/util/tsconfig.json +++ b/util/tsconfig.json @@ -4,7 +4,7 @@ /* Visit https://aka.ms/tsconfig.json to read more about this file */ /* Basic Options */ - "incremental": true /* Enable incremental compilation */, + "incremental": false /* Enable incremental compilation */, "target": "ES6" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, "lib": ["ES2021"] /* Specify library files to be included in the compilation. */, From 1a916f3a9271c9dca05e561deeebf417e3832e56 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 5 Aug 2022 00:14:08 +0200 Subject: [PATCH 162/238] Do all minor updates since last commit, make another script --- bundle/package-lock.json | Bin 378759 -> 673527 bytes bundle/package.json | 52 ++++++++++++++++++++++++++++++------ cdn/package.json | 9 ++++--- cdn/src/util/FileStorage.ts | 4 +-- gateway/package.json | 2 +- package-lock.json | Bin 792479 -> 794061 bytes 6 files changed, 52 insertions(+), 15 deletions(-) diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 7a409df31c788ca17f64cd94ae3b3d483797fc58..c4058d817dd72dd32c41c1e56a0df0e25de7269d 100644 GIT binary patch delta 190335 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

=N6{RCHi9rz@ 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

+I@frBNu1pc|#_l=Gx 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%0A{L^pm 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 FzXNYk0}%iK delta 4206 zcmchaYm5`u8HQyqJGNPpg|ak+z{a~25@N!5Y|q#ZA>ixyei?gg&w#f0HtXxyUXSgu z%MuV#(kP^gIH;#mnm~Ras;X)MS9Jp^S){6>gcPW%ND&Q}(l%9ZB30C?7f5G!$u4Rt z6;)w>%#Zo?z2AGz`JVTC_muX~_q4}eeRPqY*o1+@kD~D0R^=!#%7@|BjmnKO9jK^{ zGF|tm`gK{Kb`t?C=oi7*=uhFTtx6R{HY=BQx2;VQ(7Q$P6x3cqlyG1Q`2y^2QH(|# zS)$P?Y7JG&WAnI^G$wj2aidc-L_H$T7x-gbRY&sr4WfP{6mQkQZV88O0EIC#wNFx2tD<;P6MtlJ4Q{ z-hQyTvf@N?oeb>Wu>#!8^}}QDArHc1M#Ul!swu&@N<(n!EV88c+F9f^8Bp&X0mIL3 z1nJDkU9B8DhYZcMLK9r7Q1fMCtkYO-l2unBp1_%U&FVnSW`DjE5J=itYBe|m>gCH! z+hC4igoUt|1U_TXyBdTmMv5L&I_Wa=wxT-|sOlLu-3@1Leg9kMwE6?-0l4HM@`E{{ z8;bKnSI^pQH)hs8%9nG1i>P4ue^v zbu3=-Iwwqm-DN=YG+nbLGNwSof|U$ZzQw~g-s>L$7oT4Om!3fsKu(u)6gVI1~*yqnt(BgCxGnR8^E^C z^RpLa=k_7+_P)XHtl{Q zXlq<2snax#S}s`46`I;+XWSkzCQ>{`=9zFTC0g?h(H|*s;F6 z(HN5k%;xb6^(Nt>+y#pn!*HA_YB4?4^wSwq=kP}=`gGM-L&N2$2Xl}ugSBmE>$uBT zO<0mt#pl+fEV@c_B2R{S5YDbUAT9#i#ss`KrM1?$XtWVz&Sjk_gy=?O+|N@MgPRwbd_6(<-DDkayInaL6|c1kJ6|}*9ey`87}JxEGtHdJR9}rIl3Kj2nLeEy$Ms6 zX)_v|!5;~PYLT3|5^#r%LPtmXywQ>~nYX6K*?`D#6-sZ5QKTkaDnQxa`&PlJrhEV_ zQLB1CYsqgc>*-#S|3U?ie7qQin{Ox|f@`0at7*ECb?_9)5RGa+(j@B<#;?=GD@iPp zjWmiiMyQQ5aRXT}jk}sD4!2Ud97EMOeKBlGMrelNxM+~g6On8%7T0Bi2|=5yhNewX z!y7l0lfAL8%d6L*`sV`}{G{183{RK`M(LWDP1l{)i9k)`wotJN1{E@Pmrl@l>WQW_ z7wlE8-e`skv2n)YjFr;ya50j})4sIGvesOc_eJq>4mBG?guny~iJ+ritb1lo0$zMp zj`U8o`aW6?53ZD>Fmzn?2s}6XYW zX_@hbOZ)qzZ&B~k{{9_RQ2QGSciie9hI@b2r=}a4B4%!CCZeLXKr$kqrosiX$ucdb z>BwjsA-!GGaCx(6-4M58*+c|qTUE9mEm<457>O7z$Eo%#@yK zySMaq|C?v-Lf;(4rStv#DQ3yWT zXr5U2nd$JjO0n)UP?yMgWLn*NiRTKq>l(6RPS8RS-g0K~8o2F!M0HP$zoYc(wWWgNN4LpQGfakNhdkWe0c2>WGj66Ekp^% zFZ{AM_Jra~0}F-!3V{9@LBQn> Date: Fri, 5 Aug 2022 00:55:26 +0200 Subject: [PATCH 163/238] Fix ESM error caused by file-type --- bundle/package-lock.json | Bin 673527 -> 673261 bytes bundle/package.json | 2 +- cdn/package.json | 2 +- cdn/src/routes/attachments.ts | 2 +- cdn/src/routes/avatars.ts | 6 +++--- cdn/src/routes/external.ts | 2 +- cdn/src/routes/role-icons.ts | 6 +++--- package-lock.json | Bin 794061 -> 793798 bytes 8 files changed, 10 insertions(+), 10 deletions(-) diff --git a/bundle/package-lock.json b/bundle/package-lock.json index c4058d817dd72dd32c41c1e56a0df0e25de7269d..14f05bcc18fb322596c1d748b7159d54e934cd61 100644 GIT binary patch delta 1220 zcmciAO=#0#7zc3HB-)HII}xX%_G>bxv&qu5Tjs?!X`6nmYu2WnJq)*greA4I+O88t z@lZtu%FyQ^!cGb@Vc;QnQuHW-pht%yh$8rP@?$Wpy9naNgTC+_-uHbDfByWwEDpWD zIJ6o=&=IH20fra2_0DPJLeJ*)T(6i`ZpQsnpfheDr z*^)%Zb3!PSF9g)4;I7olN-(t~*i3MoLk8g8L!@U=m5X-ExXCi(v{5$NGTe=Kj-~UO zsT@{Y)r_+FNyAYTIRqcipyS{-AwBJw2hn04bR!Ed{fHeFSJ3@nuIdNGq~9K@G{uIa zGU=NW7C0tFNu1BA%K1!vI+~0)GD?(p7v!ok&C}`J2&2gLY@;grT=u%0mmISduj-ql zN_kg2%`foIDZR(xEGuP6NuA6x&O#}$i8>3EO&A5%-RSVoGK{~Xz{)Vz4Y$_tSMcby zZl_kVV9(6(1jSIuZRiL%$zglo{)TQqbk@^uiWWxgqasH{IVI@g{fw8Lij2BzDTX5^ z1TjuhlT$*@At}Xz8VZz>fp9uZ7lUdltv1a3;94 zj`xG?!Hn?fD`NhYus!I-v_bEd?{7B=F7+DTw6~F4wQZ#S!T6v2#r}mq_T=r6Q~14^|HZ3@bc&JJaWgEMusg-0&mQoP!QE{Wk2P>S(AAODn9V>VUc_sPzGyyI>{2 zv~GvNGzWECe86FWc1hF(UX4joI;gQ+wjlFIsSp$6;uG0etjJO9n8pmH-HGz#*kB~e zM%Zx7AVoDJb9{jCXA`oaRAdS-CDLA2^Sje$NkI!tYR!2U3hv%S5D

vm%YQEY(n z5FRhKZynM)*l4XL>Y7_WsUWU5>%i;SDsC4=UD1W~~?JjI2^()C)>&ER@i&?Zy4B0d_Y@r+7y zlVmdJO%=ty;bKN&LiO}`HX82>45cf;c?;hC>$zRv^jw@qKDVHi4r<;|NPO#VmQ(bKgco=Z~ zjm5Pl{L5>Ytu=P+YDc{}|B?W69K3Y}=(DbMm^dooZ diff --git a/bundle/package.json b/bundle/package.json index 6d0b58656..e574af3d0 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -69,7 +69,7 @@ "dotenv": "^16.0.1", "exif-be-gone": "^1.3.0", "express": "^4.17.1", - "file-type": "^17.1.4", + "file-type": "16.5", "form-data": "^4.0.0", "i18next": "^21.8.14", "i18next-http-middleware": "^3.1.3", diff --git a/cdn/package.json b/cdn/package.json index 541f5ee2b..4ee0be6a8 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -36,7 +36,7 @@ "dotenv": "^16.0.1", "exif-be-gone": "^1.3.0", "express": "^4.17.1", - "file-type": "^17.1.4", + "file-type": "16.5", "image-size": "^1.0.0", "jest": "^28.1.3", "lambert-server": "^1.2.12", diff --git a/cdn/src/routes/attachments.ts b/cdn/src/routes/attachments.ts index 3e04fe76a..723a6c03c 100644 --- a/cdn/src/routes/attachments.ts +++ b/cdn/src/routes/attachments.ts @@ -68,7 +68,7 @@ router.get( `attachments/${channel_id}/${id}/${filename}` ); if (!file) throw new HTTPError("File not found"); - const type = await FileType.fileTypeFromBuffer(file); + const type = await FileType.fromBuffer(file); let content_type = type?.mime || "application/octet-stream"; if (SANITIZED_CONTENT_TYPE.includes(content_type)) { diff --git a/cdn/src/routes/avatars.ts b/cdn/src/routes/avatars.ts index bbdf42cc7..40705b2e8 100644 --- a/cdn/src/routes/avatars.ts +++ b/cdn/src/routes/avatars.ts @@ -38,7 +38,7 @@ router.post( .update(Snowflake.generate()) .digest("hex"); - const type = await FileType.fileTypeFromBuffer(buffer); + const type = await FileType.fromBuffer(buffer); if (!type || !ALLOWED_MIME_TYPES.includes(type.mime)) throw new HTTPError("Invalid file type"); if (ANIMATED_MIME_TYPES.includes(type.mime)) hash = `a_${hash}`; // animated icons have a_ infront of the hash @@ -65,7 +65,7 @@ router.get("/:user_id", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fileTypeFromBuffer(file); + const type = await FileType.fromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000"); @@ -80,7 +80,7 @@ router.get("/:user_id/:hash", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fileTypeFromBuffer(file); + const type = await FileType.fromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000"); diff --git a/cdn/src/routes/external.ts b/cdn/src/routes/external.ts index cf02f645b..c9441fc23 100644 --- a/cdn/src/routes/external.ts +++ b/cdn/src/routes/external.ts @@ -48,7 +48,7 @@ router.get("/:id", async (req: Request, res: Response) => { const file = await storage.get(`/external/${id}`); if (!file) throw new HTTPError("File not found"); - const result = await FileType.fileTypeFromBuffer(file); + const result = await FileType.fromBuffer(file); res.set("Content-Type", result?.mime); diff --git a/cdn/src/routes/role-icons.ts b/cdn/src/routes/role-icons.ts index dd96c90e6..2e5c42dd6 100644 --- a/cdn/src/routes/role-icons.ts +++ b/cdn/src/routes/role-icons.ts @@ -38,7 +38,7 @@ router.post( .update(Snowflake.generate()) .digest("hex"); - const type = await FileType.fileTypeFromBuffer(buffer); + const type = await FileType.fromBuffer(buffer); if (!type || !ALLOWED_MIME_TYPES.includes(type.mime)) throw new HTTPError("Invalid file type"); @@ -64,7 +64,7 @@ router.get("/:role_id", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fileTypeFromBuffer(file); + const type = await FileType.fromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000, must-revalidate"); @@ -79,7 +79,7 @@ router.get("/:role_id/:hash", async (req: Request, res: Response) => { const file = await storage.get(path); if (!file) throw new HTTPError("not found", 404); - const type = await FileType.fileTypeFromBuffer(file); + const type = await FileType.fromBuffer(file); res.set("Content-Type", type?.mime); res.set("Cache-Control", "public, max-age=31536000, must-revalidate"); diff --git a/package-lock.json b/package-lock.json index b37fec3e84b03107140db4d3cde26a42c039a8a9..48f8206d6dd579df9a23e2383db6bebe965f0471 100644 GIT binary patch delta 1133 zcmciAJ7^OD9LI4kmy0>0(4t_iTGBV7ZLZ1X+MDdK?lVlTPJaof;j1DHFR+iH#_{6|Mcb0=i@8l-67F_YShk9 z)7FiBV{_k#^rlhwjVL0ay(2K|8Ulg`_!WeLhjDyVFg0APkBGT*E@#H!%{hHRq8zc8 z^K#G?%+?y|TB@2hmBV$>PbdW^$!Hanv4mUga1&o?DPm|EyMh6fQ+9TL4==+Y)&D9-LUER?hAH(i| zMhm-ps0p%n3`5Y}L&t=u$HEnBLe*Lfxa0hqgHD)5hnrGL*;HjY6b)Kaa)`C%N@aPO zC6k#MS}s-6)w1AbER|ALw8n}q#T_^2vrIV2uCdgj$yu!e^FuQZpFuMOCl64)`nZm5 zZi4gyBjMgptRJCT{o|uTI;zC8O4UPq$ho>B)Tkv*a;e~7$p~!T%$XCiQdqXz#WW!* zfiz9!QjwXt1zV`G%2oVg;w~SSs^vgkiYn4tB_}R*LcgRLfvatUx%UL*K;u0v zfL_58yfo-A_0liw(*!(WPz&6i&<(=8f{zJQC22F0{H$eGaF{|4*~hRR+GSr1&e~QI zw8ON(3t_?>SmZNSQI>KF=gmjG{-mFjd`cpz)aa=!tn%Y&5w delta 1532 zcmchX&1=(O9LMR}bjzY1L}5(F(&{F%EicWRRW?oAG+o=RscX_T$S}HgYq~aV*VkeT=y2D@-4$1J#bvXs!(4IMdv&`d0NNHT+Bguu=R74-HM|^_ zWyzIp*lq*J#a-T=tGaN=>#E7;~oYye# z4}rCtE{s$f#q{EVi1{f3w$F|;VC!^;}Fui@$nPDmk`ML{S}~z2nnv%pgyGa+E;m}OD=|u`5;~i)D)^vDI}O7AtxKOz!5|V z*YTJ?P?hSHi6I8h1x39P)3W$tgvOI;+TS22e4bb~5nsqAWhPLUZluN|aeh`R@!-*} z7q^-FX=csc02Vm_!t#4^$nmi0$_1laom9c^6%_Xlh)Sv;4l>%O3#P&uw* zD8j-GGRx&C-9J5<^Z7_RsAwwAM#p104Nr;&9o3lWP_!&_g>+Df&PJ|H3sY)__N8?t zqE?x_7Rwvg*W;@$aCQ@++Ts%*vwaWypEv>f5hnzyo5+XtmChdX&R6K&KwA!W19k$y zJ4kQa8*h6$T(YnzdgVHwq$gN~Pm~2gpO=D(h#+UlST8g)n zb41Z{p9-l{`Q&9IlqcgEb*?-|r3p`_SmG;82HdaN-Qf8S!hzd^&i+5iM$^iMWu4~B z!7dln##7Vc$wY_YvE^SGO8g6kz%F#C58%Bp43dwbqtXEqlvU+_1t`n|$SwF-b7LDe zH@3T Date: Fri, 5 Aug 2022 23:41:45 +0200 Subject: [PATCH 164/238] migrate to DataSource --- util/src/util/Database.ts | 60 +++++++++++++-------------- util/src/util/Database.ts.torm2 | 72 +++++++++++++++++++++++++++++++++ 2 files changed, 102 insertions(+), 30 deletions(-) create mode 100644 util/src/util/Database.ts.torm2 diff --git a/util/src/util/Database.ts b/util/src/util/Database.ts index f0540bdfd..31a305615 100644 --- a/util/src/util/Database.ts +++ b/util/src/util/Database.ts @@ -1,6 +1,6 @@ import path from "path"; import "reflect-metadata"; -import { Connection, createConnection } from "typeorm"; +import { DataSource, createConnection } from "typeorm"; import * as Models from "../entities"; import { Migration } from "../entities/Migration"; import { yellow, green, red } from "picocolors"; @@ -9,21 +9,24 @@ import { yellow, green, red } from "picocolors"; // We want to generate all id's with Snowflakes that's why we have our own BaseEntity class let promise: Promise; -let dbConnection: Connection | undefined; +let dataSource: DataSource | undefined; let dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); +let verbose_db = false; -export function initDatabase(): Promise { - if (promise) return promise; // prevent initalizing multiple times +export async function initDatabase(): Promise { + if (dataSource) return dataSource; // prevent initalizing multiple times - const type = dbConnectionString.includes("://") ? dbConnectionString.split(":")[0]?.replace("+srv", "") : "sqlite"; + const type = dbConnectionString.includes("://") ? dbConnectionString.split(":")[0]?.replace("+srv", "") : "sqlite" as any; const isSqlite = type.includes("sqlite"); + if(process.env.DB_VERBOSE) verbose_db = true; console.log(`[Database] ${yellow(`connecting to ${type} db`)}`); - if(isSqlite) { + if(isSqlite) console.log(`[Database] ${red(`You are running sqlite! Please keep in mind that we recommend setting up a dedicated database!`)}`); - } + if(verbose_db) + console.log(`[Database] ${red(`Verbose database logging is enabled, this might impact performance! Unset VERBOSE_DB to disable.`)}`); // @ts-ignore - promise = createConnection({ + dataSource = new DataSource({ type, charset: 'utf8mb4', url: isSqlite ? undefined : dbConnectionString, @@ -31,7 +34,7 @@ export function initDatabase(): Promise { // @ts-ignore entities: Object.values(Models).filter((x) => x.constructor.name !== "Object" && x.name), synchronize: type !== "mongodb", - logging: false, + logging: verbose_db, cache: { duration: 1000 * 3, // cache all find queries for 3 seconds }, @@ -40,33 +43,30 @@ export function initDatabase(): Promise { name: "default", migrations: [path.join(__dirname, "..", "migrations", "*.js")], }); + promise = dataSource.initialize(); + await promise; + // run migrations, and if it is a new fresh database, set it to the last migration + if (dataSource.migrations.length) { + if (!(await Migration.findOne({}))) { + let i = 0; - promise.then(async (connection: Connection) => { - dbConnection = connection; - - // run migrations, and if it is a new fresh database, set it to the last migration - if (connection.migrations.length) { - if (!(await Migration.findOne({}))) { - let i = 0; - - await Migration.insert( - connection.migrations.map((x) => ({ - id: i++, - name: x.name, - timestamp: Date.now(), - })) - ); - } + await Migration.insert( + dataSource.migrations.map((x) => ({ + id: i++, + name: x.name, + timestamp: Date.now(), + })) + ); } - await connection.runMigrations(); - console.log(`[Database] ${green("connected")}`); - }); + } + await dataSource.runMigrations(); + console.log(`[Database] ${green("connected")}`); return promise; } -export { dbConnection }; +export { dataSource }; export function closeDatabase() { - dbConnection?.close(); + dataSource?.destroy(); } diff --git a/util/src/util/Database.ts.torm2 b/util/src/util/Database.ts.torm2 new file mode 100644 index 000000000..f0540bdfd --- /dev/null +++ b/util/src/util/Database.ts.torm2 @@ -0,0 +1,72 @@ +import path from "path"; +import "reflect-metadata"; +import { Connection, createConnection } from "typeorm"; +import * as Models from "../entities"; +import { Migration } from "../entities/Migration"; +import { yellow, green, red } from "picocolors"; + +// UUID extension option is only supported with postgres +// We want to generate all id's with Snowflakes that's why we have our own BaseEntity class + +let promise: Promise; +let dbConnection: Connection | undefined; +let dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); + +export function initDatabase(): Promise { + if (promise) return promise; // prevent initalizing multiple times + + const type = dbConnectionString.includes("://") ? dbConnectionString.split(":")[0]?.replace("+srv", "") : "sqlite"; + const isSqlite = type.includes("sqlite"); + + console.log(`[Database] ${yellow(`connecting to ${type} db`)}`); + if(isSqlite) { + console.log(`[Database] ${red(`You are running sqlite! Please keep in mind that we recommend setting up a dedicated database!`)}`); + } + // @ts-ignore + promise = createConnection({ + type, + charset: 'utf8mb4', + url: isSqlite ? undefined : dbConnectionString, + database: isSqlite ? dbConnectionString : undefined, + // @ts-ignore + entities: Object.values(Models).filter((x) => x.constructor.name !== "Object" && x.name), + synchronize: type !== "mongodb", + logging: false, + cache: { + duration: 1000 * 3, // cache all find queries for 3 seconds + }, + bigNumberStrings: false, + supportBigNumbers: true, + name: "default", + migrations: [path.join(__dirname, "..", "migrations", "*.js")], + }); + + promise.then(async (connection: Connection) => { + dbConnection = connection; + + // run migrations, and if it is a new fresh database, set it to the last migration + if (connection.migrations.length) { + if (!(await Migration.findOne({}))) { + let i = 0; + + await Migration.insert( + connection.migrations.map((x) => ({ + id: i++, + name: x.name, + timestamp: Date.now(), + })) + ); + } + } + await connection.runMigrations(); + console.log(`[Database] ${green("connected")}`); + }); + + return promise; +} + +export { dbConnection }; + +export function closeDatabase() { + dbConnection?.close(); +} From cba3844c6f7a6b26c93d8061da0ca7fe6b291e92 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 6 Aug 2022 18:25:30 +0200 Subject: [PATCH 165/238] Resolve changes undone by rebasing from master --- api/src/routes/auth/mfa/totp.ts | 2 +- api/src/routes/auth/register.ts | 2 +- api/src/routes/channels/#channel_id/index.ts | 6 +++--- .../routes/channels/#channel_id/invites.ts | 4 ++-- .../#channel_id/messages/#message_id/ack.ts | 4 ++-- .../#channel_id/messages/#message_id/index.ts | 4 ++-- .../messages/#message_id/reactions.ts | 18 +++++++++--------- .../channels/#channel_id/messages/index.ts | 2 +- .../channels/#channel_id/permissions.ts | 6 +++--- api/src/routes/channels/#channel_id/pins.ts | 10 +++++----- .../routes/channels/#channel_id/recipients.ts | 2 +- api/src/routes/channels/#channel_id/typing.ts | 2 +- .../routes/channels/#channel_id/webhooks.ts | 4 ++-- api/src/routes/downloads.ts | 2 +- api/src/routes/guild-recommendations.ts | 2 +- api/src/routes/guilds/#guild_id/bans.ts | 6 +++--- api/src/routes/guilds/#guild_id/channels.ts | 4 ++-- api/src/routes/guilds/#guild_id/emojis.ts | 10 +++++----- api/src/routes/guilds/#guild_id/index.ts | 4 ++-- .../#guild_id/members/#member_id/index.ts | 4 ++-- api/src/routes/guilds/#guild_id/prune.ts | 2 +- api/src/routes/guilds/#guild_id/regions.ts | 2 +- .../guilds/#guild_id/roles/#role_id/index.ts | 2 +- .../routes/guilds/#guild_id/roles/index.ts | 4 ++-- api/src/routes/guilds/#guild_id/stickers.ts | 6 +++--- api/src/routes/guilds/#guild_id/templates.ts | 2 +- api/src/routes/guilds/#guild_id/vanity-url.ts | 10 +++++----- .../#guild_id/voice-states/#user_id/index.ts | 10 ++++++---- .../routes/guilds/#guild_id/welcome_screen.ts | 4 ++-- .../routes/guilds/#guild_id/widget.json.ts | 4 ++-- api/src/routes/guilds/#guild_id/widget.png.ts | 2 +- api/src/routes/guilds/#guild_id/widget.ts | 2 +- api/src/routes/guilds/index.ts | 2 +- api/src/routes/guilds/templates/index.ts | 6 +++--- api/src/routes/invites/index.ts | 8 ++++---- api/src/routes/stickers/#sticker_id/index.ts | 2 +- api/src/routes/updates.ts | 2 +- api/src/routes/users/@me/mfa/codes.ts | 12 +++++++----- api/src/routes/users/@me/mfa/totp/disable.ts | 4 ++-- api/src/routes/users/@me/notes.ts | 2 +- api/src/routes/users/@me/relationships.ts | 15 ++++++++------- api/src/routes/users/@me/settings.ts | 2 +- api/src/util/handlers/Message.ts | 8 ++++---- bundle/package-lock.json | Bin 673261 -> 660681 bytes bundle/package.json | 1 + gateway/src/listener/listener.ts | 4 ++-- gateway/src/opcodes/Identify.ts | 4 ++-- gateway/src/opcodes/LazyRequest.ts | 2 +- gateway/src/opcodes/VoiceStateUpdate.ts | 2 +- util/package-lock.json | Bin 467541 -> 460763 bytes util/src/entities/Channel.ts | 4 ++-- util/src/entities/Invite.ts | 2 +- util/src/entities/Member.ts | 8 ++++---- util/src/entities/Message.ts | 1 - util/src/util/Token.ts | 8 ++++---- 55 files changed, 126 insertions(+), 121 deletions(-) diff --git a/api/src/routes/auth/mfa/totp.ts b/api/src/routes/auth/mfa/totp.ts index cec6e5ee6..255cf8893 100644 --- a/api/src/routes/auth/mfa/totp.ts +++ b/api/src/routes/auth/mfa/totp.ts @@ -26,7 +26,7 @@ router.post("/", route({ body: "TotpSchema" }), async (req: Request, res: Respon ], }); - const backup = await BackupCode.findOne({ code: code, expired: false, consumed: false, user: { id: user.id }}); + const backup = await BackupCode.findOne({ where: { code: code, expired: false, consumed: false, user: { id: user.id } } }); if (!backup) { const ret = verifyToken(user.totp_secret!, code); diff --git a/api/src/routes/auth/register.ts b/api/src/routes/auth/register.ts index 9816c5fd1..2902c8dd8 100644 --- a/api/src/routes/auth/register.ts +++ b/api/src/routes/auth/register.ts @@ -107,7 +107,7 @@ router.post("/", route({ body: "RegisterSchema" }), async (req: Request, res: Re } // check if there is already an account with this email - const exists = await User.findOne({ email: email }); + const exists = await User.findOne({ where: { email: email } }); if (exists) { throw FieldErrors({ diff --git a/api/src/routes/channels/#channel_id/index.ts b/api/src/routes/channels/#channel_id/index.ts index f6f130173..a49081efb 100644 --- a/api/src/routes/channels/#channel_id/index.ts +++ b/api/src/routes/channels/#channel_id/index.ts @@ -18,7 +18,7 @@ const router: Router = Router(); router.get("/", route({ permission: "VIEW_CHANNEL" }), async (req: Request, res: Response) => { const { channel_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); return res.send(channel); }); @@ -29,7 +29,7 @@ router.delete("/", route({ permission: "MANAGE_CHANNELS" }), async (req: Request const channel = await Channel.findOneOrFail({ where: { id: channel_id }, relations: ["recipients"] }); if (channel.type === ChannelType.DM) { - const recipient = await Recipient.findOneOrFail({ where: { channel_id: channel_id, user_id: req.user_id } }); + const recipient = await Recipient.findOneOrFail({ where: { channel_id, user_id: req.user_id } }); recipient.closed = true; await Promise.all([ recipient.save(), @@ -77,7 +77,7 @@ router.patch("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANN const { channel_id } = req.params; if (payload.icon) payload.icon = await handleFile(`/channel-icons/${channel_id}`, payload.icon); - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); channel.assign(payload); await Promise.all([ diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index 788f7d6de..5fef136d5 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -47,7 +47,7 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT }).save(); const data = invite.toJSON(); data.inviter = await User.getPublicUser(req.user_id); - data.guild = await Guild.findOne({ id: guild_id }); + data.guild = await Guild.findOne({ where: { id: guild_id } }); data.channel = channel; await emitEvent({ event: "INVITE_CREATE", data, guild_id } as InviteCreateEvent); @@ -57,7 +57,7 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT router.get("/", route({ permission: "MANAGE_CHANNELS" }), async (req: Request, res: Response) => { const { user_id } = req; const { channel_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); if (!channel.guild_id) { throw new HTTPError("This channel doesn't exist", 404); diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts index 885c5eca7..c14addbe9 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts @@ -19,8 +19,8 @@ router.post("/", route({ body: "MessageAcknowledgeSchema" }), async (req: Reques const permission = await getPermission(req.user_id, undefined, channel_id); permission.hasThrow("VIEW_CHANNEL"); - let read_state = await ReadState.findOne({ user_id: req.user_id, channel_id }); - if (!read_state) read_state = new ReadState({ user_id: req.user_id, channel_id }); + let read_state = await ReadState.findOne({ where: { user_id: req.user_id, channel_id } }); + if (!read_state) read_state = new ReadState({ where: { user_id: req.user_id, channel_id } }); read_state.last_message_id = message_id; await read_state.save(); diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index 0b228ed66..b3b310d3f 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -169,8 +169,8 @@ router.get("/", route({ permission: "VIEW_CHANNEL" }), async (req: Request, res: router.delete("/", route({}), async (req: Request, res: Response) => { const { message_id, channel_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); - const message = await Message.findOneOrFail({ id: message_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); + const message = await Message.findOneOrFail({ where: { id: message_id } }); const rights = await getRights(req.user_id); diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts b/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts index f56f18d30..d0ab35bb4 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts @@ -39,7 +39,7 @@ function getEmoji(emoji: string): PartialEmoji { router.delete("/", route({ permission: "MANAGE_MESSAGES" }), async (req: Request, res: Response) => { const { message_id, channel_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); await Message.update({ id: message_id, channel_id }, { reactions: [] }); @@ -60,7 +60,7 @@ router.delete("/:emoji", route({ permission: "MANAGE_MESSAGES" }), async (req: R const { message_id, channel_id } = req.params; const emoji = getEmoji(req.params.emoji); - const message = await Message.findOneOrFail({ id: message_id, channel_id }); + const message = await Message.findOneOrFail({ where: { id: message_id, channel_id } }); const already_added = message.reactions.find((x) => (x.emoji.id === emoji.id && emoji.id) || x.emoji.name === emoji.name); if (!already_added) throw new HTTPError("Reaction not found", 404); @@ -87,7 +87,7 @@ router.get("/:emoji", route({ permission: "VIEW_CHANNEL" }), async (req: Request const { message_id, channel_id } = req.params; const emoji = getEmoji(req.params.emoji); - const message = await Message.findOneOrFail({ id: message_id, channel_id }); + const message = await Message.findOneOrFail({ where: { id: message_id, channel_id } }); const reaction = message.reactions.find((x) => (x.emoji.id === emoji.id && emoji.id) || x.emoji.name === emoji.name); if (!reaction) throw new HTTPError("Reaction not found", 404); @@ -106,14 +106,14 @@ router.put("/:emoji/:user_id", route({ permission: "READ_MESSAGE_HISTORY", right if (user_id !== "@me") throw new HTTPError("Invalid user"); const emoji = getEmoji(req.params.emoji); - const channel = await Channel.findOneOrFail({ id: channel_id }); - const message = await Message.findOneOrFail({ id: message_id, channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); + const message = await Message.findOneOrFail({ where: { id: message_id, channel_id } }); const already_added = message.reactions.find((x) => (x.emoji.id === emoji.id && emoji.id) || x.emoji.name === emoji.name); if (!already_added) req.permission!.hasThrow("ADD_REACTIONS"); if (emoji.id) { - const external_emoji = await Emoji.findOneOrFail({ id: emoji.id }); + const external_emoji = await Emoji.findOneOrFail({ where: { id: emoji.id } }); if (!already_added) req.permission!.hasThrow("USE_EXTERNAL_EMOJIS"); emoji.animated = external_emoji.animated; emoji.name = external_emoji.name; @@ -126,7 +126,7 @@ router.put("/:emoji/:user_id", route({ permission: "READ_MESSAGE_HISTORY", right await message.save(); - const member = channel.guild_id && (await Member.findOneOrFail({ id: req.user_id })); + const member = channel.guild_id && (await Member.findOneOrFail({ where: { id: req.user_id } })); await emitEvent({ event: "MESSAGE_REACTION_ADD", @@ -149,8 +149,8 @@ router.delete("/:emoji/:user_id", route({}), async (req: Request, res: Response) const emoji = getEmoji(req.params.emoji); - const channel = await Channel.findOneOrFail({ id: channel_id }); - const message = await Message.findOneOrFail({ id: message_id, channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); + const message = await Message.findOneOrFail({ where: { id: message_id, channel_id } }); if (user_id === "@me") user_id = req.user_id; else { diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index f8e62d8ce..2fce704b7 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -85,7 +85,7 @@ export interface MessageCreateSchema { // get messages router.get("/", async (req: Request, res: Response) => { const channel_id = req.params.channel_id; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); if (!channel) throw new HTTPError("Channel not found", 404); isTextChannel(channel.type); diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/api/src/routes/channels/#channel_id/permissions.ts index 798f7c8da..06a124bb7 100644 --- a/api/src/routes/channels/#channel_id/permissions.ts +++ b/api/src/routes/channels/#channel_id/permissions.ts @@ -29,9 +29,9 @@ router.put( if (!channel.guild_id) throw new HTTPError("Channel not found", 404); if (body.type === 0) { - if (!(await Role.count({ id: overwrite_id }))) throw new HTTPError("role not found", 404); + if (!(await Role.count({ where: { id: overwrite_id } }))) throw new HTTPError("role not found", 404); } else if (body.type === 1) { - if (!(await Member.count({ id: overwrite_id }))) throw new HTTPError("user not found", 404); + if (!(await Member.count({ where: { id: overwrite_id } }))) throw new HTTPError("user not found", 404); } else throw new HTTPError("type not supported", 501); // @ts-ignore @@ -64,7 +64,7 @@ router.put( router.delete("/:overwrite_id", route({ permission: "MANAGE_ROLES" }), async (req: Request, res: Response) => { const { channel_id, overwrite_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); if (!channel.guild_id) throw new HTTPError("Channel not found", 404); channel.permission_overwrites = channel.permission_overwrites!.filter((x) => x.id === overwrite_id); diff --git a/api/src/routes/channels/#channel_id/pins.ts b/api/src/routes/channels/#channel_id/pins.ts index 5c314f092..003638c57 100644 --- a/api/src/routes/channels/#channel_id/pins.ts +++ b/api/src/routes/channels/#channel_id/pins.ts @@ -17,12 +17,12 @@ const router: Router = Router(); router.put("/:message_id", route({ permission: "VIEW_CHANNEL" }), async (req: Request, res: Response) => { const { channel_id, message_id } = req.params; - const message = await Message.findOneOrFail({ id: message_id }); + const message = await Message.findOneOrFail({ where: { id: message_id } }); // * in dm channels anyone can pin messages -> only check for guilds if (message.guild_id) req.permission!.hasThrow("MANAGE_MESSAGES"); - const pinned_count = await Message.count({ channel: { id: channel_id }, pinned: true }); + const pinned_count = await Message.count({ where: { channel: { id: channel_id }, pinned: true } }); const { maxPins } = Config.get().limits.channel; if (pinned_count >= maxPins) throw DiscordApiErrors.MAXIMUM_PINS.withParams(maxPins); @@ -50,10 +50,10 @@ router.put("/:message_id", route({ permission: "VIEW_CHANNEL" }), async (req: Re router.delete("/:message_id", route({ permission: "VIEW_CHANNEL" }), async (req: Request, res: Response) => { const { channel_id, message_id } = req.params; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); if (channel.guild_id) req.permission!.hasThrow("MANAGE_MESSAGES"); - const message = await Message.findOneOrFail({ id: message_id }); + const message = await Message.findOneOrFail({ where: { id: message_id } }); message.pinned = false; await Promise.all([ @@ -82,7 +82,7 @@ router.delete("/:message_id", route({ permission: "VIEW_CHANNEL" }), async (req: router.get("/", route({ permission: ["READ_MESSAGE_HISTORY"] }), async (req: Request, res: Response) => { const { channel_id } = req.params; - let pins = await Message.find({ channel_id: channel_id, pinned: true }); + let pins = await Message.find({ where: { channel_id, pinned: true } }); res.send(pins); }); diff --git a/api/src/routes/channels/#channel_id/recipients.ts b/api/src/routes/channels/#channel_id/recipients.ts index e64662110..28d5607d4 100644 --- a/api/src/routes/channels/#channel_id/recipients.ts +++ b/api/src/routes/channels/#channel_id/recipients.ts @@ -28,7 +28,7 @@ router.put("/:user_id", route({}), async (req: Request, res: Response) => { throw DiscordApiErrors.INVALID_RECIPIENT; //TODO is this the right error? } - channel.recipients!.push(new Recipient({ channel_id: channel_id, user_id: user_id })); + channel.recipients!.push(new Recipient({ channel_id, user_id: user_id })); await channel.save(); await emitEvent({ diff --git a/api/src/routes/channels/#channel_id/typing.ts b/api/src/routes/channels/#channel_id/typing.ts index 56652368a..99460f6e3 100644 --- a/api/src/routes/channels/#channel_id/typing.ts +++ b/api/src/routes/channels/#channel_id/typing.ts @@ -8,7 +8,7 @@ router.post("/", route({ permission: "SEND_MESSAGES" }), async (req: Request, re const { channel_id } = req.params; const user_id = req.user_id; const timestamp = Date.now(); - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); const member = await Member.findOne({ where: { id: user_id, guild_id: channel.guild_id }, relations: ["roles", "user"] }); await emitEvent({ diff --git a/api/src/routes/channels/#channel_id/webhooks.ts b/api/src/routes/channels/#channel_id/webhooks.ts index 52f7ef7d5..8f0e0a7fb 100644 --- a/api/src/routes/channels/#channel_id/webhooks.ts +++ b/api/src/routes/channels/#channel_id/webhooks.ts @@ -22,12 +22,12 @@ router.get("/", route({}), async (req: Request, res: Response) => { // TODO: use Image Data Type for avatar instead of String router.post("/", route({ body: "WebhookCreateSchema", permission: "MANAGE_WEBHOOKS" }), async (req: Request, res: Response) => { const channel_id = req.params.channel_id; - const channel = await Channel.findOneOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); isTextChannel(channel.type); if (!channel.guild_id) throw new HTTPError("Not a guild channel", 400); - const webhook_count = await Webhook.count({ channel_id }); + const webhook_count = await Webhook.count({ where: { channel_id } }); const { maxWebhooks } = Config.get().limits.channel; if (webhook_count > maxWebhooks) throw DiscordApiErrors.MAXIMUM_WEBHOOKS.withParams(maxWebhooks); diff --git a/api/src/routes/downloads.ts b/api/src/routes/downloads.ts index 03c73f440..445303536 100644 --- a/api/src/routes/downloads.ts +++ b/api/src/routes/downloads.ts @@ -12,7 +12,7 @@ router.get("/:branch", route({}), async (req: Request, res: Response) => { if(!platform || !["linux", "osx", "win"].includes(platform.toString())) return res.status(404) - const release = await Release.findOneOrFail({ name: client.releases.upstreamVersion }); + const release = await Release.findOneOrFail({ where: { name: client.releases.upstreamVersion } }); res.redirect(release[`win_url`]); }); diff --git a/api/src/routes/guild-recommendations.ts b/api/src/routes/guild-recommendations.ts index ee2c26f1b..bd0140d62 100644 --- a/api/src/routes/guild-recommendations.ts +++ b/api/src/routes/guild-recommendations.ts @@ -17,7 +17,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { const guilds = showAllGuilds ? await Guild.find({ take: Math.abs(Number(limit || 24)) }) - : await Guild.find({ where: `"features" LIKE '%DISCOVERABLE%'`, take: Math.abs(Number(limit || 24)) }); + : await Guild.find({ where: { features: Like('%DISCOVERABLE%') }, take: Math.abs(Number(limit || 24)) }); res.send({ recommended_guilds: guilds, load_id: `server_recs/${genLoadId(32)}`}).status(200); }); diff --git a/api/src/routes/guilds/#guild_id/bans.ts b/api/src/routes/guilds/#guild_id/bans.ts index eb38de0db..128ff2501 100644 --- a/api/src/routes/guilds/#guild_id/bans.ts +++ b/api/src/routes/guilds/#guild_id/bans.ts @@ -32,7 +32,7 @@ const router: Router = Router(); router.get("/", route({ permission: "BAN_MEMBERS" }), async (req: Request, res: Response) => { const { guild_id } = req.params; - let bans = await Ban.find({ guild_id: guild_id }); + let bans = await Ban.find({ where: { guild_id } }); let promisesToAwait: object[] = []; const bansObj: object[] = []; @@ -65,7 +65,7 @@ router.get("/:user", route({ permission: "BAN_MEMBERS" }), async (req: Request, const { guild_id } = req.params; const user_id = req.params.ban; - let ban = await Ban.findOneOrFail({ guild_id: guild_id, user_id: user_id }) as BanRegistrySchema; + let ban = await Ban.findOneOrFail({ where: { guild_id, user_id } }) as BanRegistrySchema; if (ban.user_id === ban.executor_id) throw DiscordApiErrors.UNKNOWN_BAN; // pretend self-bans don't exist to prevent victim chasing @@ -149,7 +149,7 @@ router.put("/@me", route({ body: "BanCreateSchema"}), async (req: Request, res: router.delete("/:user_id", route({ permission: "BAN_MEMBERS" }), async (req: Request, res: Response) => { const { guild_id, user_id } = req.params; - let ban = await Ban.findOneOrFail({ guild_id: guild_id, user_id: user_id }); + let ban = await Ban.findOneOrFail({ where: { guild_id, user_id } }); if (ban.user_id === ban.executor_id) throw DiscordApiErrors.UNKNOWN_BAN; // make self-bans irreversible and hide them from view to avoid victim chasing diff --git a/api/src/routes/guilds/#guild_id/channels.ts b/api/src/routes/guilds/#guild_id/channels.ts index e3c6b8bd7..b952b4748 100644 --- a/api/src/routes/guilds/#guild_id/channels.ts +++ b/api/src/routes/guilds/#guild_id/channels.ts @@ -7,7 +7,7 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; - const channels = await Channel.find({ guild_id }); + const channels = await Channel.find({ where: { guild_id } }); res.json(channels); }); @@ -48,7 +48,7 @@ router.patch("/", route({ body: "ChannelReorderSchema", permission: "MANAGE_CHAN } await Channel.update({ guild_id, id: x.id }, opts); - const channel = await Channel.findOneOrFail({ guild_id, id: x.id }); + const channel = await Channel.findOneOrFail({ where: { guild_id, id: x.id } }); await emitEvent({ event: "CHANNEL_UPDATE", data: channel, channel_id: x.id, guild_id } as ChannelUpdateEvent); }) diff --git a/api/src/routes/guilds/#guild_id/emojis.ts b/api/src/routes/guilds/#guild_id/emojis.ts index 85d7ac053..c4bcadf77 100644 --- a/api/src/routes/guilds/#guild_id/emojis.ts +++ b/api/src/routes/guilds/#guild_id/emojis.ts @@ -41,13 +41,13 @@ router.post("/", route({ body: "EmojiCreateSchema", permission: "MANAGE_EMOJIS_A const body = req.body as EmojiCreateSchema; const id = Snowflake.generate(); - const emoji_count = await Emoji.count({ guild_id: guild_id }); + const emoji_count = await Emoji.count({ where: { guild_id } }); const { maxEmojis } = Config.get().limits.guild; if (emoji_count >= maxEmojis) throw DiscordApiErrors.MAXIMUM_NUMBER_OF_EMOJIS_REACHED.withParams(maxEmojis); if (body.require_colons == null) body.require_colons = true; - const user = await User.findOneOrFail({ id: req.user_id }); + const user = await User.findOneOrFail({ where: { id: req.user_id } }); body.image = (await handleFile(`/emojis/${id}`, body.image)) as string; const emoji = await new Emoji({ @@ -66,7 +66,7 @@ router.post("/", route({ body: "EmojiCreateSchema", permission: "MANAGE_EMOJIS_A guild_id: guild_id, data: { guild_id: guild_id, - emojis: await Emoji.find({ guild_id: guild_id }) + emojis: await Emoji.find({ where: { guild_id } }) } } as GuildEmojisUpdateEvent); @@ -87,7 +87,7 @@ router.patch( guild_id: guild_id, data: { guild_id: guild_id, - emojis: await Emoji.find({ guild_id: guild_id }) + emojis: await Emoji.find({ where: { guild_id } }) } } as GuildEmojisUpdateEvent); @@ -108,7 +108,7 @@ router.delete("/:emoji_id", route({ permission: "MANAGE_EMOJIS_AND_STICKERS" }), guild_id: guild_id, data: { guild_id: guild_id, - emojis: await Emoji.find({ guild_id: guild_id }) + emojis: await Emoji.find({ where: { guild_id } }) } } as GuildEmojisUpdateEvent); diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index d9c8f13ba..2d748d61c 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -26,8 +26,8 @@ router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; const [guild, member] = await Promise.all([ - Guild.findOneOrFail({ id: guild_id }), - Member.findOne({ guild_id: guild_id, id: req.user_id }) + Guild.findOneOrFail({ where: { id: guild_id } }), + Member.findOne({ where: { guild_id, id: req.user_id } }) ]); if (!member) throw new HTTPError("You are not a member of the guild you are trying to access", 401); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index e4a060d66..2717ec2ad 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -13,7 +13,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id, member_id } = req.params; await Member.IsInGuildOrFail(req.user_id, guild_id); - const member = await Member.findOneOrFail({ id: member_id, guild_id }); + const member = await Member.findOneOrFail({ where: { id: member_id, guild_id } }); return res.json(member); }); @@ -25,7 +25,7 @@ router.patch("/", route({ body: "MemberChangeSchema" }), async (req: Request, re const member = await Member.findOneOrFail({ where: { id: member_id, guild_id }, relations: ["roles", "user"] }); const permission = await getPermission(req.user_id, guild_id); - const everyone = await Role.findOneOrFail({ guild_id: guild_id, name: "@everyone", position: 0 }); + const everyone = await Role.findOneOrFail({ where: { guild_id: guild_id, name: "@everyone", position: 0 } }); if (body.roles) { permission.hasThrow("MANAGE_ROLES"); diff --git a/api/src/routes/guilds/#guild_id/prune.ts b/api/src/routes/guilds/#guild_id/prune.ts index efaad5800..01f18ce40 100644 --- a/api/src/routes/guilds/#guild_id/prune.ts +++ b/api/src/routes/guilds/#guild_id/prune.ts @@ -33,7 +33,7 @@ export const inactiveMembers = async (guild_id: string, user_id: string, days: n //I'm sure I can do this in the above db query ( and it would probably be better to do so ), but oh well. if (roles.length && members.length) members = members.filter((user) => user.roles?.some((role) => roles.includes(role.id))); - const me = await Member.findOneOrFail({ id: user_id, guild_id }, { relations: ["roles"] }); + const me = await Member.findOneOrFail({ where: { id: user_id, guild_id }, relations: ["roles"] }); const myHighestRole = Math.max(...(me.roles?.map((x) => x.position) || [])); const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); diff --git a/api/src/routes/guilds/#guild_id/regions.ts b/api/src/routes/guilds/#guild_id/regions.ts index 75d24fd1f..308d5ee5d 100644 --- a/api/src/routes/guilds/#guild_id/regions.ts +++ b/api/src/routes/guilds/#guild_id/regions.ts @@ -7,7 +7,7 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); //TODO we should use an enum for guild's features and not hardcoded strings return res.json(await getVoiceRegions(getIpAdress(req), guild.features.includes("VIP_REGIONS"))); }); diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 7efc53823..af04fd066 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -9,7 +9,7 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id, role_id } = req.params; await Member.IsInGuildOrFail(req.user_id, guild_id); - const role = await Role.findOneOrFail({ guild_id, id: role_id }); + const role = await Role.findOneOrFail({ where: { guild_id, id: role_id } }); return res.json(role); }); diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index 2f5141b84..d2d14122a 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -37,7 +37,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { await Member.IsInGuildOrFail(req.user_id, guild_id); - const roles = await Role.find({ guild_id: guild_id }); + const roles = await Role.find({ where: { guild_id } }); return res.json(roles); }); @@ -46,7 +46,7 @@ router.post("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }) const guild_id = req.params.guild_id; const body = req.body as RoleModifySchema; - const role_count = await Role.count({ guild_id }); + const role_count = await Role.count({ where: { guild_id } }); const { maxRoles } = Config.get().limits.guild; if (role_count > maxRoles) throw DiscordApiErrors.MAXIMUM_ROLES.withParams(maxRoles); diff --git a/api/src/routes/guilds/#guild_id/stickers.ts b/api/src/routes/guilds/#guild_id/stickers.ts index bfc462915..7913539be 100644 --- a/api/src/routes/guilds/#guild_id/stickers.ts +++ b/api/src/routes/guilds/#guild_id/stickers.ts @@ -19,7 +19,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; await Member.IsInGuildOrFail(req.user_id, guild_id); - res.json(await Sticker.find({ guild_id })); + res.json(await Sticker.find({ where: { guild_id } })); }); const bodyParser = multer({ @@ -79,7 +79,7 @@ router.get("/:sticker_id", route({}), async (req: Request, res: Response) => { const { guild_id, sticker_id } = req.params; await Member.IsInGuildOrFail(req.user_id, guild_id); - res.json(await Sticker.findOneOrFail({ guild_id, id: sticker_id })); + res.json(await Sticker.findOneOrFail({ where: { guild_id, id: sticker_id } })); }); export interface ModifyGuildStickerSchema { @@ -118,7 +118,7 @@ async function sendStickerUpdateEvent(guild_id: string) { guild_id: guild_id, data: { guild_id: guild_id, - stickers: await Sticker.find({ guild_id: guild_id }) + stickers: await Sticker.find({ where: { guild_id } }) } } as GuildStickersUpdateEvent); } diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/api/src/routes/guilds/#guild_id/templates.ts index 7e4119076..f2de46e46 100644 --- a/api/src/routes/guilds/#guild_id/templates.ts +++ b/api/src/routes/guilds/#guild_id/templates.ts @@ -44,7 +44,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { router.post("/", route({ body: "TemplateCreateSchema", permission: "MANAGE_GUILD" }), async (req: Request, res: Response) => { const { guild_id } = req.params; const guild = await Guild.findOneOrFail({ where: { id: guild_id }, select: TemplateGuildProjection }); - const exists = await Template.findOneOrFail({ id: guild_id }).catch((e) => {}); + const exists = await Template.findOneOrFail({ where: { id: guild_id } }).catch((e) => {}); if (exists) throw new HTTPError("Template already exists", 400); const template = await new Template({ diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/api/src/routes/guilds/#guild_id/vanity-url.ts index e841b8b39..b4d9f6186 100644 --- a/api/src/routes/guilds/#guild_id/vanity-url.ts +++ b/api/src/routes/guilds/#guild_id/vanity-url.ts @@ -9,7 +9,7 @@ const InviteRegex = /\W/g; router.get("/", route({ permission: "MANAGE_GUILD" }), async (req: Request, res: Response) => { const { guild_id } = req.params; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); if (!guild.features.includes("ALIASABLE_NAMES")) { const invite = await Invite.findOne({ where: { guild_id: guild_id, vanity_url: true } }); @@ -37,15 +37,15 @@ router.patch("/", route({ body: "VanityUrlSchema", permission: "MANAGE_GUILD" }) const body = req.body as VanityUrlSchema; const code = body.code?.replace(InviteRegex, ""); - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); if (!guild.features.includes("VANITY_URL")) throw new HTTPError("Your guild doesn't support vanity urls"); if (!code || code.length === 0) throw new HTTPError("Code cannot be null or empty"); - const invite = await Invite.findOne({ code }); + const invite = await Invite.findOne({ where: { code } }); if (invite) throw new HTTPError("Invite already exists"); - const { id } = await Channel.findOneOrFail({ guild_id, type: ChannelType.GUILD_TEXT }); + const { id } = await Channel.findOneOrFail({ where: { guild_id, type: ChannelType.GUILD_TEXT } }); await new Invite({ vanity_url: true, @@ -60,7 +60,7 @@ router.patch("/", route({ body: "VanityUrlSchema", permission: "MANAGE_GUILD" }) channel_id: id }).save(); - return res.json({ code: code }); + return res.json({ where: { code } }); }); export default router; diff --git a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts index 392b002f2..37ea52b58 100644 --- a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts +++ b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts @@ -34,14 +34,16 @@ router.patch("/", route({ body: "VoiceStateUpdateSchema" }), async (req: Request if (body.request_to_speak_timestamp) perms.hasThrow("REQUEST_TO_SPEAK"); const voice_state = await VoiceState.findOne({ - guild_id, - channel_id: body.channel_id, - user_id + where: { + guild_id, + channel_id: body.channel_id, + user_id + } }); if (!voice_state) throw DiscordApiErrors.UNKNOWN_VOICE_STATE; voice_state.assign(body); - const channel = await Channel.findOneOrFail({ guild_id, id: body.channel_id }); + const channel = await Channel.findOneOrFail({ where: { guild_id, id: body.channel_id } }); if (channel.type !== ChannelType.GUILD_STAGE_VOICE) { throw DiscordApiErrors.CANNOT_EXECUTE_ON_THIS_CHANNEL_TYPE; } diff --git a/api/src/routes/guilds/#guild_id/welcome_screen.ts b/api/src/routes/guilds/#guild_id/welcome_screen.ts index ab1251311..4093ec1dc 100644 --- a/api/src/routes/guilds/#guild_id/welcome_screen.ts +++ b/api/src/routes/guilds/#guild_id/welcome_screen.ts @@ -19,7 +19,7 @@ export interface GuildUpdateWelcomeScreenSchema { router.get("/", route({}), async (req: Request, res: Response) => { const guild_id = req.params.guild_id; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); await Member.IsInGuildOrFail(req.user_id, guild_id); res.json(guild.welcome_screen); @@ -29,7 +29,7 @@ router.patch("/", route({ body: "GuildUpdateWelcomeScreenSchema", permission: "M const guild_id = req.params.guild_id; const body = req.body as GuildUpdateWelcomeScreenSchema; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); if (!guild.welcome_screen.enabled) throw new HTTPError("Welcome screen disabled", 400); if (body.welcome_channels) guild.welcome_screen.welcome_channels = body.welcome_channels; // TODO: check if they exist and are valid diff --git a/api/src/routes/guilds/#guild_id/widget.json.ts b/api/src/routes/guilds/#guild_id/widget.json.ts index 97f3c3034..b7a93a46b 100644 --- a/api/src/routes/guilds/#guild_id/widget.json.ts +++ b/api/src/routes/guilds/#guild_id/widget.json.ts @@ -17,7 +17,7 @@ const router: Router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); if (!guild.widget_enabled) throw new HTTPError("Widget Disabled", 404); // Fetch existing widget invite for widget channel @@ -63,7 +63,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { // Fetch members // TODO: Understand how Discord's max 100 random member sample works, and apply to here (see top of this file) - let members = await Member.find({ guild_id: guild_id }); + let members = await Member.find({ where: { guild_id } }); // Construct object to respond with const data = { diff --git a/api/src/routes/guilds/#guild_id/widget.png.ts b/api/src/routes/guilds/#guild_id/widget.png.ts index 4298d0fe4..ec0ac85cc 100644 --- a/api/src/routes/guilds/#guild_id/widget.png.ts +++ b/api/src/routes/guilds/#guild_id/widget.png.ts @@ -14,7 +14,7 @@ const router: Router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); if (!guild.widget_enabled) throw new HTTPError("Unknown Guild", 404); // Fetch guild information diff --git a/api/src/routes/guilds/#guild_id/widget.ts b/api/src/routes/guilds/#guild_id/widget.ts index 2640618de..103f84a30 100644 --- a/api/src/routes/guilds/#guild_id/widget.ts +++ b/api/src/routes/guilds/#guild_id/widget.ts @@ -13,7 +13,7 @@ const router: Router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; - const guild = await Guild.findOneOrFail({ id: guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: guild_id } }); return res.json({ enabled: guild.widget_enabled || false, channel_id: guild.widget_channel_id || null }); }); diff --git a/api/src/routes/guilds/index.ts b/api/src/routes/guilds/index.ts index 10721413f..64b9454b1 100644 --- a/api/src/routes/guilds/index.ts +++ b/api/src/routes/guilds/index.ts @@ -24,7 +24,7 @@ router.post("/", route({ body: "GuildCreateSchema", right: "CREATE_GUILDS" }), a const body = req.body as GuildCreateSchema; const { maxGuilds } = Config.get().limits.user; - const guild_count = await Member.count({ id: req.user_id }); + const guild_count = await Member.count({ where: { id: req.user_id } }); const rights = await getRights(req.user_id); if ((guild_count >= maxGuilds)&&!rights.has("MANAGE_GUILDS")) { throw DiscordApiErrors.MAXIMUM_GUILDS.withParams(maxGuilds); diff --git a/api/src/routes/guilds/templates/index.ts b/api/src/routes/guilds/templates/index.ts index 3d922e856..e2242ebfd 100644 --- a/api/src/routes/guilds/templates/index.ts +++ b/api/src/routes/guilds/templates/index.ts @@ -33,7 +33,7 @@ router.get("/:code", route({}), async (req: Request, res: Response) => { return res.json(code.split("external:", 2)[1]); } - const template = await Template.findOneOrFail({ code: code }); + const template = await Template.findOneOrFail({ where: { code } }); res.json(template); }); @@ -47,12 +47,12 @@ router.post("/:code", route({ body: "GuildTemplateCreateSchema" }), async (req: const { maxGuilds } = Config.get().limits.user; - const guild_count = await Member.count({ id: req.user_id }); + const guild_count = await Member.count({ where: { id: req.user_id } }); if (guild_count >= maxGuilds) { throw DiscordApiErrors.MAXIMUM_GUILDS.withParams(maxGuilds); } - const template = await Template.findOneOrFail({ code: code }); + const template = await Template.findOneOrFail({ where: { code } }); const guild_id = Snowflake.generate(); diff --git a/api/src/routes/invites/index.ts b/api/src/routes/invites/index.ts index b0a349393..1b434505b 100644 --- a/api/src/routes/invites/index.ts +++ b/api/src/routes/invites/index.ts @@ -15,9 +15,9 @@ router.get("/:code", route({}), async (req: Request, res: Response) => { router.post("/:code", route({right: "USE_MASS_INVITES"}), async (req: Request, res: Response) => { const { code } = req.params; - const { guild_id } = await Invite.findOneOrFail({ code }) - const { features } = await Guild.findOneOrFail({ id: guild_id}); - const { public_flags } = await User.findOneOrFail({ id: req.user_id }); + const { guild_id } = await Invite.findOneOrFail({ where: { code } }) + const { features } = await Guild.findOneOrFail({ where: { id: guild_id} }); + const { public_flags } = await User.findOneOrFail({ where: { id: req.user_id } }); if(features.includes("INTERNAL_EMPLOYEE_ONLY") && (public_flags & 1) !== 1) throw new HTTPError("Only intended for the staff of this server.", 401); if(features.includes("INVITES_CLOSED")) throw new HTTPError("Sorry, this guild has joins closed.", 403); @@ -30,7 +30,7 @@ router.post("/:code", route({right: "USE_MASS_INVITES"}), async (req: Request, r // * cant use permission of route() function because path doesn't have guild_id/channel_id router.delete("/:code", route({}), async (req: Request, res: Response) => { const { code } = req.params; - const invite = await Invite.findOneOrFail({ code }); + const invite = await Invite.findOneOrFail({ where: { code } }); const { guild_id, channel_id } = invite; const permission = await getPermission(req.user_id, guild_id, channel_id); diff --git a/api/src/routes/stickers/#sticker_id/index.ts b/api/src/routes/stickers/#sticker_id/index.ts index 293ca0894..b484a7a11 100644 --- a/api/src/routes/stickers/#sticker_id/index.ts +++ b/api/src/routes/stickers/#sticker_id/index.ts @@ -6,7 +6,7 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { sticker_id } = req.params; - res.json(await Sticker.find({ id: sticker_id })); + res.json(await Sticker.find({ where: { id: sticker_id } })); }); export default router; diff --git a/api/src/routes/updates.ts b/api/src/routes/updates.ts index cb4577c8e..a24e94c10 100644 --- a/api/src/routes/updates.ts +++ b/api/src/routes/updates.ts @@ -7,7 +7,7 @@ const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { const { client } = Config.get(); - const release = await Release.findOneOrFail({ name: client.releases.upstreamVersion}) + const release = await Release.findOneOrFail({ where: { name: client.releases.upstreamVersion } }) res.json({ name: release.name, diff --git a/api/src/routes/users/@me/mfa/codes.ts b/api/src/routes/users/@me/mfa/codes.ts index 6ddf32f06..75e3e9643 100644 --- a/api/src/routes/users/@me/mfa/codes.ts +++ b/api/src/routes/users/@me/mfa/codes.ts @@ -15,7 +15,7 @@ export interface MfaCodesSchema { router.post("/", route({ body: "MfaCodesSchema" }), async (req: Request, res: Response) => { const { password, regenerate } = req.body as MfaCodesSchema; - const user = await User.findOneOrFail({ id: req.user_id }, { select: ["data"] }); + const user = await User.findOneOrFail({ where: { id: req.user_id }, select: ["data"] }); if (!await bcrypt.compare(password, user.data.hash || "")) { throw FieldErrors({ password: { message: req.t("auth:login.INVALID_PASSWORD"), code: "INVALID_PASSWORD" } }); @@ -33,10 +33,12 @@ router.post("/", route({ body: "MfaCodesSchema" }), async (req: Request, res: Re } else { codes = await BackupCode.find({ - user: { - id: req.user_id, - }, - expired: false, + where: { + user: { + id: req.user_id, + }, + expired: false + } }); } diff --git a/api/src/routes/users/@me/mfa/totp/disable.ts b/api/src/routes/users/@me/mfa/totp/disable.ts index 5e039ea33..2d385fdaa 100644 --- a/api/src/routes/users/@me/mfa/totp/disable.ts +++ b/api/src/routes/users/@me/mfa/totp/disable.ts @@ -13,9 +13,9 @@ export interface TotpDisableSchema { router.post("/", route({ body: "TotpDisableSchema" }), async (req: Request, res: Response) => { const body = req.body as TotpDisableSchema; - const user = await User.findOneOrFail({ id: req.user_id }, { select: ["totp_secret"] }); + const user = await User.findOneOrFail({ where: { id: req.user_id }, select: ["totp_secret"] }); - const backup = await BackupCode.findOne({ code: body.code }); + const backup = await BackupCode.findOne({ where: { code: body.code } }); if (!backup) { const ret = verifyToken(user.totp_secret!, body.code); if (!ret || ret.delta != 0) diff --git a/api/src/routes/users/@me/notes.ts b/api/src/routes/users/@me/notes.ts index 3c503942d..f938f0886 100644 --- a/api/src/routes/users/@me/notes.ts +++ b/api/src/routes/users/@me/notes.ts @@ -29,7 +29,7 @@ router.put("/:id", route({}), async (req: Request, res: Response) => { if (note && note.length) { // upsert a note - if (await Note.findOne({ owner: { id: owner.id }, target: { id: target.id } })) { + if (await Note.findOne({ where: { owner: { id: owner.id }, target: { id: target.id } } })) { Note.update( { owner: { id: owner.id }, target: { id: target.id } }, { owner, target, content: note } diff --git a/api/src/routes/users/@me/relationships.ts b/api/src/routes/users/@me/relationships.ts index b2e39d52d..0509b0acd 100644 --- a/api/src/routes/users/@me/relationships.ts +++ b/api/src/routes/users/@me/relationships.ts @@ -45,7 +45,7 @@ router.put("/:id", route({ body: "RelationshipPutSchema" }), async (req: Request return await updateRelationship( req, res, - await User.findOneOrFail({ id: req.params.id }, { relations: ["relationships", "relationships.to"], select: userProjection }), + await User.findOneOrFail({ where: { id: req.params.id }, relations: ["relationships", "relationships.to"], select: userProjection }), req.body.type ?? RelationshipType.friends ); }); @@ -75,8 +75,8 @@ router.delete("/:id", route({}), async (req: Request, res: Response) => { const { id } = req.params; if (id === req.user_id) throw new HTTPError("You can't remove yourself as a friend"); - const user = await User.findOneOrFail({ id: req.user_id }, { select: userProjection, relations: ["relationships"] }); - const friend = await User.findOneOrFail({ id: id }, { select: userProjection, relations: ["relationships"] }); + const user = await User.findOneOrFail({ where: { id: req.user_id }, select: userProjection, relations: ["relationships"] }); + const friend = await User.findOneOrFail({ where: { id: id }, select: userProjection, relations: ["relationships"] }); const relationship = user.relationships.find((x) => x.to_id === id); const friendRequest = friend.relationships.find((x) => x.to_id === req.user_id); @@ -124,10 +124,11 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ const id = friend.id; if (id === req.user_id) throw new HTTPError("You can't add yourself as a friend"); - const user = await User.findOneOrFail( - { id: req.user_id }, - { relations: ["relationships", "relationships.to"], select: userProjection } - ); + const user = await User.findOneOrFail({ + where: { id: req.user_id }, + relations: ["relationships", "relationships.to"], + select: userProjection + }); let relationship = user.relationships.find((x) => x.to_id === id); const friendRequest = friend.relationships.find((x) => x.to_id === req.user_id); diff --git a/api/src/routes/users/@me/settings.ts b/api/src/routes/users/@me/settings.ts index b22b72fb5..70f8a2187 100644 --- a/api/src/routes/users/@me/settings.ts +++ b/api/src/routes/users/@me/settings.ts @@ -10,7 +10,7 @@ router.patch("/", route({ body: "UserSettingsSchema" }), async (req: Request, re const body = req.body as UserSettings; if (body.locale === "en") body.locale = "en-US"; // fix discord client crash on unkown locale - const user = await User.findOneOrFail({ id: req.user_id, bot: false }); + const user = await User.findOneOrFail({ where: { id: req.user_id, bot: false } }); user.settings = { ...user.settings, ...body }; await user.save(); diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 0a74312ef..80012260c 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -68,10 +68,10 @@ export async function handleMessage(opts: MessageOptions): Promise { rights.hasThrow("SEND_MESSAGES"); } if (opts.application_id) { - message.application = await Application.findOneOrFail({ id: opts.application_id }); + message.application = await Application.findOneOrFail({ where: { id: opts.application_id } }); } if (opts.webhook_id) { - message.webhook = await Webhook.findOneOrFail({ id: opts.webhook_id }); + message.webhook = await Webhook.findOneOrFail({ where: { id: opts.webhook_id } }); } const permission = await getPermission(opts.author_id, channel.guild_id, opts.channel_id); @@ -85,7 +85,7 @@ export async function handleMessage(opts: MessageOptions): Promise { permission.hasThrow("READ_MESSAGE_HISTORY"); // code below has to be redone when we add custom message routing if (message.guild_id !== null) { - const guild = await Guild.findOneOrFail({ id: channel.guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: channel.guild_id } }); if (!guild.features.includes("CROSS_CHANNEL_REPLIES")) { if (opts.message_reference.guild_id !== channel.guild_id) throw new HTTPError("You can only reference messages from this guild"); if (opts.message_reference.channel_id !== opts.channel_id) throw new HTTPError("You can only reference messages from this channel"); @@ -120,7 +120,7 @@ export async function handleMessage(opts: MessageOptions): Promise { await Promise.all( Array.from(content.matchAll(ROLE_MENTION)).map(async ([_, mention]) => { - const role = await Role.findOneOrFail({ id: mention, guild_id: channel.guild_id }); + const role = await Role.findOneOrFail({ where: { id: mention, guild_id: channel.guild_id } }); if (role.mentionable || permission.has("MANAGE_ROLES")) { mention_role_ids.push(mention); } diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 14f05bcc18fb322596c1d748b7159d54e934cd61..3653e700fc92ab9c88e5c3d7e692cefbe17c5098 100644 GIT binary patch delta 1562 zcmd7S-%ndr902g#+k1O^TL?^WI4r-4vK3m|+tL;=Q!a(lmeQ`J?OMhb+tSj~pSQQa zGbd^`oSL9C`gJBQQ{%&wB|L09(fG0#&0?6y5_QQ;_GnCu^5DbV3|=rM{sS&PopZkD zoaFmG`F_qXuPbj}KC*ljlYc9YWHWp*UEhfwgbgK5)D=%@VZM)gT=DltG_O%>_-rvB ziK^3~ocf=rT01xlY+R!7GF&EMt$BUJRdy)u zYnALopKoLLHSkSc+z8qZQeJ=aP7kb-xC}Lm@E{IOKi-LibrS}ie`2ffK#I2@D}@&n z@Lr8*Mcw^)54Ey6ilfa@(QOqxwuLc`i>Yi_C~$93o4{?7_WCjwkGAH>`E)^Z$Wtk2 z&GwSR=qs76I=iK6@!LveuYI&vT`DuqiOF)AIc`emO#|aqTi$itWeB+4Y;8{OcSRi9 zW6o;0oQtLX8mHD!v#_e7B&W7?+SIF z=%WmEF5c@Ms&F1F=Nx9u1zpJMj~WGBnQMMKf( z=PDX)YHrr=OcqV0Xv$%*m^HkiILR(CDSmt=4&6;6Mg8Jt8@RTyBpUOOZyOMGp8QD+ zulKdq6Qmj-7ZA(P-2l}pFer)- zAo>Kg$KW$@HyWF#I=c1+fFK}?w5O?)Vh|X-0>bnVT$9B!>h{*40!9NjRcl+vj1s^nqs9+N|;x-Ow!eAG-}t3lj>npE^?>%IXH48%}7 zOZzcczd{~{dorR6I%r87ygy9@;b$q`T0izBfx67}d4$eBpwEfGxs3@Qtd*34Z;)<* zo4dFSe)vezzu)$l3AlT7@5#V_(faJsqY9Ojrs2Rm^(3fwg*1g^RB-kys_oiKQt<#< OS4nqCv@;}q*!&k*un)ih delta 5142 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 HzrXaKhdh4E diff --git a/bundle/package.json b/bundle/package.json index e574af3d0..1dfdbb1ce 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -7,6 +7,7 @@ "setup": "node scripts/install.js && npm install --omit optional && ts-patch install -s && patch-package --patch-dir ../api/patches/ && npm run build", "depclean": "node scripts/depclean.js", "depcheck": "node scripts/depcheck.js", + "syncdeps": "node scripts/install.js", "build": "node scripts/build.js", "start": "node scripts/build.js && node dist/bundle/src/start.js", "start:bundle": "node dist/bundle/src/start.js", diff --git a/gateway/src/listener/listener.ts b/gateway/src/listener/listener.ts index 0cf2b82b9..8c69e193a 100644 --- a/gateway/src/listener/listener.ts +++ b/gateway/src/listener/listener.ts @@ -49,10 +49,10 @@ export async function setupListener(this: WebSocket) { where: { user_id: this.user_id, closed: false }, relations: ["channel"], }), - Relationship.find({ + Relationship.find({ where: { from_id: this.user_id, type: RelationshipType.friends, - }), + } }), ]); const guilds = members.map((x) => x.guild); diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index bfe748f1a..13d555597 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -58,7 +58,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { relations: ["relationships", "relationships.to"], select: [...PrivateUserProjection, "relationships"], }), - ReadState.find({ user_id: this.user_id }), + ReadState.find({ where: { user_id: this.user_id } }), Member.find({ where: { id: this.user_id }, select: MemberPrivateProjection, @@ -96,7 +96,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { }, activities: [], }).save(), - Application.findOne({ id: this.user_id }), + Application.findOne({ where: { id: this.user_id } }), ]); if (!user) return this.close(CLOSECODES.Authentication_failed); diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index dd96d6d7b..974769e94 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -120,7 +120,7 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) { const ranges = channels![channel_id]; if (!Array.isArray(ranges)) throw new Error("Not a valid Array"); - const member_count = await Member.count({ guild_id }); + const member_count = await Member.count({ where: { guild_id } }); const ops = await Promise.all(ranges.map((x) => getMembers(guild_id, x))); // TODO: unsubscribe member_events that are not in op.members diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/gateway/src/opcodes/VoiceStateUpdate.ts index 321e6b172..7f7db9b02 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/gateway/src/opcodes/VoiceStateUpdate.ts @@ -84,7 +84,7 @@ export async function onVoiceStateUpdate(this: WebSocket, data: Payload) { //If it's null it means that we are leaving the channel and this event is not needed if (voiceState.channel_id !== null) { - const guild = await Guild.findOne({ id: voiceState.guild_id }); + const guild = await Guild.findOne({ where: { id: voiceState.guild_id } }); const regions = Config.get().regions; let guildRegion: Region; if (guild && guild.region) { diff --git a/util/package-lock.json b/util/package-lock.json index 472f1b95f0c62965ea4c9d6bc17e3a24b8ca5e16..04b2857b792f34bf4fd4e060c1603cbc4aa21385 100644 GIT binary patch delta 96 zcmV-m0H6QW#2nj?9DuX|7ND2D!2u(e5O4uAx8S1zSSXXWFc_C$Yz4%JFwX(EFwX+} z4wue70T-8`&ISaxJ>LTG@`s?>1Gk{s1hH$kf=C4vBDY9v1zqB|VowIM#JBYt2Ve*B Ciz&qb delta 2380 zcmcJQZ%i9y9LICLy8;_*=o~Nxv=mgZYkPNX`7>p)K>tE%3$zqswq4un^-6o!Yp+1b z@ZXyyzL;cv@q1xZe4%m4mThK}H>g`OSkXjIm@+F}q7H z&+~hp`#sO^`+W0xuDn|J)w#MCPa#!vWsDS#=|Tx11ZTg*Yv6_Fal?-2ouENySnKGF z(6|q6^0((KzEm&ece|$hIkH!rXcujxyf;L9r`pG&w!Stm=bZAHywP#HH#d+=P=0nw zOB=FDzrZK^#CXhY>gA&$_e3PvCP+cC!yug(B1k4ygBZsY#QbH0IA%*Wpo)O)%iQrKm>CAo>tu zTQMRPR4EKeI#O@We^=4yAMx-M8R)RYa#qqO2BKbPV2UwH*_4Y8i{zAj+&kQD;%Iib zP0)I&u!XgHJd@5TcT`H7v|~NP&bElzOmgwgcpKSkOA~y?OJ(8G6-5hNe^a3X=Z8o$ zRHhIk%*n0!**V120!sn328dVWAn_@JZKe4PC+{pqXLN-oEPaAD?Hus>t-QyPG3GM% zA-Y4`F>bcC4+pwKW7fRoasw=y5F9E_BSAQG9>K8Uk3YYMEWnK!#ZK67MKlNHf%!A% z6<4;R3@?HE7S;eKenCi8icZS`U78WIT$+(rULOF<=U8JMsf*Z!kw~0%dW6yb-fSoD z&Sdy@f2g-F2rnH%o?NL<_*#L(#V%w!c!Q`B&J?=!dyviZzkQ=Pc^wmYI$JykARGt@ zi=Uy`BZXMuByx0`EwW+ucwbUxeP9L)f1Hnb$C~6HMLsjs;P>VQqbi` z8{ufFq7?SsL>`5YXOUgS4Xo8+FuX6XWTzaK0B84!0|qJ`&*r8lot9k8-5-;Dur#A+ z%4dkiyF{rxg)HQqm#fxXxt8!6Nv?SP)__6{J>zIW6hBE=gC3e1h-=3!gJI_&mmCYG zjMFZ6!CTFR^q_nltv$GK0i9pCfW0=p0p0~33h!hAma(0FUWhQdje|>X)D-A8BY$QJ zoYVYkWQ{%)Wcj+fH1qCuyg~DS=>+5l$~t(%j&Fv)-cgpr7qdtSs9(lzo1^}1S>fI-G&4 ze<-%YGh@nacX(3*KVDR7^9w)hKq);1OAfrT{{Gl8b!njHceLd;WJ;j+2C4;@38_G3 z5CT$;KY%r0VetkamQfitU|B}BJ63Tc`}iKS0ot`X-l>80YyBn|o diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 2a1e38a47..5ccb43ce9 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -169,7 +169,7 @@ export class Channel extends BaseClass { } if (!opts?.skipNameChecks) { - const guild = await Guild.findOneOrFail({ id: channel.guild_id }); + const guild = await Guild.findOneOrFail({ where: { id: channel.guild_id } }); if (!guild.features.includes("ALLOW_INVALID_CHANNEL_NAMES") && channel.name) { for (let character of InvisibleCharacters) if (channel.name.includes(character)) @@ -194,7 +194,7 @@ export class Channel extends BaseClass { case ChannelType.GUILD_NEWS: case ChannelType.GUILD_VOICE: if (channel.parent_id && !opts?.skipExistsCheck) { - const exists = await Channel.findOneOrFail({ id: channel.parent_id }); + const exists = await Channel.findOneOrFail({ where: { id: channel.parent_id } }); if (!exists) throw new HTTPError("Parent id channel doesn't exist", 400); if (exists.guild_id !== channel.guild_id) throw new HTTPError("The category channel needs to be in the guild"); diff --git a/util/src/entities/Invite.ts b/util/src/entities/Invite.ts index 6ac64ddcb..b672caf78 100644 --- a/util/src/entities/Invite.ts +++ b/util/src/entities/Invite.ts @@ -75,7 +75,7 @@ export class Invite extends BaseClassWithoutId { vanity_url?: boolean; static async joinGuild(user_id: string, code: string) { - const invite = await Invite.findOneOrFail({ code }); + const invite = await Invite.findOneOrFail({ where: { code } }); if (invite.uses++ >= invite.max_uses && invite.max_uses !== 0) await Invite.delete({ code }); else await invite.save(); diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index f6d99125c..e7e97b7c3 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -117,7 +117,7 @@ export class Member extends BaseClassWithoutId { // read_state: ReadState; static async IsInGuildOrFail(user_id: string, guild_id: string) { - if (await Member.count({ id: user_id, guild: { id: guild_id } })) return true; + if (await Member.count({ where: { id: user_id, guild: { id: guild_id } } })) return true; throw new HTTPError("You are not member of this guild", 403); } @@ -183,7 +183,7 @@ export class Member extends BaseClassWithoutId { relations: ["user", "roles"], // we don't want to load the role objects just the ids select: ["index"], }), - await Role.findOneOrFail({ id: role_id, guild_id }), + await Role.findOneOrFail({ where: { id: role_id, guild_id } }), ]); member.roles = member.roles.filter((x) => x.id == role_id); @@ -233,7 +233,7 @@ export class Member extends BaseClassWithoutId { throw DiscordApiErrors.USER_BANNED; } const { maxGuilds } = Config.get().limits.user; - const guild_count = await Member.count({ id: user_id }); + const guild_count = await Member.count({ where: { id: user_id } }); if (guild_count >= maxGuilds) { throw new HTTPError(`You are at the ${maxGuilds} server limit.`, 403); } @@ -245,7 +245,7 @@ export class Member extends BaseClassWithoutId { relations: PublicGuildRelations, }); - if (await Member.count({ id: user.id, guild: { id: guild_id } })) + if (await Member.count({ where: { id: user.id, guild: { id: guild_id } } })) throw new HTTPError("You are already a member of this guild", 400); const member = { diff --git a/util/src/entities/Message.ts b/util/src/entities/Message.ts index e18cf6919..ba3d4f2dc 100644 --- a/util/src/entities/Message.ts +++ b/util/src/entities/Message.ts @@ -8,7 +8,6 @@ import { Column, CreateDateColumn, Entity, - FindConditions, Index, JoinColumn, JoinTable, diff --git a/util/src/util/Token.ts b/util/src/util/Token.ts index 500ace454..5a3922d11 100644 --- a/util/src/util/Token.ts +++ b/util/src/util/Token.ts @@ -15,10 +15,10 @@ export function checkToken(token: string, jwtSecret: string): Promise { jwt.verify(token, jwtSecret, JWTOptions, async (err, decoded: any) => { if (err || !decoded) return rej("Invalid Token"); - const user = await User.findOne( - { id: decoded.id }, - { select: ["data", "bot", "disabled", "deleted", "rights"] } - ); + const user = await User.findOne({ + where: { id: decoded.id }, + select: ["data", "bot", "disabled", "deleted", "rights"] + }); if (!user) return rej("Invalid Token"); // we need to round it to seconds as it saved as seconds in jwt iat and valid_tokens_since is stored in milliseconds if (decoded.iat * 1000 < new Date(user.data.valid_tokens_since).setSeconds(0, 0)) From 365abc36dd3b41680527bcf613013bb4999b613d Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 7 Aug 2022 02:52:09 +0200 Subject: [PATCH 166/238] Switch to migrations fully --- .../routes/channels/#channel_id/invites.ts | 3 +- api/src/routes/guilds/#guild_id/index.ts | 3 +- api/src/util/handlers/Instance.ts | 3 +- api/src/util/handlers/Message.ts | 3 +- api/src/util/index.ts | 10 +- bundle/package-lock.json | Bin 660681 -> 670502 bytes bundle/package.json | 3 +- util/ormconfig.json | 9 - util/src/entities/BackupCodes.ts | 16 - util/src/entities/BaseClass.ts | 26 +- util/src/entities/Member.ts | 11 +- util/src/index.ts | 1 + .../migrations/1633864260873-EmojiRoles.ts | 13 - .../src/migrations/1633864669243-EmojiUser.ts | 23 - .../migrations/1633881705509-VanityInvite.ts | 19 - util/src/migrations/1634308884591-Stickers.ts | 66 - util/src/migrations/1634424361103-Presence.ts | 11 - .../1634426540271-MigrationTimestamp.ts | 15 - .../migrations/1648643945733-ReleaseTypo.ts | 16 - .../migrations/postgres/1659833042721-test.ts | 3539 +++++++++++++++++ util/src/util/Database.ts | 106 +- util/src/util/Database.ts.torm2 | 72 - util/src/util/MFA.ts | 17 + 23 files changed, 3662 insertions(+), 323 deletions(-) delete mode 100644 util/ormconfig.json delete mode 100644 util/src/migrations/1633864260873-EmojiRoles.ts delete mode 100644 util/src/migrations/1633864669243-EmojiUser.ts delete mode 100644 util/src/migrations/1633881705509-VanityInvite.ts delete mode 100644 util/src/migrations/1634308884591-Stickers.ts delete mode 100644 util/src/migrations/1634424361103-Presence.ts delete mode 100644 util/src/migrations/1634426540271-MigrationTimestamp.ts delete mode 100644 util/src/migrations/1648643945733-ReleaseTypo.ts create mode 100644 util/src/migrations/postgres/1659833042721-test.ts delete mode 100644 util/src/util/Database.ts.torm2 create mode 100644 util/src/util/MFA.ts diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index 5fef136d5..6155ef7d7 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -45,7 +45,8 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT channel_id: channel_id, inviter_id: user_id }).save(); - const data = invite.toJSON(); + //TODO: check this, removed toJSON call + const data = JSON.parse(JSON.stringify(invite)); data.inviter = await User.getPublicUser(req.user_id); data.guild = await Guild.findOne({ where: { id: guild_id } }); data.channel = channel; diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index 2d748d61c..263579e75 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -61,7 +61,8 @@ router.patch("/", route({ body: "GuildUpdateSchema"}), async (req: Request, res: // TODO: check if body ids are valid guild.assign(body); - const data = guild.toJSON(); + //TODO: check this, removed toJSON call + const data = JSON.parse(JSON.stringify(guild)); // TODO: guild hashes // TODO: fix vanity_url_code, template_id delete data.vanity_url_code; diff --git a/api/src/util/handlers/Instance.ts b/api/src/util/handlers/Instance.ts index 6bddfa988..7c3372708 100644 --- a/api/src/util/handlers/Instance.ts +++ b/api/src/util/handlers/Instance.ts @@ -1,4 +1,5 @@ import { Config, Guild, Session } from "@fosscord/util"; +import { createQueryBuilder } from "typeorm"; export async function initInstance() { // TODO: clean up database and delete tombstone data @@ -9,7 +10,7 @@ export async function initInstance() { const { autoJoin } = Config.get().guild; if (autoJoin.enabled && !autoJoin.guilds?.length) { - let guild = await Guild.findOne({}); + let guild = await Guild.findOne({where: {}, order: {id: "ASC"}}); if (guild) { // @ts-ignore await Config.set({ guild: { autoJoin: { guilds: [guild.id] } } }); diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 80012260c..7035bc5cc 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -201,9 +201,10 @@ export async function postHandleMessage(message: Message) { export async function sendMessage(opts: MessageOptions) { const message = await handleMessage({ ...opts, timestamp: new Date() }); + //TODO: check this, removed toJSON call await Promise.all([ Message.insert(message), - emitEvent({ event: "MESSAGE_CREATE", channel_id: opts.channel_id, data: message.toJSON() } as MessageCreateEvent) + emitEvent({ event: "MESSAGE_CREATE", channel_id: opts.channel_id, data: message } as MessageCreateEvent) ]); postHandleMessage(message).catch((e) => {}); // no await as it should catch error non-blockingly diff --git a/api/src/util/index.ts b/api/src/util/index.ts index ac439371b..b3c7559f2 100644 --- a/api/src/util/index.ts +++ b/api/src/util/index.ts @@ -1,9 +1,9 @@ +export * from "./entities/AssetCacheItem"; +export * from "./handlers/Message"; +export * from "./handlers/route"; +export * from "./handlers/Voice"; export * from "./utility/Base64"; export * from "./utility/ipAddress"; -export * from "./handlers/Message"; export * from "./utility/passwordStrength"; export * from "./utility/RandomInviteID"; -export * from "./handlers/route"; -export * from "./utility/String"; -export * from "./handlers/Voice"; -export * from "./entities/AssetCacheItem"; \ No newline at end of file +export * from "./utility/String"; \ No newline at end of file diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 3653e700fc92ab9c88e5c3d7e692cefbe17c5098..0ab7c5da148f06e7b7f0690296ef992c82e1d5d1 100644 GIT binary patch delta 6058 zcmd6qX^b0Z8ON2iy}RBtO;?bnX*cQa=4#~Hp79(WBW;@TeUGp4CDe9&k3Alb=kSb8 z+Yq6WFOf*(iWh+d4OB&m08!Lpi4U}qP$fi#00|W#RZTu1gg8V%LVN(qj5p3^6GR%y zDqU%JJ*Jw6Arfn8Go>w{2XUF%UO0!ILqAc zUs-H4>Y`m0S-|{uVgLB*J_LOA(%ix)b&FgVopxtMnSDbBZ=Satrx|xyP;zA&&Shj? z9r}_5B!bndkXlIkkbK6Iwb=sdu;U7c%QcZgeCcREE7WWrjFvDDl*h@qJKCqouq&dL zors4>b(6s+IP<3YC|IqU4xXhi&rRsdruV^;+G1q2X;(xJeCI1>=Mw7BR-b!r_2dQ) zuD)Sf9iRHm(%w2>?bTR*^N5fGT=@Ll<6r!~>A}UB16&JRR>5a~VR{Ta>or>@U-p@$ zdMbdlDgcqZ;ejBGFVl7b5+5N>Wi2ML3(sAIemyNDFZ?MbVvV4WV3{uP-Bep~c1E#Qo5?m3q%UM6 zs?BJ1oPK5%oKh|G7NY=UaQ(976Q{Qw-Y6W{0Xd-cCzq`H&$_Ou+T;0pRc3p%91V)w;WBE&0UirmPJm}y=9LF-RSeGm(0p)wg@+yg=^&dizvFy% zmtze7V4W7Ro-^;HGC2~@b!mQBC}%vpuMKy&qK|U<0%Skx{#zO>pI< zxwSmb`ZAE37sVbZ=F9>9s|~2#`F~D|RzN z(~ou+SUqPwO!spn$%z4pBP5h!1L+d(QT>BzB2r5yakVzWdhIkz4e?SYp$vJg&QnQ< z!g@X-8o@cKRmG)hlPnSaLDWU@PQm6YmY~r1;_=nf`ld!z%zAUHxq6b^6zh_m5k+Qb zxL>)n~ZGL-Ag)W5yAXZ{)^Pn+ol!;RkT!5i*nWB0l^U^e?3cEDri{S(vKJts85 za@6z)xcaR*Gx+l}7Uy1}X>{&1KE?-d@tXN49jp~RqO+YYx3cwKOM=UY6oH3YFr5qz z5>>w2P}*q0o1k+VC6dEulWl1y>n^`(_O3uWA`8llwu*_2xuFV|P+ zC4pmQ7kK&W3kSf}FPI;keB+$?l6i4NxNJ*6_ zr_>J(=s^K@H3>XZEGy)A*Ef$$!?ow;o<>H%nP2YOH@%Mz&7@2db*r|iVe>}PhKSIO zE9rj5TlNcdJTmM^e;*>;BDb{v%;s1i!Xgj<0RG^*Xs#ol!S>147{1 zyK`%_r1-n-cs|{96MQ1(qRS|Tw#bl;A`7-~I#tGbn=P00(?wexvMDqdAF6y$i^lvt z1%u07+bHL2i#`rY_VK94hqY3kLCguR|3&8nXx_ZO_oj@^as<~$iw}brHcZIT+dRy4 zM$BS5D_(HuoIX@Nt_XdsO2l2^7#6RRd8t8v=0b2^V(GHBzD34$4{H5 z#mPKn3hmu2R6Tk(DmG2&YVuw-ss%e5Tg-5Dq&`ffS$%r6nuC}x+m<_gbl{BVOBJz6 z##3qo8)akNfSUKjCE10Mok7B{&w0wPG}|=}kCmHhECClvM#zqtVMxC?FaE)NaN_=x zIgZbvIC$-Oy-8j?vgp_&izu#3G5*;haACoGm`);vgrxNIIL_q|$R`$)l|WlVLjjfR zsmK5qMYQXy4sb!_8)_>H!D6R54A$DIq_(uOb>wfgXZJ=Z#s<9+Ij%XA$__@OaOE9ilBAy z0TM1Dn5{kXswD;zW7#28%n;G6R!*tSxab~AP{ccGg$67MJ9Bg>8t-QFeTfh%9+DqK ze8qr5h2w%)${DP7+(^)LZtFzmKxTva&bXY4Ej~KFdVJ5>*LjQnJ3o1yUwEZ(�f@ z5!6@DM&DkTMBiTgUh<)>&>6>i8XI4u_fL*JY<=(XdnNSJju3i!V`F{tcg%Y2z+C`6 zw-bO4gpI|6;H}>+ESNtwe17uoe7A7V x.propertyName) .concat(this.metadata.relations.map((x) => x.propertyName)) - ); + );*/ // will not include relational properties for (const key in props) { - if (!properties.has(key)) continue; + //if (!properties.has(key)) continue; // @ts-ignore const setter = this[`set${key.capitalize()}`]; // use setter function if it exists @@ -41,7 +44,8 @@ export class BaseClassWithoutId extends BaseEntity { } } - toJSON(): any { + /*toJSON(): any { + console.log("toJSON...") return Object.fromEntries( this.metadata.columns // @ts-ignore .map((x) => [x.propertyName, this[x.propertyName]]) // @ts-ignore @@ -54,6 +58,7 @@ export class BaseClassWithoutId extends BaseEntity { propertyPath: string, value: number | string ) { + console.log("increment...") const repository = this.getRepository(); return repository.increment(conditions, propertyPath, value); } @@ -63,9 +68,10 @@ export class BaseClassWithoutId extends BaseEntity { propertyPath: string, value: number | string ) { + console.log("increment...") const repository = this.getRepository(); return repository.decrement(conditions, propertyPath, value); - } + }*/ } export const PrimaryIdColumn = process.env.DATABASE?.startsWith("mongodb") ? ObjectIdColumn : PrimaryColumn; diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index e7e97b7c3..7ca50992a 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -122,17 +122,19 @@ export class Member extends BaseClassWithoutId { } static async removeFromGuild(user_id: string, guild_id: string) { - const guild = await Guild.findOneOrFail({ select: ["owner_id"], where: { id: guild_id } }); + const guild = await Guild.findOneOrFail({ select: ["owner_id", "member_count"], where: { id: guild_id } }); if (guild.owner_id === user_id) throw new Error("The owner cannot be removed of the guild"); const member = await Member.findOneOrFail({ where: { id: user_id, guild_id }, relations: ["user"] }); // use promise all to execute all promises at the same time -> save time + //TODO: check for bugs + if(guild.member_count) guild.member_count--; return Promise.all([ Member.delete({ id: user_id, guild_id, }), - Guild.decrement({ id: guild_id }, "member_count", -1), + //Guild.decrement({ id: guild_id }, "member_count", -1), emitEvent({ event: "GUILD_DELETE", @@ -259,7 +261,8 @@ export class Member extends BaseClassWithoutId { mute: false, pending: false, }; - + //TODO: check for bugs + if(guild.member_count) guild.member_count++; await Promise.all([ new Member({ ...member, @@ -276,7 +279,7 @@ export class Member extends BaseClassWithoutId { }, // Member.save is needed because else the roles relations wouldn't be updated }).save(), - Guild.increment({ id: guild_id }, "member_count", 1), + //Guild.increment({ id: guild_id }, "member_count", 1), emitEvent({ event: "GUILD_MEMBER_ADD", data: { diff --git a/util/src/index.ts b/util/src/index.ts index ae0f7e54a..259d1c97b 100644 --- a/util/src/index.ts +++ b/util/src/index.ts @@ -4,3 +4,4 @@ export * from "./util/index"; export * from "./interfaces/index"; export * from "./entities/index"; export * from "./dtos/index"; +export * from "./util/MFA"; \ No newline at end of file diff --git a/util/src/migrations/1633864260873-EmojiRoles.ts b/util/src/migrations/1633864260873-EmojiRoles.ts deleted file mode 100644 index f0d709f20..000000000 --- a/util/src/migrations/1633864260873-EmojiRoles.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class EmojiRoles1633864260873 implements MigrationInterface { - name = "EmojiRoles1633864260873"; - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(`ALTER TABLE "emojis" ADD "roles" text NOT NULL DEFAULT ''`); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(`ALTER TABLE "emojis" DROP COLUMN column_name "roles"`); - } -} diff --git a/util/src/migrations/1633864669243-EmojiUser.ts b/util/src/migrations/1633864669243-EmojiUser.ts deleted file mode 100644 index 982405d73..000000000 --- a/util/src/migrations/1633864669243-EmojiUser.ts +++ /dev/null @@ -1,23 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class EmojiUser1633864669243 implements MigrationInterface { - name = "EmojiUser1633864669243"; - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(`ALTER TABLE "emojis" ADD "user_id" varchar`); - try { - await queryRunner.query( - `ALTER TABLE "emojis" ADD CONSTRAINT FK_fa7ddd5f9a214e28ce596548421 FOREIGN KEY (user_id) REFERENCES users(id)` - ); - } catch (error) { - console.error( - "sqlite doesn't support altering foreign keys: https://stackoverflow.com/questions/1884818/how-do-i-add-a-foreign-key-to-an-existing-sqlite-table" - ); - } - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(`ALTER TABLE "emojis" DROP COLUMN column_name "user_id"`); - await queryRunner.query(`ALTER TABLE "emojis" DROP CONSTRAINT FK_fa7ddd5f9a214e28ce596548421`); - } -} diff --git a/util/src/migrations/1633881705509-VanityInvite.ts b/util/src/migrations/1633881705509-VanityInvite.ts deleted file mode 100644 index 454853105..000000000 --- a/util/src/migrations/1633881705509-VanityInvite.ts +++ /dev/null @@ -1,19 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class VanityInvite1633881705509 implements MigrationInterface { - name = "VanityInvite1633881705509"; - - public async up(queryRunner: QueryRunner): Promise { - try { - await queryRunner.query(`ALTER TABLE "emojis" DROP COLUMN vanity_url_code`); - await queryRunner.query(`ALTER TABLE "emojis" DROP CONSTRAINT FK_c2c1809d79eb120ea0cb8d342ad`); - } catch (error) {} - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(`ALTER TABLE "emojis" ADD vanity_url_code varchar`); - await queryRunner.query( - `ALTER TABLE "emojis" ADD CONSTRAINT FK_c2c1809d79eb120ea0cb8d342ad FOREIGN KEY ("vanity_url_code") REFERENCES "invites"("code") ON DELETE NO ACTION ON UPDATE NO ACTION` - ); - } -} diff --git a/util/src/migrations/1634308884591-Stickers.ts b/util/src/migrations/1634308884591-Stickers.ts deleted file mode 100644 index fbc4649fe..000000000 --- a/util/src/migrations/1634308884591-Stickers.ts +++ /dev/null @@ -1,66 +0,0 @@ -import { MigrationInterface, QueryRunner, Table, TableColumn, TableForeignKey } from "typeorm"; - -export class Stickers1634308884591 implements MigrationInterface { - name = "Stickers1634308884591"; - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.dropForeignKey("read_states", "FK_6f255d873cfbfd7a93849b7ff74"); - await queryRunner.changeColumn( - "stickers", - "tags", - new TableColumn({ name: "tags", type: "varchar", isNullable: true }) - ); - await queryRunner.changeColumn( - "stickers", - "pack_id", - new TableColumn({ name: "pack_id", type: "varchar", isNullable: true }) - ); - await queryRunner.changeColumn("stickers", "type", new TableColumn({ name: "type", type: "integer" })); - await queryRunner.changeColumn( - "stickers", - "format_type", - new TableColumn({ name: "format_type", type: "integer" }) - ); - await queryRunner.changeColumn( - "stickers", - "available", - new TableColumn({ name: "available", type: "boolean", isNullable: true }) - ); - await queryRunner.changeColumn( - "stickers", - "user_id", - new TableColumn({ name: "user_id", type: "boolean", isNullable: true }) - ); - await queryRunner.createForeignKey( - "stickers", - new TableForeignKey({ - name: "FK_8f4ee73f2bb2325ff980502e158", - columnNames: ["user_id"], - referencedColumnNames: ["id"], - referencedTableName: "users", - onDelete: "CASCADE", - }) - ); - await queryRunner.createTable( - new Table({ - name: "sticker_packs", - columns: [ - new TableColumn({ name: "id", type: "varchar", isPrimary: true }), - new TableColumn({ name: "name", type: "varchar" }), - new TableColumn({ name: "description", type: "varchar", isNullable: true }), - new TableColumn({ name: "banner_asset_id", type: "varchar", isNullable: true }), - new TableColumn({ name: "cover_sticker_id", type: "varchar", isNullable: true }), - ], - foreignKeys: [ - new TableForeignKey({ - columnNames: ["cover_sticker_id"], - referencedColumnNames: ["id"], - referencedTableName: "stickers", - }), - ], - }) - ); - } - - public async down(queryRunner: QueryRunner): Promise {} -} diff --git a/util/src/migrations/1634424361103-Presence.ts b/util/src/migrations/1634424361103-Presence.ts deleted file mode 100644 index 729955b8e..000000000 --- a/util/src/migrations/1634424361103-Presence.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { MigrationInterface, QueryRunner, TableColumn } from "typeorm"; - -export class Presence1634424361103 implements MigrationInterface { - name = "Presence1634424361103"; - - public async up(queryRunner: QueryRunner): Promise { - queryRunner.addColumn("sessions", new TableColumn({ name: "activites", type: "text" })); - } - - public async down(queryRunner: QueryRunner): Promise {} -} diff --git a/util/src/migrations/1634426540271-MigrationTimestamp.ts b/util/src/migrations/1634426540271-MigrationTimestamp.ts deleted file mode 100644 index 3208b25b2..000000000 --- a/util/src/migrations/1634426540271-MigrationTimestamp.ts +++ /dev/null @@ -1,15 +0,0 @@ -import { MigrationInterface, QueryRunner, TableColumn } from "typeorm"; - -export class MigrationTimestamp1634426540271 implements MigrationInterface { - name = "MigrationTimestamp1634426540271"; - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.changeColumn( - "migrations", - "timestamp", - new TableColumn({ name: "timestampe", type: "bigint", isNullable: false }) - ); - } - - public async down(queryRunner: QueryRunner): Promise {} -} diff --git a/util/src/migrations/1648643945733-ReleaseTypo.ts b/util/src/migrations/1648643945733-ReleaseTypo.ts deleted file mode 100644 index 944b9dd9e..000000000 --- a/util/src/migrations/1648643945733-ReleaseTypo.ts +++ /dev/null @@ -1,16 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class ReleaseTypo1648643945733 implements MigrationInterface { - name = "ReleaseTypo1648643945733"; - - public async up(queryRunner: QueryRunner): Promise { - //drop table first because typeorm creates it before migrations run - await queryRunner.dropTable("client_release", true); - await queryRunner.renameTable("client_relase", "client_release"); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.dropTable("client_relase", true); - await queryRunner.renameTable("client_release", "client_relase"); - } -} diff --git a/util/src/migrations/postgres/1659833042721-test.ts b/util/src/migrations/postgres/1659833042721-test.ts new file mode 100644 index 000000000..0820cca74 --- /dev/null +++ b/util/src/migrations/postgres/1659833042721-test.ts @@ -0,0 +1,3539 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class test1659833042721 implements MigrationInterface { + name = 'test1659833042721' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "config" ("key" varchar PRIMARY KEY NOT NULL, "value" text) + `); + await queryRunner.query(` + CREATE TABLE "relationships" ( + "id" varchar PRIMARY KEY NOT NULL, + "from_id" varchar NOT NULL, + "to_id" varchar NOT NULL, + "nickname" varchar, + "type" integer NOT NULL + ) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_a0b2ff0a598df0b0d055934a17" ON "relationships" ("from_id", "to_id") + `); + await queryRunner.query(` + CREATE TABLE "connected_accounts" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "access_token" varchar NOT NULL, + "friend_sync" boolean NOT NULL, + "name" varchar NOT NULL, + "revoked" boolean NOT NULL, + "show_activity" boolean NOT NULL, + "type" varchar NOT NULL, + "verified" boolean NOT NULL, + "visibility" integer NOT NULL + ) + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "settings" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL + ) + `); + await queryRunner.query(` + CREATE TABLE "backup_codes" ( + "id" varchar PRIMARY KEY NOT NULL, + "code" varchar NOT NULL, + "consumed" boolean NOT NULL, + "expired" boolean NOT NULL, + "user_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "bans" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "guild_id" varchar, + "executor_id" varchar, + "ip" varchar NOT NULL, + "reason" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "recipients" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar NOT NULL, + "user_id" varchar NOT NULL, + "closed" boolean NOT NULL DEFAULT (0) + ) + `); + await queryRunner.query(` + CREATE TABLE "roles" ( + "id" varchar PRIMARY KEY NOT NULL, + "guild_id" varchar, + "color" integer NOT NULL, + "hoist" boolean NOT NULL, + "managed" boolean NOT NULL, + "mentionable" boolean NOT NULL, + "name" varchar NOT NULL, + "permissions" varchar NOT NULL, + "position" integer NOT NULL, + "icon" varchar, + "unicode_emoji" varchar, + "tags" text + ) + `); + await queryRunner.query(` + CREATE TABLE "members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar + ) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + await queryRunner.query(` + CREATE TABLE "webhooks" ( + "id" varchar PRIMARY KEY NOT NULL, + "type" integer NOT NULL, + "name" varchar, + "avatar" varchar, + "token" varchar, + "guild_id" varchar, + "channel_id" varchar, + "application_id" varchar, + "user_id" varchar, + "source_guild_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "stickers" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "available" boolean, + "tags" varchar, + "pack_id" varchar, + "guild_id" varchar, + "user_id" varchar, + "type" integer NOT NULL, + "format_type" integer NOT NULL + ) + `); + await queryRunner.query(` + CREATE TABLE "attachments" ( + "id" varchar PRIMARY KEY NOT NULL, + "filename" varchar NOT NULL, + "size" integer NOT NULL, + "url" varchar NOT NULL, + "proxy_url" varchar NOT NULL, + "height" integer, + "width" integer, + "content_type" varchar, + "message_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "messages" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar, + "guild_id" varchar, + "author_id" varchar, + "member_id" varchar, + "webhook_id" varchar, + "application_id" varchar, + "content" varchar, + "timestamp" datetime NOT NULL DEFAULT (datetime('now')), + "edited_timestamp" datetime, + "tts" boolean, + "mention_everyone" boolean, + "embeds" text NOT NULL, + "reactions" text NOT NULL, + "nonce" text, + "pinned" boolean, + "type" integer NOT NULL, + "activity" text, + "flags" varchar, + "message_reference" text, + "interaction" text, + "components" text, + "message_reference_id" varchar + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" ON "messages" ("channel_id") + `); + await queryRunner.query(` + CREATE INDEX "IDX_05535bc695e9f7ee104616459d" ON "messages" ("author_id") + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" ON "messages" ("channel_id", "id") + `); + await queryRunner.query(` + CREATE TABLE "read_states" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar NOT NULL, + "user_id" varchar NOT NULL, + "last_message_id" varchar, + "public_ack" varchar, + "notifications_cursor" varchar, + "last_pin_timestamp" datetime, + "mention_count" integer + ) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_0abf8b443321bd3cf7f81ee17a" ON "read_states" ("channel_id", "user_id") + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean + ) + `); + await queryRunner.query(` + CREATE TABLE "voice_states" ( + "id" varchar PRIMARY KEY NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "user_id" varchar, + "session_id" varchar NOT NULL, + "token" varchar, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "self_deaf" boolean NOT NULL, + "self_mute" boolean NOT NULL, + "self_stream" boolean, + "self_video" boolean NOT NULL, + "suppress" boolean NOT NULL, + "request_to_speak_timestamp" datetime + ) + `); + await queryRunner.query(` + CREATE TABLE "channels" ( + "id" varchar PRIMARY KEY NOT NULL, + "created_at" datetime NOT NULL, + "name" varchar, + "icon" text, + "type" integer NOT NULL, + "last_message_id" varchar, + "guild_id" varchar, + "parent_id" varchar, + "owner_id" varchar, + "last_pin_timestamp" integer, + "default_auto_archive_duration" integer, + "position" integer, + "permission_overwrites" text, + "video_quality_mode" integer, + "bitrate" integer, + "user_limit" integer, + "nsfw" boolean, + "rate_limit_per_user" integer, + "topic" varchar, + "retention_policy_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "emojis" ( + "id" varchar PRIMARY KEY NOT NULL, + "animated" boolean NOT NULL, + "available" boolean NOT NULL, + "guild_id" varchar NOT NULL, + "user_id" varchar, + "managed" boolean NOT NULL, + "name" varchar NOT NULL, + "require_colons" boolean NOT NULL, + "roles" text NOT NULL, + "groups" text + ) + `); + await queryRunner.query(` + CREATE TABLE "templates" ( + "id" varchar PRIMARY KEY NOT NULL, + "code" varchar NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "usage_count" integer, + "creator_id" varchar, + "created_at" datetime NOT NULL, + "updated_at" datetime NOT NULL, + "source_guild_id" varchar, + "serialized_source_guild" text NOT NULL, + CONSTRAINT "UQ_be38737bf339baf63b1daeffb55" UNIQUE ("code") + ) + `); + await queryRunner.query(` + CREATE TABLE "guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "team_members" ( + "id" varchar PRIMARY KEY NOT NULL, + "membership_state" integer NOT NULL, + "permissions" text NOT NULL, + "team_id" varchar, + "user_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "teams" ( + "id" varchar PRIMARY KEY NOT NULL, + "icon" varchar, + "name" varchar NOT NULL, + "owner_user_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "primary_sku_id" varchar, + "slug" varchar, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "guild_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "audit_logs" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "action_type" integer NOT NULL, + "options" text, + "changes" text NOT NULL, + "reason" varchar, + "target_id" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "categories" ( + "id" integer PRIMARY KEY NOT NULL, + "name" varchar, + "localizations" text NOT NULL, + "is_primary" boolean + ) + `); + await queryRunner.query(` + CREATE TABLE "migrations" ( + "id" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "timestamp" bigint NOT NULL, + "name" varchar NOT NULL + ) + `); + await queryRunner.query(` + CREATE TABLE "rate_limits" ( + "id" varchar PRIMARY KEY NOT NULL, + "executor_id" varchar NOT NULL, + "hits" integer NOT NULL, + "blocked" boolean NOT NULL, + "expires_at" datetime NOT NULL + ) + `); + await queryRunner.query(` + CREATE TABLE "sessions" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "session_id" varchar NOT NULL, + "activities" text, + "client_info" text NOT NULL, + "status" varchar NOT NULL + ) + `); + await queryRunner.query(` + CREATE TABLE "sticker_packs" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "banner_asset_id" varchar, + "cover_sticker_id" varchar, + "coverStickerId" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "client_release" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "pub_date" varchar NOT NULL, + "url" varchar NOT NULL, + "deb_url" varchar NOT NULL, + "osx_url" varchar NOT NULL, + "win_url" varchar NOT NULL, + "notes" varchar + ) + `); + await queryRunner.query(` + CREATE TABLE "notes" ( + "id" varchar PRIMARY KEY NOT NULL, + "content" varchar NOT NULL, + "owner_id" varchar, + "target_id" varchar, + CONSTRAINT "UQ_74e6689b9568cc965b8bfc9150b" UNIQUE ("owner_id", "target_id") + ) + `); + await queryRunner.query(` + CREATE TABLE "member_roles" ( + "index" integer NOT NULL, + "role_id" varchar NOT NULL, + PRIMARY KEY ("index", "role_id") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_5d7ddc8a5f9c167f548625e772" ON "member_roles" ("index") + `); + await queryRunner.query(` + CREATE INDEX "IDX_e9080e7a7997a0170026d5139c" ON "member_roles" ("role_id") + `); + await queryRunner.query(` + CREATE TABLE "message_user_mentions" ( + "messagesId" varchar NOT NULL, + "usersId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "usersId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_a343387fc560ef378760681c23" ON "message_user_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_b831eb18ceebd28976239b1e2f" ON "message_user_mentions" ("usersId") + `); + await queryRunner.query(` + CREATE TABLE "message_role_mentions" ( + "messagesId" varchar NOT NULL, + "rolesId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "rolesId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_a8242cf535337a490b0feaea0b" ON "message_role_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_29d63eb1a458200851bc37d074" ON "message_role_mentions" ("rolesId") + `); + await queryRunner.query(` + CREATE TABLE "message_channel_mentions" ( + "messagesId" varchar NOT NULL, + "channelsId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "channelsId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_2a27102ecd1d81b4582a436092" ON "message_channel_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_bdb8c09e1464cabf62105bf4b9" ON "message_channel_mentions" ("channelsId") + `); + await queryRunner.query(` + CREATE TABLE "message_stickers" ( + "messagesId" varchar NOT NULL, + "stickersId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "stickersId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_40bb6f23e7cc133292e92829d2" ON "message_stickers" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_e22a70819d07659c7a71c112a1" ON "message_stickers" ("stickersId") + `); + await queryRunner.query(` + DROP INDEX "IDX_a0b2ff0a598df0b0d055934a17" + `); + await queryRunner.query(` + CREATE TABLE "temporary_relationships" ( + "id" varchar PRIMARY KEY NOT NULL, + "from_id" varchar NOT NULL, + "to_id" varchar NOT NULL, + "nickname" varchar, + "type" integer NOT NULL, + CONSTRAINT "FK_9af4194bab1250b1c584ae4f1d7" FOREIGN KEY ("from_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_9c7f6b98a9843b76dce1b0c878b" FOREIGN KEY ("to_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_relationships"("id", "from_id", "to_id", "nickname", "type") + SELECT "id", + "from_id", + "to_id", + "nickname", + "type" + FROM "relationships" + `); + await queryRunner.query(` + DROP TABLE "relationships" + `); + await queryRunner.query(` + ALTER TABLE "temporary_relationships" + RENAME TO "relationships" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_a0b2ff0a598df0b0d055934a17" ON "relationships" ("from_id", "to_id") + `); + await queryRunner.query(` + CREATE TABLE "temporary_connected_accounts" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "access_token" varchar NOT NULL, + "friend_sync" boolean NOT NULL, + "name" varchar NOT NULL, + "revoked" boolean NOT NULL, + "show_activity" boolean NOT NULL, + "type" varchar NOT NULL, + "verified" boolean NOT NULL, + "visibility" integer NOT NULL, + CONSTRAINT "FK_f47244225a6a1eac04a3463dd90" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_connected_accounts"( + "id", + "user_id", + "access_token", + "friend_sync", + "name", + "revoked", + "show_activity", + "type", + "verified", + "visibility" + ) + SELECT "id", + "user_id", + "access_token", + "friend_sync", + "name", + "revoked", + "show_activity", + "type", + "verified", + "visibility" + FROM "connected_accounts" + `); + await queryRunner.query(` + DROP TABLE "connected_accounts" + `); + await queryRunner.query(` + ALTER TABLE "temporary_connected_accounts" + RENAME TO "connected_accounts" + `); + await queryRunner.query(` + CREATE TABLE "temporary_backup_codes" ( + "id" varchar PRIMARY KEY NOT NULL, + "code" varchar NOT NULL, + "consumed" boolean NOT NULL, + "expired" boolean NOT NULL, + "user_id" varchar, + CONSTRAINT "FK_70066ea80d2f4b871beda32633b" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_backup_codes"("id", "code", "consumed", "expired", "user_id") + SELECT "id", + "code", + "consumed", + "expired", + "user_id" + FROM "backup_codes" + `); + await queryRunner.query(` + DROP TABLE "backup_codes" + `); + await queryRunner.query(` + ALTER TABLE "temporary_backup_codes" + RENAME TO "backup_codes" + `); + await queryRunner.query(` + CREATE TABLE "temporary_bans" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "guild_id" varchar, + "executor_id" varchar, + "ip" varchar NOT NULL, + "reason" varchar, + CONSTRAINT "FK_5999e8e449f80a236ff72023559" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_9d3ab7dd180ebdd245cdb66ecad" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_07ad88c86d1f290d46748410d58" FOREIGN KEY ("executor_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_bans"( + "id", + "user_id", + "guild_id", + "executor_id", + "ip", + "reason" + ) + SELECT "id", + "user_id", + "guild_id", + "executor_id", + "ip", + "reason" + FROM "bans" + `); + await queryRunner.query(` + DROP TABLE "bans" + `); + await queryRunner.query(` + ALTER TABLE "temporary_bans" + RENAME TO "bans" + `); + await queryRunner.query(` + CREATE TABLE "temporary_recipients" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar NOT NULL, + "user_id" varchar NOT NULL, + "closed" boolean NOT NULL DEFAULT (0), + CONSTRAINT "FK_2f18ee1ba667f233ae86c0ea60e" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6157e8b6ba4e6e3089616481fe2" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_recipients"("id", "channel_id", "user_id", "closed") + SELECT "id", + "channel_id", + "user_id", + "closed" + FROM "recipients" + `); + await queryRunner.query(` + DROP TABLE "recipients" + `); + await queryRunner.query(` + ALTER TABLE "temporary_recipients" + RENAME TO "recipients" + `); + await queryRunner.query(` + CREATE TABLE "temporary_roles" ( + "id" varchar PRIMARY KEY NOT NULL, + "guild_id" varchar, + "color" integer NOT NULL, + "hoist" boolean NOT NULL, + "managed" boolean NOT NULL, + "mentionable" boolean NOT NULL, + "name" varchar NOT NULL, + "permissions" varchar NOT NULL, + "position" integer NOT NULL, + "icon" varchar, + "unicode_emoji" varchar, + "tags" text, + CONSTRAINT "FK_c32c1ab1c4dc7dcb0278c4b1b8b" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_roles"( + "id", + "guild_id", + "color", + "hoist", + "managed", + "mentionable", + "name", + "permissions", + "position", + "icon", + "unicode_emoji", + "tags" + ) + SELECT "id", + "guild_id", + "color", + "hoist", + "managed", + "mentionable", + "name", + "permissions", + "position", + "icon", + "unicode_emoji", + "tags" + FROM "roles" + `); + await queryRunner.query(` + DROP TABLE "roles" + `); + await queryRunner.query(` + ALTER TABLE "temporary_roles" + RENAME TO "roles" + `); + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + CREATE TABLE "temporary_members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar, + CONSTRAINT "FK_28b53062261b996d9c99fa12404" FOREIGN KEY ("id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_members"( + "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + ) + SELECT "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + FROM "members" + `); + await queryRunner.query(` + DROP TABLE "members" + `); + await queryRunner.query(` + ALTER TABLE "temporary_members" + RENAME TO "members" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + await queryRunner.query(` + CREATE TABLE "temporary_webhooks" ( + "id" varchar PRIMARY KEY NOT NULL, + "type" integer NOT NULL, + "name" varchar, + "avatar" varchar, + "token" varchar, + "guild_id" varchar, + "channel_id" varchar, + "application_id" varchar, + "user_id" varchar, + "source_guild_id" varchar, + CONSTRAINT "FK_487a7af59d189f744fe394368fc" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_df528cf77e82f8032230e7e37d8" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_c3e5305461931763b56aa905f1c" FOREIGN KEY ("application_id") REFERENCES "applications" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_0d523f6f997c86e052c49b1455f" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3a285f4f49c40e0706d3018bc9f" FOREIGN KEY ("source_guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_webhooks"( + "id", + "type", + "name", + "avatar", + "token", + "guild_id", + "channel_id", + "application_id", + "user_id", + "source_guild_id" + ) + SELECT "id", + "type", + "name", + "avatar", + "token", + "guild_id", + "channel_id", + "application_id", + "user_id", + "source_guild_id" + FROM "webhooks" + `); + await queryRunner.query(` + DROP TABLE "webhooks" + `); + await queryRunner.query(` + ALTER TABLE "temporary_webhooks" + RENAME TO "webhooks" + `); + await queryRunner.query(` + CREATE TABLE "temporary_stickers" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "available" boolean, + "tags" varchar, + "pack_id" varchar, + "guild_id" varchar, + "user_id" varchar, + "type" integer NOT NULL, + "format_type" integer NOT NULL, + CONSTRAINT "FK_e7cfa5cefa6661b3fb8fda8ce69" FOREIGN KEY ("pack_id") REFERENCES "sticker_packs" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_193d551d852aca5347ef5c9f205" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_8f4ee73f2bb2325ff980502e158" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_stickers"( + "id", + "name", + "description", + "available", + "tags", + "pack_id", + "guild_id", + "user_id", + "type", + "format_type" + ) + SELECT "id", + "name", + "description", + "available", + "tags", + "pack_id", + "guild_id", + "user_id", + "type", + "format_type" + FROM "stickers" + `); + await queryRunner.query(` + DROP TABLE "stickers" + `); + await queryRunner.query(` + ALTER TABLE "temporary_stickers" + RENAME TO "stickers" + `); + await queryRunner.query(` + CREATE TABLE "temporary_attachments" ( + "id" varchar PRIMARY KEY NOT NULL, + "filename" varchar NOT NULL, + "size" integer NOT NULL, + "url" varchar NOT NULL, + "proxy_url" varchar NOT NULL, + "height" integer, + "width" integer, + "content_type" varchar, + "message_id" varchar, + CONSTRAINT "FK_623e10eec51ada466c5038979e3" FOREIGN KEY ("message_id") REFERENCES "messages" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_attachments"( + "id", + "filename", + "size", + "url", + "proxy_url", + "height", + "width", + "content_type", + "message_id" + ) + SELECT "id", + "filename", + "size", + "url", + "proxy_url", + "height", + "width", + "content_type", + "message_id" + FROM "attachments" + `); + await queryRunner.query(` + DROP TABLE "attachments" + `); + await queryRunner.query(` + ALTER TABLE "temporary_attachments" + RENAME TO "attachments" + `); + await queryRunner.query(` + DROP INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" + `); + await queryRunner.query(` + DROP INDEX "IDX_05535bc695e9f7ee104616459d" + `); + await queryRunner.query(` + DROP INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" + `); + await queryRunner.query(` + CREATE TABLE "temporary_messages" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar, + "guild_id" varchar, + "author_id" varchar, + "member_id" varchar, + "webhook_id" varchar, + "application_id" varchar, + "content" varchar, + "timestamp" datetime NOT NULL DEFAULT (datetime('now')), + "edited_timestamp" datetime, + "tts" boolean, + "mention_everyone" boolean, + "embeds" text NOT NULL, + "reactions" text NOT NULL, + "nonce" text, + "pinned" boolean, + "type" integer NOT NULL, + "activity" text, + "flags" varchar, + "message_reference" text, + "interaction" text, + "components" text, + "message_reference_id" varchar, + CONSTRAINT "FK_86b9109b155eb70c0a2ca3b4b6d" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_b193588441b085352a4c0109423" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_05535bc695e9f7ee104616459d3" FOREIGN KEY ("author_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_b0525304f2262b7014245351c76" FOREIGN KEY ("member_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_f83c04bcf1df4e5c0e7a52ed348" FOREIGN KEY ("webhook_id") REFERENCES "webhooks" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_5d3ec1cb962de6488637fd779d6" FOREIGN KEY ("application_id") REFERENCES "applications" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_61a92bb65b302a76d9c1fcd3174" FOREIGN KEY ("message_reference_id") REFERENCES "messages" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_messages"( + "id", + "channel_id", + "guild_id", + "author_id", + "member_id", + "webhook_id", + "application_id", + "content", + "timestamp", + "edited_timestamp", + "tts", + "mention_everyone", + "embeds", + "reactions", + "nonce", + "pinned", + "type", + "activity", + "flags", + "message_reference", + "interaction", + "components", + "message_reference_id" + ) + SELECT "id", + "channel_id", + "guild_id", + "author_id", + "member_id", + "webhook_id", + "application_id", + "content", + "timestamp", + "edited_timestamp", + "tts", + "mention_everyone", + "embeds", + "reactions", + "nonce", + "pinned", + "type", + "activity", + "flags", + "message_reference", + "interaction", + "components", + "message_reference_id" + FROM "messages" + `); + await queryRunner.query(` + DROP TABLE "messages" + `); + await queryRunner.query(` + ALTER TABLE "temporary_messages" + RENAME TO "messages" + `); + await queryRunner.query(` + CREATE INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" ON "messages" ("channel_id") + `); + await queryRunner.query(` + CREATE INDEX "IDX_05535bc695e9f7ee104616459d" ON "messages" ("author_id") + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" ON "messages" ("channel_id", "id") + `); + await queryRunner.query(` + DROP INDEX "IDX_0abf8b443321bd3cf7f81ee17a" + `); + await queryRunner.query(` + CREATE TABLE "temporary_read_states" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar NOT NULL, + "user_id" varchar NOT NULL, + "last_message_id" varchar, + "public_ack" varchar, + "notifications_cursor" varchar, + "last_pin_timestamp" datetime, + "mention_count" integer, + CONSTRAINT "FK_40da2fca4e0eaf7a23b5bfc5d34" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_195f92e4dd1254a4e348c043763" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_read_states"( + "id", + "channel_id", + "user_id", + "last_message_id", + "public_ack", + "notifications_cursor", + "last_pin_timestamp", + "mention_count" + ) + SELECT "id", + "channel_id", + "user_id", + "last_message_id", + "public_ack", + "notifications_cursor", + "last_pin_timestamp", + "mention_count" + FROM "read_states" + `); + await queryRunner.query(` + DROP TABLE "read_states" + `); + await queryRunner.query(` + ALTER TABLE "temporary_read_states" + RENAME TO "read_states" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_0abf8b443321bd3cf7f81ee17a" ON "read_states" ("channel_id", "user_id") + `); + await queryRunner.query(` + CREATE TABLE "temporary_invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "invites" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + ALTER TABLE "temporary_invites" + RENAME TO "invites" + `); + await queryRunner.query(` + CREATE TABLE "temporary_voice_states" ( + "id" varchar PRIMARY KEY NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "user_id" varchar, + "session_id" varchar NOT NULL, + "token" varchar, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "self_deaf" boolean NOT NULL, + "self_mute" boolean NOT NULL, + "self_stream" boolean, + "self_video" boolean NOT NULL, + "suppress" boolean NOT NULL, + "request_to_speak_timestamp" datetime, + CONSTRAINT "FK_03779ef216d4b0358470d9cb748" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_9f8d389866b40b6657edd026dd4" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_5fe1d5f931a67e85039c640001b" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_voice_states"( + "id", + "guild_id", + "channel_id", + "user_id", + "session_id", + "token", + "deaf", + "mute", + "self_deaf", + "self_mute", + "self_stream", + "self_video", + "suppress", + "request_to_speak_timestamp" + ) + SELECT "id", + "guild_id", + "channel_id", + "user_id", + "session_id", + "token", + "deaf", + "mute", + "self_deaf", + "self_mute", + "self_stream", + "self_video", + "suppress", + "request_to_speak_timestamp" + FROM "voice_states" + `); + await queryRunner.query(` + DROP TABLE "voice_states" + `); + await queryRunner.query(` + ALTER TABLE "temporary_voice_states" + RENAME TO "voice_states" + `); + await queryRunner.query(` + CREATE TABLE "temporary_channels" ( + "id" varchar PRIMARY KEY NOT NULL, + "created_at" datetime NOT NULL, + "name" varchar, + "icon" text, + "type" integer NOT NULL, + "last_message_id" varchar, + "guild_id" varchar, + "parent_id" varchar, + "owner_id" varchar, + "last_pin_timestamp" integer, + "default_auto_archive_duration" integer, + "position" integer, + "permission_overwrites" text, + "video_quality_mode" integer, + "bitrate" integer, + "user_limit" integer, + "nsfw" boolean, + "rate_limit_per_user" integer, + "topic" varchar, + "retention_policy_id" varchar, + CONSTRAINT "FK_c253dafe5f3a03ec00cd8fb4581" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3274522d14af40540b1a883fc80" FOREIGN KEY ("parent_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_3873ed438575cce703ecff4fc7b" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_channels"( + "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + ) + SELECT "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + FROM "channels" + `); + await queryRunner.query(` + DROP TABLE "channels" + `); + await queryRunner.query(` + ALTER TABLE "temporary_channels" + RENAME TO "channels" + `); + await queryRunner.query(` + CREATE TABLE "temporary_emojis" ( + "id" varchar PRIMARY KEY NOT NULL, + "animated" boolean NOT NULL, + "available" boolean NOT NULL, + "guild_id" varchar NOT NULL, + "user_id" varchar, + "managed" boolean NOT NULL, + "name" varchar NOT NULL, + "require_colons" boolean NOT NULL, + "roles" text NOT NULL, + "groups" text, + CONSTRAINT "FK_4b988e0db89d94cebcf07f598cc" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_fa7ddd5f9a214e28ce596548421" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_emojis"( + "id", + "animated", + "available", + "guild_id", + "user_id", + "managed", + "name", + "require_colons", + "roles", + "groups" + ) + SELECT "id", + "animated", + "available", + "guild_id", + "user_id", + "managed", + "name", + "require_colons", + "roles", + "groups" + FROM "emojis" + `); + await queryRunner.query(` + DROP TABLE "emojis" + `); + await queryRunner.query(` + ALTER TABLE "temporary_emojis" + RENAME TO "emojis" + `); + await queryRunner.query(` + CREATE TABLE "temporary_templates" ( + "id" varchar PRIMARY KEY NOT NULL, + "code" varchar NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "usage_count" integer, + "creator_id" varchar, + "created_at" datetime NOT NULL, + "updated_at" datetime NOT NULL, + "source_guild_id" varchar, + "serialized_source_guild" text NOT NULL, + CONSTRAINT "UQ_be38737bf339baf63b1daeffb55" UNIQUE ("code"), + CONSTRAINT "FK_d7374b7f8f5fbfdececa4fb62e1" FOREIGN KEY ("creator_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_445d00eaaea0e60a017a5ed0c11" FOREIGN KEY ("source_guild_id") REFERENCES "guilds" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_templates"( + "id", + "code", + "name", + "description", + "usage_count", + "creator_id", + "created_at", + "updated_at", + "source_guild_id", + "serialized_source_guild" + ) + SELECT "id", + "code", + "name", + "description", + "usage_count", + "creator_id", + "created_at", + "updated_at", + "source_guild_id", + "serialized_source_guild" + FROM "templates" + `); + await queryRunner.query(` + DROP TABLE "templates" + `); + await queryRunner.query(` + ALTER TABLE "temporary_templates" + RENAME TO "templates" + `); + await queryRunner.query(` + CREATE TABLE "temporary_guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + FROM "guilds" + `); + await queryRunner.query(` + DROP TABLE "guilds" + `); + await queryRunner.query(` + ALTER TABLE "temporary_guilds" + RENAME TO "guilds" + `); + await queryRunner.query(` + CREATE TABLE "temporary_team_members" ( + "id" varchar PRIMARY KEY NOT NULL, + "membership_state" integer NOT NULL, + "permissions" text NOT NULL, + "team_id" varchar, + "user_id" varchar, + CONSTRAINT "FK_fdad7d5768277e60c40e01cdcea" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_c2bf4967c8c2a6b845dadfbf3d4" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_team_members"( + "id", + "membership_state", + "permissions", + "team_id", + "user_id" + ) + SELECT "id", + "membership_state", + "permissions", + "team_id", + "user_id" + FROM "team_members" + `); + await queryRunner.query(` + DROP TABLE "team_members" + `); + await queryRunner.query(` + ALTER TABLE "temporary_team_members" + RENAME TO "team_members" + `); + await queryRunner.query(` + CREATE TABLE "temporary_teams" ( + "id" varchar PRIMARY KEY NOT NULL, + "icon" varchar, + "name" varchar NOT NULL, + "owner_user_id" varchar, + CONSTRAINT "FK_13f00abf7cb6096c43ecaf8c108" FOREIGN KEY ("owner_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_teams"("id", "icon", "name", "owner_user_id") + SELECT "id", + "icon", + "name", + "owner_user_id" + FROM "teams" + `); + await queryRunner.query(` + DROP TABLE "teams" + `); + await queryRunner.query(` + ALTER TABLE "temporary_teams" + RENAME TO "teams" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "primary_sku_id" varchar, + "slug" varchar, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "guild_id" varchar, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e5bf78cdbbe9ba91062d74c5aba" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + ) + SELECT "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_audit_logs" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "action_type" integer NOT NULL, + "options" text, + "changes" text NOT NULL, + "reason" varchar, + "target_id" varchar, + CONSTRAINT "FK_3cd01cd3ae7aab010310d96ac8e" FOREIGN KEY ("target_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_bd2726fd31b35443f2245b93ba0" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_audit_logs"( + "id", + "user_id", + "action_type", + "options", + "changes", + "reason", + "target_id" + ) + SELECT "id", + "user_id", + "action_type", + "options", + "changes", + "reason", + "target_id" + FROM "audit_logs" + `); + await queryRunner.query(` + DROP TABLE "audit_logs" + `); + await queryRunner.query(` + ALTER TABLE "temporary_audit_logs" + RENAME TO "audit_logs" + `); + await queryRunner.query(` + CREATE TABLE "temporary_sessions" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "session_id" varchar NOT NULL, + "activities" text, + "client_info" text NOT NULL, + "status" varchar NOT NULL, + CONSTRAINT "FK_085d540d9f418cfbdc7bd55bb19" FOREIGN KEY ("user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_sessions"( + "id", + "user_id", + "session_id", + "activities", + "client_info", + "status" + ) + SELECT "id", + "user_id", + "session_id", + "activities", + "client_info", + "status" + FROM "sessions" + `); + await queryRunner.query(` + DROP TABLE "sessions" + `); + await queryRunner.query(` + ALTER TABLE "temporary_sessions" + RENAME TO "sessions" + `); + await queryRunner.query(` + CREATE TABLE "temporary_sticker_packs" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "banner_asset_id" varchar, + "cover_sticker_id" varchar, + "coverStickerId" varchar, + CONSTRAINT "FK_448fafba4355ee1c837bbc865f1" FOREIGN KEY ("coverStickerId") REFERENCES "stickers" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_sticker_packs"( + "id", + "name", + "description", + "banner_asset_id", + "cover_sticker_id", + "coverStickerId" + ) + SELECT "id", + "name", + "description", + "banner_asset_id", + "cover_sticker_id", + "coverStickerId" + FROM "sticker_packs" + `); + await queryRunner.query(` + DROP TABLE "sticker_packs" + `); + await queryRunner.query(` + ALTER TABLE "temporary_sticker_packs" + RENAME TO "sticker_packs" + `); + await queryRunner.query(` + CREATE TABLE "temporary_notes" ( + "id" varchar PRIMARY KEY NOT NULL, + "content" varchar NOT NULL, + "owner_id" varchar, + "target_id" varchar, + CONSTRAINT "UQ_74e6689b9568cc965b8bfc9150b" UNIQUE ("owner_id", "target_id"), + CONSTRAINT "FK_f9e103f8ae67cb1787063597925" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_23e08e5b4481711d573e1abecdc" FOREIGN KEY ("target_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_notes"("id", "content", "owner_id", "target_id") + SELECT "id", + "content", + "owner_id", + "target_id" + FROM "notes" + `); + await queryRunner.query(` + DROP TABLE "notes" + `); + await queryRunner.query(` + ALTER TABLE "temporary_notes" + RENAME TO "notes" + `); + await queryRunner.query(` + DROP INDEX "IDX_5d7ddc8a5f9c167f548625e772" + `); + await queryRunner.query(` + DROP INDEX "IDX_e9080e7a7997a0170026d5139c" + `); + await queryRunner.query(` + CREATE TABLE "temporary_member_roles" ( + "index" integer NOT NULL, + "role_id" varchar NOT NULL, + CONSTRAINT "FK_5d7ddc8a5f9c167f548625e772e" FOREIGN KEY ("index") REFERENCES "members" ("index") ON DELETE CASCADE ON UPDATE CASCADE, + CONSTRAINT "FK_e9080e7a7997a0170026d5139c1" FOREIGN KEY ("role_id") REFERENCES "roles" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + PRIMARY KEY ("index", "role_id") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_member_roles"("index", "role_id") + SELECT "index", + "role_id" + FROM "member_roles" + `); + await queryRunner.query(` + DROP TABLE "member_roles" + `); + await queryRunner.query(` + ALTER TABLE "temporary_member_roles" + RENAME TO "member_roles" + `); + await queryRunner.query(` + CREATE INDEX "IDX_5d7ddc8a5f9c167f548625e772" ON "member_roles" ("index") + `); + await queryRunner.query(` + CREATE INDEX "IDX_e9080e7a7997a0170026d5139c" ON "member_roles" ("role_id") + `); + await queryRunner.query(` + DROP INDEX "IDX_a343387fc560ef378760681c23" + `); + await queryRunner.query(` + DROP INDEX "IDX_b831eb18ceebd28976239b1e2f" + `); + await queryRunner.query(` + CREATE TABLE "temporary_message_user_mentions" ( + "messagesId" varchar NOT NULL, + "usersId" varchar NOT NULL, + CONSTRAINT "FK_a343387fc560ef378760681c236" FOREIGN KEY ("messagesId") REFERENCES "messages" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + CONSTRAINT "FK_b831eb18ceebd28976239b1e2f8" FOREIGN KEY ("usersId") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + PRIMARY KEY ("messagesId", "usersId") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_message_user_mentions"("messagesId", "usersId") + SELECT "messagesId", + "usersId" + FROM "message_user_mentions" + `); + await queryRunner.query(` + DROP TABLE "message_user_mentions" + `); + await queryRunner.query(` + ALTER TABLE "temporary_message_user_mentions" + RENAME TO "message_user_mentions" + `); + await queryRunner.query(` + CREATE INDEX "IDX_a343387fc560ef378760681c23" ON "message_user_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_b831eb18ceebd28976239b1e2f" ON "message_user_mentions" ("usersId") + `); + await queryRunner.query(` + DROP INDEX "IDX_a8242cf535337a490b0feaea0b" + `); + await queryRunner.query(` + DROP INDEX "IDX_29d63eb1a458200851bc37d074" + `); + await queryRunner.query(` + CREATE TABLE "temporary_message_role_mentions" ( + "messagesId" varchar NOT NULL, + "rolesId" varchar NOT NULL, + CONSTRAINT "FK_a8242cf535337a490b0feaea0b4" FOREIGN KEY ("messagesId") REFERENCES "messages" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + CONSTRAINT "FK_29d63eb1a458200851bc37d074b" FOREIGN KEY ("rolesId") REFERENCES "roles" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + PRIMARY KEY ("messagesId", "rolesId") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_message_role_mentions"("messagesId", "rolesId") + SELECT "messagesId", + "rolesId" + FROM "message_role_mentions" + `); + await queryRunner.query(` + DROP TABLE "message_role_mentions" + `); + await queryRunner.query(` + ALTER TABLE "temporary_message_role_mentions" + RENAME TO "message_role_mentions" + `); + await queryRunner.query(` + CREATE INDEX "IDX_a8242cf535337a490b0feaea0b" ON "message_role_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_29d63eb1a458200851bc37d074" ON "message_role_mentions" ("rolesId") + `); + await queryRunner.query(` + DROP INDEX "IDX_2a27102ecd1d81b4582a436092" + `); + await queryRunner.query(` + DROP INDEX "IDX_bdb8c09e1464cabf62105bf4b9" + `); + await queryRunner.query(` + CREATE TABLE "temporary_message_channel_mentions" ( + "messagesId" varchar NOT NULL, + "channelsId" varchar NOT NULL, + CONSTRAINT "FK_2a27102ecd1d81b4582a4360921" FOREIGN KEY ("messagesId") REFERENCES "messages" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + CONSTRAINT "FK_bdb8c09e1464cabf62105bf4b9d" FOREIGN KEY ("channelsId") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + PRIMARY KEY ("messagesId", "channelsId") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_message_channel_mentions"("messagesId", "channelsId") + SELECT "messagesId", + "channelsId" + FROM "message_channel_mentions" + `); + await queryRunner.query(` + DROP TABLE "message_channel_mentions" + `); + await queryRunner.query(` + ALTER TABLE "temporary_message_channel_mentions" + RENAME TO "message_channel_mentions" + `); + await queryRunner.query(` + CREATE INDEX "IDX_2a27102ecd1d81b4582a436092" ON "message_channel_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_bdb8c09e1464cabf62105bf4b9" ON "message_channel_mentions" ("channelsId") + `); + await queryRunner.query(` + DROP INDEX "IDX_40bb6f23e7cc133292e92829d2" + `); + await queryRunner.query(` + DROP INDEX "IDX_e22a70819d07659c7a71c112a1" + `); + await queryRunner.query(` + CREATE TABLE "temporary_message_stickers" ( + "messagesId" varchar NOT NULL, + "stickersId" varchar NOT NULL, + CONSTRAINT "FK_40bb6f23e7cc133292e92829d28" FOREIGN KEY ("messagesId") REFERENCES "messages" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + CONSTRAINT "FK_e22a70819d07659c7a71c112a1f" FOREIGN KEY ("stickersId") REFERENCES "stickers" ("id") ON DELETE CASCADE ON UPDATE CASCADE, + PRIMARY KEY ("messagesId", "stickersId") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_message_stickers"("messagesId", "stickersId") + SELECT "messagesId", + "stickersId" + FROM "message_stickers" + `); + await queryRunner.query(` + DROP TABLE "message_stickers" + `); + await queryRunner.query(` + ALTER TABLE "temporary_message_stickers" + RENAME TO "message_stickers" + `); + await queryRunner.query(` + CREATE INDEX "IDX_40bb6f23e7cc133292e92829d2" ON "message_stickers" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_e22a70819d07659c7a71c112a1" ON "message_stickers" ("stickersId") + `); + await queryRunner.query(` + CREATE TABLE "query-result-cache" ( + "id" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "identifier" varchar, + "time" bigint NOT NULL, + "duration" integer NOT NULL, + "query" text NOT NULL, + "result" text NOT NULL + ) + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP TABLE "query-result-cache" + `); + await queryRunner.query(` + DROP INDEX "IDX_e22a70819d07659c7a71c112a1" + `); + await queryRunner.query(` + DROP INDEX "IDX_40bb6f23e7cc133292e92829d2" + `); + await queryRunner.query(` + ALTER TABLE "message_stickers" + RENAME TO "temporary_message_stickers" + `); + await queryRunner.query(` + CREATE TABLE "message_stickers" ( + "messagesId" varchar NOT NULL, + "stickersId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "stickersId") + ) + `); + await queryRunner.query(` + INSERT INTO "message_stickers"("messagesId", "stickersId") + SELECT "messagesId", + "stickersId" + FROM "temporary_message_stickers" + `); + await queryRunner.query(` + DROP TABLE "temporary_message_stickers" + `); + await queryRunner.query(` + CREATE INDEX "IDX_e22a70819d07659c7a71c112a1" ON "message_stickers" ("stickersId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_40bb6f23e7cc133292e92829d2" ON "message_stickers" ("messagesId") + `); + await queryRunner.query(` + DROP INDEX "IDX_bdb8c09e1464cabf62105bf4b9" + `); + await queryRunner.query(` + DROP INDEX "IDX_2a27102ecd1d81b4582a436092" + `); + await queryRunner.query(` + ALTER TABLE "message_channel_mentions" + RENAME TO "temporary_message_channel_mentions" + `); + await queryRunner.query(` + CREATE TABLE "message_channel_mentions" ( + "messagesId" varchar NOT NULL, + "channelsId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "channelsId") + ) + `); + await queryRunner.query(` + INSERT INTO "message_channel_mentions"("messagesId", "channelsId") + SELECT "messagesId", + "channelsId" + FROM "temporary_message_channel_mentions" + `); + await queryRunner.query(` + DROP TABLE "temporary_message_channel_mentions" + `); + await queryRunner.query(` + CREATE INDEX "IDX_bdb8c09e1464cabf62105bf4b9" ON "message_channel_mentions" ("channelsId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_2a27102ecd1d81b4582a436092" ON "message_channel_mentions" ("messagesId") + `); + await queryRunner.query(` + DROP INDEX "IDX_29d63eb1a458200851bc37d074" + `); + await queryRunner.query(` + DROP INDEX "IDX_a8242cf535337a490b0feaea0b" + `); + await queryRunner.query(` + ALTER TABLE "message_role_mentions" + RENAME TO "temporary_message_role_mentions" + `); + await queryRunner.query(` + CREATE TABLE "message_role_mentions" ( + "messagesId" varchar NOT NULL, + "rolesId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "rolesId") + ) + `); + await queryRunner.query(` + INSERT INTO "message_role_mentions"("messagesId", "rolesId") + SELECT "messagesId", + "rolesId" + FROM "temporary_message_role_mentions" + `); + await queryRunner.query(` + DROP TABLE "temporary_message_role_mentions" + `); + await queryRunner.query(` + CREATE INDEX "IDX_29d63eb1a458200851bc37d074" ON "message_role_mentions" ("rolesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_a8242cf535337a490b0feaea0b" ON "message_role_mentions" ("messagesId") + `); + await queryRunner.query(` + DROP INDEX "IDX_b831eb18ceebd28976239b1e2f" + `); + await queryRunner.query(` + DROP INDEX "IDX_a343387fc560ef378760681c23" + `); + await queryRunner.query(` + ALTER TABLE "message_user_mentions" + RENAME TO "temporary_message_user_mentions" + `); + await queryRunner.query(` + CREATE TABLE "message_user_mentions" ( + "messagesId" varchar NOT NULL, + "usersId" varchar NOT NULL, + PRIMARY KEY ("messagesId", "usersId") + ) + `); + await queryRunner.query(` + INSERT INTO "message_user_mentions"("messagesId", "usersId") + SELECT "messagesId", + "usersId" + FROM "temporary_message_user_mentions" + `); + await queryRunner.query(` + DROP TABLE "temporary_message_user_mentions" + `); + await queryRunner.query(` + CREATE INDEX "IDX_b831eb18ceebd28976239b1e2f" ON "message_user_mentions" ("usersId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_a343387fc560ef378760681c23" ON "message_user_mentions" ("messagesId") + `); + await queryRunner.query(` + DROP INDEX "IDX_e9080e7a7997a0170026d5139c" + `); + await queryRunner.query(` + DROP INDEX "IDX_5d7ddc8a5f9c167f548625e772" + `); + await queryRunner.query(` + ALTER TABLE "member_roles" + RENAME TO "temporary_member_roles" + `); + await queryRunner.query(` + CREATE TABLE "member_roles" ( + "index" integer NOT NULL, + "role_id" varchar NOT NULL, + PRIMARY KEY ("index", "role_id") + ) + `); + await queryRunner.query(` + INSERT INTO "member_roles"("index", "role_id") + SELECT "index", + "role_id" + FROM "temporary_member_roles" + `); + await queryRunner.query(` + DROP TABLE "temporary_member_roles" + `); + await queryRunner.query(` + CREATE INDEX "IDX_e9080e7a7997a0170026d5139c" ON "member_roles" ("role_id") + `); + await queryRunner.query(` + CREATE INDEX "IDX_5d7ddc8a5f9c167f548625e772" ON "member_roles" ("index") + `); + await queryRunner.query(` + ALTER TABLE "notes" + RENAME TO "temporary_notes" + `); + await queryRunner.query(` + CREATE TABLE "notes" ( + "id" varchar PRIMARY KEY NOT NULL, + "content" varchar NOT NULL, + "owner_id" varchar, + "target_id" varchar, + CONSTRAINT "UQ_74e6689b9568cc965b8bfc9150b" UNIQUE ("owner_id", "target_id") + ) + `); + await queryRunner.query(` + INSERT INTO "notes"("id", "content", "owner_id", "target_id") + SELECT "id", + "content", + "owner_id", + "target_id" + FROM "temporary_notes" + `); + await queryRunner.query(` + DROP TABLE "temporary_notes" + `); + await queryRunner.query(` + ALTER TABLE "sticker_packs" + RENAME TO "temporary_sticker_packs" + `); + await queryRunner.query(` + CREATE TABLE "sticker_packs" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "banner_asset_id" varchar, + "cover_sticker_id" varchar, + "coverStickerId" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "sticker_packs"( + "id", + "name", + "description", + "banner_asset_id", + "cover_sticker_id", + "coverStickerId" + ) + SELECT "id", + "name", + "description", + "banner_asset_id", + "cover_sticker_id", + "coverStickerId" + FROM "temporary_sticker_packs" + `); + await queryRunner.query(` + DROP TABLE "temporary_sticker_packs" + `); + await queryRunner.query(` + ALTER TABLE "sessions" + RENAME TO "temporary_sessions" + `); + await queryRunner.query(` + CREATE TABLE "sessions" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "session_id" varchar NOT NULL, + "activities" text, + "client_info" text NOT NULL, + "status" varchar NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "sessions"( + "id", + "user_id", + "session_id", + "activities", + "client_info", + "status" + ) + SELECT "id", + "user_id", + "session_id", + "activities", + "client_info", + "status" + FROM "temporary_sessions" + `); + await queryRunner.query(` + DROP TABLE "temporary_sessions" + `); + await queryRunner.query(` + ALTER TABLE "audit_logs" + RENAME TO "temporary_audit_logs" + `); + await queryRunner.query(` + CREATE TABLE "audit_logs" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "action_type" integer NOT NULL, + "options" text, + "changes" text NOT NULL, + "reason" varchar, + "target_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "audit_logs"( + "id", + "user_id", + "action_type", + "options", + "changes", + "reason", + "target_id" + ) + SELECT "id", + "user_id", + "action_type", + "options", + "changes", + "reason", + "target_id" + FROM "temporary_audit_logs" + `); + await queryRunner.query(` + DROP TABLE "temporary_audit_logs" + `); + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "primary_sku_id" varchar, + "slug" varchar, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "guild_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + ) + SELECT "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + await queryRunner.query(` + ALTER TABLE "teams" + RENAME TO "temporary_teams" + `); + await queryRunner.query(` + CREATE TABLE "teams" ( + "id" varchar PRIMARY KEY NOT NULL, + "icon" varchar, + "name" varchar NOT NULL, + "owner_user_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "teams"("id", "icon", "name", "owner_user_id") + SELECT "id", + "icon", + "name", + "owner_user_id" + FROM "temporary_teams" + `); + await queryRunner.query(` + DROP TABLE "temporary_teams" + `); + await queryRunner.query(` + ALTER TABLE "team_members" + RENAME TO "temporary_team_members" + `); + await queryRunner.query(` + CREATE TABLE "team_members" ( + "id" varchar PRIMARY KEY NOT NULL, + "membership_state" integer NOT NULL, + "permissions" text NOT NULL, + "team_id" varchar, + "user_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "team_members"( + "id", + "membership_state", + "permissions", + "team_id", + "user_id" + ) + SELECT "id", + "membership_state", + "permissions", + "team_id", + "user_id" + FROM "temporary_team_members" + `); + await queryRunner.query(` + DROP TABLE "temporary_team_members" + `); + await queryRunner.query(` + ALTER TABLE "guilds" + RENAME TO "temporary_guilds" + `); + await queryRunner.query(` + CREATE TABLE "guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + FROM "temporary_guilds" + `); + await queryRunner.query(` + DROP TABLE "temporary_guilds" + `); + await queryRunner.query(` + ALTER TABLE "templates" + RENAME TO "temporary_templates" + `); + await queryRunner.query(` + CREATE TABLE "templates" ( + "id" varchar PRIMARY KEY NOT NULL, + "code" varchar NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "usage_count" integer, + "creator_id" varchar, + "created_at" datetime NOT NULL, + "updated_at" datetime NOT NULL, + "source_guild_id" varchar, + "serialized_source_guild" text NOT NULL, + CONSTRAINT "UQ_be38737bf339baf63b1daeffb55" UNIQUE ("code") + ) + `); + await queryRunner.query(` + INSERT INTO "templates"( + "id", + "code", + "name", + "description", + "usage_count", + "creator_id", + "created_at", + "updated_at", + "source_guild_id", + "serialized_source_guild" + ) + SELECT "id", + "code", + "name", + "description", + "usage_count", + "creator_id", + "created_at", + "updated_at", + "source_guild_id", + "serialized_source_guild" + FROM "temporary_templates" + `); + await queryRunner.query(` + DROP TABLE "temporary_templates" + `); + await queryRunner.query(` + ALTER TABLE "emojis" + RENAME TO "temporary_emojis" + `); + await queryRunner.query(` + CREATE TABLE "emojis" ( + "id" varchar PRIMARY KEY NOT NULL, + "animated" boolean NOT NULL, + "available" boolean NOT NULL, + "guild_id" varchar NOT NULL, + "user_id" varchar, + "managed" boolean NOT NULL, + "name" varchar NOT NULL, + "require_colons" boolean NOT NULL, + "roles" text NOT NULL, + "groups" text + ) + `); + await queryRunner.query(` + INSERT INTO "emojis"( + "id", + "animated", + "available", + "guild_id", + "user_id", + "managed", + "name", + "require_colons", + "roles", + "groups" + ) + SELECT "id", + "animated", + "available", + "guild_id", + "user_id", + "managed", + "name", + "require_colons", + "roles", + "groups" + FROM "temporary_emojis" + `); + await queryRunner.query(` + DROP TABLE "temporary_emojis" + `); + await queryRunner.query(` + ALTER TABLE "channels" + RENAME TO "temporary_channels" + `); + await queryRunner.query(` + CREATE TABLE "channels" ( + "id" varchar PRIMARY KEY NOT NULL, + "created_at" datetime NOT NULL, + "name" varchar, + "icon" text, + "type" integer NOT NULL, + "last_message_id" varchar, + "guild_id" varchar, + "parent_id" varchar, + "owner_id" varchar, + "last_pin_timestamp" integer, + "default_auto_archive_duration" integer, + "position" integer, + "permission_overwrites" text, + "video_quality_mode" integer, + "bitrate" integer, + "user_limit" integer, + "nsfw" boolean, + "rate_limit_per_user" integer, + "topic" varchar, + "retention_policy_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "channels"( + "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + ) + SELECT "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + FROM "temporary_channels" + `); + await queryRunner.query(` + DROP TABLE "temporary_channels" + `); + await queryRunner.query(` + ALTER TABLE "voice_states" + RENAME TO "temporary_voice_states" + `); + await queryRunner.query(` + CREATE TABLE "voice_states" ( + "id" varchar PRIMARY KEY NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "user_id" varchar, + "session_id" varchar NOT NULL, + "token" varchar, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "self_deaf" boolean NOT NULL, + "self_mute" boolean NOT NULL, + "self_stream" boolean, + "self_video" boolean NOT NULL, + "suppress" boolean NOT NULL, + "request_to_speak_timestamp" datetime + ) + `); + await queryRunner.query(` + INSERT INTO "voice_states"( + "id", + "guild_id", + "channel_id", + "user_id", + "session_id", + "token", + "deaf", + "mute", + "self_deaf", + "self_mute", + "self_stream", + "self_video", + "suppress", + "request_to_speak_timestamp" + ) + SELECT "id", + "guild_id", + "channel_id", + "user_id", + "session_id", + "token", + "deaf", + "mute", + "self_deaf", + "self_mute", + "self_stream", + "self_video", + "suppress", + "request_to_speak_timestamp" + FROM "temporary_voice_states" + `); + await queryRunner.query(` + DROP TABLE "temporary_voice_states" + `); + await queryRunner.query(` + ALTER TABLE "invites" + RENAME TO "temporary_invites" + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean + ) + `); + await queryRunner.query(` + INSERT INTO "invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "temporary_invites" + `); + await queryRunner.query(` + DROP TABLE "temporary_invites" + `); + await queryRunner.query(` + DROP INDEX "IDX_0abf8b443321bd3cf7f81ee17a" + `); + await queryRunner.query(` + ALTER TABLE "read_states" + RENAME TO "temporary_read_states" + `); + await queryRunner.query(` + CREATE TABLE "read_states" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar NOT NULL, + "user_id" varchar NOT NULL, + "last_message_id" varchar, + "public_ack" varchar, + "notifications_cursor" varchar, + "last_pin_timestamp" datetime, + "mention_count" integer + ) + `); + await queryRunner.query(` + INSERT INTO "read_states"( + "id", + "channel_id", + "user_id", + "last_message_id", + "public_ack", + "notifications_cursor", + "last_pin_timestamp", + "mention_count" + ) + SELECT "id", + "channel_id", + "user_id", + "last_message_id", + "public_ack", + "notifications_cursor", + "last_pin_timestamp", + "mention_count" + FROM "temporary_read_states" + `); + await queryRunner.query(` + DROP TABLE "temporary_read_states" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_0abf8b443321bd3cf7f81ee17a" ON "read_states" ("channel_id", "user_id") + `); + await queryRunner.query(` + DROP INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" + `); + await queryRunner.query(` + DROP INDEX "IDX_05535bc695e9f7ee104616459d" + `); + await queryRunner.query(` + DROP INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" + `); + await queryRunner.query(` + ALTER TABLE "messages" + RENAME TO "temporary_messages" + `); + await queryRunner.query(` + CREATE TABLE "messages" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar, + "guild_id" varchar, + "author_id" varchar, + "member_id" varchar, + "webhook_id" varchar, + "application_id" varchar, + "content" varchar, + "timestamp" datetime NOT NULL DEFAULT (datetime('now')), + "edited_timestamp" datetime, + "tts" boolean, + "mention_everyone" boolean, + "embeds" text NOT NULL, + "reactions" text NOT NULL, + "nonce" text, + "pinned" boolean, + "type" integer NOT NULL, + "activity" text, + "flags" varchar, + "message_reference" text, + "interaction" text, + "components" text, + "message_reference_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "messages"( + "id", + "channel_id", + "guild_id", + "author_id", + "member_id", + "webhook_id", + "application_id", + "content", + "timestamp", + "edited_timestamp", + "tts", + "mention_everyone", + "embeds", + "reactions", + "nonce", + "pinned", + "type", + "activity", + "flags", + "message_reference", + "interaction", + "components", + "message_reference_id" + ) + SELECT "id", + "channel_id", + "guild_id", + "author_id", + "member_id", + "webhook_id", + "application_id", + "content", + "timestamp", + "edited_timestamp", + "tts", + "mention_everyone", + "embeds", + "reactions", + "nonce", + "pinned", + "type", + "activity", + "flags", + "message_reference", + "interaction", + "components", + "message_reference_id" + FROM "temporary_messages" + `); + await queryRunner.query(` + DROP TABLE "temporary_messages" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" ON "messages" ("channel_id", "id") + `); + await queryRunner.query(` + CREATE INDEX "IDX_05535bc695e9f7ee104616459d" ON "messages" ("author_id") + `); + await queryRunner.query(` + CREATE INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" ON "messages" ("channel_id") + `); + await queryRunner.query(` + ALTER TABLE "attachments" + RENAME TO "temporary_attachments" + `); + await queryRunner.query(` + CREATE TABLE "attachments" ( + "id" varchar PRIMARY KEY NOT NULL, + "filename" varchar NOT NULL, + "size" integer NOT NULL, + "url" varchar NOT NULL, + "proxy_url" varchar NOT NULL, + "height" integer, + "width" integer, + "content_type" varchar, + "message_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "attachments"( + "id", + "filename", + "size", + "url", + "proxy_url", + "height", + "width", + "content_type", + "message_id" + ) + SELECT "id", + "filename", + "size", + "url", + "proxy_url", + "height", + "width", + "content_type", + "message_id" + FROM "temporary_attachments" + `); + await queryRunner.query(` + DROP TABLE "temporary_attachments" + `); + await queryRunner.query(` + ALTER TABLE "stickers" + RENAME TO "temporary_stickers" + `); + await queryRunner.query(` + CREATE TABLE "stickers" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "description" varchar, + "available" boolean, + "tags" varchar, + "pack_id" varchar, + "guild_id" varchar, + "user_id" varchar, + "type" integer NOT NULL, + "format_type" integer NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "stickers"( + "id", + "name", + "description", + "available", + "tags", + "pack_id", + "guild_id", + "user_id", + "type", + "format_type" + ) + SELECT "id", + "name", + "description", + "available", + "tags", + "pack_id", + "guild_id", + "user_id", + "type", + "format_type" + FROM "temporary_stickers" + `); + await queryRunner.query(` + DROP TABLE "temporary_stickers" + `); + await queryRunner.query(` + ALTER TABLE "webhooks" + RENAME TO "temporary_webhooks" + `); + await queryRunner.query(` + CREATE TABLE "webhooks" ( + "id" varchar PRIMARY KEY NOT NULL, + "type" integer NOT NULL, + "name" varchar, + "avatar" varchar, + "token" varchar, + "guild_id" varchar, + "channel_id" varchar, + "application_id" varchar, + "user_id" varchar, + "source_guild_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "webhooks"( + "id", + "type", + "name", + "avatar", + "token", + "guild_id", + "channel_id", + "application_id", + "user_id", + "source_guild_id" + ) + SELECT "id", + "type", + "name", + "avatar", + "token", + "guild_id", + "channel_id", + "application_id", + "user_id", + "source_guild_id" + FROM "temporary_webhooks" + `); + await queryRunner.query(` + DROP TABLE "temporary_webhooks" + `); + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + ALTER TABLE "members" + RENAME TO "temporary_members" + `); + await queryRunner.query(` + CREATE TABLE "members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "members"( + "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + ) + SELECT "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + FROM "temporary_members" + `); + await queryRunner.query(` + DROP TABLE "temporary_members" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + await queryRunner.query(` + ALTER TABLE "roles" + RENAME TO "temporary_roles" + `); + await queryRunner.query(` + CREATE TABLE "roles" ( + "id" varchar PRIMARY KEY NOT NULL, + "guild_id" varchar, + "color" integer NOT NULL, + "hoist" boolean NOT NULL, + "managed" boolean NOT NULL, + "mentionable" boolean NOT NULL, + "name" varchar NOT NULL, + "permissions" varchar NOT NULL, + "position" integer NOT NULL, + "icon" varchar, + "unicode_emoji" varchar, + "tags" text + ) + `); + await queryRunner.query(` + INSERT INTO "roles"( + "id", + "guild_id", + "color", + "hoist", + "managed", + "mentionable", + "name", + "permissions", + "position", + "icon", + "unicode_emoji", + "tags" + ) + SELECT "id", + "guild_id", + "color", + "hoist", + "managed", + "mentionable", + "name", + "permissions", + "position", + "icon", + "unicode_emoji", + "tags" + FROM "temporary_roles" + `); + await queryRunner.query(` + DROP TABLE "temporary_roles" + `); + await queryRunner.query(` + ALTER TABLE "recipients" + RENAME TO "temporary_recipients" + `); + await queryRunner.query(` + CREATE TABLE "recipients" ( + "id" varchar PRIMARY KEY NOT NULL, + "channel_id" varchar NOT NULL, + "user_id" varchar NOT NULL, + "closed" boolean NOT NULL DEFAULT (0) + ) + `); + await queryRunner.query(` + INSERT INTO "recipients"("id", "channel_id", "user_id", "closed") + SELECT "id", + "channel_id", + "user_id", + "closed" + FROM "temporary_recipients" + `); + await queryRunner.query(` + DROP TABLE "temporary_recipients" + `); + await queryRunner.query(` + ALTER TABLE "bans" + RENAME TO "temporary_bans" + `); + await queryRunner.query(` + CREATE TABLE "bans" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "guild_id" varchar, + "executor_id" varchar, + "ip" varchar NOT NULL, + "reason" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "bans"( + "id", + "user_id", + "guild_id", + "executor_id", + "ip", + "reason" + ) + SELECT "id", + "user_id", + "guild_id", + "executor_id", + "ip", + "reason" + FROM "temporary_bans" + `); + await queryRunner.query(` + DROP TABLE "temporary_bans" + `); + await queryRunner.query(` + ALTER TABLE "backup_codes" + RENAME TO "temporary_backup_codes" + `); + await queryRunner.query(` + CREATE TABLE "backup_codes" ( + "id" varchar PRIMARY KEY NOT NULL, + "code" varchar NOT NULL, + "consumed" boolean NOT NULL, + "expired" boolean NOT NULL, + "user_id" varchar + ) + `); + await queryRunner.query(` + INSERT INTO "backup_codes"("id", "code", "consumed", "expired", "user_id") + SELECT "id", + "code", + "consumed", + "expired", + "user_id" + FROM "temporary_backup_codes" + `); + await queryRunner.query(` + DROP TABLE "temporary_backup_codes" + `); + await queryRunner.query(` + ALTER TABLE "connected_accounts" + RENAME TO "temporary_connected_accounts" + `); + await queryRunner.query(` + CREATE TABLE "connected_accounts" ( + "id" varchar PRIMARY KEY NOT NULL, + "user_id" varchar, + "access_token" varchar NOT NULL, + "friend_sync" boolean NOT NULL, + "name" varchar NOT NULL, + "revoked" boolean NOT NULL, + "show_activity" boolean NOT NULL, + "type" varchar NOT NULL, + "verified" boolean NOT NULL, + "visibility" integer NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "connected_accounts"( + "id", + "user_id", + "access_token", + "friend_sync", + "name", + "revoked", + "show_activity", + "type", + "verified", + "visibility" + ) + SELECT "id", + "user_id", + "access_token", + "friend_sync", + "name", + "revoked", + "show_activity", + "type", + "verified", + "visibility" + FROM "temporary_connected_accounts" + `); + await queryRunner.query(` + DROP TABLE "temporary_connected_accounts" + `); + await queryRunner.query(` + DROP INDEX "IDX_a0b2ff0a598df0b0d055934a17" + `); + await queryRunner.query(` + ALTER TABLE "relationships" + RENAME TO "temporary_relationships" + `); + await queryRunner.query(` + CREATE TABLE "relationships" ( + "id" varchar PRIMARY KEY NOT NULL, + "from_id" varchar NOT NULL, + "to_id" varchar NOT NULL, + "nickname" varchar, + "type" integer NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "relationships"("id", "from_id", "to_id", "nickname", "type") + SELECT "id", + "from_id", + "to_id", + "nickname", + "type" + FROM "temporary_relationships" + `); + await queryRunner.query(` + DROP TABLE "temporary_relationships" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_a0b2ff0a598df0b0d055934a17" ON "relationships" ("from_id", "to_id") + `); + await queryRunner.query(` + DROP INDEX "IDX_e22a70819d07659c7a71c112a1" + `); + await queryRunner.query(` + DROP INDEX "IDX_40bb6f23e7cc133292e92829d2" + `); + await queryRunner.query(` + DROP TABLE "message_stickers" + `); + await queryRunner.query(` + DROP INDEX "IDX_bdb8c09e1464cabf62105bf4b9" + `); + await queryRunner.query(` + DROP INDEX "IDX_2a27102ecd1d81b4582a436092" + `); + await queryRunner.query(` + DROP TABLE "message_channel_mentions" + `); + await queryRunner.query(` + DROP INDEX "IDX_29d63eb1a458200851bc37d074" + `); + await queryRunner.query(` + DROP INDEX "IDX_a8242cf535337a490b0feaea0b" + `); + await queryRunner.query(` + DROP TABLE "message_role_mentions" + `); + await queryRunner.query(` + DROP INDEX "IDX_b831eb18ceebd28976239b1e2f" + `); + await queryRunner.query(` + DROP INDEX "IDX_a343387fc560ef378760681c23" + `); + await queryRunner.query(` + DROP TABLE "message_user_mentions" + `); + await queryRunner.query(` + DROP INDEX "IDX_e9080e7a7997a0170026d5139c" + `); + await queryRunner.query(` + DROP INDEX "IDX_5d7ddc8a5f9c167f548625e772" + `); + await queryRunner.query(` + DROP TABLE "member_roles" + `); + await queryRunner.query(` + DROP TABLE "notes" + `); + await queryRunner.query(` + DROP TABLE "client_release" + `); + await queryRunner.query(` + DROP TABLE "sticker_packs" + `); + await queryRunner.query(` + DROP TABLE "sessions" + `); + await queryRunner.query(` + DROP TABLE "rate_limits" + `); + await queryRunner.query(` + DROP TABLE "migrations" + `); + await queryRunner.query(` + DROP TABLE "categories" + `); + await queryRunner.query(` + DROP TABLE "audit_logs" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + DROP TABLE "teams" + `); + await queryRunner.query(` + DROP TABLE "team_members" + `); + await queryRunner.query(` + DROP TABLE "guilds" + `); + await queryRunner.query(` + DROP TABLE "templates" + `); + await queryRunner.query(` + DROP TABLE "emojis" + `); + await queryRunner.query(` + DROP TABLE "channels" + `); + await queryRunner.query(` + DROP TABLE "voice_states" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + DROP INDEX "IDX_0abf8b443321bd3cf7f81ee17a" + `); + await queryRunner.query(` + DROP TABLE "read_states" + `); + await queryRunner.query(` + DROP INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" + `); + await queryRunner.query(` + DROP INDEX "IDX_05535bc695e9f7ee104616459d" + `); + await queryRunner.query(` + DROP INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" + `); + await queryRunner.query(` + DROP TABLE "messages" + `); + await queryRunner.query(` + DROP TABLE "attachments" + `); + await queryRunner.query(` + DROP TABLE "stickers" + `); + await queryRunner.query(` + DROP TABLE "webhooks" + `); + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + DROP TABLE "members" + `); + await queryRunner.query(` + DROP TABLE "roles" + `); + await queryRunner.query(` + DROP TABLE "recipients" + `); + await queryRunner.query(` + DROP TABLE "bans" + `); + await queryRunner.query(` + DROP TABLE "backup_codes" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + DROP TABLE "connected_accounts" + `); + await queryRunner.query(` + DROP INDEX "IDX_a0b2ff0a598df0b0d055934a17" + `); + await queryRunner.query(` + DROP TABLE "relationships" + `); + await queryRunner.query(` + DROP TABLE "config" + `); + } + +} diff --git a/util/src/util/Database.ts b/util/src/util/Database.ts index 31a305615..c46931084 100644 --- a/util/src/util/Database.ts +++ b/util/src/util/Database.ts @@ -1,72 +1,100 @@ import path from "path"; import "reflect-metadata"; -import { DataSource, createConnection } from "typeorm"; +import { DataSource, createConnection, DataSourceOptions, PrimaryColumn, PrimaryGeneratedColumn } from "typeorm"; import * as Models from "../entities"; import { Migration } from "../entities/Migration"; import { yellow, green, red } from "picocolors"; +import fs from "fs"; +import { exit } from "process"; +import { BaseClass, BaseClassWithoutId } from "../entities"; // UUID extension option is only supported with postgres // We want to generate all id's with Snowflakes that's why we have our own BaseEntity class let promise: Promise; -let dataSource: DataSource | undefined; -let dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); -let verbose_db = false; +let dataSource: DataSource; + + export async function initDatabase(): Promise { if (dataSource) return dataSource; // prevent initalizing multiple times + let dso = getDataSourceOptions(); + console.log(`[Database] ${yellow(`Connecting to ${dso.type} database...`)}`); + + //promise = dataSource.initialize(); + //await promise; + + console.log(`[Database] ${green("Connected!")}`); + + return promise; +} + + +export function closeDatabase() { + dataSource?.destroy(); +} + +function getDataSourceOptions(): DataSourceOptions { + //get connection string and check for migrations + const dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); const type = dbConnectionString.includes("://") ? dbConnectionString.split(":")[0]?.replace("+srv", "") : "sqlite" as any; const isSqlite = type.includes("sqlite"); - if(process.env.DB_VERBOSE) verbose_db = true; - - console.log(`[Database] ${yellow(`connecting to ${type} db`)}`); + const migrationsExist = fs.existsSync(path.join(__dirname, "..", "migrations", type)); + //read env vars + const synchronizeInsteadOfMigrations = "DB_UNSAFE" in process.env; + const verboseDb = "DB_VERBOSE" in process.env; + if(isSqlite) console.log(`[Database] ${red(`You are running sqlite! Please keep in mind that we recommend setting up a dedicated database!`)}`); - if(verbose_db) - console.log(`[Database] ${red(`Verbose database logging is enabled, this might impact performance! Unset VERBOSE_DB to disable.`)}`); - // @ts-ignore - dataSource = new DataSource({ + if(verboseDb) + console.log(`[Database] ${red(`Verbose database logging is enabled, this might impact performance! Unset DB_VERBOSE to disable.`)}`); + + if(synchronizeInsteadOfMigrations){ + console.log(`[Database] ${red(`Unsafe database upgrades are enabled! We are not responsible for broken databases! Unset DB_UNSAFE to disable.`)}`); + } + else if(!migrationsExist) { + console.log(`[Database] ${red(`Database engine not supported! Set UNSAFE_DB to bypass.`)}`); + console.log(`[Database] ${red(`Please mention this to Fosscord developers, and provide this info:`)}`); + console.log(`[Database]\n${red(JSON.stringify({ + db_type: type, + migrations_exist: migrationsExist + }, null, 4))}`); + + //exit(1); + } + + return { type, charset: 'utf8mb4', url: isSqlite ? undefined : dbConnectionString, database: isSqlite ? dbConnectionString : undefined, // @ts-ignore - entities: Object.values(Models).filter((x) => x.constructor.name !== "Object" && x.name), - synchronize: type !== "mongodb", - logging: verbose_db, + //entities: Object.values(Models).filter((x) => x.constructor.name !== "Object" && x.constructor.name !== "Array" && x.constructor.name !== "BigInt" && x).map(x=>x.name), + entities: Object.values(Models).filter((x) => x.constructor.name == "Function" && shouldIncludeEntity(x.name)), + synchronize: synchronizeInsteadOfMigrations, + logging: verboseDb, cache: { duration: 1000 * 3, // cache all find queries for 3 seconds }, bigNumberStrings: false, supportBigNumbers: true, name: "default", - migrations: [path.join(__dirname, "..", "migrations", "*.js")], - }); - promise = dataSource.initialize(); - await promise; - // run migrations, and if it is a new fresh database, set it to the last migration - if (dataSource.migrations.length) { - if (!(await Migration.findOne({}))) { - let i = 0; - - await Migration.insert( - dataSource.migrations.map((x) => ({ - id: i++, - name: x.name, - timestamp: Date.now(), - })) - ); + migrations: synchronizeInsteadOfMigrations ? [] : [path.join(__dirname, "..", "migrations", type, "*.js")], + migrationsRun: !synchronizeInsteadOfMigrations, + cli: { + migrationsDir: `src/migrations/${type}` } - } - await dataSource.runMigrations(); - console.log(`[Database] ${green("connected")}`); - - return promise; + } as DataSourceOptions; } -export { dataSource }; - -export function closeDatabase() { - dataSource?.destroy(); +function shouldIncludeEntity(name: string): boolean { + return ![ + BaseClassWithoutId, + PrimaryColumn, + BaseClass, + PrimaryGeneratedColumn + ].map(x=>x.name).includes(name); } + +export default dataSource = new DataSource(getDataSourceOptions()); \ No newline at end of file diff --git a/util/src/util/Database.ts.torm2 b/util/src/util/Database.ts.torm2 deleted file mode 100644 index f0540bdfd..000000000 --- a/util/src/util/Database.ts.torm2 +++ /dev/null @@ -1,72 +0,0 @@ -import path from "path"; -import "reflect-metadata"; -import { Connection, createConnection } from "typeorm"; -import * as Models from "../entities"; -import { Migration } from "../entities/Migration"; -import { yellow, green, red } from "picocolors"; - -// UUID extension option is only supported with postgres -// We want to generate all id's with Snowflakes that's why we have our own BaseEntity class - -let promise: Promise; -let dbConnection: Connection | undefined; -let dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); - -export function initDatabase(): Promise { - if (promise) return promise; // prevent initalizing multiple times - - const type = dbConnectionString.includes("://") ? dbConnectionString.split(":")[0]?.replace("+srv", "") : "sqlite"; - const isSqlite = type.includes("sqlite"); - - console.log(`[Database] ${yellow(`connecting to ${type} db`)}`); - if(isSqlite) { - console.log(`[Database] ${red(`You are running sqlite! Please keep in mind that we recommend setting up a dedicated database!`)}`); - } - // @ts-ignore - promise = createConnection({ - type, - charset: 'utf8mb4', - url: isSqlite ? undefined : dbConnectionString, - database: isSqlite ? dbConnectionString : undefined, - // @ts-ignore - entities: Object.values(Models).filter((x) => x.constructor.name !== "Object" && x.name), - synchronize: type !== "mongodb", - logging: false, - cache: { - duration: 1000 * 3, // cache all find queries for 3 seconds - }, - bigNumberStrings: false, - supportBigNumbers: true, - name: "default", - migrations: [path.join(__dirname, "..", "migrations", "*.js")], - }); - - promise.then(async (connection: Connection) => { - dbConnection = connection; - - // run migrations, and if it is a new fresh database, set it to the last migration - if (connection.migrations.length) { - if (!(await Migration.findOne({}))) { - let i = 0; - - await Migration.insert( - connection.migrations.map((x) => ({ - id: i++, - name: x.name, - timestamp: Date.now(), - })) - ); - } - } - await connection.runMigrations(); - console.log(`[Database] ${green("connected")}`); - }); - - return promise; -} - -export { dbConnection }; - -export function closeDatabase() { - dbConnection?.close(); -} diff --git a/util/src/util/MFA.ts b/util/src/util/MFA.ts new file mode 100644 index 000000000..2e47b2fce --- /dev/null +++ b/util/src/util/MFA.ts @@ -0,0 +1,17 @@ +import crypto from "crypto"; +import { BackupCode } from "../entities/BackupCodes"; + +export function generateMfaBackupCodes(user_id: string) { + let backup_codes: BackupCode[] = []; + for (let i = 0; i < 10; i++) { + const code = BackupCode.create({ + user: { id: user_id }, + code: crypto.randomBytes(4).toString("hex"), // 8 characters + consumed: false, + expired: false, + }); + backup_codes.push(code); + } + + return backup_codes; +} \ No newline at end of file From 7af574b0e8711f7522f258a5b995be2f4cd323bd Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 7 Aug 2022 03:06:52 +0200 Subject: [PATCH 167/238] Clean up commented out code in BaseClass --- util/src/entities/BaseClass.ts | 46 ---------------------------------- 1 file changed, 46 deletions(-) diff --git a/util/src/entities/BaseClass.ts b/util/src/entities/BaseClass.ts index e72d09e9a..0cb885fae 100644 --- a/util/src/entities/BaseClass.ts +++ b/util/src/entities/BaseClass.ts @@ -8,30 +8,13 @@ export class BaseClassWithoutId extends BaseEntity { this.assign(props); } - /*private get construct(): any { - return this.constructor; - }*/ - - /*private get metadata() { - console.log("getMetadata") - return dataSource.getRepository(this.constructor).metadata as EntityMetadata; - //return this.construct.getRepository().metadata as EntityMetadata; - }*/ - assign(props: any = {}) { //console.log(`assign (${typeof this})...`) delete props.opts; delete props.props; - - /*const properties = new Set( - this.metadata.columns - .map((x: any) => x.propertyName) - .concat(this.metadata.relations.map((x) => x.propertyName)) - );*/ // will not include relational properties for (const key in props) { - //if (!properties.has(key)) continue; // @ts-ignore const setter = this[`set${key.capitalize()}`]; // use setter function if it exists @@ -43,35 +26,6 @@ export class BaseClassWithoutId extends BaseEntity { } } } - - /*toJSON(): any { - console.log("toJSON...") - return Object.fromEntries( - this.metadata.columns // @ts-ignore - .map((x) => [x.propertyName, this[x.propertyName]]) // @ts-ignore - .concat(this.metadata.relations.map((x) => [x.propertyName, this[x.propertyName]])) - ); - } - - static increment( - conditions: FindOptionsWhere, - propertyPath: string, - value: number | string - ) { - console.log("increment...") - const repository = this.getRepository(); - return repository.increment(conditions, propertyPath, value); - } - - static decrement( - conditions: FindOptionsWhere, - propertyPath: string, - value: number | string - ) { - console.log("increment...") - const repository = this.getRepository(); - return repository.decrement(conditions, propertyPath, value); - }*/ } export const PrimaryIdColumn = process.env.DATABASE?.startsWith("mongodb") ? ObjectIdColumn : PrimaryColumn; From 29e88a440f2d9cc64ed7dff6f816d3fd0462acad Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 7 Aug 2022 21:43:38 +0200 Subject: [PATCH 168/238] Add migrations --- bundle/scripts/db_migrations.sh | 32 + .../mariadb/1659901151025-initial.ts | 1219 ++++++++++++++++ .../postgres/1659899687168-initial.ts | 1245 +++++++++++++++++ .../1659899662635-initial.ts} | 14 +- util/src/util/Config.ts | 6 +- util/src/util/Database.ts | 33 +- 6 files changed, 2519 insertions(+), 30 deletions(-) create mode 100755 bundle/scripts/db_migrations.sh create mode 100644 util/src/migrations/mariadb/1659901151025-initial.ts create mode 100644 util/src/migrations/postgres/1659899687168-initial.ts rename util/src/migrations/{postgres/1659833042721-test.ts => sqlite/1659899662635-initial.ts} (99%) diff --git a/bundle/scripts/db_migrations.sh b/bundle/scripts/db_migrations.sh new file mode 100755 index 000000000..b0e1131c1 --- /dev/null +++ b/bundle/scripts/db_migrations.sh @@ -0,0 +1,32 @@ +#!/bin/sh +read -p "Enter migration filename: " FILENAME +[ -f ".env" ] && ( + mv .env .env.tmp + source .env.tmp +) + +make_migration() { + echo "Creating migrations for $2" + mkdir "../util/src/migrations/$2" + npm run build clean logerrors pretty-errors + THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle + THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "../util/src/migrations/$2/$FILENAME" -d ../util/src/util/Database.ts -p + npm run build clean logerrors pretty-errors + THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle +} + +npm i sqlite3 +make_migration "database.db" "sqlite" + +[ -z "$FC_DB_POSTGRES" ] || ( + npm i pg + make_migration "$FC_DB_POSTGRES" "postgres" +) + +[ -z "$FC_DB_MARIADB" ] || ( + npm i mysql2 + make_migration "$FC_DB_MARIADB" "mariadb" +) + +[ -f ".env.tmp" ] && mv .env.tmp .env + diff --git a/util/src/migrations/mariadb/1659901151025-initial.ts b/util/src/migrations/mariadb/1659901151025-initial.ts new file mode 100644 index 000000000..d15e0add8 --- /dev/null +++ b/util/src/migrations/mariadb/1659901151025-initial.ts @@ -0,0 +1,1219 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class initial1659901151025 implements MigrationInterface { + name = 'initial1659901151025' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE \`config\` ( + \`key\` varchar(255) NOT NULL, + \`value\` text NULL, + PRIMARY KEY (\`key\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`relationships\` ( + \`id\` varchar(255) NOT NULL, + \`from_id\` varchar(255) NOT NULL, + \`to_id\` varchar(255) NOT NULL, + \`nickname\` varchar(255) NULL, + \`type\` int NOT NULL, + UNIQUE INDEX \`IDX_a0b2ff0a598df0b0d055934a17\` (\`from_id\`, \`to_id\`), + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`connected_accounts\` ( + \`id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NULL, + \`access_token\` varchar(255) NOT NULL, + \`friend_sync\` tinyint NOT NULL, + \`name\` varchar(255) NOT NULL, + \`revoked\` tinyint NOT NULL, + \`show_activity\` tinyint NOT NULL, + \`type\` varchar(255) NOT NULL, + \`verified\` tinyint NOT NULL, + \`visibility\` int NOT NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`users\` ( + \`id\` varchar(255) NOT NULL, + \`username\` varchar(255) NOT NULL, + \`discriminator\` varchar(255) NOT NULL, + \`avatar\` varchar(255) NULL, + \`accent_color\` int NULL, + \`banner\` varchar(255) NULL, + \`phone\` varchar(255) NULL, + \`desktop\` tinyint NOT NULL, + \`mobile\` tinyint NOT NULL, + \`premium\` tinyint NOT NULL, + \`premium_type\` int NOT NULL, + \`bot\` tinyint NOT NULL, + \`bio\` varchar(255) NOT NULL, + \`system\` tinyint NOT NULL, + \`nsfw_allowed\` tinyint NOT NULL, + \`mfa_enabled\` tinyint NOT NULL, + \`totp_secret\` varchar(255) NULL, + \`totp_last_ticket\` varchar(255) NULL, + \`created_at\` datetime NOT NULL, + \`premium_since\` datetime NULL, + \`verified\` tinyint NOT NULL, + \`disabled\` tinyint NOT NULL, + \`deleted\` tinyint NOT NULL, + \`email\` varchar(255) NULL, + \`flags\` varchar(255) NOT NULL, + \`public_flags\` int NOT NULL, + \`rights\` bigint NOT NULL, + \`data\` text NOT NULL, + \`fingerprints\` text NOT NULL, + \`settings\` text NOT NULL, + \`extended_settings\` text NOT NULL, + \`notes\` text NOT NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`backup_codes\` ( + \`id\` varchar(255) NOT NULL, + \`code\` varchar(255) NOT NULL, + \`consumed\` tinyint NOT NULL, + \`expired\` tinyint NOT NULL, + \`user_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`bans\` ( + \`id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NULL, + \`guild_id\` varchar(255) NULL, + \`executor_id\` varchar(255) NULL, + \`ip\` varchar(255) NOT NULL, + \`reason\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`recipients\` ( + \`id\` varchar(255) NOT NULL, + \`channel_id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NOT NULL, + \`closed\` tinyint NOT NULL DEFAULT 0, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`roles\` ( + \`id\` varchar(255) NOT NULL, + \`guild_id\` varchar(255) NULL, + \`color\` int NOT NULL, + \`hoist\` tinyint NOT NULL, + \`managed\` tinyint NOT NULL, + \`mentionable\` tinyint NOT NULL, + \`name\` varchar(255) NOT NULL, + \`permissions\` varchar(255) NOT NULL, + \`position\` int NOT NULL, + \`icon\` varchar(255) NULL, + \`unicode_emoji\` varchar(255) NULL, + \`tags\` text NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`members\` ( + \`index\` int NOT NULL AUTO_INCREMENT, + \`id\` varchar(255) NOT NULL, + \`guild_id\` varchar(255) NOT NULL, + \`nick\` varchar(255) NULL, + \`joined_at\` datetime NOT NULL, + \`premium_since\` bigint NULL, + \`deaf\` tinyint NOT NULL, + \`mute\` tinyint NOT NULL, + \`pending\` tinyint NOT NULL, + \`settings\` text NOT NULL, + \`last_message_id\` varchar(255) NULL, + \`joined_by\` varchar(255) NULL, + UNIQUE INDEX \`IDX_bb2bf9386ac443afbbbf9f12d3\` (\`id\`, \`guild_id\`), + PRIMARY KEY (\`index\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`webhooks\` ( + \`id\` varchar(255) NOT NULL, + \`type\` int NOT NULL, + \`name\` varchar(255) NULL, + \`avatar\` varchar(255) NULL, + \`token\` varchar(255) NULL, + \`guild_id\` varchar(255) NULL, + \`channel_id\` varchar(255) NULL, + \`application_id\` varchar(255) NULL, + \`user_id\` varchar(255) NULL, + \`source_guild_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`stickers\` ( + \`id\` varchar(255) NOT NULL, + \`name\` varchar(255) NOT NULL, + \`description\` varchar(255) NULL, + \`available\` tinyint NULL, + \`tags\` varchar(255) NULL, + \`pack_id\` varchar(255) NULL, + \`guild_id\` varchar(255) NULL, + \`user_id\` varchar(255) NULL, + \`type\` int NOT NULL, + \`format_type\` int NOT NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`attachments\` ( + \`id\` varchar(255) NOT NULL, + \`filename\` varchar(255) NOT NULL, + \`size\` int NOT NULL, + \`url\` varchar(255) NOT NULL, + \`proxy_url\` varchar(255) NOT NULL, + \`height\` int NULL, + \`width\` int NULL, + \`content_type\` varchar(255) NULL, + \`message_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`messages\` ( + \`id\` varchar(255) NOT NULL, + \`channel_id\` varchar(255) NULL, + \`guild_id\` varchar(255) NULL, + \`author_id\` varchar(255) NULL, + \`member_id\` varchar(255) NULL, + \`webhook_id\` varchar(255) NULL, + \`application_id\` varchar(255) NULL, + \`content\` varchar(255) NULL, + \`timestamp\` datetime(6) NOT NULL DEFAULT CURRENT_TIMESTAMP(6), + \`edited_timestamp\` datetime NULL, + \`tts\` tinyint NULL, + \`mention_everyone\` tinyint NULL, + \`embeds\` text NOT NULL, + \`reactions\` text NOT NULL, + \`nonce\` text NULL, + \`pinned\` tinyint NULL, + \`type\` int NOT NULL, + \`activity\` text NULL, + \`flags\` varchar(255) NULL, + \`message_reference\` text NULL, + \`interaction\` text NULL, + \`components\` text NULL, + \`message_reference_id\` varchar(255) NULL, + INDEX \`IDX_86b9109b155eb70c0a2ca3b4b6\` (\`channel_id\`), + INDEX \`IDX_05535bc695e9f7ee104616459d\` (\`author_id\`), + UNIQUE INDEX \`IDX_3ed7a60fb7dbe04e1ba9332a8b\` (\`channel_id\`, \`id\`), + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`read_states\` ( + \`id\` varchar(255) NOT NULL, + \`channel_id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NOT NULL, + \`last_message_id\` varchar(255) NULL, + \`public_ack\` varchar(255) NULL, + \`notifications_cursor\` varchar(255) NULL, + \`last_pin_timestamp\` datetime NULL, + \`mention_count\` int NULL, + UNIQUE INDEX \`IDX_0abf8b443321bd3cf7f81ee17a\` (\`channel_id\`, \`user_id\`), + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`invites\` ( + \`code\` varchar(255) NOT NULL, + \`temporary\` tinyint NOT NULL, + \`uses\` int NOT NULL, + \`max_uses\` int NOT NULL, + \`max_age\` int NOT NULL, + \`created_at\` datetime NOT NULL, + \`expires_at\` datetime NOT NULL, + \`guild_id\` varchar(255) NULL, + \`channel_id\` varchar(255) NULL, + \`inviter_id\` varchar(255) NULL, + \`target_user_id\` varchar(255) NULL, + \`target_user_type\` int NULL, + \`vanity_url\` tinyint NULL, + PRIMARY KEY (\`code\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`voice_states\` ( + \`id\` varchar(255) NOT NULL, + \`guild_id\` varchar(255) NULL, + \`channel_id\` varchar(255) NULL, + \`user_id\` varchar(255) NULL, + \`session_id\` varchar(255) NOT NULL, + \`token\` varchar(255) NULL, + \`deaf\` tinyint NOT NULL, + \`mute\` tinyint NOT NULL, + \`self_deaf\` tinyint NOT NULL, + \`self_mute\` tinyint NOT NULL, + \`self_stream\` tinyint NULL, + \`self_video\` tinyint NOT NULL, + \`suppress\` tinyint NOT NULL, + \`request_to_speak_timestamp\` datetime NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`channels\` ( + \`id\` varchar(255) NOT NULL, + \`created_at\` datetime NOT NULL, + \`name\` varchar(255) NULL, + \`icon\` text NULL, + \`type\` int NOT NULL, + \`last_message_id\` varchar(255) NULL, + \`guild_id\` varchar(255) NULL, + \`parent_id\` varchar(255) NULL, + \`owner_id\` varchar(255) NULL, + \`last_pin_timestamp\` int NULL, + \`default_auto_archive_duration\` int NULL, + \`position\` int NULL, + \`permission_overwrites\` text NULL, + \`video_quality_mode\` int NULL, + \`bitrate\` int NULL, + \`user_limit\` int NULL, + \`nsfw\` tinyint NULL, + \`rate_limit_per_user\` int NULL, + \`topic\` varchar(255) NULL, + \`retention_policy_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`emojis\` ( + \`id\` varchar(255) NOT NULL, + \`animated\` tinyint NOT NULL, + \`available\` tinyint NOT NULL, + \`guild_id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NULL, + \`managed\` tinyint NOT NULL, + \`name\` varchar(255) NOT NULL, + \`require_colons\` tinyint NOT NULL, + \`roles\` text NOT NULL, + \`groups\` text NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`templates\` ( + \`id\` varchar(255) NOT NULL, + \`code\` varchar(255) NOT NULL, + \`name\` varchar(255) NOT NULL, + \`description\` varchar(255) NULL, + \`usage_count\` int NULL, + \`creator_id\` varchar(255) NULL, + \`created_at\` datetime NOT NULL, + \`updated_at\` datetime NOT NULL, + \`source_guild_id\` varchar(255) NULL, + \`serialized_source_guild\` text NOT NULL, + UNIQUE INDEX \`IDX_be38737bf339baf63b1daeffb5\` (\`code\`), + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`guilds\` ( + \`id\` varchar(255) NOT NULL, + \`afk_channel_id\` varchar(255) NULL, + \`afk_timeout\` int NULL, + \`banner\` varchar(255) NULL, + \`default_message_notifications\` int NULL, + \`description\` varchar(255) NULL, + \`discovery_splash\` varchar(255) NULL, + \`explicit_content_filter\` int NULL, + \`features\` text NOT NULL, + \`primary_category_id\` int NULL, + \`icon\` varchar(255) NULL, + \`large\` tinyint NULL, + \`max_members\` int NULL, + \`max_presences\` int NULL, + \`max_video_channel_users\` int NULL, + \`member_count\` int NULL, + \`presence_count\` int NULL, + \`template_id\` varchar(255) NULL, + \`mfa_level\` int NULL, + \`name\` varchar(255) NOT NULL, + \`owner_id\` varchar(255) NULL, + \`preferred_locale\` varchar(255) NULL, + \`premium_subscription_count\` int NULL, + \`premium_tier\` int NULL, + \`public_updates_channel_id\` varchar(255) NULL, + \`rules_channel_id\` varchar(255) NULL, + \`region\` varchar(255) NULL, + \`splash\` varchar(255) NULL, + \`system_channel_id\` varchar(255) NULL, + \`system_channel_flags\` int NULL, + \`unavailable\` tinyint NULL, + \`verification_level\` int NULL, + \`welcome_screen\` text NOT NULL, + \`widget_channel_id\` varchar(255) NULL, + \`widget_enabled\` tinyint NULL, + \`nsfw_level\` int NULL, + \`nsfw\` tinyint NULL, + \`parent\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`team_members\` ( + \`id\` varchar(255) NOT NULL, + \`membership_state\` int NOT NULL, + \`permissions\` text NOT NULL, + \`team_id\` varchar(255) NULL, + \`user_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`teams\` ( + \`id\` varchar(255) NOT NULL, + \`icon\` varchar(255) NULL, + \`name\` varchar(255) NOT NULL, + \`owner_user_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`applications\` ( + \`id\` varchar(255) NOT NULL, + \`name\` varchar(255) NOT NULL, + \`icon\` varchar(255) NULL, + \`description\` varchar(255) NOT NULL, + \`rpc_origins\` text NULL, + \`bot_public\` tinyint NOT NULL, + \`bot_require_code_grant\` tinyint NOT NULL, + \`terms_of_service_url\` varchar(255) NULL, + \`privacy_policy_url\` varchar(255) NULL, + \`summary\` varchar(255) NULL, + \`verify_key\` varchar(255) NOT NULL, + \`primary_sku_id\` varchar(255) NULL, + \`slug\` varchar(255) NULL, + \`cover_image\` varchar(255) NULL, + \`flags\` varchar(255) NOT NULL, + \`owner_id\` varchar(255) NULL, + \`team_id\` varchar(255) NULL, + \`guild_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`audit_logs\` ( + \`id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NULL, + \`action_type\` int NOT NULL, + \`options\` text NULL, + \`changes\` text NOT NULL, + \`reason\` varchar(255) NULL, + \`target_id\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`categories\` ( + \`id\` int NOT NULL, + \`name\` varchar(255) NULL, + \`localizations\` text NOT NULL, + \`is_primary\` tinyint NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`rate_limits\` ( + \`id\` varchar(255) NOT NULL, + \`executor_id\` varchar(255) NOT NULL, + \`hits\` int NOT NULL, + \`blocked\` tinyint NOT NULL, + \`expires_at\` datetime NOT NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`sessions\` ( + \`id\` varchar(255) NOT NULL, + \`user_id\` varchar(255) NULL, + \`session_id\` varchar(255) NOT NULL, + \`activities\` text NULL, + \`client_info\` text NOT NULL, + \`status\` varchar(255) NOT NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`sticker_packs\` ( + \`id\` varchar(255) NOT NULL, + \`name\` varchar(255) NOT NULL, + \`description\` varchar(255) NULL, + \`banner_asset_id\` varchar(255) NULL, + \`cover_sticker_id\` varchar(255) NULL, + \`coverStickerId\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`client_release\` ( + \`id\` varchar(255) NOT NULL, + \`name\` varchar(255) NOT NULL, + \`pub_date\` varchar(255) NOT NULL, + \`url\` varchar(255) NOT NULL, + \`deb_url\` varchar(255) NOT NULL, + \`osx_url\` varchar(255) NOT NULL, + \`win_url\` varchar(255) NOT NULL, + \`notes\` varchar(255) NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`notes\` ( + \`id\` varchar(255) NOT NULL, + \`content\` varchar(255) NOT NULL, + \`owner_id\` varchar(255) NULL, + \`target_id\` varchar(255) NULL, + UNIQUE INDEX \`IDX_74e6689b9568cc965b8bfc9150\` (\`owner_id\`, \`target_id\`), + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`member_roles\` ( + \`index\` int NOT NULL, + \`role_id\` varchar(255) NOT NULL, + INDEX \`IDX_5d7ddc8a5f9c167f548625e772\` (\`index\`), + INDEX \`IDX_e9080e7a7997a0170026d5139c\` (\`role_id\`), + PRIMARY KEY (\`index\`, \`role_id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`message_user_mentions\` ( + \`messagesId\` varchar(255) NOT NULL, + \`usersId\` varchar(255) NOT NULL, + INDEX \`IDX_a343387fc560ef378760681c23\` (\`messagesId\`), + INDEX \`IDX_b831eb18ceebd28976239b1e2f\` (\`usersId\`), + PRIMARY KEY (\`messagesId\`, \`usersId\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`message_role_mentions\` ( + \`messagesId\` varchar(255) NOT NULL, + \`rolesId\` varchar(255) NOT NULL, + INDEX \`IDX_a8242cf535337a490b0feaea0b\` (\`messagesId\`), + INDEX \`IDX_29d63eb1a458200851bc37d074\` (\`rolesId\`), + PRIMARY KEY (\`messagesId\`, \`rolesId\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`message_channel_mentions\` ( + \`messagesId\` varchar(255) NOT NULL, + \`channelsId\` varchar(255) NOT NULL, + INDEX \`IDX_2a27102ecd1d81b4582a436092\` (\`messagesId\`), + INDEX \`IDX_bdb8c09e1464cabf62105bf4b9\` (\`channelsId\`), + PRIMARY KEY (\`messagesId\`, \`channelsId\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + CREATE TABLE \`message_stickers\` ( + \`messagesId\` varchar(255) NOT NULL, + \`stickersId\` varchar(255) NOT NULL, + INDEX \`IDX_40bb6f23e7cc133292e92829d2\` (\`messagesId\`), + INDEX \`IDX_e22a70819d07659c7a71c112a1\` (\`stickersId\`), + PRIMARY KEY (\`messagesId\`, \`stickersId\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + ALTER TABLE \`relationships\` + ADD CONSTRAINT \`FK_9af4194bab1250b1c584ae4f1d7\` FOREIGN KEY (\`from_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`relationships\` + ADD CONSTRAINT \`FK_9c7f6b98a9843b76dce1b0c878b\` FOREIGN KEY (\`to_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`connected_accounts\` + ADD CONSTRAINT \`FK_f47244225a6a1eac04a3463dd90\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`backup_codes\` + ADD CONSTRAINT \`FK_70066ea80d2f4b871beda32633b\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`bans\` + ADD CONSTRAINT \`FK_5999e8e449f80a236ff72023559\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`bans\` + ADD CONSTRAINT \`FK_9d3ab7dd180ebdd245cdb66ecad\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`bans\` + ADD CONSTRAINT \`FK_07ad88c86d1f290d46748410d58\` FOREIGN KEY (\`executor_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`recipients\` + ADD CONSTRAINT \`FK_2f18ee1ba667f233ae86c0ea60e\` FOREIGN KEY (\`channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`recipients\` + ADD CONSTRAINT \`FK_6157e8b6ba4e6e3089616481fe2\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`roles\` + ADD CONSTRAINT \`FK_c32c1ab1c4dc7dcb0278c4b1b8b\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`members\` + ADD CONSTRAINT \`FK_28b53062261b996d9c99fa12404\` FOREIGN KEY (\`id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`members\` + ADD CONSTRAINT \`FK_16aceddd5b89825b8ed6029ad1c\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` + ADD CONSTRAINT \`FK_487a7af59d189f744fe394368fc\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` + ADD CONSTRAINT \`FK_df528cf77e82f8032230e7e37d8\` FOREIGN KEY (\`channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` + ADD CONSTRAINT \`FK_c3e5305461931763b56aa905f1c\` FOREIGN KEY (\`application_id\`) REFERENCES \`applications\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` + ADD CONSTRAINT \`FK_0d523f6f997c86e052c49b1455f\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` + ADD CONSTRAINT \`FK_3a285f4f49c40e0706d3018bc9f\` FOREIGN KEY (\`source_guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`stickers\` + ADD CONSTRAINT \`FK_e7cfa5cefa6661b3fb8fda8ce69\` FOREIGN KEY (\`pack_id\`) REFERENCES \`sticker_packs\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`stickers\` + ADD CONSTRAINT \`FK_193d551d852aca5347ef5c9f205\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`stickers\` + ADD CONSTRAINT \`FK_8f4ee73f2bb2325ff980502e158\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`attachments\` + ADD CONSTRAINT \`FK_623e10eec51ada466c5038979e3\` FOREIGN KEY (\`message_id\`) REFERENCES \`messages\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_86b9109b155eb70c0a2ca3b4b6d\` FOREIGN KEY (\`channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_b193588441b085352a4c0109423\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_05535bc695e9f7ee104616459d3\` FOREIGN KEY (\`author_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_b0525304f2262b7014245351c76\` FOREIGN KEY (\`member_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_f83c04bcf1df4e5c0e7a52ed348\` FOREIGN KEY (\`webhook_id\`) REFERENCES \`webhooks\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_5d3ec1cb962de6488637fd779d6\` FOREIGN KEY (\`application_id\`) REFERENCES \`applications\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`messages\` + ADD CONSTRAINT \`FK_61a92bb65b302a76d9c1fcd3174\` FOREIGN KEY (\`message_reference_id\`) REFERENCES \`messages\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`read_states\` + ADD CONSTRAINT \`FK_40da2fca4e0eaf7a23b5bfc5d34\` FOREIGN KEY (\`channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`read_states\` + ADD CONSTRAINT \`FK_195f92e4dd1254a4e348c043763\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_3f4939aa1461e8af57fea3fb05d\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_6a15b051fe5050aa00a4b9ff0f6\` FOREIGN KEY (\`channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_11a0d394f8fc649c19ce5f16b59\` FOREIGN KEY (\`target_user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`voice_states\` + ADD CONSTRAINT \`FK_03779ef216d4b0358470d9cb748\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`voice_states\` + ADD CONSTRAINT \`FK_9f8d389866b40b6657edd026dd4\` FOREIGN KEY (\`channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`voice_states\` + ADD CONSTRAINT \`FK_5fe1d5f931a67e85039c640001b\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD CONSTRAINT \`FK_c253dafe5f3a03ec00cd8fb4581\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD CONSTRAINT \`FK_3274522d14af40540b1a883fc80\` FOREIGN KEY (\`parent_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD CONSTRAINT \`FK_3873ed438575cce703ecff4fc7b\` FOREIGN KEY (\`owner_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`emojis\` + ADD CONSTRAINT \`FK_4b988e0db89d94cebcf07f598cc\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`emojis\` + ADD CONSTRAINT \`FK_fa7ddd5f9a214e28ce596548421\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`templates\` + ADD CONSTRAINT \`FK_d7374b7f8f5fbfdececa4fb62e1\` FOREIGN KEY (\`creator_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`templates\` + ADD CONSTRAINT \`FK_445d00eaaea0e60a017a5ed0c11\` FOREIGN KEY (\`source_guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_f591a66b8019d87b0fe6c12dad6\` FOREIGN KEY (\`afk_channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_e2a2f873a64a5cf62526de42325\` FOREIGN KEY (\`template_id\`) REFERENCES \`templates\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_fc1a451727e3643ca572a3bb394\` FOREIGN KEY (\`owner_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_8d450b016dc8bec35f36729e4b0\` FOREIGN KEY (\`public_updates_channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_95828668aa333460582e0ca6396\` FOREIGN KEY (\`rules_channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_cfc3d3ad260f8121c95b31a1fce\` FOREIGN KEY (\`system_channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD CONSTRAINT \`FK_9d1d665379eefde7876a17afa99\` FOREIGN KEY (\`widget_channel_id\`) REFERENCES \`channels\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`team_members\` + ADD CONSTRAINT \`FK_fdad7d5768277e60c40e01cdcea\` FOREIGN KEY (\`team_id\`) REFERENCES \`teams\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`team_members\` + ADD CONSTRAINT \`FK_c2bf4967c8c2a6b845dadfbf3d4\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`teams\` + ADD CONSTRAINT \`FK_13f00abf7cb6096c43ecaf8c108\` FOREIGN KEY (\`owner_user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_e57508958bf92b9d9d25231b5e8\` FOREIGN KEY (\`owner_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_a36ed02953077f408d0f3ebc424\` FOREIGN KEY (\`team_id\`) REFERENCES \`teams\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_e5bf78cdbbe9ba91062d74c5aba\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`audit_logs\` + ADD CONSTRAINT \`FK_3cd01cd3ae7aab010310d96ac8e\` FOREIGN KEY (\`target_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`audit_logs\` + ADD CONSTRAINT \`FK_bd2726fd31b35443f2245b93ba0\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`sessions\` + ADD CONSTRAINT \`FK_085d540d9f418cfbdc7bd55bb19\` FOREIGN KEY (\`user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`sticker_packs\` + ADD CONSTRAINT \`FK_448fafba4355ee1c837bbc865f1\` FOREIGN KEY (\`coverStickerId\`) REFERENCES \`stickers\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`notes\` + ADD CONSTRAINT \`FK_f9e103f8ae67cb1787063597925\` FOREIGN KEY (\`owner_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`notes\` + ADD CONSTRAINT \`FK_23e08e5b4481711d573e1abecdc\` FOREIGN KEY (\`target_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`member_roles\` + ADD CONSTRAINT \`FK_5d7ddc8a5f9c167f548625e772e\` FOREIGN KEY (\`index\`) REFERENCES \`members\`(\`index\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`member_roles\` + ADD CONSTRAINT \`FK_e9080e7a7997a0170026d5139c1\` FOREIGN KEY (\`role_id\`) REFERENCES \`roles\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_user_mentions\` + ADD CONSTRAINT \`FK_a343387fc560ef378760681c236\` FOREIGN KEY (\`messagesId\`) REFERENCES \`messages\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_user_mentions\` + ADD CONSTRAINT \`FK_b831eb18ceebd28976239b1e2f8\` FOREIGN KEY (\`usersId\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_role_mentions\` + ADD CONSTRAINT \`FK_a8242cf535337a490b0feaea0b4\` FOREIGN KEY (\`messagesId\`) REFERENCES \`messages\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_role_mentions\` + ADD CONSTRAINT \`FK_29d63eb1a458200851bc37d074b\` FOREIGN KEY (\`rolesId\`) REFERENCES \`roles\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_channel_mentions\` + ADD CONSTRAINT \`FK_2a27102ecd1d81b4582a4360921\` FOREIGN KEY (\`messagesId\`) REFERENCES \`messages\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_channel_mentions\` + ADD CONSTRAINT \`FK_bdb8c09e1464cabf62105bf4b9d\` FOREIGN KEY (\`channelsId\`) REFERENCES \`channels\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_stickers\` + ADD CONSTRAINT \`FK_40bb6f23e7cc133292e92829d28\` FOREIGN KEY (\`messagesId\`) REFERENCES \`messages\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE \`message_stickers\` + ADD CONSTRAINT \`FK_e22a70819d07659c7a71c112a1f\` FOREIGN KEY (\`stickersId\`) REFERENCES \`stickers\`(\`id\`) ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + CREATE TABLE \`query-result-cache\` ( + \`id\` int NOT NULL AUTO_INCREMENT, + \`identifier\` varchar(255) NULL, + \`time\` bigint NOT NULL, + \`duration\` int NOT NULL, + \`query\` text NOT NULL, + \`result\` text NOT NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP TABLE \`query-result-cache\` + `); + await queryRunner.query(` + ALTER TABLE \`message_stickers\` DROP FOREIGN KEY \`FK_e22a70819d07659c7a71c112a1f\` + `); + await queryRunner.query(` + ALTER TABLE \`message_stickers\` DROP FOREIGN KEY \`FK_40bb6f23e7cc133292e92829d28\` + `); + await queryRunner.query(` + ALTER TABLE \`message_channel_mentions\` DROP FOREIGN KEY \`FK_bdb8c09e1464cabf62105bf4b9d\` + `); + await queryRunner.query(` + ALTER TABLE \`message_channel_mentions\` DROP FOREIGN KEY \`FK_2a27102ecd1d81b4582a4360921\` + `); + await queryRunner.query(` + ALTER TABLE \`message_role_mentions\` DROP FOREIGN KEY \`FK_29d63eb1a458200851bc37d074b\` + `); + await queryRunner.query(` + ALTER TABLE \`message_role_mentions\` DROP FOREIGN KEY \`FK_a8242cf535337a490b0feaea0b4\` + `); + await queryRunner.query(` + ALTER TABLE \`message_user_mentions\` DROP FOREIGN KEY \`FK_b831eb18ceebd28976239b1e2f8\` + `); + await queryRunner.query(` + ALTER TABLE \`message_user_mentions\` DROP FOREIGN KEY \`FK_a343387fc560ef378760681c236\` + `); + await queryRunner.query(` + ALTER TABLE \`member_roles\` DROP FOREIGN KEY \`FK_e9080e7a7997a0170026d5139c1\` + `); + await queryRunner.query(` + ALTER TABLE \`member_roles\` DROP FOREIGN KEY \`FK_5d7ddc8a5f9c167f548625e772e\` + `); + await queryRunner.query(` + ALTER TABLE \`notes\` DROP FOREIGN KEY \`FK_23e08e5b4481711d573e1abecdc\` + `); + await queryRunner.query(` + ALTER TABLE \`notes\` DROP FOREIGN KEY \`FK_f9e103f8ae67cb1787063597925\` + `); + await queryRunner.query(` + ALTER TABLE \`sticker_packs\` DROP FOREIGN KEY \`FK_448fafba4355ee1c837bbc865f1\` + `); + await queryRunner.query(` + ALTER TABLE \`sessions\` DROP FOREIGN KEY \`FK_085d540d9f418cfbdc7bd55bb19\` + `); + await queryRunner.query(` + ALTER TABLE \`audit_logs\` DROP FOREIGN KEY \`FK_bd2726fd31b35443f2245b93ba0\` + `); + await queryRunner.query(` + ALTER TABLE \`audit_logs\` DROP FOREIGN KEY \`FK_3cd01cd3ae7aab010310d96ac8e\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_e5bf78cdbbe9ba91062d74c5aba\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_a36ed02953077f408d0f3ebc424\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_e57508958bf92b9d9d25231b5e8\` + `); + await queryRunner.query(` + ALTER TABLE \`teams\` DROP FOREIGN KEY \`FK_13f00abf7cb6096c43ecaf8c108\` + `); + await queryRunner.query(` + ALTER TABLE \`team_members\` DROP FOREIGN KEY \`FK_c2bf4967c8c2a6b845dadfbf3d4\` + `); + await queryRunner.query(` + ALTER TABLE \`team_members\` DROP FOREIGN KEY \`FK_fdad7d5768277e60c40e01cdcea\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_9d1d665379eefde7876a17afa99\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_cfc3d3ad260f8121c95b31a1fce\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_95828668aa333460582e0ca6396\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_8d450b016dc8bec35f36729e4b0\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_fc1a451727e3643ca572a3bb394\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_e2a2f873a64a5cf62526de42325\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP FOREIGN KEY \`FK_f591a66b8019d87b0fe6c12dad6\` + `); + await queryRunner.query(` + ALTER TABLE \`templates\` DROP FOREIGN KEY \`FK_445d00eaaea0e60a017a5ed0c11\` + `); + await queryRunner.query(` + ALTER TABLE \`templates\` DROP FOREIGN KEY \`FK_d7374b7f8f5fbfdececa4fb62e1\` + `); + await queryRunner.query(` + ALTER TABLE \`emojis\` DROP FOREIGN KEY \`FK_fa7ddd5f9a214e28ce596548421\` + `); + await queryRunner.query(` + ALTER TABLE \`emojis\` DROP FOREIGN KEY \`FK_4b988e0db89d94cebcf07f598cc\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP FOREIGN KEY \`FK_3873ed438575cce703ecff4fc7b\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP FOREIGN KEY \`FK_3274522d14af40540b1a883fc80\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP FOREIGN KEY \`FK_c253dafe5f3a03ec00cd8fb4581\` + `); + await queryRunner.query(` + ALTER TABLE \`voice_states\` DROP FOREIGN KEY \`FK_5fe1d5f931a67e85039c640001b\` + `); + await queryRunner.query(` + ALTER TABLE \`voice_states\` DROP FOREIGN KEY \`FK_9f8d389866b40b6657edd026dd4\` + `); + await queryRunner.query(` + ALTER TABLE \`voice_states\` DROP FOREIGN KEY \`FK_03779ef216d4b0358470d9cb748\` + `); + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_11a0d394f8fc649c19ce5f16b59\` + `); + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` + `); + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_6a15b051fe5050aa00a4b9ff0f6\` + `); + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_3f4939aa1461e8af57fea3fb05d\` + `); + await queryRunner.query(` + ALTER TABLE \`read_states\` DROP FOREIGN KEY \`FK_195f92e4dd1254a4e348c043763\` + `); + await queryRunner.query(` + ALTER TABLE \`read_states\` DROP FOREIGN KEY \`FK_40da2fca4e0eaf7a23b5bfc5d34\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_61a92bb65b302a76d9c1fcd3174\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_5d3ec1cb962de6488637fd779d6\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_f83c04bcf1df4e5c0e7a52ed348\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_b0525304f2262b7014245351c76\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_05535bc695e9f7ee104616459d3\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_b193588441b085352a4c0109423\` + `); + await queryRunner.query(` + ALTER TABLE \`messages\` DROP FOREIGN KEY \`FK_86b9109b155eb70c0a2ca3b4b6d\` + `); + await queryRunner.query(` + ALTER TABLE \`attachments\` DROP FOREIGN KEY \`FK_623e10eec51ada466c5038979e3\` + `); + await queryRunner.query(` + ALTER TABLE \`stickers\` DROP FOREIGN KEY \`FK_8f4ee73f2bb2325ff980502e158\` + `); + await queryRunner.query(` + ALTER TABLE \`stickers\` DROP FOREIGN KEY \`FK_193d551d852aca5347ef5c9f205\` + `); + await queryRunner.query(` + ALTER TABLE \`stickers\` DROP FOREIGN KEY \`FK_e7cfa5cefa6661b3fb8fda8ce69\` + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` DROP FOREIGN KEY \`FK_3a285f4f49c40e0706d3018bc9f\` + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` DROP FOREIGN KEY \`FK_0d523f6f997c86e052c49b1455f\` + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` DROP FOREIGN KEY \`FK_c3e5305461931763b56aa905f1c\` + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` DROP FOREIGN KEY \`FK_df528cf77e82f8032230e7e37d8\` + `); + await queryRunner.query(` + ALTER TABLE \`webhooks\` DROP FOREIGN KEY \`FK_487a7af59d189f744fe394368fc\` + `); + await queryRunner.query(` + ALTER TABLE \`members\` DROP FOREIGN KEY \`FK_16aceddd5b89825b8ed6029ad1c\` + `); + await queryRunner.query(` + ALTER TABLE \`members\` DROP FOREIGN KEY \`FK_28b53062261b996d9c99fa12404\` + `); + await queryRunner.query(` + ALTER TABLE \`roles\` DROP FOREIGN KEY \`FK_c32c1ab1c4dc7dcb0278c4b1b8b\` + `); + await queryRunner.query(` + ALTER TABLE \`recipients\` DROP FOREIGN KEY \`FK_6157e8b6ba4e6e3089616481fe2\` + `); + await queryRunner.query(` + ALTER TABLE \`recipients\` DROP FOREIGN KEY \`FK_2f18ee1ba667f233ae86c0ea60e\` + `); + await queryRunner.query(` + ALTER TABLE \`bans\` DROP FOREIGN KEY \`FK_07ad88c86d1f290d46748410d58\` + `); + await queryRunner.query(` + ALTER TABLE \`bans\` DROP FOREIGN KEY \`FK_9d3ab7dd180ebdd245cdb66ecad\` + `); + await queryRunner.query(` + ALTER TABLE \`bans\` DROP FOREIGN KEY \`FK_5999e8e449f80a236ff72023559\` + `); + await queryRunner.query(` + ALTER TABLE \`backup_codes\` DROP FOREIGN KEY \`FK_70066ea80d2f4b871beda32633b\` + `); + await queryRunner.query(` + ALTER TABLE \`connected_accounts\` DROP FOREIGN KEY \`FK_f47244225a6a1eac04a3463dd90\` + `); + await queryRunner.query(` + ALTER TABLE \`relationships\` DROP FOREIGN KEY \`FK_9c7f6b98a9843b76dce1b0c878b\` + `); + await queryRunner.query(` + ALTER TABLE \`relationships\` DROP FOREIGN KEY \`FK_9af4194bab1250b1c584ae4f1d7\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_e22a70819d07659c7a71c112a1\` ON \`message_stickers\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_40bb6f23e7cc133292e92829d2\` ON \`message_stickers\` + `); + await queryRunner.query(` + DROP TABLE \`message_stickers\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_bdb8c09e1464cabf62105bf4b9\` ON \`message_channel_mentions\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_2a27102ecd1d81b4582a436092\` ON \`message_channel_mentions\` + `); + await queryRunner.query(` + DROP TABLE \`message_channel_mentions\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_29d63eb1a458200851bc37d074\` ON \`message_role_mentions\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_a8242cf535337a490b0feaea0b\` ON \`message_role_mentions\` + `); + await queryRunner.query(` + DROP TABLE \`message_role_mentions\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_b831eb18ceebd28976239b1e2f\` ON \`message_user_mentions\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_a343387fc560ef378760681c23\` ON \`message_user_mentions\` + `); + await queryRunner.query(` + DROP TABLE \`message_user_mentions\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_e9080e7a7997a0170026d5139c\` ON \`member_roles\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_5d7ddc8a5f9c167f548625e772\` ON \`member_roles\` + `); + await queryRunner.query(` + DROP TABLE \`member_roles\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_74e6689b9568cc965b8bfc9150\` ON \`notes\` + `); + await queryRunner.query(` + DROP TABLE \`notes\` + `); + await queryRunner.query(` + DROP TABLE \`client_release\` + `); + await queryRunner.query(` + DROP TABLE \`sticker_packs\` + `); + await queryRunner.query(` + DROP TABLE \`sessions\` + `); + await queryRunner.query(` + DROP TABLE \`rate_limits\` + `); + await queryRunner.query(` + DROP TABLE \`categories\` + `); + await queryRunner.query(` + DROP TABLE \`audit_logs\` + `); + await queryRunner.query(` + DROP TABLE \`applications\` + `); + await queryRunner.query(` + DROP TABLE \`teams\` + `); + await queryRunner.query(` + DROP TABLE \`team_members\` + `); + await queryRunner.query(` + DROP TABLE \`guilds\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_be38737bf339baf63b1daeffb5\` ON \`templates\` + `); + await queryRunner.query(` + DROP TABLE \`templates\` + `); + await queryRunner.query(` + DROP TABLE \`emojis\` + `); + await queryRunner.query(` + DROP TABLE \`channels\` + `); + await queryRunner.query(` + DROP TABLE \`voice_states\` + `); + await queryRunner.query(` + DROP TABLE \`invites\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_0abf8b443321bd3cf7f81ee17a\` ON \`read_states\` + `); + await queryRunner.query(` + DROP TABLE \`read_states\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_3ed7a60fb7dbe04e1ba9332a8b\` ON \`messages\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_05535bc695e9f7ee104616459d\` ON \`messages\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_86b9109b155eb70c0a2ca3b4b6\` ON \`messages\` + `); + await queryRunner.query(` + DROP TABLE \`messages\` + `); + await queryRunner.query(` + DROP TABLE \`attachments\` + `); + await queryRunner.query(` + DROP TABLE \`stickers\` + `); + await queryRunner.query(` + DROP TABLE \`webhooks\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_bb2bf9386ac443afbbbf9f12d3\` ON \`members\` + `); + await queryRunner.query(` + DROP TABLE \`members\` + `); + await queryRunner.query(` + DROP TABLE \`roles\` + `); + await queryRunner.query(` + DROP TABLE \`recipients\` + `); + await queryRunner.query(` + DROP TABLE \`bans\` + `); + await queryRunner.query(` + DROP TABLE \`backup_codes\` + `); + await queryRunner.query(` + DROP TABLE \`users\` + `); + await queryRunner.query(` + DROP TABLE \`connected_accounts\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_a0b2ff0a598df0b0d055934a17\` ON \`relationships\` + `); + await queryRunner.query(` + DROP TABLE \`relationships\` + `); + await queryRunner.query(` + DROP TABLE \`config\` + `); + } + +} diff --git a/util/src/migrations/postgres/1659899687168-initial.ts b/util/src/migrations/postgres/1659899687168-initial.ts new file mode 100644 index 000000000..4ffb897d1 --- /dev/null +++ b/util/src/migrations/postgres/1659899687168-initial.ts @@ -0,0 +1,1245 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class initial1659899687168 implements MigrationInterface { + name = 'initial1659899687168' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "config" ( + "key" character varying NOT NULL, + "value" text, + CONSTRAINT "PK_26489c99ddbb4c91631ef5cc791" PRIMARY KEY ("key") + ) + `); + await queryRunner.query(` + CREATE TABLE "relationships" ( + "id" character varying NOT NULL, + "from_id" character varying NOT NULL, + "to_id" character varying NOT NULL, + "nickname" character varying, + "type" integer NOT NULL, + CONSTRAINT "PK_ba20e2f5cf487408e08e4dcecaf" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_a0b2ff0a598df0b0d055934a17" ON "relationships" ("from_id", "to_id") + `); + await queryRunner.query(` + CREATE TABLE "connected_accounts" ( + "id" character varying NOT NULL, + "user_id" character varying, + "access_token" character varying NOT NULL, + "friend_sync" boolean NOT NULL, + "name" character varying NOT NULL, + "revoked" boolean NOT NULL, + "show_activity" boolean NOT NULL, + "type" character varying NOT NULL, + "verified" boolean NOT NULL, + "visibility" integer NOT NULL, + CONSTRAINT "PK_70416f1da0be645bb31da01c774" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" character varying NOT NULL, + "username" character varying NOT NULL, + "discriminator" character varying NOT NULL, + "avatar" character varying, + "accent_color" integer, + "banner" character varying, + "phone" character varying, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" character varying NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" character varying, + "totp_last_ticket" character varying, + "created_at" TIMESTAMP NOT NULL, + "premium_since" TIMESTAMP, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" character varying, + "flags" character varying NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "settings" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + CONSTRAINT "PK_a3ffb1c0c8416b9fc6f907b7433" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "backup_codes" ( + "id" character varying NOT NULL, + "code" character varying NOT NULL, + "consumed" boolean NOT NULL, + "expired" boolean NOT NULL, + "user_id" character varying, + CONSTRAINT "PK_34ab957382dbc57e8fb53f1638f" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "bans" ( + "id" character varying NOT NULL, + "user_id" character varying, + "guild_id" character varying, + "executor_id" character varying, + "ip" character varying NOT NULL, + "reason" character varying, + CONSTRAINT "PK_a4d6f261bffa4615c62d756566a" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "recipients" ( + "id" character varying NOT NULL, + "channel_id" character varying NOT NULL, + "user_id" character varying NOT NULL, + "closed" boolean NOT NULL DEFAULT false, + CONSTRAINT "PK_de8fc5a9c364568f294798fe1e9" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "roles" ( + "id" character varying NOT NULL, + "guild_id" character varying, + "color" integer NOT NULL, + "hoist" boolean NOT NULL, + "managed" boolean NOT NULL, + "mentionable" boolean NOT NULL, + "name" character varying NOT NULL, + "permissions" character varying NOT NULL, + "position" integer NOT NULL, + "icon" character varying, + "unicode_emoji" character varying, + "tags" text, + CONSTRAINT "PK_c1433d71a4838793a49dcad46ab" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "members" ( + "index" SERIAL NOT NULL, + "id" character varying NOT NULL, + "guild_id" character varying NOT NULL, + "nick" character varying, + "joined_at" TIMESTAMP NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" character varying, + "joined_by" character varying, + CONSTRAINT "PK_b4a6b8c2478e5df990909c6cf6a" PRIMARY KEY ("index") + ) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + await queryRunner.query(` + CREATE TABLE "webhooks" ( + "id" character varying NOT NULL, + "type" integer NOT NULL, + "name" character varying, + "avatar" character varying, + "token" character varying, + "guild_id" character varying, + "channel_id" character varying, + "application_id" character varying, + "user_id" character varying, + "source_guild_id" character varying, + CONSTRAINT "PK_9e8795cfc899ab7bdaa831e8527" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "stickers" ( + "id" character varying NOT NULL, + "name" character varying NOT NULL, + "description" character varying, + "available" boolean, + "tags" character varying, + "pack_id" character varying, + "guild_id" character varying, + "user_id" character varying, + "type" integer NOT NULL, + "format_type" integer NOT NULL, + CONSTRAINT "PK_e1dafa4063a5532645cc2810374" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "attachments" ( + "id" character varying NOT NULL, + "filename" character varying NOT NULL, + "size" integer NOT NULL, + "url" character varying NOT NULL, + "proxy_url" character varying NOT NULL, + "height" integer, + "width" integer, + "content_type" character varying, + "message_id" character varying, + CONSTRAINT "PK_5e1f050bcff31e3084a1d662412" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "messages" ( + "id" character varying NOT NULL, + "channel_id" character varying, + "guild_id" character varying, + "author_id" character varying, + "member_id" character varying, + "webhook_id" character varying, + "application_id" character varying, + "content" character varying, + "timestamp" TIMESTAMP NOT NULL DEFAULT now(), + "edited_timestamp" TIMESTAMP, + "tts" boolean, + "mention_everyone" boolean, + "embeds" text NOT NULL, + "reactions" text NOT NULL, + "nonce" text, + "pinned" boolean, + "type" integer NOT NULL, + "activity" text, + "flags" character varying, + "message_reference" text, + "interaction" text, + "components" text, + "message_reference_id" character varying, + CONSTRAINT "PK_18325f38ae6de43878487eff986" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_86b9109b155eb70c0a2ca3b4b6" ON "messages" ("channel_id") + `); + await queryRunner.query(` + CREATE INDEX "IDX_05535bc695e9f7ee104616459d" ON "messages" ("author_id") + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_3ed7a60fb7dbe04e1ba9332a8b" ON "messages" ("channel_id", "id") + `); + await queryRunner.query(` + CREATE TABLE "read_states" ( + "id" character varying NOT NULL, + "channel_id" character varying NOT NULL, + "user_id" character varying NOT NULL, + "last_message_id" character varying, + "public_ack" character varying, + "notifications_cursor" character varying, + "last_pin_timestamp" TIMESTAMP, + "mention_count" integer, + CONSTRAINT "PK_e6956a804978f01b713b1ed58e2" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_0abf8b443321bd3cf7f81ee17a" ON "read_states" ("channel_id", "user_id") + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" character varying NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" TIMESTAMP NOT NULL, + "expires_at" TIMESTAMP NOT NULL, + "guild_id" character varying, + "channel_id" character varying, + "inviter_id" character varying, + "target_user_id" character varying, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "PK_33fd8a248db1cd832baa8aa25bf" PRIMARY KEY ("code") + ) + `); + await queryRunner.query(` + CREATE TABLE "voice_states" ( + "id" character varying NOT NULL, + "guild_id" character varying, + "channel_id" character varying, + "user_id" character varying, + "session_id" character varying NOT NULL, + "token" character varying, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "self_deaf" boolean NOT NULL, + "self_mute" boolean NOT NULL, + "self_stream" boolean, + "self_video" boolean NOT NULL, + "suppress" boolean NOT NULL, + "request_to_speak_timestamp" TIMESTAMP, + CONSTRAINT "PK_ada09a50c134fad1369b510e3ce" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "channels" ( + "id" character varying NOT NULL, + "created_at" TIMESTAMP NOT NULL, + "name" character varying, + "icon" text, + "type" integer NOT NULL, + "last_message_id" character varying, + "guild_id" character varying, + "parent_id" character varying, + "owner_id" character varying, + "last_pin_timestamp" integer, + "default_auto_archive_duration" integer, + "position" integer, + "permission_overwrites" text, + "video_quality_mode" integer, + "bitrate" integer, + "user_limit" integer, + "nsfw" boolean, + "rate_limit_per_user" integer, + "topic" character varying, + "retention_policy_id" character varying, + CONSTRAINT "PK_bc603823f3f741359c2339389f9" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "emojis" ( + "id" character varying NOT NULL, + "animated" boolean NOT NULL, + "available" boolean NOT NULL, + "guild_id" character varying NOT NULL, + "user_id" character varying, + "managed" boolean NOT NULL, + "name" character varying NOT NULL, + "require_colons" boolean NOT NULL, + "roles" text NOT NULL, + "groups" text, + CONSTRAINT "PK_9adb96a675f555c6169bad7ba62" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "templates" ( + "id" character varying NOT NULL, + "code" character varying NOT NULL, + "name" character varying NOT NULL, + "description" character varying, + "usage_count" integer, + "creator_id" character varying, + "created_at" TIMESTAMP NOT NULL, + "updated_at" TIMESTAMP NOT NULL, + "source_guild_id" character varying, + "serialized_source_guild" text NOT NULL, + CONSTRAINT "UQ_be38737bf339baf63b1daeffb55" UNIQUE ("code"), + CONSTRAINT "PK_515948649ce0bbbe391de702ae5" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "guilds" ( + "id" character varying NOT NULL, + "afk_channel_id" character varying, + "afk_timeout" integer, + "banner" character varying, + "default_message_notifications" integer, + "description" character varying, + "discovery_splash" character varying, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" character varying, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" character varying, + "mfa_level" integer, + "name" character varying NOT NULL, + "owner_id" character varying, + "preferred_locale" character varying, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" character varying, + "rules_channel_id" character varying, + "region" character varying, + "splash" character varying, + "system_channel_id" character varying, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" character varying, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" character varying, + CONSTRAINT "PK_e7e7f2a51bd6d96a9ac2aa560f9" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "team_members" ( + "id" character varying NOT NULL, + "membership_state" integer NOT NULL, + "permissions" text NOT NULL, + "team_id" character varying, + "user_id" character varying, + CONSTRAINT "PK_ca3eae89dcf20c9fd95bf7460aa" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "teams" ( + "id" character varying NOT NULL, + "icon" character varying, + "name" character varying NOT NULL, + "owner_user_id" character varying, + CONSTRAINT "PK_7e5523774a38b08a6236d322403" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" character varying NOT NULL, + "name" character varying NOT NULL, + "icon" character varying, + "description" character varying NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" character varying, + "privacy_policy_url" character varying, + "summary" character varying, + "verify_key" character varying NOT NULL, + "primary_sku_id" character varying, + "slug" character varying, + "cover_image" character varying, + "flags" character varying NOT NULL, + "owner_id" character varying, + "team_id" character varying, + "guild_id" character varying, + CONSTRAINT "PK_938c0a27255637bde919591888f" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "audit_logs" ( + "id" character varying NOT NULL, + "user_id" character varying, + "action_type" integer NOT NULL, + "options" text, + "changes" text NOT NULL, + "reason" character varying, + "target_id" character varying, + CONSTRAINT "PK_1bb179d048bbc581caa3b013439" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "categories" ( + "id" integer NOT NULL, + "name" character varying, + "localizations" text NOT NULL, + "is_primary" boolean, + CONSTRAINT "PK_24dbc6126a28ff948da33e97d3b" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "rate_limits" ( + "id" character varying NOT NULL, + "executor_id" character varying NOT NULL, + "hits" integer NOT NULL, + "blocked" boolean NOT NULL, + "expires_at" TIMESTAMP NOT NULL, + CONSTRAINT "PK_3b4449f1f5fc167d921ee619f65" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "sessions" ( + "id" character varying NOT NULL, + "user_id" character varying, + "session_id" character varying NOT NULL, + "activities" text, + "client_info" text NOT NULL, + "status" character varying NOT NULL, + CONSTRAINT "PK_3238ef96f18b355b671619111bc" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "sticker_packs" ( + "id" character varying NOT NULL, + "name" character varying NOT NULL, + "description" character varying, + "banner_asset_id" character varying, + "cover_sticker_id" character varying, + "coverStickerId" character varying, + CONSTRAINT "PK_a27381efea0f876f5d3233af655" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "client_release" ( + "id" character varying NOT NULL, + "name" character varying NOT NULL, + "pub_date" character varying NOT NULL, + "url" character varying NOT NULL, + "deb_url" character varying NOT NULL, + "osx_url" character varying NOT NULL, + "win_url" character varying NOT NULL, + "notes" character varying, + CONSTRAINT "PK_4c4ea258342d2d6ba1be0a71a43" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "notes" ( + "id" character varying NOT NULL, + "content" character varying NOT NULL, + "owner_id" character varying, + "target_id" character varying, + CONSTRAINT "UQ_74e6689b9568cc965b8bfc9150b" UNIQUE ("owner_id", "target_id"), + CONSTRAINT "PK_af6206538ea96c4e77e9f400c3d" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + CREATE TABLE "member_roles" ( + "index" integer NOT NULL, + "role_id" character varying NOT NULL, + CONSTRAINT "PK_951c1d72a0fd1da8760b4a1fd66" PRIMARY KEY ("index", "role_id") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_5d7ddc8a5f9c167f548625e772" ON "member_roles" ("index") + `); + await queryRunner.query(` + CREATE INDEX "IDX_e9080e7a7997a0170026d5139c" ON "member_roles" ("role_id") + `); + await queryRunner.query(` + CREATE TABLE "message_user_mentions" ( + "messagesId" character varying NOT NULL, + "usersId" character varying NOT NULL, + CONSTRAINT "PK_9b9b6e245ad47a48dbd7605d4fb" PRIMARY KEY ("messagesId", "usersId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_a343387fc560ef378760681c23" ON "message_user_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_b831eb18ceebd28976239b1e2f" ON "message_user_mentions" ("usersId") + `); + await queryRunner.query(` + CREATE TABLE "message_role_mentions" ( + "messagesId" character varying NOT NULL, + "rolesId" character varying NOT NULL, + CONSTRAINT "PK_74dba92cc300452a6e14b83ed44" PRIMARY KEY ("messagesId", "rolesId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_a8242cf535337a490b0feaea0b" ON "message_role_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_29d63eb1a458200851bc37d074" ON "message_role_mentions" ("rolesId") + `); + await queryRunner.query(` + CREATE TABLE "message_channel_mentions" ( + "messagesId" character varying NOT NULL, + "channelsId" character varying NOT NULL, + CONSTRAINT "PK_85cb45351497cd9d06a79ced65e" PRIMARY KEY ("messagesId", "channelsId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_2a27102ecd1d81b4582a436092" ON "message_channel_mentions" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_bdb8c09e1464cabf62105bf4b9" ON "message_channel_mentions" ("channelsId") + `); + await queryRunner.query(` + CREATE TABLE "message_stickers" ( + "messagesId" character varying NOT NULL, + "stickersId" character varying NOT NULL, + CONSTRAINT "PK_ed820c4093d0b8cd1d2bcf66087" PRIMARY KEY ("messagesId", "stickersId") + ) + `); + await queryRunner.query(` + CREATE INDEX "IDX_40bb6f23e7cc133292e92829d2" ON "message_stickers" ("messagesId") + `); + await queryRunner.query(` + CREATE INDEX "IDX_e22a70819d07659c7a71c112a1" ON "message_stickers" ("stickersId") + `); + await queryRunner.query(` + ALTER TABLE "relationships" + ADD CONSTRAINT "FK_9af4194bab1250b1c584ae4f1d7" FOREIGN KEY ("from_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "relationships" + ADD CONSTRAINT "FK_9c7f6b98a9843b76dce1b0c878b" FOREIGN KEY ("to_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "connected_accounts" + ADD CONSTRAINT "FK_f47244225a6a1eac04a3463dd90" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "backup_codes" + ADD CONSTRAINT "FK_70066ea80d2f4b871beda32633b" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "bans" + ADD CONSTRAINT "FK_5999e8e449f80a236ff72023559" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "bans" + ADD CONSTRAINT "FK_9d3ab7dd180ebdd245cdb66ecad" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "bans" + ADD CONSTRAINT "FK_07ad88c86d1f290d46748410d58" FOREIGN KEY ("executor_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "recipients" + ADD CONSTRAINT "FK_2f18ee1ba667f233ae86c0ea60e" FOREIGN KEY ("channel_id") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "recipients" + ADD CONSTRAINT "FK_6157e8b6ba4e6e3089616481fe2" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "roles" + ADD CONSTRAINT "FK_c32c1ab1c4dc7dcb0278c4b1b8b" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "members" + ADD CONSTRAINT "FK_28b53062261b996d9c99fa12404" FOREIGN KEY ("id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "members" + ADD CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "webhooks" + ADD CONSTRAINT "FK_487a7af59d189f744fe394368fc" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "webhooks" + ADD CONSTRAINT "FK_df528cf77e82f8032230e7e37d8" FOREIGN KEY ("channel_id") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "webhooks" + ADD CONSTRAINT "FK_c3e5305461931763b56aa905f1c" FOREIGN KEY ("application_id") REFERENCES "applications"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "webhooks" + ADD CONSTRAINT "FK_0d523f6f997c86e052c49b1455f" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "webhooks" + ADD CONSTRAINT "FK_3a285f4f49c40e0706d3018bc9f" FOREIGN KEY ("source_guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "stickers" + ADD CONSTRAINT "FK_e7cfa5cefa6661b3fb8fda8ce69" FOREIGN KEY ("pack_id") REFERENCES "sticker_packs"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "stickers" + ADD CONSTRAINT "FK_193d551d852aca5347ef5c9f205" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "stickers" + ADD CONSTRAINT "FK_8f4ee73f2bb2325ff980502e158" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "attachments" + ADD CONSTRAINT "FK_623e10eec51ada466c5038979e3" FOREIGN KEY ("message_id") REFERENCES "messages"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_86b9109b155eb70c0a2ca3b4b6d" FOREIGN KEY ("channel_id") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_b193588441b085352a4c0109423" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_05535bc695e9f7ee104616459d3" FOREIGN KEY ("author_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_b0525304f2262b7014245351c76" FOREIGN KEY ("member_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_f83c04bcf1df4e5c0e7a52ed348" FOREIGN KEY ("webhook_id") REFERENCES "webhooks"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_5d3ec1cb962de6488637fd779d6" FOREIGN KEY ("application_id") REFERENCES "applications"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "messages" + ADD CONSTRAINT "FK_61a92bb65b302a76d9c1fcd3174" FOREIGN KEY ("message_reference_id") REFERENCES "messages"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "read_states" + ADD CONSTRAINT "FK_40da2fca4e0eaf7a23b5bfc5d34" FOREIGN KEY ("channel_id") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "read_states" + ADD CONSTRAINT "FK_195f92e4dd1254a4e348c043763" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "voice_states" + ADD CONSTRAINT "FK_03779ef216d4b0358470d9cb748" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "voice_states" + ADD CONSTRAINT "FK_9f8d389866b40b6657edd026dd4" FOREIGN KEY ("channel_id") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "voice_states" + ADD CONSTRAINT "FK_5fe1d5f931a67e85039c640001b" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "channels" + ADD CONSTRAINT "FK_c253dafe5f3a03ec00cd8fb4581" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "channels" + ADD CONSTRAINT "FK_3274522d14af40540b1a883fc80" FOREIGN KEY ("parent_id") REFERENCES "channels"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "channels" + ADD CONSTRAINT "FK_3873ed438575cce703ecff4fc7b" FOREIGN KEY ("owner_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "emojis" + ADD CONSTRAINT "FK_4b988e0db89d94cebcf07f598cc" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "emojis" + ADD CONSTRAINT "FK_fa7ddd5f9a214e28ce596548421" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "templates" + ADD CONSTRAINT "FK_d7374b7f8f5fbfdececa4fb62e1" FOREIGN KEY ("creator_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "templates" + ADD CONSTRAINT "FK_445d00eaaea0e60a017a5ed0c11" FOREIGN KEY ("source_guild_id") REFERENCES "guilds"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "team_members" + ADD CONSTRAINT "FK_fdad7d5768277e60c40e01cdcea" FOREIGN KEY ("team_id") REFERENCES "teams"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "team_members" + ADD CONSTRAINT "FK_c2bf4967c8c2a6b845dadfbf3d4" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "teams" + ADD CONSTRAINT "FK_13f00abf7cb6096c43ecaf8c108" FOREIGN KEY ("owner_user_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD CONSTRAINT "FK_e5bf78cdbbe9ba91062d74c5aba" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "audit_logs" + ADD CONSTRAINT "FK_3cd01cd3ae7aab010310d96ac8e" FOREIGN KEY ("target_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "audit_logs" + ADD CONSTRAINT "FK_bd2726fd31b35443f2245b93ba0" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "sessions" + ADD CONSTRAINT "FK_085d540d9f418cfbdc7bd55bb19" FOREIGN KEY ("user_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "sticker_packs" + ADD CONSTRAINT "FK_448fafba4355ee1c837bbc865f1" FOREIGN KEY ("coverStickerId") REFERENCES "stickers"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "notes" + ADD CONSTRAINT "FK_f9e103f8ae67cb1787063597925" FOREIGN KEY ("owner_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "notes" + ADD CONSTRAINT "FK_23e08e5b4481711d573e1abecdc" FOREIGN KEY ("target_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE "member_roles" + ADD CONSTRAINT "FK_5d7ddc8a5f9c167f548625e772e" FOREIGN KEY ("index") REFERENCES "members"("index") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "member_roles" + ADD CONSTRAINT "FK_e9080e7a7997a0170026d5139c1" FOREIGN KEY ("role_id") REFERENCES "roles"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_user_mentions" + ADD CONSTRAINT "FK_a343387fc560ef378760681c236" FOREIGN KEY ("messagesId") REFERENCES "messages"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_user_mentions" + ADD CONSTRAINT "FK_b831eb18ceebd28976239b1e2f8" FOREIGN KEY ("usersId") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_role_mentions" + ADD CONSTRAINT "FK_a8242cf535337a490b0feaea0b4" FOREIGN KEY ("messagesId") REFERENCES "messages"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_role_mentions" + ADD CONSTRAINT "FK_29d63eb1a458200851bc37d074b" FOREIGN KEY ("rolesId") REFERENCES "roles"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_channel_mentions" + ADD CONSTRAINT "FK_2a27102ecd1d81b4582a4360921" FOREIGN KEY ("messagesId") REFERENCES "messages"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_channel_mentions" + ADD CONSTRAINT "FK_bdb8c09e1464cabf62105bf4b9d" FOREIGN KEY ("channelsId") REFERENCES "channels"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_stickers" + ADD CONSTRAINT "FK_40bb6f23e7cc133292e92829d28" FOREIGN KEY ("messagesId") REFERENCES "messages"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + ALTER TABLE "message_stickers" + ADD CONSTRAINT "FK_e22a70819d07659c7a71c112a1f" FOREIGN KEY ("stickersId") REFERENCES "stickers"("id") ON DELETE CASCADE ON UPDATE CASCADE + `); + await queryRunner.query(` + CREATE TABLE "query-result-cache" ( + "id" SERIAL NOT NULL, + "identifier" character varying, + "time" bigint NOT NULL, + "duration" integer NOT NULL, + "query" text NOT NULL, + "result" text NOT NULL, + CONSTRAINT "PK_6a98f758d8bfd010e7e10ffd3d3" PRIMARY KEY ("id") + ) + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP TABLE "query-result-cache" + `); + await queryRunner.query(` + ALTER TABLE "message_stickers" DROP CONSTRAINT "FK_e22a70819d07659c7a71c112a1f" + `); + await queryRunner.query(` + ALTER TABLE "message_stickers" DROP CONSTRAINT "FK_40bb6f23e7cc133292e92829d28" + `); + await queryRunner.query(` + ALTER TABLE "message_channel_mentions" DROP CONSTRAINT "FK_bdb8c09e1464cabf62105bf4b9d" + `); + await queryRunner.query(` + ALTER TABLE "message_channel_mentions" DROP CONSTRAINT "FK_2a27102ecd1d81b4582a4360921" + `); + await queryRunner.query(` + ALTER TABLE "message_role_mentions" DROP CONSTRAINT "FK_29d63eb1a458200851bc37d074b" + `); + await queryRunner.query(` + ALTER TABLE "message_role_mentions" DROP CONSTRAINT "FK_a8242cf535337a490b0feaea0b4" + `); + await queryRunner.query(` + ALTER TABLE "message_user_mentions" DROP CONSTRAINT "FK_b831eb18ceebd28976239b1e2f8" + `); + await queryRunner.query(` + ALTER TABLE "message_user_mentions" DROP CONSTRAINT "FK_a343387fc560ef378760681c236" + `); + await queryRunner.query(` + ALTER TABLE "member_roles" DROP CONSTRAINT "FK_e9080e7a7997a0170026d5139c1" + `); + await queryRunner.query(` + ALTER TABLE "member_roles" DROP CONSTRAINT "FK_5d7ddc8a5f9c167f548625e772e" + `); + await queryRunner.query(` + ALTER TABLE "notes" DROP CONSTRAINT "FK_23e08e5b4481711d573e1abecdc" + `); + await queryRunner.query(` + ALTER TABLE "notes" DROP CONSTRAINT "FK_f9e103f8ae67cb1787063597925" + `); + await queryRunner.query(` + ALTER TABLE "sticker_packs" DROP CONSTRAINT "FK_448fafba4355ee1c837bbc865f1" + `); + await queryRunner.query(` + ALTER TABLE "sessions" DROP CONSTRAINT "FK_085d540d9f418cfbdc7bd55bb19" + `); + await queryRunner.query(` + ALTER TABLE "audit_logs" DROP CONSTRAINT "FK_bd2726fd31b35443f2245b93ba0" + `); + await queryRunner.query(` + ALTER TABLE "audit_logs" DROP CONSTRAINT "FK_3cd01cd3ae7aab010310d96ac8e" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP CONSTRAINT "FK_e5bf78cdbbe9ba91062d74c5aba" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" + `); + await queryRunner.query(` + ALTER TABLE "teams" DROP CONSTRAINT "FK_13f00abf7cb6096c43ecaf8c108" + `); + await queryRunner.query(` + ALTER TABLE "team_members" DROP CONSTRAINT "FK_c2bf4967c8c2a6b845dadfbf3d4" + `); + await queryRunner.query(` + ALTER TABLE "team_members" DROP CONSTRAINT "FK_fdad7d5768277e60c40e01cdcea" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_9d1d665379eefde7876a17afa99" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_95828668aa333460582e0ca6396" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" + `); + await queryRunner.query(` + ALTER TABLE "guilds" DROP CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" + `); + await queryRunner.query(` + ALTER TABLE "templates" DROP CONSTRAINT "FK_445d00eaaea0e60a017a5ed0c11" + `); + await queryRunner.query(` + ALTER TABLE "templates" DROP CONSTRAINT "FK_d7374b7f8f5fbfdececa4fb62e1" + `); + await queryRunner.query(` + ALTER TABLE "emojis" DROP CONSTRAINT "FK_fa7ddd5f9a214e28ce596548421" + `); + await queryRunner.query(` + ALTER TABLE "emojis" DROP CONSTRAINT "FK_4b988e0db89d94cebcf07f598cc" + `); + await queryRunner.query(` + ALTER TABLE "channels" DROP CONSTRAINT "FK_3873ed438575cce703ecff4fc7b" + `); + await queryRunner.query(` + ALTER TABLE "channels" DROP CONSTRAINT "FK_3274522d14af40540b1a883fc80" + `); + await queryRunner.query(` + ALTER TABLE "channels" DROP CONSTRAINT "FK_c253dafe5f3a03ec00cd8fb4581" + `); + await queryRunner.query(` + ALTER TABLE "voice_states" DROP CONSTRAINT "FK_5fe1d5f931a67e85039c640001b" + `); + await queryRunner.query(` + ALTER TABLE "voice_states" DROP CONSTRAINT "FK_9f8d389866b40b6657edd026dd4" + `); + await queryRunner.query(` + ALTER TABLE "voice_states" DROP CONSTRAINT "FK_03779ef216d4b0358470d9cb748" + `); + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" + `); + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" + `); + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" + `); + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" + `); + await queryRunner.query(` + ALTER TABLE "read_states" DROP CONSTRAINT "FK_195f92e4dd1254a4e348c043763" + `); + await queryRunner.query(` + ALTER TABLE "read_states" DROP CONSTRAINT "FK_40da2fca4e0eaf7a23b5bfc5d34" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_61a92bb65b302a76d9c1fcd3174" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_5d3ec1cb962de6488637fd779d6" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_f83c04bcf1df4e5c0e7a52ed348" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_b0525304f2262b7014245351c76" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_05535bc695e9f7ee104616459d3" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_b193588441b085352a4c0109423" + `); + await queryRunner.query(` + ALTER TABLE "messages" DROP CONSTRAINT "FK_86b9109b155eb70c0a2ca3b4b6d" + `); + await queryRunner.query(` + ALTER TABLE "attachments" DROP CONSTRAINT "FK_623e10eec51ada466c5038979e3" + `); + await queryRunner.query(` + ALTER TABLE "stickers" DROP CONSTRAINT "FK_8f4ee73f2bb2325ff980502e158" + `); + await queryRunner.query(` + ALTER TABLE "stickers" DROP CONSTRAINT "FK_193d551d852aca5347ef5c9f205" + `); + await queryRunner.query(` + ALTER TABLE "stickers" DROP CONSTRAINT "FK_e7cfa5cefa6661b3fb8fda8ce69" + `); + await queryRunner.query(` + ALTER TABLE "webhooks" DROP CONSTRAINT "FK_3a285f4f49c40e0706d3018bc9f" + `); + await queryRunner.query(` + ALTER TABLE "webhooks" DROP CONSTRAINT "FK_0d523f6f997c86e052c49b1455f" + `); + await queryRunner.query(` + ALTER TABLE "webhooks" DROP CONSTRAINT "FK_c3e5305461931763b56aa905f1c" + `); + await queryRunner.query(` + ALTER TABLE "webhooks" DROP CONSTRAINT "FK_df528cf77e82f8032230e7e37d8" + `); + await queryRunner.query(` + ALTER TABLE "webhooks" DROP CONSTRAINT "FK_487a7af59d189f744fe394368fc" + `); + await queryRunner.query(` + ALTER TABLE "members" DROP CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" + `); + await queryRunner.query(` + ALTER TABLE "members" DROP CONSTRAINT "FK_28b53062261b996d9c99fa12404" + `); + await queryRunner.query(` + ALTER TABLE "roles" DROP CONSTRAINT "FK_c32c1ab1c4dc7dcb0278c4b1b8b" + `); + await queryRunner.query(` + ALTER TABLE "recipients" DROP CONSTRAINT "FK_6157e8b6ba4e6e3089616481fe2" + `); + await queryRunner.query(` + ALTER TABLE "recipients" DROP CONSTRAINT "FK_2f18ee1ba667f233ae86c0ea60e" + `); + await queryRunner.query(` + ALTER TABLE "bans" DROP CONSTRAINT "FK_07ad88c86d1f290d46748410d58" + `); + await queryRunner.query(` + ALTER TABLE "bans" DROP CONSTRAINT "FK_9d3ab7dd180ebdd245cdb66ecad" + `); + await queryRunner.query(` + ALTER TABLE "bans" DROP CONSTRAINT "FK_5999e8e449f80a236ff72023559" + `); + await queryRunner.query(` + ALTER TABLE "backup_codes" DROP CONSTRAINT "FK_70066ea80d2f4b871beda32633b" + `); + await queryRunner.query(` + ALTER TABLE "connected_accounts" DROP CONSTRAINT "FK_f47244225a6a1eac04a3463dd90" + `); + await queryRunner.query(` + ALTER TABLE "relationships" DROP CONSTRAINT "FK_9c7f6b98a9843b76dce1b0c878b" + `); + await queryRunner.query(` + ALTER TABLE "relationships" DROP CONSTRAINT "FK_9af4194bab1250b1c584ae4f1d7" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_e22a70819d07659c7a71c112a1" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_40bb6f23e7cc133292e92829d2" + `); + await queryRunner.query(` + DROP TABLE "message_stickers" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_bdb8c09e1464cabf62105bf4b9" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_2a27102ecd1d81b4582a436092" + `); + await queryRunner.query(` + DROP TABLE "message_channel_mentions" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_29d63eb1a458200851bc37d074" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_a8242cf535337a490b0feaea0b" + `); + await queryRunner.query(` + DROP TABLE "message_role_mentions" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_b831eb18ceebd28976239b1e2f" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_a343387fc560ef378760681c23" + `); + await queryRunner.query(` + DROP TABLE "message_user_mentions" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_e9080e7a7997a0170026d5139c" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_5d7ddc8a5f9c167f548625e772" + `); + await queryRunner.query(` + DROP TABLE "member_roles" + `); + await queryRunner.query(` + DROP TABLE "notes" + `); + await queryRunner.query(` + DROP TABLE "client_release" + `); + await queryRunner.query(` + DROP TABLE "sticker_packs" + `); + await queryRunner.query(` + DROP TABLE "sessions" + `); + await queryRunner.query(` + DROP TABLE "rate_limits" + `); + await queryRunner.query(` + DROP TABLE "categories" + `); + await queryRunner.query(` + DROP TABLE "audit_logs" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + DROP TABLE "teams" + `); + await queryRunner.query(` + DROP TABLE "team_members" + `); + await queryRunner.query(` + DROP TABLE "guilds" + `); + await queryRunner.query(` + DROP TABLE "templates" + `); + await queryRunner.query(` + DROP TABLE "emojis" + `); + await queryRunner.query(` + DROP TABLE "channels" + `); + await queryRunner.query(` + DROP TABLE "voice_states" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_0abf8b443321bd3cf7f81ee17a" + `); + await queryRunner.query(` + DROP TABLE "read_states" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_3ed7a60fb7dbe04e1ba9332a8b" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_05535bc695e9f7ee104616459d" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_86b9109b155eb70c0a2ca3b4b6" + `); + await queryRunner.query(` + DROP TABLE "messages" + `); + await queryRunner.query(` + DROP TABLE "attachments" + `); + await queryRunner.query(` + DROP TABLE "stickers" + `); + await queryRunner.query(` + DROP TABLE "webhooks" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + DROP TABLE "members" + `); + await queryRunner.query(` + DROP TABLE "roles" + `); + await queryRunner.query(` + DROP TABLE "recipients" + `); + await queryRunner.query(` + DROP TABLE "bans" + `); + await queryRunner.query(` + DROP TABLE "backup_codes" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + DROP TABLE "connected_accounts" + `); + await queryRunner.query(` + DROP INDEX "public"."IDX_a0b2ff0a598df0b0d055934a17" + `); + await queryRunner.query(` + DROP TABLE "relationships" + `); + await queryRunner.query(` + DROP TABLE "config" + `); + } + +} diff --git a/util/src/migrations/postgres/1659833042721-test.ts b/util/src/migrations/sqlite/1659899662635-initial.ts similarity index 99% rename from util/src/migrations/postgres/1659833042721-test.ts rename to util/src/migrations/sqlite/1659899662635-initial.ts index 0820cca74..f82e7b0da 100644 --- a/util/src/migrations/postgres/1659833042721-test.ts +++ b/util/src/migrations/sqlite/1659899662635-initial.ts @@ -1,7 +1,7 @@ import { MigrationInterface, QueryRunner } from "typeorm"; -export class test1659833042721 implements MigrationInterface { - name = 'test1659833042721' +export class initial1659899662635 implements MigrationInterface { + name = 'initial1659899662635' public async up(queryRunner: QueryRunner): Promise { await queryRunner.query(` @@ -411,13 +411,6 @@ export class test1659833042721 implements MigrationInterface { "is_primary" boolean ) `); - await queryRunner.query(` - CREATE TABLE "migrations" ( - "id" integer PRIMARY KEY AUTOINCREMENT NOT NULL, - "timestamp" bigint NOT NULL, - "name" varchar NOT NULL - ) - `); await queryRunner.query(` CREATE TABLE "rate_limits" ( "id" varchar PRIMARY KEY NOT NULL, @@ -3438,9 +3431,6 @@ export class test1659833042721 implements MigrationInterface { await queryRunner.query(` DROP TABLE "rate_limits" `); - await queryRunner.query(` - DROP TABLE "migrations" - `); await queryRunner.query(` DROP TABLE "categories" `); diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index c358444f2..97a73858a 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -19,10 +19,10 @@ export const Config = { config = (config || {}).merge(DefaultConfigOptions); // try { - // const overrideConfig = JSON.parse(fs.readFileSync(overridePath, { encoding: "utf8" })); - // config = overrideConfig.merge(config); + // const overrideConfig = JSON.parse(fs.readFileSync(overridePath, { encoding: "utf8" })); + // config = overrideConfig.merge(config); // } catch (error) { - // fs.writeFileSync(overridePath, JSON.stringify(config, null, 4)); + // fs.writeFileSync(overridePath, JSON.stringify(config, null, 4)); // } return this.set(config); diff --git a/util/src/util/Database.ts b/util/src/util/Database.ts index c46931084..26ac794ee 100644 --- a/util/src/util/Database.ts +++ b/util/src/util/Database.ts @@ -7,6 +7,7 @@ import { yellow, green, red } from "picocolors"; import fs from "fs"; import { exit } from "process"; import { BaseClass, BaseClassWithoutId } from "../entities"; +import { config } from "dotenv"; // UUID extension option is only supported with postgres // We want to generate all id's with Snowflakes that's why we have our own BaseEntity class @@ -14,28 +15,29 @@ import { BaseClass, BaseClassWithoutId } from "../entities"; let promise: Promise; let dataSource: DataSource; - - export async function initDatabase(): Promise { - if (dataSource) return dataSource; // prevent initalizing multiple times - - let dso = getDataSourceOptions(); - console.log(`[Database] ${yellow(`Connecting to ${dso.type} database...`)}`); - - //promise = dataSource.initialize(); - //await promise; + //if (dataSource) return dataSource; // prevent initalizing multiple times + if(dataSource.isInitialized) return dataSource; + + await dataSource.initialize(); console.log(`[Database] ${green("Connected!")}`); + await dataSource.runMigrations(); + console.log(`[Database] ${green("Up to date!")}`); - return promise; + if("DB_MIGRATE" in process.env) { + console.log("DB_MIGRATE specified, exiting!") + exit(0); + } + return dataSource; } - export function closeDatabase() { dataSource?.destroy(); } function getDataSourceOptions(): DataSourceOptions { + config(); //get connection string and check for migrations const dbConnectionString = process.env.DATABASE || path.join(process.cwd(), "database.db"); const type = dbConnectionString.includes("://") ? dbConnectionString.split(":")[0]?.replace("+srv", "") : "sqlite" as any; @@ -61,9 +63,9 @@ function getDataSourceOptions(): DataSourceOptions { migrations_exist: migrationsExist }, null, 4))}`); - //exit(1); + if(!("DB_MIGRATE" in process.env)) exit(1); } - + console.log(`[Database] ${yellow(`Configuring data source to use ${type} database...`)}`); return { type, charset: 'utf8mb4', @@ -82,9 +84,10 @@ function getDataSourceOptions(): DataSourceOptions { name: "default", migrations: synchronizeInsteadOfMigrations ? [] : [path.join(__dirname, "..", "migrations", type, "*.js")], migrationsRun: !synchronizeInsteadOfMigrations, + //migrationsRun: false, cli: { migrationsDir: `src/migrations/${type}` - } + }, } as DataSourceOptions; } @@ -97,4 +100,4 @@ function shouldIncludeEntity(name: string): boolean { ].map(x=>x.name).includes(name); } -export default dataSource = new DataSource(getDataSourceOptions()); \ No newline at end of file +export default dataSource = new DataSource(getDataSourceOptions()); From d334340fac32577075d79c000ad55c9f19b8bfcb Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 7 Aug 2022 22:04:24 +0200 Subject: [PATCH 169/238] Add basic env var documentation --- env-vars.md | 17 +++++++++++++++++ util/src/util/Database.ts | 2 +- 2 files changed, 18 insertions(+), 1 deletion(-) create mode 100644 env-vars.md diff --git a/env-vars.md b/env-vars.md new file mode 100644 index 000000000..c24ea1a21 --- /dev/null +++ b/env-vars.md @@ -0,0 +1,17 @@ +#Fosscord Environment Variables: + +|NAME|VALUE|DESCRIPTION| +|----|-----|-----------| +|LOG\_REQUESTS | ports to include, or exclude (-) | logs requests | +|PORT|number|sets port number to listen on| +|CDN|string|CDN address| +|GATEWAY|string|Gateway address| +|NODE\_ENV|production/development|sets node environment| +|DATABASE|database url|points to what database to use| +|EVENT\_TRANSMISSION|string|event transmission type| +|STORAGE\_PROVIDER|s3/file|How to store files for CDN| +|STORAGE\_LOCATION|path|Directory to store files in| +|STORAGE\_BUCKET|s3 bucket name|S3 bucket name| +|DB\_UNSAFE|any|Ignores migrations for database, enabled if defined| +|DB\_VERBOSE|any|Log database queries, enabled if defined| +|DB\_MIGRATE|any|Exit fosscord after connecting to and migrating database, used internally| \ No newline at end of file diff --git a/util/src/util/Database.ts b/util/src/util/Database.ts index 26ac794ee..d0d39f4c1 100644 --- a/util/src/util/Database.ts +++ b/util/src/util/Database.ts @@ -92,7 +92,7 @@ function getDataSourceOptions(): DataSourceOptions { } function shouldIncludeEntity(name: string): boolean { - return ![ + return ![ BaseClassWithoutId, PrimaryColumn, BaseClass, From c70d15b56406b0e09aaba78bc9511a44cb7de68b Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 7 Aug 2022 22:32:04 +0200 Subject: [PATCH 170/238] Clean dependencies --- bundle/package-lock.json | Bin 670502 -> 103377 bytes bundle/package.json | 45 +------------------------------------ bundle/scripts/depclean.js | 4 +++- cdn/package.json | 1 - package-lock.json | Bin 793798 -> 794026 bytes 5 files changed, 4 insertions(+), 46 deletions(-) diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 0ab7c5da148f06e7b7f0690296ef992c82e1d5d1..5c7aa2ba754b2a83f4b2d30f35889132f4f2eee2 100644 GIT binary patch delta 2133 zcmZ9MdvwiL7RT3l-Sa#5Cb^e*+{pVek~XDkDl>|%M71fa*ji^VWmDKw&6Uyis zlSb$dUm_)Fgw~R%#a>fN(N1+t6tm(v!j!g>XsDEFqL|-JX4S0u?{|KCoxS(j-|zlx zyPI^X!nN`nJB58?f9wsnH@W@xc{$dO2nt8L3>9zJ`8wJ+RBz;`aF_i;yEOZx?uX_{ zDjZ+N>PUN2Xs10tStDF~7I-&E3O~i7nH|y;y!Ms|r`*%b&uB_8-_s6Ni97`3b2LzJ zm`9>Ak$VxIt6|sHLjU^DOs;VG+9EfG z@OVbg59h_4x{v0)IE{RT59jvSW*@4mWiag=#|N>%v9+JzOg>Uz@>E`mi+L&;>De+8 zMRR2|s*W>>%yPXDeano`&Og}+jX8W5nr88Jc4l*HBb`t?htI&!V*U|{5^i%U*vP${ zzTe3!Id*xOA626*iQsE`p;NLes(j3c53cEC6z${h;L2BgvmIHN5XkI8*+OYyev1x5 zoMyoJH5t@ zH&Wy(8q-%MF_b+kE9tXTDHzS`FB@6KjDeD&V5D?WOS&A!aPVmvgTmhC1nzw;JEL@z zd>IjAYD%{nCqGVH(L41d%)d6QwoMfs36*UAV*hptJ@sG&~I6m(Xoc!p_i)nJcr zP6&8JAkcgXC@67c*T z6HPap%wUGf3>8vQ_l)8c`3nSM(ovXuDY_D zdoX>yioopNsv|ko+|IZUJH{>Z>pv(AoToe5RorV2Za0@2qVy0!p(FKvFOKKxM?CN$ zC|7TDq;CE2BK=1raVb~Zt*HV*FCIZ*A1J3qcJ0 zyY(bkf7Ru*>V*C^r*}{5&l%0Wq+>XKxaz<$ywVj1&s1DhKUobY}}vd6#D#z^wOtOt#n3z&$HGrdUr;kC}vp>lwzg` z7d}jLe`BhR2^UO{nQ*9?-PjCXV6veas)JYd>?2p(52xkP~LioP-~e+?~;5o0jzQizdd4 z1=(gQU7TpR1GIIr5f7)EGMrp!>hR_u;m6S><_;ZQX2x>5Uu+y2yt>geqI|2li~Z&1 zHsx+NTD8yhs4f8k45F?WgP(oO!p-eMA?va! z44@$n_b;1RKI;u^P8A*T@Rm_%>8=(cyiT=8;gc#1-rd^Jh3}2S(d)O&r8Z(5+~|s- zlTBu`1G0Zw@hH7(22sX6bA*Zc`I8X)C*wz1y803y?r`!nDfa-}3voA)yNmlg!`2vg kb^r(?=|ZC0FObvSor&Zg?mEou?QZ2ktBWLJ`nX;H0d^xPZ~y=R literal 670502 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

WMn|sXJy9DLq6^}Y=txyO`)~Zum!2i zQ(=iyT)HyGwegJUO2-kN$EDUD)jHn!>L(xl7jBh+4Ja1z zgF_%**Eqww3_8(6OgX(osbrw@f)6qyL4%Vwmc0O`%da*pJykfB0B4%x}0+Dik`KH zFiv@L2-f{HGl|^EtJ6Up^tvA&iAH15_3;^RdQlZ04EC6<)@@cg3M8G>C2dk|h){&R znC}KOfu!;mDfCpx$CcG~Kg19P2+z^3cct)54?X(%b)ni{iJ`=^tB_>FzPwoPYTf0I zPd&cI6=Zq4R{orXtJ&%mN&4=v+%&lYHXAx+Kpj-|CW zcc@&&@QIOe!L9gTzwzi2Z1}+<1VQnkfpK=<3l5c(!I6BO?g*%wZ8WDxqDnE943oEP zG~Ns=lU0RRn!Qz>T5*{m?N_2E2%NkgR_bCkVT7Quv$)N^4ed=~V_|bJGzuz?I)06) zlRkCTS08M*zu}(iQ3OawzfJVGB#7VMV<&Qmho_eyWI*P{?rLfM;dB@3eUaYRHl4T& zBQv6r=hZj0z`+cS+U^)a@Ru-17w?T>OVJ%et;|~?+qGewnG}yCCuv7 z9(gw$;9l1~Hp~D?y}%c-;{s;=pGZYNHz%&(kv{|wMSwmv$xh@D^G+{|jK?c;Vq4Lp znmON&4U(%IN37kpc3a6~T`6UzgS3^Ky(zEgOuWJ+))}yyVPa98+WerzGQHioG?d#I zRwN#G7UNnom#Ga_-dj8LX%{1UhCnaiSs$IHeANq)>2D6X4~ zt-WwA_IRQ}0nzImf&E2=#^{(S%RV0bvMNL}Kg$@y5|sqY1u9>|@*qktbU@fwSCtjJ z)l7`<)DO;PGr+Tvm`GLL6PAZ&3zHV2!%TL}SgYk-oap3h+T}CWi(P1WSSDgSXtXnS zknH5B4M&Y?HAh!5e!S6zt7uBl>L;P}{p!d!(n=)c?34fo)AOILF ztn?pHAgGK6IRCI!<-#iTS=6a=xq#a8PB9QYJ{1-f%`fGr&Q~tod!=3WL=G+`B;_Zc zPiwe?2Ke*8q0RXG5WmULxjyKJ1R)3aVLDKJMtvSrG$IM26 z3B%M|R%W@h!o`Koc6u-|yt|*YXIw=cCsJ*w(j!meQ_EQp@<0!xZU>K*sUK8E@o`si zVtF}lT+d+O`+4i4)h`fjud7!4dADXM3^GDh3qQUkE1JBaW6Q3 zmi;1?@hXyDr#x?D7|SDhm{vP;yr#A&4^U;PVejZyJbOJ455yr4=U(o&Jt5DR0Vio2 zTDQBZMRqz#v)bG@vVhv`%!RSAJV?P8$ky-6^>31S-lsoUgv`2+Ra-%=;7{?YNa4NG zYTHGuhO2FZ>jnfVZYmn2M@I{rz)9PIiI3pBNo-iJ@sJGCmy!shwX4fqI>_#{s?T=q z=7yTj@$ri4wfakOx1hu}4F7vK&+{Vhsqf{7Jq$PHe{UOpKnigN{sCr9 zAU}6QSw=Xsfwi`;If|PdqXoPI?o0KBQ}GXoQt!56=>qTG(I* z^I5*yS5pnH%>u)U02dv!Pl+O00{EXCt-tug2h*qc$W!C#Ym6KQ4K(wd%MKNg%IEc;S8V& ziXQ^rja|;1LjmH`riV8R$ZDw0mR$gNJ6AECQxG?Y_LFnhzK^x(yh9j&b$9wOMfu+ErMVOPzghI&1V7{$w#7nVaQoWDC<*siS`@ z>X;GS8pz?Pi?A$fF4y>G`R>o|n}1a_qDo!vuMzMf-)d3Os3x$q^16vt)ICce&NfnYk6_RTUI5# zI%##ZF2u_5GjPTV?+R^)b;uCs49{N=FTGTp@>=QiRd zrK6sN=bb#;X#61St`aE~2W0b8)%kA@SW=+xi=TbAK0v9U6Y-*Y&}Yy{+@c!4(6I3S zC8YP)pW^*uh8zr^cuHgkZFT_jUVP|G==+Tjf!p_P_QtPE{-0G@1&n|I<-_bYlxtm@ z4BoafN^+%OAi`juA}TM8jpL@Haw|$QbZaPB`y>dPEv`?x{Y`zou`A@7YH3-&yX}zy zrQup_U7uk2cBE$Vq(_f27#%zJU9;0$5pBf{W_8FpRBN{z=}~e@R#iRN7fJ~rJ?m#| z?Z5sMF{UrWMd`ev-2x?yE{B=oYiQCR8kvC>4Yb6~DT&Y*Ax!yo0|baZbOR~)*Prue z&Rwttp6IEQ3B8L@na*Fj9KYq|^5i}tPQk4&2vd-2KlQu*x#@33SBnySxOnp;FX3f$ zm*Vah|M(_=b9wW!D^AuZ`pQKx{`ylK(ASC<#E`4iV1Nu1u{y+o%U!JfKKLraj|KPd zeq3p1eCuXHPkLE^oxZmKJn8iNE=vBdKfVXaLl1(3dXc?FBf>6UDi-Y28(*yU<*5pc z5$JR;<|Y@j7Ln>df%5+K2b$0hISiN8iq$TFWiRiA#g8aT8874_KqZ0JwTpbf%}|iC zFhIbjkq!OYQ~#$#SvfN@2+54cp(*Q{`NYS8h(J zHNNCH_tdLk{5YxpPRRBF=^O2Id&jpzxfUUhs+!!`2jNmw@~&L(A3FGgpe?OI)17Mb zma8ZX=>(N6fD2DY$*>W%*O-Wd>&?`OR2#SFebEtEOzQ8ro_9UN0+0#W zIkmRc(eWX*=u*{eyc>18-8pXdI1i?dtOrdi&bU@*JaQ^9%d9zEPmh#3U@+|92E8t0 z_GEj%h%5EBG$R{G**{^06N7Sq-Jk$MF7hip(>5L^kZ;_fkGS&i24@C6d=r8bNUc3D zL~tz)&-&PSOOeBkFLn3sB9e!D!)mV9w!=8GyHdBUSf1|_*%N#DcyjQDmbjvOY&bmh zTDy2g_9{tt7rNWb=`P3vAk5r`T+bHf6W+OKHf(I|^=pjn7MTj^l@Ci23aPmvd*;*4 zr6P1gyx>j`tU!V>tWe#?Eon1a*N2Coo)ckUt(zjd*+t7qFB+-zOypKeL7P}}DB!^P zb#%-#JaH+9V{)qk(=94{rQ3v4#Uu;#y(io#H26yqIw{(ZMChLKnJ4#G3!!;sO)aqz ztJX9K!@GRo_V8h2M7h*hg|>f#2OqGrCL76Oyb=gHRgdt7S+B2a$11Z>T!}bn>t=&r ztrtT&#VX4nBpIJLZhy~&7pr;Lxz|JQk>aM#ht@|txspBe<9Y=t8=(3^MjF8?+jRmr z?(!+w=hoHbOy2gXRz-5A18?9N0BSZ49e15Vzk5}j)pKr`AE0S>-CYH|#6eYFziDQP z7H;^tWbep{^^6Lssh{t|mQn}30v2bW3Lf4;%@lyClHr{e|CC`7Hn zzI0)HEb2LVdH^V2nY>pm2=_cv{x`2L@Z7564Ce|=ESQd| zbmlCs%kW-dpK`L-7xH%9XW&%WOeVTQ`jj{(9j1QF}b#8C|?PQ!-55hNRJJ@UldZ;zL(T8Hc4J`*W8HGt zeI|6ga2JE)bQ5rVENBl#AZan1oB?zM6Cnvj*p6j0w z14bhG+>UG}D|Nmw_O3ALd&@2rCU~4~muY<(g@=3M#*nhjk=K`<-;=2g{DAl`D>3p>W#E#pVMpYik0&c2`0zbx65x zk&GSmlJ(54XR5vsgu!}wm@-pU4I7oVm$f=>Os~2VWnbOwF>c%@`XLo3Ou#IA(0=7H zqI-K{oSlYpn>=28*H;lR?@5c6yX$gd6fqab`ov}Ut;iPL>H8-u@S6QF#@74F{Adex z05C!!^8H_@NS@c@kzT4Y6HjsWjnOd{4A1h8Q;p2#w7J?e8q9GcZ+6~zeQ5QX{f!Gg zSulzPH5UJ`N)Um)f zQ!O#YAZh0|Aua}XO?7!VxDF<5B@=nr#f}5ht5-)_4UVjO(`XIz?N-iirS6fPQp9hz zr|e;g#8L<)ilg2QIxM(}w$3HcwS$c0jcrocgm-P1Ph{}LaR_{a>Jo@GJX(~$V|rf* zo>rx#{+8h#InrdR1hr0J2%=^6m05k3Z0q5+1_78+kWQ8@(qqj7DU9|9r?-eQWi!CC zw8!lhifs&YZq5np>JZZT|I6N+HLI#-3!=~YFEVz$l`*%V*l?pV??G&^L8MX9ikm0s zL0Y9#9_qK>0d_d2?aFoXoQkT56>HiKWPGD$38xZNy!ImqZV?I1^bj`K@!)YSIA zRRm}AmoMS~)@2nD@4Wrs^5QwTio@4SviVgG*Y+U@{3o1#HHtk?v3=6tX|Scpb*(Uj zjX&X2>3v0XZt?!R>#MP&h1KG>{Lth17|0JJXxn^_=Qe~9v+&gyI=d&YS5s-{Hqm-} zJ|1r|m_W6MT!>%Y;%l?-6CyE0T@7rw+8~m-t_h#7EmBOG`qD%JL<)9-{&SWww@Br>7HIt)3jzVN=o^7dH|lx=!_v68NP=h|LAzS zv8&UlNyDo0RZ%MX((-#%opR22{GgUn2IOt^pJz{Ume2n}MmkRyJh$_*QO#vnG}_+v z`b?~93v9rf!eGd@I5{I)ekMZ%tSWW_w`Fe)`j8s#!J$);+OJ2hz3^AIC*f)>ScnU8 zrmln;u5H>^o%MufUg9N$G7qR)yLZ}og7AFW@9L=&xEwpDhtMUGOO@vcI+zY?5KY%( zM)NTfa`S#@j8v9P?6Ik2?Z{aV8dQhXIc>E*U`-~SD67iak`OmisSrGsL)DyB$UQwp z1nBzT`%E;rsbjyVrHmceA$sh5=|#fmwpKL{4(EPnE-X)m&`E{Go|V_PLeQs(Rp;fZ zIi5XfYean~8q(_ttnRBaIv6Dx+5tJq|=gYQNU1=G&9C98l^VF zCAre=j<2P@-$Q*c1#{?uo98%uF#r<|@jBnVf^7s%URmX!YCtcg>Y5iS-hu451#Qpx=d@&HP|M<5R1@u~x9}QTWxL)eSI?AN(Xk6H?>xD9IQhH5m*j<30k$+~;xB)|SF|tC=BG;@@9RC&_J+K^T2PS{nW zVR*~>l&wHHT#taL$ks6`i=Mn`W!bhzcNSAKQwFP*w(a{>!C7TZ4F=LE0ZJ($xn?Tf zz~I|iS&iR@pdQNXzyB@wv`#kDBjiP23TO|g%apNb3J>~&Zi z(}sQ>BXpQXhU^Bmg(-)jrAI5IY1aBzG(JRI^UwdDb7uSa2Wohr8~(pPbDZQmdo@~i6=&JBYm@4FKy6A}Uhj*z?^@`O zf8;;)Qh5b(sgMkX_&aOFTv&w%SN5Iqns8EL>uo-$*yhWkVqxZh~$JT2MrJGbNats?fKENM8K=QixovogX+XX@O6O z{|NAez2g%I9OVb{ob02pxwI;^O?|^|wpI&C8-z1$cl(~rr(}iRy8B+H_J|3rO%>Ox zMP01QC@JX1Y%&;4X^mL!^9{aGEP=YvA28P;JUd%mrN(yy{Gk;2XOg)2T9Q1DRL6#ER)n+&iU24PefT=m@SckIEp8o(JTtlUJXMn3N$3An`OM;i!JUr-;S zRWE_mvtY?H1Lw^1WtGz(7i;B`p}VB)?_|LLxENpONJ}BWNqhJd#%xSi zt&w7D5xPO51`{)3Kby_6P_w&@+S+Mv=dfXF*0Vy`!Z%E)*2$hY%y^GhG+8a^2I zareB6AOGX9@~F~>{*9Xl&fTzxA-z)j;lQ5lD~k;sxkQr|Yb~F^`kj6c!bRG3rtS8z*Q_+ybO;1)B z1+Vfu`an0h8N0Iw87A@gx|AyUZVlWwis8ggY;ufo-wa*&brk`80?nb&!K7RJd&thU z_Bp`zJ;a)q9!V+bdn0~9Qj5W~+uYY9mzKr~o225z+^DweyNBAcGVrC?YOiL-$`D6u zEj5k0z9cJMN8fJQcxkkWbh{Y{-I@p6+LmRFeQRMpz>Rl|736e&@-qMOhn?4v96LJx zk=uM1j=8K(E%@SHJU*QRlb_779r%Z&hS(;I@IIsPUHktC??kHr`RfGcg*00-ouJz5 z4d&J`9PvRbRg&tVNi!8^fzLr4EVui(ue)unlV;1QanL(zbC6Yr+L*=47x=RqdeqZ;410!q@8fm1x zS~QwjA%R(f=ZQ{j<J|T%>~&K-Bo9pdq*-b=^g@T4l@LQ10;1M_W4H zd*<;YZ~Pr)QS>h56$!XHFu5%Gqu+9%on?TfuMvgiA@=QP+jlm^uSzyskwdg~Z@e8B|GT6Zy74}1&OgHY^YJHS$WPsZz( zHtMBQcf>8z+5$Qs7)_O1%f3R?TDsL+Xl;Ma?s1ctk1)-SciT8tgh3h}7*rgnS8Tqg z=f20m&cUA&x&4aO@w%EKN8L4oboZP-ELAB%JRQvmesLPFEK{dGA>)3NhRJ5B&>h?A zYS6RH)h22L+)VBnSaTOSuE)=uxoo(d_JkSk#v^&P>UVhAn@J;WPmd!D*3O%*#%;K) zCa9IGEPq1VP>ArW1HwP3Udgd@O)vbwcPZQOu9a7Uc*6Gyei12t74vCxI=*VxryWkC zy**;|Gon2jx-3D45xH8<14j$G5)R#vX&SjkZ$0lLX4Pu!d7@csWS#1;-s(lWFy(on z$%y+@l7^$4`X7ir&4D)DdnOl_Cq|Ff`rCJ20LyQ>cmO&tw|Jg=KGb4MOvY=6!y6o9 z?>sG3O<7)#`c`!}T=4#M+tlkDqKd~&dMFFw%&hO%sby}oVWZMzsl<_hHG58e`mY=5#qB5BFO_{wC+4GFbF znp)`k#(EdUVzO9Dj@m0;#bDn0#zlLB}z2r0^xc^}OCa5I?R3Xp{7Xot99qc5%ZCA!GRPcJr7IKy=9L>s)hs$vks(G$4Q*vf z0jCbT8)!YrG$=DiqJ9q>@vT)q?Q4lB(k>I=?qRxvV1$8mn`zj#wl+8G=wr%|Q_Dbk z*O};7hP$fQ2LcCv@3E=Ac8_%O0R1_$|E8CcW8ehwgpbp+V%qR4d5bv<*;P>0T9d88 ze8ff^+c1-I85dJ^aYAMlE43jP0MXAN<7;-7Z4}ACBX?XnZDU$MR z*}_E+=9eg}-_u5uW8CDv8~Y2(ATCZVeD^vapMx0 zA40iU2K1T6I)ekkIX^4{$gim8|CF6Vw*x+YU_2LJpV|o5ks$@QUIvI1!t0f_(2vsH zpsK~4OzLe`8nR3Ptyo_hQM$w1vp*6lJ=YW1|BXZFf%bd>RYV5#vwUgzUX83;a4pm1x;4BlwC2;4 zFmToC1QTvgA}*t469?-c`$daJ6q0Gqsth8UuY#}tyQHpv5alh>U-RWXjQ@+X(BCJ! z-Z8o$`tX^Vdjm7q(&g!~MJoQ4;nl(V{dIF&6>1yPv_r#|d&@f2NnqA!ciC=)o(-$R z(+FwttxWdT+Mra8)$n(K_E>wRRnL z65_pvi$*->Efsvetm_qi9cBhqna)ss%@JsYsgUZRrcDL|H=fg@Wuw+hv#YiG-M9Si zCPL=XNW|+XN zvh9C6A4Fb3kiy<0SNroTe_Mg6$kw^){3|k{aee3KHR7kAlH1d#{*e3H;ooFQ)|@KL zK)y^mZsi2`w0ZmdYYMXfT833egOp6CY;waLo-DZ@u~46qm5Qs-+pe;7!GY)a4>U)|XQ;og-4CE|`ZHN(d@;B@*NM znx2liOrONQ=X(^eCm`5EQr(Eu|z=7^U^{?{bujkt-;pth#W)prLB;Yn^JcP;{ z_;(5o{gJmMHu9H`j{1{;%lV4m&~&Rm&*1Ky*wxN^Giq1Bg7Yce07N09J& zEtFN|ur<4hh>}>-5!cFMO9tagKcYEyp$_S3v)a`go3NJo@jToPTEk}8hgs)CveFu_ z#x;Dbip+#kV?3K+Vc+u?thbe}*nMR&{6b(^+xgIOoTK&RtpC`*4V8X7&G#OKt8*oP z`beSV;iO+d%zMXTCxYRhkANP5{ORwE>bV2$_!IO0|3CQePWdO)FGBl72nNx868Jb% za|M`F!3BDe`FoY6+3SqI+$b95MVwsU_Q{>uSoaxjMYTmzT?GX1M6|iCvdDOCG3iF_ z!IYpHOIk}c?N*$Fv1rINnMiSF#Esd$BUV@1uAHU07wFu^T3j^Q9ShZRToriwOTIMe zj1&lcUTy_mEA}Z}U%AZqe;KocJyow5(#=~3zw!Y@4+r0V=m=RQkj0@~uaHlngkSXB zXd?Iy(uyaM*9}p>*`uJTTdZT9@v6&jy}q{71!gpoqz?X*W2<_mZb zV+1|3*;H?DoF<{IH}$*B`xCBr{R8&kFj*~ zPE%xB(l z31UGL7x+bU(<_BIaz%RGOyi{MPAsbDI{3lPwoKDW`?9Yig8??Qm4VcoswCI#y7a>H z4y~|3g+qfPWoe6~HTp0!yIb27<_2Gz%xg31DzdNn)R!EU_f@0#Qx$hD>i&VaocPav z@%JzY`o+uWhE{cU!lt8S)EoDxWfO)opt5eCx8vO>*8A1p=}roQVg&iq@tvh4%a7li zo3x)E^eJbPpYrKpVR^nfV!N6QBoPA%E7h0T0puz)af&N#NF`fl9C_Q08fOA*stwq6 zMuhelBy(+C>3JQCr}1pS`@_CQ2jX}yVX%B^J!H39`nVh5osj2_17o!Z0>@OVgitq!sE zLnX!d^$fR#Ud`NF{b7C6nYrRfSGSgA3i3Q24?^0X!qlYg1Sj_9%JKo8PwYgfI(y!uZQUIKk++7P59dt}$jS#mK#zIx)faka7WekE)!d4kTe`!_n1eJm z#cc}Bc$1l~S)sL&vcyxVjn8}{YXpgkWiw;iSdJDbg1K^&uL&rTPKSilX(6NOZo)2$ zj-rw_rPqhY{DcaY0dE(EJiW~`+vI$v! z$vS4$Tp#RddmOm5-io28VOi&3sV|UVHAUNNN93WeL4>7tGp2skk^j`$-RzzHAyV>L z3+Fp~_YkiT^V7UO1Ksi3+|M$k$+siK&-|`P4=S;&)tZ?`3R6)T4`-wG$ZDINT_3Yl za^i*5 z07{XRmkRl5P9A7Qfr)ls$I*261b)5%=8XJ%jF$4|pq+$GWHZ)h%b;HyuQ`c`lBh1# z5QgwtmEovqPG&ta;EB#e8AtuGAPli}L^W8Yvx_^Fv#l&cm0BJ$q(iQktuVQUm+xZ* z?5^DEFIu&3eD7be`CgYp1C~@DB83mC=dS#E4?+EkRqKqy{*G!kEot6Ykks$C!^xoy z<=u8Fq!H8EBw?dT?lICBb)o-6+v-_6B~}(Mw?|B{TbdNr2wJU~?5@ZpnaAQ4K|mnq zV*{tC^h0l!oxMvX$Itx=7T>mu5#MGWP zk@~{IHobL%;lQsW+QSY|wJ&FD82sAv4?Qc6!fD+btyGz*H#6NFjGAn(8!+o(-|m9( z)fjPmH*x9^f4iQ|M`rWO$Pl!K#Ew%;iUFpD;V*#?^mab{a-^u-sP?`Jxd;7-(tGa| zJ?yVM)$HK9jY?bz$&gZ11 zND$Mmj90A=O*r9F8)I|LX!aIOk$p=Gzmj^84A*uNY;OM2FZ@$R;jihOGSnmL%CEeo zbrfOP!49+4q&nE8NKfK3g3n-YLFa%QThiB)<+SbFf=R4~`|)T^R$|rR2zMaUh&a(a zt2g4qcHA?l*&wEP4HZLXa#LLPwh{U~Abe@T{K3O{NafSa$r0KKWx&cs#n!9L2t?L- z=|EBS=Gy4B)=MY{Zw1RbW=`d)(`GhFW4v(fQ5Q2iY8SRpwgnvuIaX3Qp)0PqWMJ&6 zZLIaZIpMus%Iz?KcQc0k7FG9E5s2KA#3?jVPB-rs%)Jo}4!^wEmG3K_d=maM&5WU> zrQ1eRYYPX54^-%e(WK*qH+IQUJT&?q4>-xKo6nWNWxffV$Z5Pu0qBKO1EX)P zktI0Iy608wFro&XNK2Re*kdQbK}H*mF=c85>eTT#i5T2l4*dWP>afCPrp(nUG!>$Y z3C&<$iy1Zpn2hQf-K&WDKn48kf>&X&lklGA0E+q?^#!zocaOUc3m`Ah-mUSK`e3qO zQkB@;O?!%OR&~!^X|r~(UCk(`iD7DWqY{Wwiw|OQsE0DLg%MS~il@Pt9z~&SkIk0p zx|f-f-SS5W$vlZ>gs_wO-VNs@@`#DhujVX)qR{<9u3B@=>?&bjiB?%VteC{3UM5J> zNuCVTSs?)jY8pnaLO}oCmGkuY`O0rA={v9s#NTEwS8Xbyssa3*`Tl)wf z*eVrgF*)GTRnx!+iMOw>+0!MY zH|8Mf;zAo$sX_T2?Q|+6$$h*+JwX*oX}sX+-D9W9`F-rVt@7W_#JqvgNs6ht$61RY zBF_Cnxyw;Hni9R|TYWAk0fS*Q7g(XVMzff}0eaz_*ZD0}0hJ5K5syFYkzcZgOE-0d z{GA$(ufAmkr;2J-Vq%=>)y$8eXS7eg zC_WF&{O*$s{dfn9He4yV+t*jr@_(3HDbr{P{P#00z4cbhfL9OOz0_9w!x1^CcV^?x zDhX{vgqdCKHo;|yX23QHyNOKqoSHh(gb^gFMb05GE+*;9-#G}|LTgrUqbxfWeO#q? z%f+V$doIu~7I~hP_jA51o%i*Y3*O8J5x;A`zKBpi!ukJ66S&?H(f_-YHQxyOE7^p% z)mg8ro8Po`{!5JLI!9*D=lIB(If>SzPPi+z^1S|sLtiflKY=YvtJ6zGxxlNjuiiZD z(Gm{pEvi$7+RBOyGc1hl&{jF9n%Q78ap7kb1 z8_~V}-o~@}VdfZV7yVR9l{wuT)J%wJV2%4@l=oaES=a*d^-PZ{yBKDz~8%tI{yHx6-r7^)AC`uHuUry zC+8RI(u>D1AM_XzDP8>gutK~j%ChEf;%4?@1%;N{Uwg8&1fxQgo&#CkY#M|+Q zMd4}*>hWTqPd_~36gKo3np(_}zAID8r}S>OJbICH~DPSAe`6 zS@G<>vr^U-jc;U13#U72R2iDAY4rkx(K@OcD5%$_J3i{soi^)aU&YMY8kG z+fgoj!IFRi%*UU3AkO}+kaLCEl7IKVpUOA?00waE0@|@Cuu%T_>bKKtmpo|Rftz

h@%0Cwe{$6cOL@&rbok1b{7LtYBy^6YazB>+LI+0qW}Y%v6djl?E4{II#97erDEpY?6EvRz6Da69O-YKY_IxFzfmlGP}hA zG;+DYY0qfR*{3|kU;cnKp~lg80y8A85iSAtQ_kryaK?)Xgy7kJ)X1XmNg(m~Ulti%+=murZ%E32BFqD0znu z6Au*@sXp)GV{6CxbQNmm+M=VdGwNdwJ+=m3SQKJ#=(%L}tUL?t7-~>S534YbLDyR< zes1pMmoKtczmN{GEF!pyb09&$Enj6Xeoa0Zmj#5oc)o8x{NW6EHP8xhEx#0AOS2 zUF;X{K2Wg5dr#!gosGVip)W-o|10kREAF|J2?2BXSM_tgfG7tExhyxg*p4zTx2SJK z+;7y=$Dqq&*X@!07D2N7w4dqke=B^rvJCzX@78gc2JNPbj8}_(AYv-jkYE`#;(gdkZXM)}JH#10T4mvGr4Fd$QG!rY`{b84wVup-) za$$!qX?tY+sSmGeQNBUV(^ALsjso@l(BE(M*-yUN{nPn{K;c&o@O(1)t|4y#~Atr#Dps7Z!zkii4x`>NB7P%DT;m^w#=4Nlx7Xhz zmDrdyMaJv}8=_|pR!PthH+UQO!iLg8$IZ36>8xVDj>N8jk!-IgNPFIzDeGzvwflA? zVgq}p(AYLcTEn5!U5Tg>lx8D;FJO8`DkZGlvAT}rq~{6de5%E+B+4(w-*b|?)za6< zO+i!cQLfBS|Zzg+Mi!&zUjurLqY+!OzK=i7PY(wix=;Iqvg-)7M)a_1GGZ`y>ou`L1Yw-56gF7Gycnp9YE}m-ZX0BUt+427F`Xlr zy;2A!!KWhaZH%Tpo*$a`yqhQbv82TBvD>d<=nV9XoAdLWy#V5ippM zRe?f(&zU{ekN+Aw1o|hUqQc@HC6-;qkJ1VksAo)HUU*NE)nQFHyX=aJB6i38(z7Y4 zs?H!-UE8Kan;d0a6HV)VA9^5szdrNYQ8G{tp-cCX&Iaj;u%J63hPB=>Asa2m^&?%4 zo~(L)CdnS9!cG$Cr;mEcB7zV8AigYlhw^fwOOZ6}JCnasDN;;VI(lw5A>*IdDuuxc z5l}2Ze(I@ymwzW8rua5=I2=1$zDv$$u4W3M@{@0y3$B~e)!#_MM_2G1IqGWn<^`M= ziyt)(gx;PGNh)sH(IorpXmehdl-*SSm*VLkvA_-FGaKBz_#P`P`-_q3v7t4Nx;?+) z3~DZoBp3qoOFDEVqg9GJjKVgtT(?FDyB_fkoDL6TZA2~2ptJ5!^%{@C&c#JCI52$y zHIc5feJpkEvqFKZv$Q-b^otCB5>xn>tJm*YlY7eJ!l54>=ndraf!@6M-htYzHfn7t z%^mAPsOw)%Z!d18J&?_dhNL%AO_yCjC8I5@y z+U-FbLt~^Zsb=RlIoQQHp8^rzg~0ztG;o^~`;8<}0(_x>(rfP#z^t!&_)tsbsL^U< zvp9skOW7FoAp4zH;NDa zZ2H{e$gM~FeO&BmFvdyF7&+MXag{SEc7upA&Z_-p^|20lXvh8iZ>QG4qj~l{vVQg{ zE_swomgHt%=J&7N2ILF9b2^C&z+X%v-q^?Y*zjW0d}JD2!Jbd_`by4{uYF4_M25y; zIy@i;yg#le8-KC#_mV5L)|%g<&1}mJ_N`TSXifJrXuO7|uN%;>gyo zc1D5jCBZ(D`a(Z#kX<7U4q$U-?Rgb}Wku9R$1Dlo#&eT2>-cs!SoYC%yzg5bYs98} zZ#BLb*En*+eN*~ZG-AO57Z>_$e_zbl6ML1VNb#AHh&p}bnfLc3)p$L~V(4V4T=(?O zpAdV3o|{wEL(vQJKq3Fj<@o6rf|K{tW&E8Kd2@m9d$hWh5SFR2h?uedbmqsj zOe(ET5<&M=TVsvIY-*<-KJg$>QuEqfY0;fcs&mxv3=)|L4$7^>(Hx0KQmsRiwXQ7a zFm~co9eonLud?6wD#-rz=X}nw-xKQ>R{2b<7a%WZSv-61^aeJaV%;h-=hbG7Sulv- zGd5nWF3^<~9Lc=4j2l^o??bkO();DO%Q!pl0NceqI-DYrH*y?(GP68Nu%#v%BdjUy zJD;B3(Zb4yQ~J)m(uCvt??md~sGen6=8j9)xRellt4e)O7~e#Cu2;LbRt1z(65u9acOliEM$^3?@}ju& znZPdsjgQMx9!3KnR(@VvfzA`p^BYJ0gw^E#36-2z%=}h~kSDB4A|ZeJo=lj|EA2MQ zD;<`dDCme9G_=uR-kMu=dotd+DLI=(t8f%`4z{)5(KW_guued`{pDx_tDeqM_G>_c+PIfLY+d3}z{vIqk!nhK|^)i>5 zuai)Cr-t;GMau&b0wdo}bFRJ|Xc{=y#pTiKYuv(joV*SpX_q_qk7K4TA9~Pl@T-j5Z=`>L~T@yxMlwy1U&^>%^+t91JG1Q)$(9Y9|mA zWl>2@vE_DmTraa{YEa`mS07r-j)AV^xX;_78ux1>MbbyV93Q-n3n&+t9;1hs4u|3d zThRY-s4>m}9k+d(0EJFoO{a8+V?+ejRf`H3$%^7r+|ActW$K}P<7kzq^ zCZ`m5PKQrw3VvCfobq|at^NDIfBUJIakZDcUlFW4t zwB+Qas8H*Av~Ej7U7uv6&VK223Pnyw$8Dsi>Ei!d$#dH^?d)P$8Uwh4GyNfu@;T@y z?enf9bAbo4=<@ih0Q92VVdOW}5rUB}zlk$19r1iUm}^T{tx|}t3yv*{M!L2t+7_LY z?v_nSv!YGH6|*AK6^^4;tuL9FiFSH4%ro2y=0FZVZs|KnjsxA#1%bb>A)o>D>1u_7 zhR;Iz7XO#&BtMX!lS%8dX%k0afcfKtuL8siw6o4ih?V(@(bBN8)Ozuz>-Pqkm0{zi zg0&Xaj#`;)cpfTja4e{F-QiT#Tb?4#El)7@WPOOyx--R@6)JZ3QJX}B6!}#8Unr$O z{E_TR9{o)h%LQXaFYoc$yWPD1#6evtc^|WKJ`?EVX*7N zwlV7_=XTLJV(^ijYv4dB@L_1YBr}NRSf05n&z^IdQjLU7O!DO-zFU=Fv>7Y zWYt+rD*aVYiAp=ZuLXC2`$w&%Cjt2b3BO#slLI^(F8Sm4j22Pd>H(Do3eVYom8>`7 z$*NDo4ReGO4TrE5VgxxN*W82~gxs!a2?R{90xPonGLQ;fiiDQn@9kY#~+n8ups@+h) zm~J;R8M4a!T14z>L6&(0+It}j?kJ}fyZ>my(Oo>f2YzIsN1l|$I9j3|>$r}6=O^3a zVG_F}V*fQZ$oUL!bzm70Kj`N;v+L-honq_7c8_A$B`lH$CleI*?(nAp3s){o0)DQc(BavvIr$n;&;UXbhs=XhPRV zt<7NX;6tUwrs)Q=5~kOH%BUqrYf4w`x6JKe(|=4g50QS=Q^yjKOHo1!4_;D=J7Y6jnTYkHE++ zN7QP_YEf-&NWZ;UCPaje$NQ$H+2~?O(KBt*lLJNPp$kb{9y(K4*y7PuzX>Db-Lw)i zrXSW^r;ep-nHTE=v|jzZ&E-M8Zqc=R8YO%5wXcrY-Enw%%Kv6q%tOiYTNCcb6TKDY zr+s7jbbsf5iECcr`eC=(El@b`+ZVnHkS}CA9n5>v8sn?cJliK@)@jw0dB4T6jh;n? zgM<$k0|b)qN`sS^gGr4XVq~iq%=q?P=nMnLbF#HHjTen(TIt8r{h=NmYM)w+5Xkt_ z9qBk5;8z^XkM%(zOupgk|2=J;`rAngJYd=ow#~wl(mb;DgJplg=Yb&j5nj%(=f`jP zJ)An4>yFZ^EAwn@(OcFC$rx$&XE8okha(1o+C_P0Qd7)sN`Wzg*-DB}MglG?dnQ!e9P?(Go>(cOixH0O2Vj@s~feFxbJ~yW))>gnZ+$ zpYAvRWHEi~xUKc#vOmH(sKCD?)>Vg=j+XZsnx8kHdRFElnNbx8ZLKLF@(|bwe3zaMU(yWgd7wZn2m~a2!YcRf@*{z+EYl z{_qNGvgjx*F#O^keeMH!c4_MIMp(SU$qm z=F`15fGqM%#&dRsS=W<3&F=;jNA0Bq-{Qt}Givn2%p2|pP!5CdS#FmGj>5OMVXYmk z+hN;`gEir9yXkuFF4i?xu5G--j9Dt+?73~#d7E8NJEni{+T)zmbgQVN`GM14(!ED; zC$#2}-_pEpvyXE1ti9Pddd+fKim$O+)(AJ_C7a1{Y{sK%f4u5*>txoe&tgj9>BTzJ z!-)xaw{^9K`0}K|FMAy=ZSbbE1>S@|0md8ZSgRRaV2xT7%xK0g$dCcUJ^t^nc*fw>lW5}uTG6?4KiOcekj|-Ti^LqKf>F_QexNO%fu>?#KKjmVte#Xrd_(ri; ztRSPKHT}?8`upE5HwMwA{8vC=Cf^eNbY(!!x@Q`>^^G2nC_drmU2RbwQT%FGO|$Q0 zu`Ep118BpLs?!BYI9ku#WZQiU|&hf(vvip-T@fQ*`+E&BHUK}>7qBv_tS&PH> z1QSsn&r~BZ>erW?PzcA@Ja~Kem&DBvf!2V$`-gma1O^;=d;oh9@{#b*)kG-8Qdh6e z*6PC8O@!%+;-Wy5P>Zw1iloWbm_<7yHDH}3RddJ$rcbJ3qY-+u{$bo=vj8@)$m9^& zihZ4tLP|YMyMwC-cw@y~Znl)AdMdio+?4)-nVi}_#LOm@azT|!U?;$rU*KeGO~mTn z?DhKNIWcNNp*byUVLinOAv@TOWs6F(K&tYSmAaoso>4KNd?48kTY^lGo1y50qr(nq zRC&~&o9ms@tZNBdR-O0clN{^$LVFk!R;1KntA+&i2zhB+&SSatbYXN&Q9}u~k{hQ1 zk6^T3K6Cj{DCyeQ5orGAKk{*`&t2O>K>omXNnXCoi6CkVY=_0tlUIJligMOur|Hmw z<1D)oKclkhS`;cewx)uDjEknu?~?K*ey_dl^vc z6|dTy5K72RmGwPr11S_(DbW(h!%tCWTb}ym-<=qh=WEXb?A{(iRpHUtso;^Tb@7H! z+1J`t&72r2?)Iiq9pp||h%&dH96CLw#m#~!A-a_a!{FYf`9|n)$}Z?@eTQr>$z43> zutw7?>%gMF=@hDoBq63aZI95rV(DjYLwA!#l98ml%c9Oi(N18CqoCU+rxyop-cKce;TPYnnTI1|i z)%42F%a$s)h7JVgkj9OOsin1PYq#C_#B|+&HEM^{oHRQ-bir-rLqlNqSntLndYc-a z+LDfxZ$FE^LT&e?BM<#B6mbg`@OJw`(ToQZ$DivlVbz4q9^=VE?*y}*gFDJ@+Q7Jx zDs&87Z;!U4nNJxFwc4jAo|mRl%KUVX z%w%89_vAvU+_`)eg-Lg3+p(OoxI}j$NVLyu&W`37=%S03zr6D$<-B$cL*&+C>HDVU zxWz{8+&;W$La^|x5Vn3AUr?51B^pc#gawtJ5?!{`=AB5-dElHXy`uv_|9s{n6tMEM zEFvrU4ZQNsx1lOksP;yX=F+sfZzS2Ww#$@Cn@cf)V5``8)4`g%s96kU?Q2U|^F1Wx@lfiqV$x@+SZg+t`Jf)ijo#dMvl(>PWw;p<=ptmQsyrM9 zWTQT6!+-;v#UN9IK)WJcz1duFkH&#mbKmIeSj_pqfDo_lQ=Y2%f;zckgx(+jE5C=+ zxQ~}w2X?AMg65g^m(QMq-PxdFA!`!5_e1VEQJ?&gcct?WxcL!$zg8i1uovgiIyeVM z3)gIQwy5D7v)6U%bA97C*J8^cx1(L7-8MKCoogWARp}9oE`+JbAb;-f=`PLRe;YMdh&fWO&%l*{WZDaKL@hJL zgJETv#OZV-rgkG+P{F|*ZZo5{ga)F z0oxla2kq7}pvTU1+rEd6BXQktu7Jjv;%67uU2f{Xmje9z-=4a!C*K>EJNY0}@79Ip z-gfF`F8oS_ydFX9pBSBh{{`vuxzp3I?}byq!qwKP3`;03*0R-*c3ZFl>JEho41 zY1HhiD~8`Y^Cb}lSgmI^mol;&43nyhcMQL^#|9=VyNy+d@q@u30_{2Cy6-Jg z3!jch&B!9`=47Ed=9+fV)?#giTXU=!S->=w8II1#s39Y{QSclUrC`wyT>OGLdB*S= zYzZ0Xm)+R+}S%xP6q9*SGMjZ{&#=xKO?jcZ`+2R2G^vQH@kY@J9mv|Sk+r=koYoYHV(}_0Cz)zJqHze(k_B^qg1v{|K#jq4T>Q!>7 z*Tq?7U5RWq)TPO!+Vkd)xLnvnyV0M|6fEq(A_TLyT{F}8z(uuLvo#Y5yD}ABp`$2x zD@*YR?X$Z#*yJ|c`2!z0ah#%`9}`CjbQvk7mkT0kzL2dxFJ{v600USkdq&o$Nv9{x zC>)3;C6yLV~?tq5DkH zL;QkBE+O8#Nck}Mb&(%OsAYVd>Y#E=zY2;W>1eO-DKs^h`d}x=vx+JRu<19bG$$C! zlA=5qPJ3>*;vK4kszz=H+5SL=W(#fLe8n}oUB#DnUMFqNNOZoH-$;xK2A9#+#pp1Rt;HXAope&kODel(wlsnBeohcvCzk8_8RUi^1hxd~Rxk6X{J z>~m!4&En4!wEVV@a0_?iSx^G~iWCDKG&uW!t1OKMjWz2tDYGyKQ{zQOq0q+AdonkFBbC7tc;x94(%t1)_^{~jOa7sw58hB zequ@8WqU%o<3_FPC=|Aw)x4%LY$sDx(!x&P@bOpCfNM9zF~9S4@?mMS>yHyIyyeeK z$ul^>)cGNZ{?|^oQSWQB8Zw!tCNYt#O)_hCRjgn0j7&o|Su2vWUALAJi;9o;wJD`x zyGi8$RUIlas_GW6qoITnT~pjzjf%fW8M>+sULoq52Y?FicZ>8c7W&cp|BtNxEihPA zf!yOiXz;tJrF#L-ust`Osn$wnW8Y;>65aMShxYAVl~?M7F_lBV?zJ#?F(VoiVV&9? zeCmigCe9>xvLE%@CSsVa`i{o2eUfrQja&@9GD;IB$fG(^zHACsZ)^8;Nq!Sg?g0e; zhhe%4z!QxXz>B(zm%+J_yCsvk=|))Hl~gC_X9KLmW`o+g4oi~~wmTiGq_g&z`a&MY z>S*QeLjmbeN3>>jYL$_|I|3{4^1RJLmUiK$BgLJ3>KR6EP^{<5nc~!H_yBVn7~ALp^v{rorNDl!ybJlB94-5P-+x&Ht$hWYo26B8uB751 z=;G24-&PTkNhi~TvFQn;_5qQ6BvrS;ZkKf>Y~}4IO4ia@ZoO+KzS&-&h&?cgjyzSU zh22OgW0{tP#=U5#ypxnu9Z2quU9zda+ENBu>jeuP6TCl&7^-?c4JW(DsVMm$5X-q{ zeQwh3k%iX|Az+urBa~_KEyI%~)@aZ6CN_l<+SZsKPTk&eY|VNYH)aASu{K_1YP&1f zvf?mb!A1XgS)a>7ME$v)D3WhfA*|90-|(La%+7 z?BMQvl`uxW(K%hQEHj>s+T>8~RnVTWa2S6K9o#il7JY^3dYsqAx3Z5O?C*W4w~)b<)nd_nWTwUSwi09<|~ar0YyO*pz+_R z8h)wwAY7z;>38!$IW|7bmBG&}z#WONcvv9y74b1!nXwywkJX5EdnqmtsuSbXXp`Z~ zg$i@`C6^`@(T%tB)kd&Asv3g6Nldn$80omraVQmRl4)nm)?1!DGFI7OJ5a8~cg;V% zNhwg&Fp&{u=FgJLsFP#fKJvF8`qR9R7*jJEwvW3pk_slZNp*No#6=DnHF z{~zkgSROPaJkY?ogLt+L-i#!;XLtq1Pp}J5^HqX=)C!t)le36TicY(|G)0#!tKO<~ z4#OR@WEvvN64|=GV3Y|mn;zse(A`CKiZrr5k)6&LHKa5-!hy`$Gyu!mG2l*;O zISMzPjmc?!HQKH+Sv_>DX*gR_Go7ha=7T{C!^wTv3^X!shz91tlpCqZEcUQqY{v@Q zG(|=(?DXI?y}dJx*tG@NS(Q5nkMBB=it2?QcMV~wPjj*PUFYCVcbz{3VgfKPw8;=( z&g3OU4&wH*(zMaFH3()gGO+z|M}v+>eLRhcerL*~)U-cJY^_}j_sOs!X9_tDmNWPW z!!%g7l0l|COS!$ad96*#@txdw{Vkcr3kLFKiU02UY780W^8k!{#?A4{N6LMZX-_{K zkbHVn#J*o?m;bQA8jmR}gMNW~_nhm8Ul3F|xD#dN4-1{}N=(VbKIGb+g}!Mb-K9wN z>Tw$ zHJ2acSPd1s(~+eR z933e>j$im+xu<;zwm|tyTy%qj6?NS)4{(YhC&gzk0unj|b&zJEsh!^h`FWO}@TRFr z>S?(l)UM^THcKb>#6o{vpLRs?Z9B*9ulaGLc{}HaCt89C$69&@+AP-;&$-32w=lAn zAP#y}tQs>@93;9y9HQdL!{Y)|JSWQv;&ST3l#szHWzr)m1sPMIed8ggSTt#5|u zF2J^ISG2}BK9AB@Mz;prY^>dJU|eo&zc*In?|;itemtEAta3NNS%hallskpJ83G1h zGlviaO=Q*_&PQD#X13MFx((eIb~cJPdb-sa!QQ3AbkiDgLq72Akta0y!w8#^Gj9Of zJ~kw-sxUUPFfUhQJ)s8vx1N~DnNE5RTIxrGE2q&Wpg|0Czx3rEW_lsp~Bj^Dfv6V{;^ zvOFFH0zPM(5o)6^QW>U|H_l!PEHEj0?V#WqnrV(hqKaC8v-~LPTdiZMb{F}&_{0(TYbo3LfW))==5OnafwvDm%MUyQ5{Iw8IOeR44yH`Y^Hy}v+zm{8q8(hn zhgDWPWa%|%g&MBuaYNBr(y2_lBGL}YwJ}%lYLlis3m-1y{=`MsbxI(`xR&Aiw0ScG zlb16st?vt5f{Ea<$K3c(hsoo+Ozb-7ud!pjhs_RA=mGt)w{1@!I=9v$PS+0g z2K@%~T0Q^Gbt;|mO3aw`yx-ETh7iwtZL=wmXkZu(PVkgr2q0p;RkqC&Wm_yZ1AhyZ zRAw8Jfk`pw&F5o1cc>i^F|utEG=`DOO$Sq3(u})4i_Z1^Kd?sM!mu7WevH2ZiOx@p zYW5d`B||Q6z=|zV)t;Zr$bgRmnw>^7#I8YalquQKUL>$BE`~#j8Ht&(?+GmJE}WV} zY%SSQCsC637^S;R$Ue7gdwy19$jDtQV{L0LX1H=yIsV+Pc^a(U>+w#GoX2YD0#*L5 z8ah#{7*x@%&fHf%H~?$+XIh@NN1+ywWCO*SsWI3s+OaZUQhREZNY>Otls*zR8g-?+ zn~hs^cPcvW2=H)ot%0O%WWw(ynO_p@cqTUqI{Nm(pK}Kk`cqY6LBSY6>pfync_N*2 zDvvUn*xtkmP1hB|bLX3;F1G4jhh>@^moEuGlO0>^DqLw4FKn`o+v-hb9b(>Q?bXH^ zT1(rC1T|L|*ih7_W?m2Se0-SBe~#6a&iz;2c-TW*nm!*Ek)6qvi+Q44t>!CPXBVy( zGNzq)QsEWaES+&`?7Hk6lUNC>%`<19ZZ`l|Y{)_|s4>MZUm^`TV|`^U0Y{v-KP>TlTt_ltxZjOmqw^-ng`v zn}4%yyOIuB)4*Agee2OiDSL{4DhVl5|GS;4TkY`{vZ(z{QR+A7k`-GMud_p`jV^&dhb&3y zgno!Q{Y~(^St{zVU4Yb!qd~G~EHyBMoUoCiUQi8Ua>$8@YC3($efDkgU=4AKQW(G0 zJWTr1JZ}|)d^}Q6f}tsV?#AuWkQ&Xp&eFv(K}*%Sro1w`GgFSU?N<^W4XR`7P-RdZ z<>5z_iT^$S+yD7Le}fr>)dsuzlivplp5*}A9QUfHL8oH5&C20H=M8nd)bD?HJBaY= zZ>z2J*XKhBtHpt>M&jpNx*kCWxE*jm$6I+by#7t_yxJ9YFa%2H;JG2d5H2*9&-H_(y&|mLuH0TrYfvB@1w3W02 zKIH_R@9H;Mu@^>Bsja-I8h-T9yDp0z|3vuDG|wD4zXwYZ2)E=L_;haWPbJUl)OZB{aIrg>(<`F(Y4z6x}*mLTru37EZzwQ;81xgHR8 z3^P-v(JIKs3bpE!iCLfQ`KYn<4`XB;GkwZ-`mMsAW_xfjHWa2$L{sN8EsB=Nd@0=| zB3?;GH6Y}{d3Eu|-!=jP(Wqj9AHUT{xKeDg8A2bgs_Ron0ZYqOW=F{8Flul8*)8nH-PnK(GlC$W@9(b_Llbr^mTwZBFSy4j0WXZ3a zaMjI0xQ7QRe*quD@$Sc$(C!N*d704qgJ%K*+ho@|{M^cUl@fZN>DNRn_FsQc^##3B zPNXhH#58KG`Hy;9rt@%6^Dd&^ACrr-4uAJmt?De=n1KiYJ6^7==HZtPbKi~Y9@T(4_wYxN{> z>;=(rx=DsF#v8C|*K#dD4#Rvz)JDXC96_P|e1*!cKc*tK7KfqH>mlu&>1-FABu3HP zYLj)xCnnup;eX5Pk7w_{|1B+j&FAK*zx#qAY(F*$mnYQO5_|W!yCPY#>FRBjSAN+^ zgSXZPY29o#59WLn?wi}3aYx*|6IgAjS4$SueyJ(?XlP1iuS4>I?=Y*@3Zr54rlDZZxaSyxL#@3 z+=<~4edjZ?q9S(WFi@>j=PTZJ0toE$Yi2fyFdD{IWrZu)p|;ru9b9Ygla{F>==QM8 z-M)g2FchJNU3w-)q--sQl-A>UHyF0tGk%s#jl;S>@5e@d&D%%57R>(n%D^dxSws3) zae}6}akx(NFQJitABUb>hH1h6JI7T^1F+%@43CtP?J*vBrSeLkviM7ZzHY$VIa-ZJ z>eY(jI|pr-G*4h7iug7T&rVAHWd^M9nM7MW=!~_ zB`MMBAj5VYTD=nQ4+_ooV~;E zhgd{qtztzA9N#$f8_{}~kdb7LB7M^mM1)=@4VI*uRDz7>eNQwTci<}1F}GJ66u%e> zI_qjOX{Qg$Ex++AfNzumrwP3k9n2yK+!aO<}Yh;j8t05%q^**XI|JyWEY84nPuUn?pqM z?gWNv*2S^ElIPsj;r4+jp76P&nroYKs5}e8ocIa){h>WyZrTs`{}sh=MwawTF22+O zP>eR%?ZhgM?1s(GeZh;tWT@zkI(t{OG4~U5X-&$VJX%P%?tNV*QoaHD|!f0A$L1mJje))~SJ{l#5Gr zu>`q~ik;%Q=VR|;cwN$vCwVO=oWg%c0e|UQe6Q&7r~jfIbyH?>Clvs~^YM=QrdZ0v z_d7UMOCfu%mOQ~dINQcx-Z6Vl{h+1I(Kyp;3%-vZ>dSnY`Ho6MDPGhQ)ZRv#2Y9yG z3+v8wI75^$PR6#*uB{DK>$$t6AGUfXfjHmV{ILZ5s|p+7;lImN?s$6@iGEx2UkDyq zd!i1y3Nkn^I12#K1B4n+y<)T~Vl99k4I)CQk#En@G237clvPVw%N!X9L~RYdnQL04 zTRC;m(?PRica459Olz%l+6orY$QRRC`bL$R^PcE05Hw zWvl2`?e4GE%u#%q<7ik5t+OE}tf0@BiO7X)43gdIH8W2eD{7<>m<`iu`v@&1tqm%8 zJlWq7093IK(b2Ys%_qrvIWd|xACr$xq=Z7sjO%R~-I{hv{WjbOe3^lDUWIBKaL1HR)I~+p#+sV}3)yCUgYNJSP z-c7=;R~qXK)2$u)nqaF1dsrZ-EB9gQ=6V}09m5@wM6}SE?W(G=eZU1C{{g*YJlzhI;e_ihQZjY1}=uexs&bO6_51X$88!Bp*WG)jC#<^i zyg7YY!S;yvAMqG|{9sljgbd5R{U1vZT4!_NZ9RV>SSpOm8^}BWsTX=48LiuXr>8j$ zalPBEK!@)diBI$6C?>=ufVa$+ws`13YpA#%QS;O=Z9s$CIQ_H$@aIJ{I0V80I;UDt zf}8B)U}>%w%D0|>tWzQR?SCB$ssJtU$~-b;=y$2GA|o@_t*REQD)c)ri5ke>>D611 zBdZM~?`MsShBE9(0st;ywP8D9hC}_+UbKl|x27;<;B{0SQTdwZHfh0ZLZT|QeT!Lg~{s|iS z!jUpxcj>VdtF>A?YR!%FmYequnbzraSL11YR;;^N9nnXd z=Bz)hbHQ}iar6n_4)SHXPPk%a?;uRI^I_z7LK&*l83hAbp!t5Tkk^sicT76}ROxiC zpLvht|7G^v`Su>H(zj9Z_TGS^u4;|oUvNQ7gX_5qy2STvM_6@uwA=1Ch#KuQlCe>1 ziW_C27M{sXw6v3tmfU=6QZBAHF;np9eRsY%wAHmN=1d(T@RL;!Y1lI@O}$A*YCr3- zCwl*BL7y+HWndzQa@j55I6hMSe}EMG8`Y9=x7T?q)7w)ix*^5;oN3L}zP0rZ*`U!0 zIvGYB`YAm`7+Yj;=U_BP&S2s!@NK?88j(g3=z3=^aJHrhNhGSld{E~aVmRlQ+2NXn zk7DEh5qn+?u^ceObcj1tXs(d-JsAcSlfKTe^NaOyX-T=1fR`hOldvpr`t=>;i6Lcp z%k1-H(G&STKS zOak8ifn^Vo?(~Ve6J+E)No#A=jtbb7D^mN^Rp1E^&gWuGe*E4rs1t}uhVRJ;VXYsB>&cu4t z>)=$E8ceC4B;gz`20G1%y_9UlE5ueBsZ(1P@?_1T>}pc1^KN}BJF6DW1VtUMJ`uLvj-8l#8u+X}967yF!0K39 z$JIhJ*Y-|N4szGn@oV7C7_&Miu}Xx4AbI>j9Icy^Ry5l%QVUODKm_#aA0_K2mkZRs z9-h3;Gcw^xaahOd*fQRHQ9|Dp;KyVCT{(ZLM_^}yb}QTQ&T@TScvm_`pW3r>x!X@P zj|=ksz6y4}I>U#ZNm4WD#?XhVd$iMOtp}~34g-C0?)v;HW4_?md^0|-WH@+Uu?=0mP>Ilw9`yI&tiQ;8|-fd1e}ZGxw0}<%A`Xn zVW6-dfP|P9!FK(+y^sk4>iIRa$#&;u3fs~J|$^H*LnSZ<(KVIc~m43R9x0bKlY{rZf z27$pFdqHJF9!jUC$^rKieCheqehp7|Nn^-^M$1;67BfT#vvs@cu9x*Ly6kzDwCoHA ze9|1{I*YLy#`DOl<K3FA84Q^>kJU{B^mY1x9JDh2x2X>v%uwxyF)a2X%!}AC_J|^d&2HlxlO1? zR82U`R0kZ;N5%m(A72Xbe~%lNc@hpy&6+fj4GC+Sin)b8Qa{;G`o>|nu#|;$$lF_J z6fp=*6`aO|F#}|1Vu3<2h4xjF{(>;Q13!Y6yAYiA zN_~`u&4s!V0k{`*FkKYO#WsKxj#@eAU;|wJ!SyJ+UnlhGlP!D)@^QJ!DQ{S+uB%6Y zN$;Ut&i*USj7#_EgQ=<~`jHExX73*XQU%qAaFc&;+$14xYR`WckYB(fJ%3q&ewxtw z6z}+k^sSmKVbh>mvz&4SH+i>pU-fYbD^wbhj> zqsU-?FQ>9yoj6Z6>eK3|C!9LV`5lk0#2(fRMwWzDT!nBVQ?8QBv4t3IC<>pe8HLAd zp;cqT)hed2tpwk+sK6~cnwNyKt5R!fv8L+CeA^pxrtS0;WJGnRL0d_rY=Gsev*2-G z=Wc479$8wq>smU65Yaf>$pGgp!(6Y^Y={tstmJ1m@oJOaMJmb>qouX|FXprLW$lf! zMe_ltFB|SJALwR(83Be6-HnDzyJD~{1lV;te^ zj1Iy*I_9x8Iy14F)XJp8hRp*$6!os+^`1FTm3GgcaKs^?D}gg-k+SbGG=g6SFqv_vfa-%OSMH$lpZ{MN%`oE{r>RSm*4IR zR@+h+sV+45QDHY0qnYZj(jNa4XyLOvxjBdKZsqD&dMHx*N|=USE^ZpO(gy>gg%bV@ zM)!`QI@B7>o#hS0oKJpfnr+uQ`AH z>eStTx1g7YZCTNII%42Kzq=aBbMLaJzk7ILmx5(}{tLiOQe+q!sd~E|*zVOyRA$33 zKgdk0g6}S`R0lAoH+T1QB%db>a&@BLtw!l?oelHf1*24@n{i+6jitf9yHk}6YZ$54 znYBCFoEbyuY&gLEU>0-(VozCvK;(mA=1%Y~((w6=97BZz$HpQ`w2rH2Jsx**v!0J_SsA!sfCZ z)o|s9y((9&7k5Grb78b4-{{d&XpPr9V@?~cH*7UsAxU8_%yHBH3y#;bId>-$SJvI# z%~mpDj91Oj@fTe*@wG@BPU&@+n%%LX8i)B@&Nlt|s91>O13D5c+Gr9?YtUsUoR((w zkV2+(FA{M|YQ<{UP_Xt?m7tdNMa)&b98wQ5r%F}bQa#9Dzs}E9_7q->xsUbf)xLko zpr1Ak_O)0RaV)MV52oSyQ+nCw`Jwk zL3dAnbtK)11@^U^g!H=ZDxJe_EYBEYZr2h~58Ex>I}7n+|Mh(3%EmpNeWi|m?~ntH zefjanTlV)$KX~NJY4PBZ>&_H)(S9fH)r-PcJs~f0XSQQ%!R-9VPqgrV?#@qs?A;x| zQpM6{Vm8)h{eZFlK!lp(na_14R3LZKu(L2WdK$+JhN%SBlh-!Al4Z@BNJu8c7^}?O zzCZ-#jEY=e>ghW(V32TP-7{YqQ+KOW9zP3Puro~@#W>oU zjjT@46LF89L|eW-0F8Bs>a6eVaCxy&>>VNv)&q5oa|ShEg?KWXOFJ3W3)~>w?KE_{ zs4Sw3+0Ag)M<&VD;eLh_eovxbIltzY9wgP=sXIoLJM_ckadm1{1gkh6n6A|uh~&L) zOY89CR8d_WleP-B+QvoW&d`t+Eo#5(;xihbu8ZbP2kI@ap6tU{)~X4$!2q5V z!MyMIVHC9Vc78TyC^X^Z;ar%rNK221u)PA@e=}A^to6@Qif8xgPX5dC+4G&fSv+yJ z+RjS~?O#;^?aQQrz0>DtpdkfnM~6Y|ZSYozvVaewWwU`Za(hfdE(in1T*HB4mt+!e zLUZeZfwu?bq~WfP^Jb7E#46a;M|&=tngjCM>HH_IXBDZ3-EzmTawX5eGLL+@X@7iR zg~4FJE|CIn9omf!I?&KUR9b$gThMC{fbljPXl?g5^;&%pF_9CE!=ULh!#pfPf!Sla zO_N^7Z^;0fGFtRoQE9h7*|Sg)e2I45-Eirj{dB|FSEJtT>Yc8^TP*-K5{tcRJ9AT;yx7iKdJD&rdi6>_4}&T@|CiXMvdt{<5ObK(8}V_Z>vxfK$Ed& z>WRonETKo-uxopMBo1+Hi?t&!F;btWJB`FMEkfQ?F|E{HvmQ?s}n~LCJe{0{*c058dDv;1r$1 zQ19;OZOQZPSM{eawDOSM4RLyi4;vlE5Bp&aYcO{j z8BSwmSECmPanq5q9cw2w=P)sCnKNdc9*wlr?O1)~m@0{3=pi&dSjUX^uPd9aDnIU(HVhbER&bh!KxWIwI~O7JTmzz3=?8t}zQCjxQ!BJ^SpqKMU( zB|h&p?P`|Pi5^_{yu$wWG;RcLCV$f~{~I)D+*@oG;U@~7qAZYBzlHMW~iAh0?QFE=&EVa4U3>Q-V)7(F!V@<8B$Rp zrvhS;lg$)&g?X{*blb~5*2;ic++mJrErle9R+g|0l=d-hNHFbHs}5}n&LLXbZfN#V z%lo!Pe&2m(Q7HHAal^jo#k$oxcYL~1LZ9&Iq{mLYI=usNdcA{o$uf>DyE$yFg5^A^ z_4BYZUW`@@-cg&&o!FSTMObU^#sj9SkNoYPY8h?2V=NDZ))2FW;8xZxmjTM^D!gT;nyXZ=*2 zjkLv_%(MgH*$ay)$jx$=6#HD?Gjo(7yq-TEk#1zFWTb98n^usH>kJfiAw6+}(%+u{ zkM@V9enF{jd*y5AXzjjy{iew8y}r{X@}}a}E6K-<0!DtW zrtUBy0lBqK3f`)pwuw@2l#zgOiT)KJdsJqO_J=$C! z)S_L?d>dvW_{Zfe<%#?04mwh+1f!x`MPy#>p_b4_h6^_F_p&(a z)Eg>crY_k&i0LX@9g5CIj`og%uHpz6QwHz3R=~_>%szF4IvG0VwAa|L`xGRxnvE%s z>6jo*Z;G|v_Tc~aJT&TTzkcXrhC-;1Pmd$Dl2^x9z^m71$8gy{K+4DNAsuEdhkvCTaz)A z{sKA7+Lb#+dE%&&^*HNUD4-cs^;(eQWEWDzX8QdjKr z)1o<1WGmhTQ+1bH+YG}OL}a%XU11swGSScrWi%1iR?rbwu9|A8f+D%Yz)U7%0r@N3 zxc0gFJ9F(!_nLF(&wzWcRbpE*#mTG|W(@+JV_ur9hYFqVX|u-7$GE!B zht>=Y;W!rNIF>~)(Y&tm@Fx)%sx#kT?m#8zPtg>mb`uLs0=u&-VktZLX)n*(b9G^_m#+!JB}tR zqy#pOPSpJ-GO@JA8YY7(`4Sflt>)D+Z8vY)T#SygEg&ipGhVBc)F2iI?YDMvSs;Fn zS^eP4g?bG0DU1>=`e7S)y#-JBX~goH=#gLF7x_9;e8DpS<5g-a4`p`waM?zrm4e}Y zqn^%ljqZu9EtaooeiiT;v9hF8T^K|(oG^+;@G4tOr-hfzvwml`q5z17p|LKx%U$eR z8gGr6$I|&9whptC!2;A_dQIggTyx{EUsb{DcbdO+)GrR<@5Qj?mzVe>G%Tv|39{xN zFpcxKz~YaZ<{yBqi9sb*S*G<544f9AdVEb*Wdq0ZE$rAq^vs*NS)d!3irf3XQ&E4= zPIyHTWZ~-FTMdQ1JoDo^XRHnY%%mEOd!Prp-eM3HnZf*YI-FZwRoo}*JfX%zos@~; zp&4XmrW4Fo<~Ab~j5lW*tVOKD(TF-`oPqUiHvDd>{mA-%|F=IzXsN2WuOIx)_Lk67 zb?9fV*gq*U#nMlBzZuJ-Bu6)W5BRlu&{B|PIVObCG}jEps5Fkg~0 zD}S`wtYw;Q);gxQY#<$^hUx9d2@kqUTQyBQ3^qloz<{m+MXvYt!jII|#F~sLYLCgK z`~H*C@^=2?Jot5C{JVw+42%P6$LB9!!6TPG#B-%S&*y2)nQoI_r|CEBLCc%gNiEmD3q3lgC1hQ7If;@1tWpbz;2f3C&l@}!pGveVv%KAu%0F|}zAAqBt zb-|DF`Oij1`Nmo~%ITSY1rhKnUbJ!esg`8^q$1EGea3m`M3$gJl6X3iYUA}X?04gmWv%2jVMPj0)S&JZ8J zE&q_j)Jj3NUE>RYK$56TX+vAr8=z=eO zU+%qQ75qh79-^U~F8}7%dhWMht?4^ir)~usJio2DtGIZw(BDYhgtTNPTRm@4X|g?rQBOKXf`EK zb(X8)0T){iFaZ|)}JfwY(>`%%1HIqPg2%RJ{{OMzOB=(Z$U)aHpXlI)8T zX#!Nn9S2H8pHEG*6S?x)PcOk9DOvg49ub$2>eLLxCU!1T)JS?VWF;k}YAwIM*~);j z46w_q(WVaI=AJob`|U{XkH=Fs_1nmt>-wRP>ZvA5g|fHnYT9C;FzVY*eqt9t4fX~P z9q`Iq`Ov8hN((KBzK(zUf*V=boYe;?LoJPwF_!EJZRw+y+np#)W7&gIcPTNMvxBI) z9k*;*OTAc&IJCtcn8~u~`JyS+M8}Tf#u~Dsjg}Vfise;L_G5Q3vLNCB#y*s@oU2hT z!1yl>uW}gJ)j9Gf*^1XA3;>!kERHRh#}1(f5__?b-VJu%5-k_$<|-h)rD6D7dZB<} zYu5*Sx{{kq0!;v#H!4;}e6TmWv?e!9rhyZRG!Fw=nFn^fwfeK|&ck;OZ)?c@z!M(T z(0cA905C3oQYd^8R2l!r2HF{-^X~D>*1QiRLlv##Qztq|XK7WBH*LY~^mqD)&727pQVAu8ADn9v2 z!41Lv%@HpQykfiG!Q)Tl;eb@@ZE}nZSDl6E<={nb=ZU{$b~}2!^oj$3FsW)M)q`F) z%)(l|$QMLc&}#I`CFCuWUBQt*QE(7Nd#dBEAoT78sw{x|m{CVWzKTi5m#~LkSIq>$ zxEl`&VauV?j-|C8#jeK@Diz)~P{jT2HiIS@~r?qjI3iQsqmBVr9)&5KGl}<^I1I(vVEvr+^rIEORKw zS=KLJK(hC(V@2jM>2jqIpRdnT)A}mfcDFtdeEV48o#~YebPD8s9qGK-_z<(~kJe<~ zu48$8U>(!qr*UkKhu%2tDpUjVu*Sjl*xm#+qco2Ja^FpjIBOhiWw_>?W!>4eB?M1$ zrQe^_NGWS~Ti=1;?^xDjtp_&?0cW>r!q?^9BZH;1GqBTgysQ6zBYWh^^@S>{4WgCL zwIVXp1)DPPDUOT0W6m&rqx4%wF^F(E;_`JAl-BChEm>5A@RcmpE!_K<66`fBS;p!lcQi9xZm zM%uT#@z}t=-j7fqejV|=+joF00RNo}zLVH;zkq0{tEc)p_`ck?Z=NvE&;PSteYK## zUzjy`r5*0p6H;yGlk#2ldrK6S^Y#N!zNNx=zM7`96kC8sVvi}UHI4e?davb-B z{vhgfc?<^D%~~DAMv)dV?$Ev;W272lYjaCZMv8)a4o}Vkm+Ue&k|cgDo9M4rGm;Jc z>)1O`hTHz{F||}J$j^Eb3Wv&qnLEb);YKLQopwO^@-5Lf8SoU_-oCZel0Z|;bU{ds zCNvUpb`%`QV82uiBbxCIyiHKaN(;Ch(p1cGy**AxOw{cU277r=^x32xH&$L-Sh};r zHM8D{{FfDj=bF5-S)w$@-;-s?=a$ykQ$DMv_ju4mIU4qS_WT~=$G%LiI~C@M2i@>J z+$+}Fx`{F=&&=@4powoA<*2kCZ}gKYE5)MP$2YF=6QvH8`t!(qs2eWyntbi_7;K@q zEX2JNC7=OG)>B~h_lGRoZ&wkvfpnfUn3`N<&s3g734?Dh2T+FG@Cjy_*cp`Kh{jq* zP$`cH3|)k~P}Par*vo>3I^-m73>DXfpYMips3PfL{d0h+OfXkiyAMN5<(#VXioAUS zoC#Ka||HpTs=ARr5mb@u6p! zn8QWRHl-?mA-!;)fG@a@%CeguR1hSm{+u-z;=eKH@_EUgGX3@3ESN?i9kV-S109)) z$__Iv-ievAMpnT*jW>8`4H|5#VR-s*8G18iNY?6_Ms*EYX~a!OIjGIF>EoH=jC6H4 z+66JXm|sT}-jUK1nDe(Fm53>==L1Je3Cw*+27-I{h`(hpzB4gJj|8+B=U z%`r`Nv>YS6h>rA`yjB@J$Ue0iE<5v>A-y^~U=YORn0cV}jtb&RmsY>GBiN1ASI3d@ z)mA=zbBP`P`bSxWb_orgHD+bJlquO#c^6;03ME!&6ofOr(TUy2^CDikU#Jc1# zLfdOVs!OCk5v@k}ctf-lM_H`p+6E@mj-qtjn6>6gIf4-%1-f)IQ0=@0f7DnuK&Ac^ z1}<0j<7mp{AP$V?9#`AvaAvm6@s)9$oMJ2O&S4P6+BVw>HL zzXY>;?eF`rZu&~y|IGLsKAxYv;^6U3#qys-Hb^Xp>VZE8mcAF3&3Jb_`-8-62skn~ zbSv@w?X$O1wFaFJMolD(=yo2anjMAiZd$K1v(?HPF0;-o^sIqC+Xk)e!JGDK>>_MJ zcDK*1ru??1NF6Drkd-iUhALUZm!nCTSjcyz^ND{1r~XUd@AyPj#{C#cc+9^)h(X>_ zzT)83^?--3b7-Q0?$TX{4;H$W!VmgxdH|CJOmp(Km-nSzAloJprp zQYwvVG0OAn<{W;qe_x~ukL);6zT@}tLPyE{kl!WAD~4AJuOjzi-v*m)d&1Untxp7w z+#cgi4V49_0KjPlH&%SBJ)O6${@(5qne0SX4{wL*tc$WCKVHz@YBwZMk%eB*v}5-T z*|O<;BYkVS?}*Fsss59k`#bnup!FVB{ge^;KNHq7)o=ctKdEwyuY`7txrmhKJ}yq6 zv$Zd^cO*Jpj;Y$NqvHos#=*x|*rC(((+Lqb2(8l-8g*-AkNcFqmMBAVnR+`TIf-mK z`z0C=599dz!2N)QFQSuY@c%ox`;(ksMXcml_2R8e-dJ+RGs)@D6veXjO(05Q36ePL zLg@uKBBN=9yR(s4t9$6Q4U@CmOl{Nf$c)NrR(ms*eU%@tvp}&Lj+T#Dtw+{ZqgRUe zKLvz(6xu)0y^z9{)##Ziew(1UTaz+h@nLDl6-8K>t9Ml^%&Q8R&~I=a+MKA`ZZ}cr zbSuyE1vd_x3N3JgLvZaufKiC=D@(75A{$-q=T1iSwbq;kXu>|J*!#_{E+lNy6L)^H zNq4M2|%N?uFahsTBBhi{)egKab6sYOMgP@l-wm)PF3X z`*_aJL)vHg`2Ct-9hapx&uu+t(}j*HBn~}*TI+XOgwWp)B`oxZJpyIWEvA!emmUhe zLv4$UIi$UwOl?HWs7;9fwjM}4uRffYY zCW@k-Dugy3HDkY+*E{{3Ru{^UZl-Fn96Bh##RuvlwD|bv2VDXSkI{d)1X!oFR}!HOQ8)35M<~`WVAvzQ8k2A*2jH-m4ZI&2oF%P_ zIWX_&`1dblAqduogt0k_NdnfUbbQW0pO$Q_yu~8xa?HTz5GotQjZR%?q?1Hh1<9(B z?xw4SPi<$S-|Dz9L?&UeU?PttCT4v>yw(dQ-e90Z{%oGE|NOcP_H?Hg ztD-C?lj8)Ujpa8bOWw`#zwZ04gyg2r=;xl5b1wW%hv#~H@2lBqB;_7Jo~9Dr7}w?6 zTc{mPg5s`}{vL=cw86TRXEw2Io&|C``-pN5Ez*1GsnF4LlTZ$v)j~-!!Xj_x-kXPD&T=xhfXvWZ9qFB5&Cd zKScqvXAh^3n(@ozFxYNg=%}RO$KktzuIfg; zIU;V&k~9C_m?Ux@B=J4L=>gL}4n6)xwPOCwq^P&Hp94_b^@HSZVr>`Bv7m2t)W^)s#${f{p{p%pb zJ2}Afqm)_m;}Gd%DE2+I_cR9iJLx;lAFuS8O?aBfRo(6t->dg;1%8_dqEP^QpEnvr zBk9UPtKVPZ^Ca);are+`N(;u^trnyGaG;S27mAuSC=R`pMw=3j^BZl-nQOifV`5e- z%tK3eR0aE)>rc*%SIl$Ws-^#qZDq3hLm)m_ijvxqVdbkTN&O0lZ)IibQUyf4Av7sS z3e0xr9Ra0CCk4lk|SmUd;6-R_^KVVT*0fiaJ-d`N6+oDfDqXt4yeIsGIVIonvKE@ zhVIhoGTkpsyk0|SuM3V(L#a>2>7btHV_%}QT^rAIv@3f;W0{Q$I@l5!*VO%dm7-Gm z?J_>Dd{to@$QLm7JT&iWfwo|_!1_T6c~n`i#~jqfQ}GnLtZapEefYQZ7$8UW+lbOX ziIcwWDvhk|UUth-A`cOyN_BOH1$onjxT09C+=YIns$Sv1fj3{528fGrY_FDhFvM8Y z2kj|_pjjf%f{AM!+MOBiHCp4Sm~!1UN2$XlwhS$@K9y9go=!t-t2Au4X=Mv@oB183 z0(bnuF0ml#42{3gg_xQHOZK7g)d}d3tChwaD0vr*a!_D$RXoeuYo- zElK~Y-2ML@EQUzL|30RUBTzNfYQctmWUZIs+dmTrAowi{r8=lcy-;Jl1wb84Xrt$+ z18f3#I!S~$$&6K;T7V8FZmS;QvZ)JgPqeAQfn3)%O>aR7ea@3b^0q)ns%4iBJZljeqYy!&8{!Pgd^LP(xN^C zbj0O+I32eHKp`iQHpN@TikgqnQK~Z>iz=$P75XgnkkCN~^=&!eeM7i*=g+7A54`wk zklLSEjU}y;1LePOS&7^B0yAY@DHL`?yEbv^MN2Z z%dXzOg-G1S%?Ua*TOk`P+`;WUvL9U2*c;*Sp?yEy^1#75dJ z)+q)?G!jEkCOo6CR|s{W(|s);M$HCaAIDyI(-HFa(8YsL@*xzB)Q-&zKJdc_pIbIUf8e`+ozqx>J5-`0>-jrdk3B2Awg+F3WQDS%o|H$_7a# zZMV0Twp?GqxiVM?qa-X8E*rQRo6jV9q&6XDri@pieo!a#!#*Xq)(X%AW2rA;UC$O| z8M9NS##_8*_JuCm>0Qn7cx*vGz#Y5T$d{zU$(4Y`JIQca>{SLc-(0n){h)VHVYh|6 z=bN}&tN#Y{Diadr7W(&pD>EurYw`QYmfL|z|1?0a7c2L3isU3=?;aM{DUw$S>4rIPIERaYPBUUJC0p?dv6V*Z)Ru)jS+gj+nn1pGH|1ui zg2)=b8l*~uu>*Nne-dr36!A@Fs8V`&(t4!>-+gSW?6tN0x1xM&Xc82YDUEfoCCaZ& zw~k=qg0m2)-JM07iDAs7)oK$#n3eChoH`Vv+63fvb}PPLUrA2UbLInmGa%+BCG8TQ zp<{dVbGa%EoP*BBubup`ySR*pe5^&!1S|DrvRD;5A z@ETLbFXydQV`R#aqc4vsI7D9A;1>pdor`K7WGc$s>ZP~#-C)2SN5)E!KU z5!;}9MyqYOajHrd+n&v+&K0Wu?*{7QBkD9T?^3>61_&+|z>OpxLvhcYpYs%(yB!J% zjWgMIcj$2>PRZYjDp;=Ny*+2C(6z=n<>Z#Qbor59%oY|*WHPtuq{rE@vmd9msjyMP zZD-16262EEok1qFr+{fibewe7hlyrPKiS%vOHQP1Hko1TYNx)G%D;h7=1(0%AEITk z@%1<$Tt3=|x$Wpeu;S5~dgU0t5I#jxF*;1qKDwEvbf?`h9h_BDA>+$j z1V@LM%%bx!#yf-kidPak4U$0*1@({9L5vv(D|D9;VJTwXDlPmUtn*j~(C8BQ;s+ZY z_Tq<`?r)0a(|^CK6#6T_I1d-B7|~)G;Q1))a@GCr6N^A^?0}0wy->z zwdepv>vc9)S_nYHF%&JbQO&z%o zec!It6J9@ePiS|%0%*b4r^QTFiEOBwep?m~n4FUe zG!|_L+1R#|dYBSwuoyLV%W&h+y;iucn=`a-uagWW1tG|kBLZvB6{cNZ7}H`NB`P9B zgZ!;HM`^*Fy^5by<|}-j$_{FLELYcLk4(G50V<31;2?S>WqMj)9Js@p-Rz1s4Lxil z7?-4Va7I(t^IS3l~RblGE4huIUs=X>3RN5@_RL^D^wxN zR|ZWs0jXN}_85&uK3N}xoTSkJh%;VCvJckv+%kt|LekB#z|`9Is7vyNo=%ZiOqd|t zZ(DXv%_pmMvF5XsTZNV-K|T7b!nK`eTUXpa4o|7hd`NFcUq<4($45A#!+2l-R#CaD z_&0=o?w9GNaOR25eWh@}m;X-PmeTMCy5lHMrxiNBsc>drX^c&yC9vF34IC=$`B2K; zP7_Yt1xb<;p2$pmT3?Ye9fl3BL96YKE6C&+rp{JIeEqvOHW zvKkG^YK>!`AhN+|G+nlJvw>5cHHxy5fsFTDwAu+Z%hLgBcHy?0<6*kBy(OKooEfcm z$VdzGE;O8>{|e)%)I?Bt45|6Op1}~yGPHKbx<9ZskDKR)@`Z^vpT1>lc0)fk=AA)9 zQ`4a7x{X{&b_aW6OA8_%VbOqx2KNT1wMh;rpv2y~mo9n%m?j;RYMV7c_ zW&umiYw{?q8`yR>Y`KgOuNOlv=;6hL^tiqtcxtliL`E;L9dRF6o0++rWn67H7)}Al zK{wsF0g!&~;06WwZFZiv^U)pqt{12z@UGEoYsF@wR6Smo>8lZx!IUwg&`h59>BV8} zIgLls{U_ZeM{36cIpffERjLLUDEIzpd{t1k07Zy!om~y@+sGiDvoYK!=K=gUhyyI`qB*l(XGM zq=URgbiIRFQ!kR2_06!m46y~~^y+P^8&dVdNa(kXKu~;XFFF8Q164QFOep3R;NP=Q zMOi@M?STPb`p$}>Y_D3rD}d0yeyN`4Sh_7Azbc#MENAcIG z->@|Pj!leZ_~TNO0zU#&vab_5V)^%1!O8L~tHO4!?xs9EP6iEhzUZ;(X;rTZRGvYn z&N-)f?vp7yeJ)|nYB0nv7zw%=E#kfrZS>0=Tm7d^D6MQyP*GYHb?Yp3&KN zT_%nVLbjJ_U@beX1#~PaphDGnLTcnHBIQ65yB$PSoJnk2i*HZ#ruzA;%~aRAG98P)E|QP7xnr!OUvq-U0GTKfBJ%*|J5nyA9nBkX>cc7SBJy9jQEWzaOJm8 zz|4LvasQ2fepT-J!}?tg>$_z;p4}g*-Xk$st>cTYio^>!Ubvf8qVgL?&mv^44-&iY z4d{b)z+qki-V|zG4Vl^;w^2K7+(-Jm(Off{P{z$$`;}>=QjuT{civ_;nAp$bRu5fe z=(k#Ud}dzGg-Y!n51A_~nRc%Wce7^N7GS1^?tPd0gt*Fep3L+o^ zii%iK89}QkNZ&r>Z?6gV%Z_!<-g&b!Z^XT4yAMOdk1 zyio+e_@AdH8Ymz-n;msux&m#vUU|w(o>G1W+STW77L#taJm6f?@LThiv|1J!F~k$L zh4wm&q!llAEgp`eEVO~THOrZVUvwof9dMI`awc+%cIwau46zU$9lS-`8vC$uUlRCC zyLxHwTuG#20Y_u?h6TLQyedQGgI!$p*8)x`+kM(l1G}c!|528EeV@YXdw4&Y*}X7| zc`7l+;Q^x#8Z%44c*LepE84i2+C0=?(@g6%V84~Jc>-pyCs7xM2;tE3e0~rzI$^n+ z)d)|f?`cq9>p zrVQ*&zZh?)3OrnLo-hQ6i3jPrD|RIXH*RgWd!O8Mx%31Dl>i1j@cgo8nktR!`qsi* z6h)PD;(;ZWIdDI%*ak}h9Dx4q?o(Y2#$)ojie5Croa7h z6+>swO}%plQmNjtof7tU{<+Kk52!64=ZBS=$Hf40j~}XRs!#rqWa)!?w%kM{HfxDn z9rl@C7AO9upN|E$Z~63m82J*Iq_Ef(E+QBLp`)hMv&aI04HJ_?4{|NZSGQqdj3m%v z6de^;Hg>0`U0$|Q(=B9CULiB z$uw^Fs7&Bb+#^1~q+`t%Q!eNTjGy=R0;aWLvNPaKZv^a$Aaf4{z8$Uym{+W`8RtQ2 z)Bt0w@*Z^X(p9eX##FC&V4%^8q^-qX9+5v~*;Op{n8bBt8)aq5#ou~i+jr9M%v(N`RXv? zFl&i+`B7h$i9IygLKzNu#Zs`Rk>TE=@rlFd);4w<9wdii_?jpaLx;I_Q;y)Jp~a zJMhmb2Q@Cc41{2Ey;F`PDzkns4xYdLaZ}0uPw(HZq#U~fT0 z$$Z*09n{C1sjv1yJg!!v=lBUYSIQ9SdwprPT#NLwLywv;wMUGD8wJ~>fag8KLA9J3 zuzL!U`|Eh@>)q{aKi-NaKB6_DHD1W@P{pI&)C*YSFj&K>kF)S1F^CrK(*K>sDW;v6y(!gC_P*iu5oWjB}5lsjk;?Zpf?>LM5j_iII8VV6{BOVoP0YttiZXm_X( z+3(eD%J%vyMg^f0?;4_W%d*ZU9+2x#!sTFUY!%uC46O8$2O&Z@*-Z9XC?~WAnURa7yd~__WIJ;br06v}X^SG8(Sd8a z4oHt`@4Cyyh=;c7tjGyeM#4TAEHx4#&2Vqsv1b^4lz?yJzu@hTZIP(RO$5Q)M1+dyZ81{g&{WoVR-VQ#24 zS|dC^82E&-Mt;yIaFN@0!&~L?87Bt0kB8V%Pk91AGT=X)Di?Il0aM&e>v;#)Qc(Ud zt1-G+vZAN!4%KPqRs)8q5d_JMtEEynwrc-KSNG?^}zaEqT!Hytb7gB*Lt zUNfA|wLu6})1wqOBsv9i8%D|^oQF8xSGwVy8S{)1Kc^*GhGAfxb}0cssz_Wo*qXf^w-6m*5|e`(Ng3y;p}h1XR4n{t`v)IRfLs zic^QXtUVg0wwode8U$?z*AmnV4raO);bySk)w0k*)Td%ZQ;PCvJFBPQn9M`Mf`Scka^U`zr{>53C4?L^ukG$Ckf;hcF z_27gYG!TnA#746a#gW7DJicv?SOyCg<7K*RQHiw!-qoqtS~%Oq8f4z~mYXD#Y4Fkw z6VwymBrx9#j60vt<*7>|y^Zz102<)F$Kv$|sS6UEdOv26$K^_h9Y2+0MZqc`0LDej zJX{L4g z-x)jB+FHOeGPapO)NZCC0h9J=;qY^Z^WQa)$r+Vd_#hSXQvZDNT9i-)ZNbid`M>?~ z_b3D%v`lML`5D1MKk|l4>#&C_S|6`C^OuX#^RPyFqQA9KQ@{|Q<4i*^+U|_Dzx`2t z{go7x4M-$CE#o8N+}oivDR08w~0&oz)$5E(#|sOC1E_PP08x6HDa>(NVl@##3q z9*i^$f-1CAKH1GSdG%Pw1mhcac~7+$GWc>PKF;w8 z|MrJ_UvXa|@H`Xa`1q$Me0zO`_O}cOK(AzK4@~GL;80uhIB_1Z;td}Hf7Md<^K=qy zag#zPSSL3lISCR@3D}|B5ErXxku16pyhd$1pr*?~)@+R|5{xkxBeJ{D%^{SV#lA=P zeT?r6hw6M9W;Pfv{mdXb>H^PM5D3TYLAvTOAcK^>2hRA_^Mm488UU9LBF)u7ECum} zXe#g8Id`t4C-i*hH5dSn=OxrpPCY#jJUeof%TmYrJJl9tF5Bf1o-;+@`U8)7$(_9u zLzS*{{potv{~bsN5Fa={;+d6Jdp=kK<vuZ2kbTrU#yJ>_vI=%MJ5+>$L!Z?{{bB zOs0RUGQWZNyqFlTj^Y1$x7_^^EQRsylE2_s{m%-39r?($ImjK=T+aab8v2z1u^XOq z7jL{Aq9>dUJD;iZ8LXP8mXjO8{}Te)eH(C&gZzJk)>^x;n)-8G3^29h2f)w35+78n zSlX$|m>whZCND0%s90f~jS9&W@%y7_JdBpJ-7Hp$oyj7DtYgq^xCh+W{)QtO?FDym z3U;XryB_J23@7-5HJKRgpYpT2NWfjQsyp;tfK{W@_em$XC+<(G+XE7ARJpoHc)JI{ z%_DmR#!|`5-rEeTcIMA0pX>JVsHIR#qtoOwqu-)-s>Ze_J{VlP51eUOFinnM#EZBS zqf0-7V0$etxqXZ!U}#~7#KD}2c-Y@H?Qk&J-q{R)Sp}{pR5?dSP1%(Cj!VAbs6Z;b zR{+4Itmk$9rS$))iw2AqEtflr{_0~T_dlHzN5E8L(VXs`oCuqsU}hyR6>(0WD;Hbi zmdZ0oxZbN!7EX6=f4WKzZCBXs;k^L{GMhNp-&nRE`J0_3d58z5CpF{Z$L9o8XrC1I zJDvRQ_?%i2AH!=P{0zF4n$~SA_mk56pb4Bj$=@aZb*3rEs5$lxKdBX$8QI{6s@Csy zdHCHi21oOZ(PQGlL&o`cHS{V{E4B7Ue?4Xoyd|Hb`E_364=}GO1U;h4cQ~pLM@6fy zkK=63l@{!AWstJ_*+-nLS56@WEbvy~?K#vAmiD~0e^XWO?sJ+SDT=da76FYA@;xT4&$M!H() z0~bz|q(7Oh_|0I+k?0{G4jmRD2IFSWnt6og(y7!4(`f@&M^=p4yBLic%--%dCsb;< zQl#jcs7;H@MYv*f!bjS=uBCTe7{K|eoV;P0?_K?8D!tP+o@3)RpJMV47upcUdJj|5oB$mT{sy4D_ zhA{}%j6e^*fi6*C{8+CyJ}d{QPlKsein@b&Vw(I%%MHaXDaQ?pSn;l z3zn~a`2#3KV5tx9zQ!G%(Gy-G1~Ow8eV5$hjVatv7x|DEn|8GEnv>B2Moga?HFVYL zMFVotn(4ji*do?sUkPC4# zkA$iKpc~O~%)!ICEXkpJG=*zZR0-1Kie~^H|EkjNyB{D7n*rp|R8zNkFf(y(Ym>a8 z(u6-2!W6<_;FC2d3F~4Tce>j;zOpu&aGbL7E>_1qzsGJ+(%QPs@nTHK1-!=g*rs#W z2c`Boe9!F4mo#6b>w_GFOZD)NpjIw;hFSR;&}6yN2arW@Pz?Mo<{;)$(_@NQklV47 z=c`7~a8YTxTPJ3xIaHttJjEJw1Zy*16O`rT3mYDdGp{>=_~Cp>iA3V;b77OL8mp?Q z>De1p8)P3sO5f(uKC5Q0+oqr*TkC0DuuSi1{u!FJ%BsH8!XTtluJQr$^Zjfb^uonF z8&chgZpOGMU`wlD@?yqKcDokS(%lvlAmiNW^t#MaAMV4r5T^LSCIzXz&wJB`)o(aT zZ!mITbTu91RTsiD$R z#29N~65HkmBx7lZ-jvk(W@p5A2auB*i=F7Iw%DN$uqJJN&kUiCFfDbW*Fp$X>pzpZ zCH#Llk)=csSnc%IWrKifkq@st2?fRw&~==e2HMsd4IAXtFK50t8jdm(#`i@;4-du` zD1sAb3VIdo_yehuSvrW-mn|x7PktUy?9L4#_wYxz$jf5!>HG-;P|@4xzGJ zfpXJ2;S#z8@f^?l3S2iTEv#zl=e>S^GgPh2OuaNHcwtzA_~6&p+H7s`|6{pzm9%_u z^@3&!fb||K3J1!4tF-w~=Hg^>4k3hd~MxFN8=gJx{dRyio(O6%B9rRw(q z$nfIHP>u4Ge1U^wMFvu#w)BWzLJeD8{qn$(s(t~={+Vrpj%%Qm3kda9Ka^=v*Yso; z~` z7+gsFM1aRTZd{~)`{PWyN(@51O4V%TOYy8PJpj*s3|Ac^b~ohrofPf^9Juf_y7o+-buPZ4**ce3gk0~!D|Oer z{u{~Hx$Arm>Rfv{5;ZSAv6nhmUk^{Mt4|F5<$-#;NOj8Is!{ijHXypHLCD}_SL@z7 zOaFvh=)4@zuFfB8Ie@y2p5z;aV>Ia}W>n{&*_-9w7Q$pB3Y?{eg zXTNi9UNyxh7`sTkqJBRB`zCj!F0hY_0azbDRGHHMGsWRiLDtunV@YuH0U*L*v95S@zgNJWCFkS?%z97pR?9eH1y`- zD<)gUdwXZxovt~{#L}zLyBe6!BlD$i<_jdyR&$Du*{~Or^wh*sQGp3uhShF+S>8BC zu399xzbvG?dND5OC?EDe+Q5Hzai`q*Cdw4t8v?th)5{{aIK7bW^IxmQenNrw%I7^K zA4n4b7WBqw|Ioj8vnZg*5=&p_g+5TA=?RV9zEv>orG%o5v_B!;0b^%PHFE~ztPNcI zCfWrddwqoSalV)nHY@p|!U@b4%eEYm?{lVS&_zE7sUHH=mR#=6p?s#mKM%1h*8`Y& z09c9nU&cnu20rhVpPr>aJBgx)s@v{S<}P4I=2%^evE=rw`6ONO4O~IIStxpHI8ikW zq8D9mtb@SiY&KBLr7$|Uj6t#(y5{@+Zkz6z!`CPFo?QPSY&AYuRWE)`Ik@0sm1|R# zDdxbOb&T-K&>ZEpm^(T`jxM;G*(X2P5m5UNuCC0oPdpinGZ8$(Hkb6G)5xKLh-ZCf zHlW4kT5IXV2wCj>MhK?bHJIJPNTe3Cbv2%Bgzk)&2~p`A1z+&vIM1zYOQ6nRe-Lj3 z<@e0YcM|W&xSpS!^J`a41j^F)vT`*4eaLvZ&kYJ*UQ-M3oxQTg1J&y|j#_kLd$1?= zstk*v!0*QXQbamSkL|_wL@-4gX5dxmG_~*j#4Ay$oes0%s@`8W;_Lx9+cbjepDmM9=dVMPY0{F|6M{wYtcRwk^9zRUm0f+0db9fZglddw``zIOd9kU6j`7vO(`gfY?&=xWh~Irqwp3WLMkF_bqA9png>n( zl#T%D&}hKRN*|v#(*_LEA@^5R;SHqzM7|bi_;aOGT%mYD|o{b-7bj62qu?j@x zhsv|@Ny>V=yrs%pF^tVrvd1YHdtoCQhc(ievBzj!z_JcHa@bQswb7jm$+lp%9kr`$ z7W*aM9gx_v%f*F}3!FdOhkayQL^s)Q?|}26ZAt7^@m@7>Q(&KhBsGu~Qw6Y|g6fBj zDV{H0g6`?A6(~P7uh1idBt1M&VnPpkB4nCPS_Bo~P)}ZG;~fnS;B40GY0WM?Qi_O) zW(s5;nq5-QM$7RsJP0xdDG*6;XxGt_g(I{V*y|H|t=s;8N&@>^1r`vZD%JGTbh?j> zo(#x`i6Qq_Rq@kXh*z4=xx()I4iV@#0M2>zYVGsy)vBk*g^syDpt+X=J=v&ylmGW9 zi=XQSWgjnFInK8R$p$xtogPq+tJaI>*y1IZ^0?le3V*wG*)pw4H#o(`tK)jS=Xh-w=cJU=WgI4)L_Y_%$IK9x@6_pA^L z#)~{hkZCj5dZ3uON%S2yN>@#|M`Cl@lx(Rf>uy)Fo0ioS4GOdv*uoTL3I^LUC#x}9 zz+ui4#Y!M>YsAO;Iv=` zs?%q1pv#p$fJ@3f&9r7)(^v?-Bq8A)8l*6TYy&AsQEQzbjaF-mTC)iQb&KYFhptRk zXcOVW$~u$nL^!NGiz3`{?yezK$M@*~w{B1Lv&5S!*7)5Qb3^B+T4+$!;0DJmnWLz9 zM|WU+ElA7+>7*J+p?MBi;MF;vF-#{HrIR`*|gRZD*04p>`mv%ZYA_v{d* z$(-H^(O#TO#bWL3x{*%Jd$a|$P(7KV;~rtRK*JGp2d_4ZR!HH|coTJ&vFC3=o9K=r z#lF~}0A5Nj@*AqZhx<1d?VERdI40Gr{?GyW z5_o_h?todPX*NIkBvnQln$w;w%o7I@4~CS^$R%3@TlBEqrG5$uNk|fmo+;8~gGHEt z6UM=8*+lBQZEm_MbZ;{NtZ+j}hiSjjO7=m#ziU`^_Tj!$kZ#}UbQr#XhEUDxoaT~VEunt_3h^X_Or+8yLE7GSwVNU#Hkd?>_& z-6v(?w$BO(6rD8j$382UQ}{#|K7y=@5|$sU!+N~zjXb+B0dV;fO}A|E^19F24|DX7 zive65KUA8JO zlJS;RqopPDgp_|Q?H(5{f%&joRg?J1glIAS15$MRGc?$ZyQ0%|gBcEQAyu;>!e_B) zCg`Jen{MJeooo!13G2w&fXY|#nC-TEMyv_sHW|3tBs6W4SG)U6sk-pLAf&Alr5nJ( zp0=bc^F)7ms?*DYB@8Zqd{s+*IO3r)>|lr3%l2r3P%_eK?217uD{wFtb9goDGGewC z(hUoaaR}3cVmnH#eiNE6MhxqSOF!&-YOjAtXnZvUb0b(Ukmt89&}a6*sb$(9|4~*) zT)6im_AVU$EzeH3*7M@_vfAjZM15!4oo4Hc${1ai{N`j%PgMpvq_F0PA?41wMGM8o zc0k0VbyJdUFt;;WMB~MlR~Tp8Y_>o#u|s9q!i*VTSc$xYMMSQIFfY=#2kP0ogD%3^ zRW-R&JMNUq^IKI+?D)qUodXQEHb8e^Yg3kGKb)^pdi~IwbX~BdsmtnsQI%%qdz0KC zCj3lR1a939r*s_40zv81#B6VJoa_a|;S$P)Y-Fawe&*^a7?(U*ELQUj(v7S!G2k@I zI*8cdz=%{uz;a|VvI*y^dp~DPNAvPB2L0G-r&Z=^SO2L7JiZNhq;8;prGfIaV{Yk^ zJrQbMi{-Lj3BdE(0Dfg@#C!Nr1>^)An1jmAwh*=GM-yl{hdN8Dk#7i;SYnPmUiTx4 z57e-`!0bd2(agk#%y>e=u>{iLa2uvDxVb^rqd06h@epKrTp0Zu5eV4u#l`f3c>w^O zr`SKxSyjjXGn2anc(q;$rSs=n4FTlkh~BmKio=TYEJe9+y>kbdDW>58&NUrWX=q?{ z*R<8tI)xCgo1Wd^%xtM=0tCYvH0#g#`1$5nU&LHHy6#TJY7S@|~eJzanwk+ZCXH=x&v9dzno7@RW-u+DNnT^-9g&)?fsO#HaRSEAW-QXaO7ulw-=Ahmn-lN+^7n>GKRc>KD zSDvG>m2L<(-bLHiE^Y&F!hEg7m^dA5BX#a9@|XjI=2oD>es(}natSvKe4_=oR943T zvYa>o{{w@1jumMD9_PdqP-Fs_KFFLfGB7u}bVrsJ(OpZrm*@T8fhF4nmsbTXz!Yo( zh2b;@_igcH`c#SQf`&CeMN?U%nufrkQ?^Zf&lJ^B-eQWR*b8ntWR{J_mV~iwpFj_m zECw)B3^*5JT0JQobg+Iaz$9C1E=X-Y16|hxA&J3(Zx6cc$S1qL=7mds%i!0>5ifxR z`T~|(%AKHo<3o>4(+EnZT!o7p(gnvfGQYZCAW#h&&s8qVKmNVc(C*BW?SW18_x@^?x4-AQuH|vYWsSk0s2A z+N|XEActdM>>!}!GfSk9g)CO;fd?hvUaMR9Musn3!I_eQOf;Zosk$;^*s_|#nKWkl zk;Mk_N3BAs8vp#;zm`?J7h4oOwi;Wuek{oP50F*&jX>T|)5rMf-Qo}6uJ-!jF}tpK z1o`RNzm98t0J}-pAr0-xVTNtkL^U)GhTJVX>cD2anR?wIr;5oumU@Y(G)EwHMwZ5h zZMeuV*D{b%uiFSZs4}0@i$Qz8joPgl!X&lM-3RA#R`p_ks;&Kr%!kuzC4i3W*2-YW zY^Vc6xQVou;mC)Yv+j-=f(M}p-KH3z&Z6hd@jE;P#|2^+dj}vNqRqwh*WEpKq=R(1m>ss2RoJ* zO{>3RR*Ox4b?7Z-J1cHXq;0-fQDI_wn4`tA)6>NT==l%fyC_(sWIrRiEy%$oHDbfj zj-(YGPU+Cq+eI+%53d6A&B-cjOy97uyxDzf9F;uyhu)iVDFBr6pUTMoY9Sx`qn42#w5iy(+GHD4lBZYa@W5wcz{-5`pLprE>9*Vvf!kVQP2 zY^-dCG1V(6Jhxgv7C?M-mzNgWB~$)&;=#s zP^RuyPV-|V{3M%>9qkUAJ8S4-LxXXI$J2OJfiBBd*g3|^PqofJ5v}iCk>A#SAb>K{ z;in4h?V1-ls6ze0*KxfMCU`J*DUa@wKx85+{r9z3C&E2<&|x) z>+fC2XcNqSMy#hRGx7VOwJr*I3ub|;n*y~r?e0!<+9UR=)V$%AAAt3gRo*g%@AhBm zP+Mf}d^3{5xTRrMNJ>Umj+?R_GmgL9X8yRPu`6!c@ANesnVRZ|^Cp-X!*W-JiYDr< z*aMlZ($H)pq&e3$wg#Ss7CY%WSv-Uy$l;ehW28dNHyw-h=G4@h zZRTT~H8Rl26pSTZDw`<8D2H3OuA=jMmhv00oyEqF9S$c40~lFn9rV&z54Q2CRYu8= z|BouL^2ZY{^~c{8#{&taJHSprXWnbX_wk$p584mW@^o#0pvyi$*(=%Gdr9TboZYT_ z*!6seoljRQN0~J>Z4ZnNaW)ZvFOFsUO1SpOMuY?wjWq`=L+=W6g!)T{Mtsn_#l*bG|uA~y0BA5;3!+Q>V4y);7lp!ddH zV+_qnk~8=FY&PFoT*jkTd+q!E<-`RA?25BqH$fqcv|{!?imUda_Npue`j0jdx9-x1Eo{hpA0ncP@5E4(22Z?_!-!2Q50 zb8;YF+RA=vVqGl=;9UJ%I_yg~R=%qZd~j(lOQ#cJf!A$KZsbu6O!EM z7E1^owuiZVXd?m!VSX}Ag)M0GwWo|!1+A%;he)+HjyA^veT4vDOfQ`=CpD}(_{aYo zmcvS?KKf;F_?q28*iAR zE1NX2W5p<&uLF6tZ|v88WTSmJ#vRAvprHyeDh}ZXeZB;JORwVip9BXSl%RW5sVn@$ z2+lH^%~MOqV;AEm5~g(LoOwhwyy4TCyCuB)4FCb&e^HANz5Q}!Lb{I%^qhfrg}g?4 z%Preol04}OYZegP0&2Fz(V>uIhUZ6|Nw%AQZr@cnpthsS+6`qlL>5ND4@2)_Z(!t zU8n4r*-6YzxBEu|dVK;arQ-%1Cn0*$HZH@eLHPfqfxNikjnu6+FMltE_LuFJIl;j4 zJm_v(Eq2%M>;7WkBJbYd@mo9Ze;$h;igQ4ytqytv&|l46?>9Iejhh{79S$J0`6(#$ z;T3-}q?mxEVjF68w7o>3qd61ltf=g^wm+I=u;7TX(T@|=#p5+T_lILUn|1LipU#vZ zlPBx7DBIgv|7LvLFFYJaXr6k@{em-eI&^?I34D62r9bxO$Q8&ov*}B zdA2~Gql)&fR>V^qV!4(Z4lcJjCkQ*z$h0Dd^H+s3>|%(i(Q6{^v^7;B6h(1DWzGvt zVn92~9@+M2TtkM`Zn}zh`LMgQHVuKq6(j9g|J0uUOPOoW#q}?z!PqNHfx@q=QczOk z#PgW)XR^~JP#-55*TNfyE*4@= zT2!<)8yr6+n5N%G{cIN%wA?!UQjSqW6|59yN1p{wEjq?jQcR&#SPdHp&>;WMCWM=^Ea+?pZcA;!H!ToO2 z_4+$;u!}HRrx;LBp^cWK&Wc|48hC5G(&WxGU0Tkb9}BrE%@f#J35l4BmMvzD;nrh0 z&{~9vS9-BcZ>E$z!uo1q{uGqoTK?YhO@I>^)cgH9ke>E>0oh|`?UI_yT|YorRu4!* ztP$KFmX0lB{szS{9fc)L-PcFq;4E}+2Jy(SW$CkXt`)ML&Mg%a9Lx+C@|#s z9ecNh*LEjrZ98f>o;UGK24yfIXrl3vSDbx0_dc;dUK_06y#yaGJ(|Fe3sx-P1f!^m z$DH7Fike&lHm6y0rwrmMy`a4G;_AJL?SK*8I%tS*9UGD*p!y*=4{ZE?`;D1;$nBA$+;+^{!G^04V;lLEQW}8KlNdM&^~nG|GFeLzQMwXDcv) zBeTl>mDQ-QFs?e<*12)(f{rrVv!JbWN9DxeD>eFehMv7&8$GmWIY@FGTU*k;wX^WFBKw(=&6>=hpB=>r#jczgMkdtFu6 zn+H5z>gxH4TinZndbiZsLN`nW05|+{%D$}kZ2BqWst3Ej>$=Z#U{|-CnD)0Fo=J_{ z%Wsx$UDVO=j8u--e~a+|g1D;356@Fxe6#H9D^mqj6rB}` zr%wwq?}4sU!vB_N%37E=LiyuA0AN_e958wl1l8cvE)=z=AlnYULO z`LTI>R!l?pMoSIdnrf=u%X@J+iB}`K;WjmB$+!H8rg8AVf#)5S1bsSZ_HKag=|W}X z6#=D7f7TsM)~R?P4@IY?9Tu}`+uQh)=5W60v`Kp)e>4KFYU)kIsD$pLUU`4%TkX?5 znAQfcw<=NKOb$uCw4cK%L!+=}x5uJZYxqV`5Q zUk}-9(R?p7zX`&ZlIQ-e>ppKp?Tv7|-{tA~|HsP1AIhQ1K>tm02y{oedP{&tbkZF^ zxJz=zH}^vyCPqCXY`B&Qg&N!vR%l|1oR-fFMAj6kBcN_P$+rxUNg}<(4}H`UQbw7F z&bT)i_5@->60HOp$rEU`;opUZZo?DzsSN*#a_GRJh4DsG{3lwtS3lP? z=he+K{YDe_pK|dum-wY|`A-w{jgb3qE*F2lW%pooJQb@K{_u12?tX((w%&hJ30ScH z2LX%edz_-^-hQT05-M{+4{9w`bhS?wJu*fqXmGH{sxr0-P&@5oQ%@nc!d8p;rPU!I zj_@*O(`PNy$jE~M>xqka)=ht@$9USsU32S#I%)e)jk3?qq%x=Uxkv4_Z{W&>pI91o z)utz5h~w<%XUM*)hd)R5^NmWRKmVmfe!1TV4vXtEsrX_J&YY4J<&RPOWwQRPo{F@=t8dN3#)<^V04V{32W9atD6 zV(86#qmI2_vIC$8E2wPpnzi$n^Of1>kiA^^pp~=;@7nanWQHl|`MwL+rsD++-}$Hq zmzXMTq8F#@O3^ne*Dt~Bg-N`16#o_cAIf^`XUFufxZIu`M(bd`!v4XkX#|m+DDNmm z>LMy=*rsTWp|pi?)N4k{Ku-jIMfR7D-E;)1-Q(?<=gxQc6D-0{3ph;TKI!y9(T*o}LL-rBl+!BIlX$DO(7&9_5AB3pB+1EWR(C$Oz93WLUcY2(R8 z&uKRXBs)w$x{s?|gC}S3D3f2}>lrEi8HxoYa@J#>`J0|?11M25!gE^0Q-1pFwtt=t z5PCVqPRkD`7(P25SD5}1X@1)5#R)n6T2rQ@AStb7`+L5}bWF~k+YJg7kWV>UH#c2p zw-o1{cDvEZd&2_`kxOTOpbNB}m{ej&I=2@f)7X+3md-7Q8*-5=`uG8<#n!=d*4MuN zOEADA#Xm#vRXY3<1cQxUAQ${nQ(iB;))a{((M2ao%hFbpfKs~pC_3Q1eA+h_2Qvz2 zJ7HHABJ^gv%;tqPE^e9}*(G_g2ha53h6k=p2xA4CK3LRdw7BW7`o^ZZ2L0Y~qW}M) z|C?lgMhCz6px^HJf*@`$sd?nP9c4?b53D>ubbl{3v?;7gQG;9hyqmesJYZZOq4AcF zIx(25Mg|P*x7+MS#G|6-IqYyoie z@Lf%$H0E}^%aG-M&?d%RP&zPzgEXUuuwkHEiH@claX1?e9jk+<)RauIr8i^czPObY zb(r-)?y)l?c~vU5_BaCtyjEjwDj)gqDS&-$=J6!NU8*y$bjgdlUB#ESMh3Fw0I07y zP`93sns(AH{Jv*M{zmlOZS@U}cfZv{r``sUdWZ}SrdSv1GnnCTMmdenhp?J) zZiqW8Nm~pO7@h|m%?JcvFtBx!c2_Aq5mueNtL-Aa32A&ZXc>Ys_?Tf^BI^-=mpOv( zET&gD{?lmt<_QFQ|913!+wv(Izg<%oopQpOQ&}6cJQ=N*o0Lt*1fK8vpocM$6YO** zqioP{XtC4AoA!MGu(hm{0M9tkB07RnIr)MA;x94~LIxW6F1 z9;xnR!#)3@CfI4C)7!1(KAj@t2pt(hGPG>3xd+YuDaPOT#hBf}>w~*f z#{(VD+Hu@mjlg_K^-$}~+|t}x^uIK`|Kb6A8u5OHDdds|`C}8|aSwo?$1h8~l)HRz zix^zy2%tG&i(VLmkwkGgW^i+3FCBVIT43ejWX!0bKkI-Az?_&lgUut>$cN*OtLzuM zNh&n^i$t0?@Fj*fx-1rtn(obnm^X$2Q2Fa62H%VV{FWJcWl=Y7xK}8=*H3;`P0zE6 zhi3@CKI)GV{;&nW_rrHJkKu~yg{>4Ft?-DT8wiv)LZV+xBxW{GwzCz(M0C?!5+QEo zeh(Gp#he?ntg;Z}8QhGObU3hP#K0dBgfN+ReMTTw8dOUYc~V|?)Igr*Pd&N%TDw-B z-dknzg4tK7uc@|FK>a-u@v`(8cW2LKNf#fEXqsWf*k0*lL#5h`HVJtn(L<-@65M3z zAm~1xIPglE(E%w^u zs{XOX{FfQH&Lc*D0{Z(hpWktcZgw~$;^wQGXK0OczSSU^r6rTN+ht5pzA2AkN{2+e z)9Gv|e_*uQqvc?N6F$>jkhE>+SVT5Ppo2_0*T%anPCd{ZZ$->kuF_ZGakp1Xl)b`7 zO&~u_{QbpXe%u29`ti$}pjNZQi5v#q&@+>#l5KO>7uEx+au|(!)1e1cJzxiGvTW;clDV_MwEhz5*9CR>r38VJ1A$decX)2^ zTshy5WrB6TehK6IZvcSHjG#U zKh&hc9$65LhSyRPbKOC=Dv>24jkWtdhMq*dcs+oeHaASvI0?M0=^qvznV^&(ZMP$3 z8H3D}{kYZH^4z?$_IQ~Rt*}22-a+ZYUtb;g%LTu-R;4a>t|bAFb&8P6&V_wzJXvf~rJeOX6JM>C zrmPK-Ikj(hQGT3KTOpWrcAn9w#mZ}Izx7B!2@ZFaKUdarqZwDk@;NK%=TrdJysvZp zeME4-)jbW||5lR(`lK^a=%IwniVZwh#)F;>&4wK7raHDB4tdXkqd-oZ_-3)-XOaZv zIvx^p%ro|ajkh|upl%nAw8F)HI}=Dz=9dSemPY)SN#N&*daNz}eVF>T*FCDf{a6!M zjTPqT8`6(@3x7cvqj(ZE6ce=88?1VViJ{H2A#K_HvA*QltYOBhf;!+W$J6!kB(jD* zdIXMedq6k)TN8_r7O!u^W~~_hKLA%xE4qIlx*oT?$JpcVHIWvs_Wg7_?CI8?$6Dc# z!H8giyB$YKmAIeLIPO~>j*BA?-WcNEi;`$fZF6zM0P{vv7tGX&JE|r&ijefkWg0Wd zDEr7`KgTj|uc&ITA1nGw-`_XA>e0fv$l`whjocU4{XXKj+2@`rZhojq4n}J;XBo9) z%Rqlr!-EAJkN`U zudih;VIPWGLs{xY&G~>Z|bI%P}&gk0#J2SSqc~}_Sl%XVKuVrCx z+ialAOd-)!Zb)Od2n&|RAcP+j(}1J~Q{0@bmsq|RZ^pa4amc>XG=C1~=Y>tb59m+! zyT`zj3u>Yx8lcjuv2N}cc6Ubcy65XJ23@XvwX)5_^Kv0)?%`O`uS*~ zXwtz%tnOOPX(zI9s=?)oNp|BUrqXi(WA>>Kj2cUwb2Vno2i@*yHi5NfAKsaJ-ozTN z-!SQekfs(_iwV^h9w0v;u{7hWns^TylPFusT}L*$1RjIgyZD%2#Y4BVw&?w^WBD*Th6b6G?GUpI zrYmORstZq)rqf;ZJ3EaZPQ0yHixO_$;?eu@GO$>ie(KS|JA3~-8Qc#ze2MVamDYd0 zB&GukoR@`GAH0<$VTR!3Zq@B@j2IL`gxdgR2#f6sSWEQ~;A!PNVX%r9 zGty6^wud`ADqbO?Kb^r0&9pQdQD{BWnpiMa){M#TBB2&9zJ27+eVqWV>*uo8CXByY zoc1Tk;?(ux_lbilnd%!Cs2bq`f~XN0%N%JUFQKS6X{f!N+W896Jb`_J+o)2)wHz;wNPPrb|MWiN;2r<;%*CL2lr}R$%`9e?6 zz-{v$OTf9BP@-LF9V1sWc z2H(__r?XDKi3}567Ic|t&HbJsb#^|jhg!b2r}=)mB8RR$AX=`~_KXypuRRUwC`z%$ z;ll07V=zbEw-&Re0Q#=(G?Kvza!|`G|Aj~C)M4N^g1Fq_8;r}ZY64ko((Yo|ahnN{ zOd;7h(8F$F(-Fr{nu}q>-a2c;+K|}(uwr@*1vS#i02TQD4hq|bYr&~@fDI9hyA6E? zmnPz3#|!McL-ccYbZsT`JZ5>LaQ+pJblv72n%D1Zf)uB+O_+k(Eq%`qT^b}m2t3nT2Wun7lhMhGIDPX$$!c4%YHr5n zd@>yCt4WJ*$=eY~qUiM@pEVc<>$!w^pjl}eiDHYhw9K9nbjy}UW;LbxJY~&~!6e~J z$@GmW^&^S#pI%E;f%IGV%-?~`+bzzRy#1~w8ohinPPWFlYY?f#Ze)5EN_jW6@@=Tf zvgYsC(-0YM(b%Kg!>)zPm@#p-QbNhNr6wWYSnNU`L`}8+gg4Ve0$ zycc7p_F?=*$%Hi->oZFH#khXh0^s`LyPCLWGUJfh^Wk1H*&t$kdZ(-ursyxHsv2r8 zu69&z=jgExV?&W$n$m2{WMHldqZ=AEmc7=b!%cI45R=4Uf%RpCn&O?hO5Wyc)Z{IA7&Yb=u*01m<+HJRlXx>6yBdv;>gZN_Ig1MC+*H2 za)*>RPd1a)4&rBufb<&?o3b(7uV+KPLP||gfAH!4VxYg<4S@gM&oxg+3d(4D!NKl# zMIoTUuxw{8TiS3OjoVN@9-u8t(HDCZ-DXA?R0?;QZA?)u&ZiX}79vO;Lvq9|w>pxm zZEvP{ydih|@^n19m0zk?zZz&ydt#K}diq06K#2%Q z6W~*f{Q^_@K_iX5WdgEH1QbjN3q28sMyp=2VRp;OvTKd3aER_uk;so+F$S--Fg~J2;OW~!mWmpsk++?roui$ zvymS8+}P|Tt-S~zP{r#oi_uW=r6Jt17q%l&p*smh4B4)tB3&tiSuOTkKV9P$Pq=5) zAL>}|FTT2o-|4EqN&wv9FYVMXVQGDC_xkBsbsuj5( zOO{wr%xKx$P4S(h4Wvw!X08t*G&l70$n5Lhtg&i@!?iMFh9WT%qP81gk~;0p9aV?o zH5^Y_nKpEYBSbKFk*&o7uBY(pzTDxPg@#%e}^iT@2cqg~l4T@xc_lVYiVYFsV)2Q{$byzVQF2 z+W1R`a;BT_7t|!XN`l<6ktbNVniM}i|KHXxF;Oy}<3*C$f)}l0`oK*fcp^+4)b=ztf?=XdOY>Mev<3AY zY5xgemafg`>gZo3#uLcO4ZcCKa;MfJ$Hf#{$DG^Ox;Q!UL<`LBH4@N}J)VsVHjVA| z{4nXV9EivCq^ucvT;h9OSTmF54$E_KJmaIG)q+#M)!QOXeQh=knX4s{s?+l;$|R2q z-Hai)w)=lVzJD3$j~iWp|M*iqo&X@oyXfjkb zMQ4!3t9Byk174js;*l*DY&TEl>dqB*hfM0XlvO_Tm4$#XV)q>qeniGMZ}l5#`P(kf zU|OH5?L|{>(~Vxrq`9ugs}L45(bO9b1?o(VTt|A#luuBrH5OB8FQ_}Kx0w2#X^+`) z+6da69g8)x1yq>Ee6i`wBM2E8@6_iX0ko=qJeLOl4idd?Z~^1>t9m3EFN^W0x!5F! zCAM0%NMWAagLo%T#sguX_>fNyGSi0HCD16M9FupRX&KY3Z=m^%B^q;hYz2@+Ow&;! zjDe&q*>`5eKQbAvqREH(>d{O0@V17^{LK<14iex|{wU+u&}CGaT=}tfvRS zq2P>LjKU0C19h$)l3XoZ6rHALRH&#QZrqe!s~XkoVtKlKXRGuBJ??1A&MehD~q0ZqZELg*nHH zNuwq7lMQ2~sJ$Zwao=W&Q0QcnZMuh7J)_Z8rj4o5UYSuJHn1ELD0t&1J8pw#t#_yT z!ucP2iJchpwQ1RpectyjkJEZrUG!$XiWqOX;Kz&O_oG^W!mUo2dZQy;htmEf3b|Dd zZZ@qB+Gk%-(~|s9N|vi!Xfv!J2w^uGtjBo)JZv2U8*9-j#v^)1H?+fu$BiY+HdbvG z!p6kfTw)>JBG82ABHEoFKod8+vxN4;cbw`%8vxGe$s!l%=j?H~T4F=6FMuJI@?oDFYa_6bNMNqUQH{fPYGT+zrVDpN^ufinX zACY@e2INC%5P|&Ta_0YGtR=QZCTR8nI@zM?t4T^6Nk=alCl|$tfUcL;* z7ZiRo6uv2OF8$fx0q{cAC7`#^t6S)6bVLSMR72|`{@OZpYdZ+G z(1gfNC)HXd*luiI#yes+Aq~yir6?g=qe!U{jZoYoy_#MwnEkUV^4fmBh*JMluAe5q zfcW&UlJc9vJ%8@D!Idvt9n<5wJmT^z=ne%`X&nTy*VwO?p~+YIao;wpNBhtdrZcG# z+I9k+$7(j^Rk1Gg9aAZlT^`AyKK9F94LyD^Yic|hZjjz^;4VX2Y`{&gRqCNDrXDpBahgK4s=2<7}zUnRZ? z$m`5GB(MKEfs*(Hlzq-xWBitdzJc`euyLCjx@b`8l-QGvKGXp+57vm~c8yU>@{+Xc ztB2-pv|qa|zFMPqw7M7u^V%lF%+`K9KqZH9!$H3Yl(#IF3q<_qG(~Y_846d_~89_Vsdbs&EQNlkUL2t3FtQjs(jE$Ld~@Lf{okaNTpaj?CMB*Sq=xvO8wH z(pyfWaOgXY(G*+ph0r~p$01M@m$r>Ju41dB<|( z$W-1!U$6t!@vXc|*{e5R47jGupTFdB$xyLe*j}EWf8nk7-wNA^6+gHe@nMei-0}Hg zk6@+3o8epFL_U-X0l?=RjQqY@^8fsj6*1ECpRs#f0Dyzk&g+%^J98q{-b5u7psdGv zZ~MTp@%%OPHz4uybD&tTV*Yyrs({q8tge6lzx*9o$yIFVQ7Gy6x9KkH=fdKje|}}3 zdM;st!3@}W=6}jsWchp`BJ%&f-EcN! zV|%h`4kbegk$o-1r_nT^k1Tr(6a!AsTa)mXDh=$Q2g%wS#C^WE>QA+GrP-^-oylaU z?2?0OT%`jn`oJRa%ZK_%@Y{*bGL|@1PXWkf;5))%1>^vOBh!2jj6Q^fVf%H_-%Wr^icngB?ylBJw% zO+tJkfQxkKkC7_ZGjx~H>BDdzrqXfAFW5RED>{p?(?+cywD(}M4zm1Lek|+-twtGC17jUzz?HY>o{oWZHYc6 zF-nY9JZE(bdEVxo>8>JfW<9=MX-v1VC{F4NkLfx1&f6Sjwhk@ANg7>k2hOl#VXjaI zm-(oAwL9Mt@Qo24ZVtn!`%em#@Kn4zhk7PtFJkm@U@pD^bD+%N2IP4-i0j%#IKH14 z6vj!~zr!?{qx33M3K{IIGX>jrLeNQXLh$BBFASLP8O2Xl0lYqWQqEkKqv_mT>KmVO zkE4O(HuQn}cK%c`(oGr66j8SYC{LDE@zQJy8u`9uwS6)R=PlL) z{bcFzJ_)5`>>1LE&PTJTcQAjj&f7R&1621^gB)bVFpp!*Uo4kK<0dvb?2En-cA`pgKrZ z8S8RH0{+ zZ)m;j18(QdvxR*=U_KrMV!_nmU>r2UYPGqg}*_Lf;2TFO}An0zk%u(E8gM!#i(+~=i}6!v^K(Oht_A(-eu+})=9P- zbaHI$JQ*_OWLBKGD`;Ub#`}$tPVbayb8R64E1Tn4Q^pl*vt2h=+k|z=L;YAm9ryd} zTA-|+92zhDZO6LroP_L6wmvzYo!?O-Tgr$AngiuNqSvD>#S%fL-=xM{=)7H~cyU%d zFP71#r3XMff@$8(l9S}w{c^V2E*_fGS=U$KC<&@RfLk^G=j#NnsfXG84xACeurLKs zIOnt1g)?3Xu@fnQ_Y3AIP2+!LGn~1qc*ze$UOcRvHPIYPZXZeP*|_HqDp*{xS+{ar z#sh;Up>2a4BYi`T6r>hvb zQsKyfTO?PW$Y{{5FOMU|fczsZ`*O)UkiObkIW4QCtxYSKS#6@WpQsup3N7gS$+u>G zwNLAFjHvrZdQ@resD;_v3bPI=2C5%v>blzz=l$_a9JHECd~(?BriV$>t;+mBDgy4w zll6g(pSaInpV=>#+{G9y#=!Snk!PNHx5N$N?|v>vzUolp&289(P__{aIZ~*tWlk7i z>)53Z_GAF%Q!D;TQTZLdY{I$QWue?%gM+LvdNfz}{0v7R-$A@<`7Df&>p=U52TdG1M#Sd z#=%Ab&|1RlbLAjK!km~-hVzuDjK{I!vHN7Zs)|sK3%Wtplx4qLJrIxrqKpvd7&%Vk z8f7T&=6G-wzozw1k21wz|0Cjmz2*%Iug8^RkNH7YTRU{?td@-?n~nxkti|X^vQX@v z%FL_Ns-V<5ow=82?N*4#&BGq<_9xAy!-;{fjQp96hfSX#6+aqP$>Dy}kGg*@fKJZZ zEd28>0CJWN=lG;<2m=2NVt-ub1E_Cd=yD`I+DyDnR(wK@5mKxp>tk#Us+KCH=JY6zLnkqkilxRq zwl%98YR6{A8z^^E-zd@;4_TS8TN`>tLuTZ#@1o9Z)2FUjfm%Pi`oxer zQFDl6_HvkXs5#rF4xNshcBXwhx@*vW1Md?RmZt$hhy`*?GUwi*P_`y;45TkQtH zXCul%Qyw%uytWz1M7tH&SCp!0O_pn>-TFKfb##cVnYAF8>uHUzAq{M|8QVMJ=%>*7QS~p6&#LlV)P98N1>be5RkqcNS=>= zur^;CHXj_=e}RMEuW?TS_s;W@c%KBkF0KZcIaxINdNduh0dwiW!D{_@u(HI2U0U_^ zwwW+H%s`>G?qT6=6V6Mj3T3Uk9BI2XCB+$3Jd$DCnvzmw^9_^!PgL!HI#%(GbhcMo z?@{*`Q_LT!x_3+52H}aR=H$OIvYw=63f@Xu9BOl?@dVDtkE8Q(@B9>Ri1h zA0{IUg-i9DUAMOA`J*ZokxAcO@{Rgxwj@Yw5iGPyZ!9i_@0ex}O!?Xn4j`%NlnV*D zj9F#^xQEWs@V86|oMTPJfd3=0U1sGwe3aN{IkwiVG?Y=Tuh*p^8>HfRE?TrtHzT|~ zpd!fsg&emZghgC#zrd|^mY_tiWaL_2_nkGFaHmmR(5zYrR zy_TIXqIt!r`7@q)VnpAeW1B84M>NUtm|z9Mt zdfL<|F2tQEu8!wJ*ASZyS6= zC#DGxu?2q4?NlAxqle09RwOT;K<&{KD<-%<62Yh4WUsB z)tPF#lp0{Btg{K-*zonEI@ITy<ckTnEnT*Vjtu`|b%iM+IIIwGVA zu1toDh9@uNsfG{wgQG_@`6QhuB%5f_n4a<*%?KyeMs2`is@7c!31sRu+5K#Ar0y;x z-j0c%#b-W`9(?_lM6p?UciE|!kG?5-F7sw6xcpsCyhP0)6sOT8d-K&MJf*njU?C9P^5gd)HGxeBc9n zJjp|l921fn&v$)ts3O0iw#WN)@3TYmf|Q)H--8hSeM<}}4Z?gr0ABuIxJv?4d;zkvS%RRw6sa96)fUpCR|9SLOUxL@ZjpYl_*%+%I0lq)eU zw?cX*b%;(U-Gqp`;SZeG(nqMobsNWSo0!z0_XGuwuKB?wkJFyk=vBFXf4FHa2%;(+ ztAnW9YmI}+O1xE7Dvg%Y)-P$6kgf#K$OLsUD9_^x;h4R7f_r&#&f%6#dIe(k4}c&{ z_9+CLsLCn!j!Dq|mRYR&N~cARI+jZf#3QfIg8ih@?n`ZvBV!-2!mtt#_pEFLgZ5-; zjaodhpqE{CID(YvWqr1z$O*OXUd_OF5X>QRO4R!2*AA{}sHTwJ;wu0I+`&l8(s0Vwd__}4-4eqsQ~ z`ybx&Nk65H*?zT83E*qgouIJ^tIp93s#RaVsx zZ-Jmf;>nvXL)J7Xh)9Cu{!B}N?1HNUS(>*k-+#`(jy204hxjNvk+W*mHdLGw18?*P3vz#f;vD{)tcn7DLcniQ0 zD#&j@!k{HW$hprDfASm%<{KDAx_!Fo{-d1pyfPWKIV zFcCE_a(DaLvNdY9ri*5m-M1Z*>O14zY+>6YJi>4V>C0GG||Mk++dn3}sgu#0&^9}aZFcSP;DPM~z4 zr3`zBMvZn>Bj|dI>XH;zbyJnRR2;ZUd{?9HCdzYl_^BLt838>5_b~!mOkz(4KMOG5 z$m;RM^YjoR4~4@yRDLCiOPUJ-6%tC3)afExhCQeVaaV!iXLZq)Iv$rRAfU$~<>*F= zEOkAlYZd#r_5BGkS8HLDsf2VR*hdv)kgZAQscj%dkQ<)c5aw$hQpIq}hv;8A#|3LXXKo~ktg}U@6LLK7F*;1@$&dYz* zLObc17YjZ`>iw?Dp|vuoI|F@k@H=kg)_Xc(}%Sz)7neJB`65!Dl@S=9hRYN z{U9XZIvFWL*3{Jf@lc^hGi1i4+bOR!6U!O8Knqv<_{(O&UqS21Fux=gy=U(eGu*@N zA{a36Hk9IUIfb(-(84J-^Dh&_`^5?f;r)PeM1TlUlvtz6{D{=K;lAFOSN0ywGDAKc zQC+!djyZX{$DHA)wp?hvNa0$c;df$)S0$E~E~_kwA@dkjXUTRrA%e!tkJjHOf^zcx zJs#hG_8Eu7*@y8VpZEOkmBk>kp54XFd=7z|-Q-k#$9js%??nPityzH3!o8jF`dI-g z1DS;VbjrkLw@WJ`*~8i0avk;dgjG%S#Mx`J6}1~yp@%@gblh<|WwBi?>QVd6aOBSi z6>7zrB0e-Ky^v(draA2;;nh+4W#%r%>l3T)tbPl>{;TNCiYA>sihtXZyI-mRnfH&& z@uuk`(5lZSjj1edq}su+P38V#i_?t9HM)AGU!#xcpgK&LW6wGcsl`N@(jMxzQ!Z(& zt0Q`hQ+#)C4kIR5_U5!ms8ERg>(w2Mvps6fYaRQ?QuzFN8f zwXcSkV^;(vHX`HhJ3d>-2Vg@bDD71aI6h`r4DB9w)7=^sCX<0YAcdIYO_Uwf(x}Y~ zzF(hj+$~(b4FypZWTTI!%3No<4dka${hD200pW~#q*m5+wxi6gvjg{z00Af|^YmPb zvpki}KVx#eSh)c6FGiQ+@nm+G9S<92==CMlb&u_?Z6R<&ueRsr#&SJJkHlPIw;O+y zFe8mIp?l@FF<#nEMU)%kSnTbH9%QkmO{@Yn0yhSnr0fVoyyd7DJ z5B5}`Wd5C36?lFM*$?X#qWEDp5eK;M+dFC6XIKO?w5E?9ukkAunyX`|ci&v0Kg2g(LNm<_T+c|B@d8*SQlog$ zB0|d(>N2}V}Zp0MPiLsu=^gEk~=?(a$Z65j!tX5m~ z4$~;%18B2NAJ&JV(WycaSsjaD6?_N_{~D zXy?e!PXj;0?+>dL(8I%savW|)VGtW(cMt{>8}r@XAmk=1G&mybgsa%wG7 z^~rR!I?Bv`IFD*md}?T2x4!KSI^06k=I&wZ@WH_u&13Pdqxo0e@qfktR*J(f(92j5 zJmqN~(aS9dpo_ohUVXms3mkvkWjS<{^E5a#>8TXP3rJhu`Tkvg>F?yE1RCUEN1{sFJbch8ncAH>yh49IU~hL&tsIfxH_U znlbfLbA=x#yVO`iQw6O*v=)C*lC=OA#5u$DnNR)v^`Z{-HnU=$1)@81%l|n7PAhx> z`|0N#*ms$Og}_eig-x5i3RIf5pkUO&?NK=7%GUyazQlq)RkgZChqW;#b=w?-LXHXFaM7M_Lk{u(X{7yN*d!cnC# z!>l1USXes^2^ol#sAyg5*khC4WD)eY7L_(;y`vrB+zwrK_&8G1L`0#SdZ$BS$CW$-)<~FqvRLTFkJMfhbIVJLcqOecd3t5~k%TsdldqM?R`F2OH_mxp9}EyU|5&{^HAv}DTa;D-OB_{bqxLWi6I0N#yfJ-xC(+Qqc^ zN^`VARAlQsLqhf}13xVI3HUdjYE{ z+ntLs2F(cF4zlzD#fhm=!Yy5UFm6`jQKe(LO;O#|^ltNKlTkklKc3aaL(sZ_6@Erp z+^_Qi{`U_{i6e88@_ia0ZI+Ey+W-H9d~{ShGTd&R0@Y6zGA&_#}?*M$@s2^ykf0aCElu zG+0%!%6uLip>tLjX^KKEgu+|@6^3~o0WLt;&+yNSWj~W9ofMEiO|gK ztpuVn0{}tvbjGX>8 zp82@i2aJ3iQi?;?j>qWx-c}^jdWx6RhZ}*;)PHqEq)#+hWJc z&j_;O6+a^8SvVPX@riNPSh3w2DHIqqwGGS+XW!FNfDv8jm`g}j;oz+4!d5K%q{~O}#2CA3Q;Gf3JhfwebTDb*+ zKgY(%8IhFVN0_$RVGpa?sx>jzJX)0#EH=en*Qd23AzI6z-P;)SToUI{%&s8~hLI?< zzHyi*QBQ`VLAAJ=K(j}2rnUFRj|#7n%H(B;ra*@Mkkjk=vLATn`Or+yeC`CRB`ez{ z<-@RvZkNOE3T^KAe7L!$#_uYVL(IZR6&DnrM8GnH6@gxaiud$BzGAp||F^#Lmn&=cc@e% zcO2tO#Md@zq9BL%Y`L3TOAMJ%vAc|Ym)ILV*OB8MXES)!ljjUnFc~)39zLaww$L}k zMQgOM<$86KQrx^x|5yBxd4)5{*WG7WxJJnS$Txgj<|6{KvfTL>49aTd`VvEAlWu zo+>WiY3nkM52N`cb{7*BUG`R*bHs+Ln!2V&jv1`B-D4nN6R)GFO`PDj!+o{ajcVEo zavb&}TJM;PmUY)d{;RnP1zyNceJi(oGsu~ClD~by^XYOoTs$384ksi>uF3gQQICG+ za2zpWcYR0{s$bban(%N)MM6l@a?F#n9U>)7zJb9V{7%SE47Sa#amvQ0iMKDAbZ=iT^06=MLr{RxHHKhf(E_)0$IwvK^1?g~syDDx!uni_?*g zWq4lSLAw(xJcjfx*1{>zbycs{@yIGUu8i#MWW!DTRBkKAj<5R(x053kC+E&u_`cqF z-&z1<|MzZ5=029kJGo`9*}l?GHukaK1uDAzXtK!zwjs zC%qI~)R1U1aIn$5U0*G|qp|Z_gK6*3Y&lXmCM(MWL5Sg|c3jKdlpT_QCQ+-zP&>is zS>Gu)`~0v9vhzvt*)!^H0Lo*)FB3v)EIICkR) zQ)b^8j0LH+54n{gV_IiNDX6jD)1An!r_OH2k%I#a#VlPw%U;-*m#0;V+6EKPnT=bVR|-a(EYc>!D>UJ_r z7UU+_8|-vvtSB#R%m(g^-mVyOV1}Nzai^3qbS6lbJ=)e`*-f{2XR!^c+fLN~(ID9u z66seoG$(##`$cuLS(+%PdUz#QPEm=!tHt^;bgVO2{xo(==@+J$ii^# zh0sH2aFnsiZju;$TT44KPFK+oG1ksfj#Ws6YsWN10oOO8}1)heh&5cFzZhZ2aEe#9H{fiez0suA6pSRJVX zEg-`U6#iKS;x2AEHa%&u$%@}spfQnUM8t$8YOXoNsSrybZ|2*XOJby(&;dKUy(jo- z(S8574^87AZ?3*Hq+e%{-{7x8QC~-Ws@Kllo&Qv?omMGA>gmY|hr}llos?1+b9)~J z2ETD?24eM>p1zUwW=)8SNzq#oyD)`VHPL1h!R2r+e(_`p>oKUp^M zINi+#2dM*f8UI_}pGWh!D0J{+cE!8J3ef;Py|X;HyeLdL>Bq-|wlimi;S5h#{i9?L zX~%Cm96k_$JBiw)JNo1Hy659JwUA~@3^==IDz*u6#~`@(Rrp3C#*Xi(YBnqHNh z?fpOS#eL`2?>n%3dK!3k(kSQXF?Fcicse2cRa9TrDZ=vQSvdp`=vkMWI}6qZkAOeG zvlN_WeLySQ2$gqHL-!A}{f6`>`^5sUudIEMohB9+(Z%Bf6 zu`TwUuE{UuTv>;~$1biHU_6z5Kjd_MzH$+Yo{ui4=RA%^^xe2Ot$UTKh7ksVhs%Ap zR%{l%d<+prSM}Aep_kS*DB0Je?n)3*TQT zu2GI>PA=TwO|ay@j-|X8Xueb-T5gZa;equ9Tv!LzBAD8Hraln%9N{m7aVM=*>>h)~ z^$qm82n?LZ^m(68MgI>_Z6f+xEuU8GhCK zCr8C84tB2E{rUZzJhpN6hl_#;Vb!xpe8};)9a+hxDGEs%uhX%w8+yCo8sxa;*!$;4 zf}di`Ge$4#y~6rsOgYrg)EI>Vfx6+wmLjib!!9QtCSKZH`_(4EI&KZC-#1f!9QE&;I=<^qchjL)WA(2Q zN{|N7F6RZI{E)ZoLYSBJUJ=S=OgRO6+*DWGKoq^unM1Wf2bH=DB^lQtXvvw|UToLK zqp3>Tp{O3F@m{r3Uk)j1+LD808YH_dB@)Yiecv@YqrQv;tQK&!?|Wt*+RYc>@;&BX z5Y`ia>N5+fFveE00nA^cujoIgbYQ7hR0WUANgi2JG|HzAD`hRsy-8@ym(?S|o9(e3 zcQIye_q9n-XVP#!MHm|i`tx)rO72EnF+Is_dDFejS4c@UQav<*yS{I%7e2pG&w`_-I>3yB88msPR_k9cFzv)c0 zmEDbk3oMz9o6T z`ru`v$*!t7h7ooj?TQx?gnrF| z3$|N=+K#zlxYU|f)plyf>2S$w^mO93o7v;14 zTJdyFR!mtsV#$JAtlM)xb-a2{YSvPvX*HK!oKI>tg_47{$CwSjIgt?@B35&`3EBA$ z#hBbK>^C~2!|JG7-!}-Kamd;JzyG`|O!8w$?KhJ3)GB8NLg`J#kHHd59RF_>O1o|^ zEA)A{S~1q{N0dXHv#w%H$~dWe?C)uRfplb$cB5@&9S>NBUMI<+?^gX4Ut7_gQogoq))hDS2yz1Imi*zkf7*hPZMF33gC!eka(aa$J7MLMU3Z z2suUL%ArWcx?jgXsRe~GP^0**UJG!gqdVYafX3{zR}B12y^ zxsB&mn@+7JYdAXJ*wG*;$u;K( zYO0LWy@zPlcWMm3j5C!r<1QV%-!4|w-{z?g3l<^e!=MvpK1&(q2x-cz3j);^%F*3S z^_2j5d>wIT_O;P&782_|PH|X+Mc2HwCPD86P?IlFal>ljNsI>@Y296RpbRu~n8G!T zaM#tCpXao4Op;vsYy8tPmsj14?3Jt|nRkVx)%(iq+ckdOU8j-Aac% z;%H1#G2`{gcC-PHXv#*TCG<=%g1Xbu8Z``Y7bJ?0vEz#NgjHLiI!R!eT15S{!YLb% zyIe>UTV|+WNkZ`cJySv!iGD26r=_;_aJu z`*q?BN7sLp(^5^`4XYlBOU$6p2f-#x)&0th2bCGMoh^1VaTL$VL%%{-TUwY@1B_QC zbVarkxyshbRj41@O@}}9&f6-Eb~;%;a+yW4}PAf{lg~7W#=#5ocA{2;}@PcoOu)TwzLmb ziQnC6yy}a>Z@x}(D)4#sPoD0>eCf^mx}Ud=Uo#Ret-&7}PrgrLDgRz!HO1TOpTXUz)mcwegimz?9GL$7mOH23TG&&69Fxbq_Bu0_JHlJU&e z=hvQb&b{$(x1jc&%~s z<-NPRd$-q~sJh$d$?tB7-Cq3kE1%q5y3O$E($|YRXH-0zvS)#P+iS_o4IkdSb6l3i z`tzjqFMQx7&+?S)U6xQUZ(UM!zp>yYY4i5#r|7(_ddd+jyVqAaU$@0SrG#4!(idJj zi|k8wPT4KrQZjC9eM)&()8r#5efn{kHFFELm)&M|Mtv9ZE&F0o`0w_mpYHbB;PJfP zr-XAKJ^8{qAN=>XcRyY7(eGV$s~1D_=B+CW)XSTnS*9n?!kL%yFM>G#rA5S5x#b?m zg71Bo`0F}ms_JkvTylJ6AE4*i>c5f8?S@yw>*wM4Z}j!>N9wG>1&8Yj+0t+O0Je~M z9`Y&czfmxeFLMTp73aBezy95T7oX)bJc8vzCfyyBzIrk9-P||t&PAT(Gk~T9)=5rUM1B%sbZHx^H&o5pd%m35M+$;@vVEpy?d$z zQK+9Qg`mG{Kyt;N+7qhY`P)BG!u(xJH+;KNViPGu|u>Q$HInc zhkq^0=zZ?wmpyYg1M3E+n{;~OcK0K=SZ`&QqKZ*?7UEw-;dxd--1)C^9$M4z)?Fz! z=>_h`)LxGomDy%mL3(SS>dzf?JcR;W6nI~uULH5tPBq2#f^B;>fOOcnA~c{QODd2n zxI8^VMy(Onj)&dWEsp3bkBy)1q~_ZV62JZp(xwi)R!IIAjrSB}XWjfokX@z)m|gxX zN8>}M%O6>#l4$K~7z$+nePLXr-$`<~{vXA8tC_6WxQf6MQg-o21~Y_Cf~&U%{OvN%V40uhJCct&e zuXTN)=+(uO{y=Y!pZY*=*T=E~VUC;*vAkf`nTns4(#ju0_a;}dWyO~63T6ERzn-Sb z#p^%+{K`lS${A#nV_<5XJIBBS(5j9J$)VYkT^PE-|5U3WpY$N~)8DoW_X&SHzE;iW z0}{>u`<72}GmBsv==P^*z8sU?(@A>f2yr3&0aO`OeQ;Jmq0BXZ0#w%>ADj)h;UKai}l#3&QoE;vo$FBo${eIhJd+P5#;59 zip2n7DWQ*Eh3Gp7oj$o(uw{jS0dGI4igOarL|Qg?IeEq>%($hYOgyy0sz0Juvvzwo zSg9&w*}A#L9Hkb_m8Q;4`-5KKxqd|V`?9a@u_@AFm{4QF&JuH2LEY}VY-g@b@h1Nb zd3F{=H$zAV?h18PFH|9+^QH-{kw z<^{Olt@4&nd85TbUajpmGlFYlT@gRV+cqW~WTxLsC}FlYwnutD(`aUE zw<;kTYE>TwW_?wY=e=Mysp36aJygbGhYLEci)x`Qf_clodC+?!ZA{C^&&9Av0wS0-@o(6Cl&G00zE6L?1Th0f|P`>TzG@%9BP001)zmebMh4tX1 zdwv|5P^Kn_5dufrbGy##<7;IHxQteV9HaAIgngER@++&Ues!S0Z*SnUwuJDs`)o5; zPsqbp-+p)G^bLHD7xNWfA#a}`33e=8X1m+Fv{Mvcch0*8Aint$v~RoY4i4)VoFWa_ z_I0%nz`Z^>Lp7ffMSwq$iv{uP0`Sauc(Zg_HkCv;lNC6FZVj0>?8f4{zZE()Sx$Ei@GdKYmEC?u+e*xn=%7OM{SNK{FH1lSL!41gy=c8)Y)$bQj zBzVj&6P^I0gwpQ(tns^fc?J$NX$O=b8JACM06E?sLvM4*F&+Q1(Yx({W;#GcH88o%e&ZNG@WDR03JyumSoDK|a*-q1p~U4b8~$FdUhAkXFjO6E9ac$i1?C`&x7t5lK@h?0{i^< zBYR#cw^&+Tk#c@~FRj4gdZDemr*G;z^1IIedi!_#eiSIW`X(xG8dOrup$;s2`>c=O zbJGP&!~dZl~~N`fXr zcC30z{g)w6Ip8{33H>Wr9uy)Kb8KaX&?6z=)6kv9JJV2dVgdphOW(*Vg==1ha8%wz zC#)*InMtuTHQXtm_X~qOy{`O}yk1MF0L0}@mfp=*UUpqg@qd0@zbpgEgP4NDvS5pm zxeuzQBgk)dDrJVOs%MA!4`@3T!@eM^)amJpe1T8w*VSI>bLQaa#??vM ztxsy3sIRW4YMnf_xkKP-;_U2^t3NnyWKuEIj%O8C z0 zbA1AX8QU^goJvOWs45-?exrj7uvJj=E!6Jot;um;-QsI>I5YgM(-?Sh2Q%d@+%UmI zy4IIUB9$%d$kItkbOCsNWZp7rYc@KdPCxZWT(Ph$3Fi+wR z44gYk%`Dclsrq)2%m02qWp33zc@~&LaIzCYqr$WggnR~cZioLU>U<@~8$@7_~%#tbO%1N+{07w z@%exgKJ&sILtqZ_Zl2C`4PX|&9N2;jsWe5TlJD~g zQ|Hglj>nV1TmZ@>vuX-=X6X`Wx2w^U$(!pj9o!~in4Ucl1z+XsmM>&=uYZB!ypvOp zawg}qe||xDKzH9V^2}e!+z7=o=q{cEBY#j7-AxP<>F!_U1QQ~vSWRN+1!at&jy6u< zb8>J*cp>fX`%d4B!=SdNHqzVR{bRZP|O7whDXq@=TIUCt$3M$eMCx^)oqa}C3WEeSlV@hcW^C%G=cPVlX zg~{HcwybD~H|@^$?RlSdJM0=9GwUv9L4BNnpUIZxDns(fK?PV2=~IRuFq4`pHtmr= zBsIM?N920a{)%e9LZUP`KZj>7pfWM}lf-@kW+pbW0Mi+^`9I5%dlHK}IbQnx;n=QE z%r4(ZXml43m{7)sOB0<ZEy~J3|-KBooSx1N~N**(<^|+a|QIJ6(n43=bIG?0DB}|p{ zz(|9GfFK?_>AI`QSOKLv2qzw8Z8kF-S#FM1{D6GJKD|?4Il|tn{eNYkJv05&#~;om zMWDa8bAJ%{*J%O#*T2glU>LR1W?~#>+tp-QT{SfFFgkX69eli6A4s|@wc4YATe~=; zk64OA5e$ku#_I*ub<*R0>262rDsgKB?}0-C?#?cl)^YzXkOmOT0%%VU2;xKZG>32= zGrb()PVm2-g&&o~>G@wiA?$r!)|5ms%`8vo6fSiymr?S(+ndMj$!X%*dBHKwEO2rc zGtOb~F7Wc?>;PTf^0DCbzW7A``StQdaq)yeK^XBq68>O!z8j|7U~fWL_!_~ubNRd* zcp|=hNAIlIcY|&*-^+pL&fdL_JWX{P0e+<0*Oiu&kFxMyPC_X*qtJ$bVQ)iZ%2aGE zJRSQp>;CE@Ei}i^>%pyXCEb75GXBYZ7LG}Cx7D)Tc+np z0UPJP%8C7|SzYmg99D()TH6P^F+ZhKI;;;?@+Ng7JVkjM^`}!LvKzMH4QzrNuaDY* z*{tbw6U_N;N<-7Boi!RV19=!5HA4GZI|#6q;Bubs=P62}lhyjj93v>evd|{INeviT ztUJ#p*4MnDw|O%d-ZEiw69B!Db0INHD`I@8w-qiNiiGa6ecM|l)d6%b=`j4XF8TcS zxN&4|U>w%=Tv`uxw<8~rVP{l>6x?7qbRsB1(QnqRql(4aVJ`H^HuF^xi}&W}>e~R&v|;ZsJTY+-_0 z83&uADzrxtn>|lxlgL>aMu!|UIm83Q!z6+pq_2;msz-}sD{VvSjgsBkNxfOroA#8= zrj}Oq!yeMIbZYKW>;B|RMri&OpIVr&9YGfz{?W2}r|=<9QO1#TCoAvlW&bm9L!S zk9J`pp6=ogKZ&Btv>A3Tf0si{gv$$D)+-J@XzWyJJni=uE!A2c=()ciRbpFUYlg9M z5|WXtOmkIb4&IEJ9;>SriZ8cQ!aXW2lHIEdcN#U?-6-MM@02FJPjtLXaXKH|p0U*n z`!+Kb?seO{+mshZ%!we&sk++fPfuVrWCTNQ(pCNEuVxvC*Ce1k%lKScLl7Z9CbRi% zO;_`j`#h8EI`+>;HGriAU-_b43C-3LuL!%LamK<1lj$ zmea}Se~p9x$Bri#2i8wYu8gxYsg?b=oWz=^dp%{ATYq${N|mF@&{M>tWzlsa6(d1D_UKTho!R&ZfCU* z&Zd)d=OSZ1QTAtN?{)Nhug0AP{>&?U{yl|mGAFwoa;_mS?BW`G6ljlX>E^V8{L?JM z|Ln5*faEL-<}4=5pPve62YlbHm8aJrpB$rt*}5YHv{6|SCcmMSMuR`hyHg4@&+3T9 z9D^g!xS`%pDjjp-F1eZ5M2Kb+jr(;s<#3nVxeYU(F-`8E4Z7>~+M2GLU$Y->pOV!u zgfcmK&fh76`6}1%Pg^Hl@zfJ=mrHo3#@>4xJ|H3UbDbCa4ifHW2PEA6>n)%76C}{6 z1!|xk3UY-}cOfnfz2=x(OL8QS7JO&5S!zkc9n;fkpId}mbKl_j$)@F2TD!;_TfE$! zqHBD|`eP{~q!ml3DM}O}0ciAm1?3Jh_fY=;mn@_1%ZK{{i~>}y>*Q&ApPlaywh<`N zq}63=T8N6!pC#T+Yi^TZjAjGf*jqV>j`XUA5EG||aC?O7%wm`GgeDZ+UkDZ+w|YX* zYOhFd-Qt*$O*08o9wxata!+CfkO6LBS_k@_=c4qm**?ienn6`S>=22QlnuB{1exKkDkpzrxSVCQvu zyQ>7yH%!0^ZzC7d&ZFbw1C%mb@tjig9U#4%A3*f(-?`uOv%=-zA~M59C`*LMYOPR| zEIFJEP2FEP3yTtQ1=Ttv#@a?g@#KEc=(PGv#pyw>+&$0Yycc<@5IaoBBzg~HNwl#Y zjiRq)Q_G z5QXMwks62jWYDIz(VP*sEnD0}hG_!pT+{!d z7HvLBex^FRXxqGWO*(=_Kac_ZmV(8D;T zNVWZbu8)7vuHRKXz0k9dMNmIJ^1gfy@aVbZ3RLg;Nq3IDyeGla9UPjw<;H5eo;um3 z&<7$NNUPPf(udtvv}{cWYTlaJp*oWte{IUxWZfd#%6PXxyIi{~3&#>#8yx(>R2M8R zrnlGwDEia3`}2>=h#}6JM)jc273CNAsTuIc8>R%Vw&N1=;a?|g_uxmrwaXt!0_$qZ zumx-1?VC!2Hr^jNslyGYoIdJW+9VE)!#L>n*M|{36Q#{4j{Rt8kiL!VsJ$blNq)lp z$*NB$$ia@3>}a2`89g5J^tiQ|B)iE&qSy;gT?T5WO(wy^RN?0H^4T>s@aN^HO&VOi zb>Dq@O0H#0=epj;GyUqYxc=b9-Uj=>z83uD=57c!Vq2#=oN3&-54z~p_4GDyFnl_K z9F|F(8(EnM@}M7|#!NKJN`tJ{Xp8N#v_oEKhMbuU>vgrl0ABsID z>UIXIvjLmosQ-Dyt`ljx@P zpHIdA5v>11f^{iq_)kh!O%g<_F+v*wy>F?P8_FR%MF*P-tUWe}fk=21i?ve7(wz9M z^`xTImG8#~X!D&G%eJrBg3Nc^NL#guuqth8B#)DP#7IlFhbzdWnn#cvh~8bF&lTGB z&f#Gf-8I^OTHEPi=sM?;0Z974>8dlN&)0@NSU>*)C#SJ}YDe{UUw>7Ibr7mX7x-3# z-UjhPg+7kz$2R1dU~_!c(*su*rgmTNPgJOq$DGTH#cF}EfG~EFkaEou6sz?{o>OS5 z(chT#oTjpMG7ZoW+2sUf(VOLx8Ic{_o=^8vB+hiG0!NCm-V%iqxy|zpv zbN;wn;gHRqtgYR0W!t;sn%L+<)f(z|MU*N%F~Z` z+w}+ke-yyWjqQI_{NCLa{p4in7Npcmjd;nAgWaGFz32sxI+1p-*a`v80Se7=wA19l zb`TUDdq6S>I>88Yw3X9F=O3oH@+)etZ zO&+7J1}&aBzidHwGi}gW5XX!_77$Z4V{I-cF7(Bk%G=dlobKR&V7FYi)1^M<437UY z6Sf97`fUo@we03Xwy{@yA4=!J=>uxt@S$+0`nVsUxuR~{-Nnqyok|}$I^$A2#*uy} zSYhMd%JuPzw&dKATX_<4eW9SlBTkrNzg?ldbi|(qi?mH767&}x3a|KZc7C5vw0haz z&f((P2&^Me?w$`P`r7Pfsj3CBknao!cE%TbVkO)-{$3EDDA$~9K*!)IAdNus z8$L={TGFVfxqWt`s55MLECrz_PXJV{ciNN#Z7}Szrnr{|;gk@D_Hi%L8+k&ggMqV| zqqvFZ#lc$jFnr!0Mxu6LGQYaSA1=G_6apd}pnE~;b^Qt$^)&g~5BY7t>jT+ZAJycW z`?2q$UQ%}8kP2^)u`p{%Wq;M$r&Y2`GpW^{3B96wA{enitW>ovIiLmC7WaHF3Fn5q z!!sDV2c@O2zivRru}#BnL(6J5aGYkg?ZQH z>v$6^_tz?Tp;cn$O)GzK#C1$+Q7b1h(rplSPyIH>5{@e!3T4zfrNuhKx^1{X?RxmB zy}_eH7m39ql|`A@3Q z&Rov@iFIrZxbdz%NxVKfn5|43x}3MENjsh-D(=lXvli8xb~gJq6pXb_MLX?=-lR>K zPHZ1mSV#a976w4^7x;UlJ&*~4SsD-J zcZ%tUqwjt;`fJ+FtI^{vD()a7juHRnh*XC?}^Vwf3;g)jowfSPaBfFlISYG z?76NEzNH|`cwxnWIF7c1j>zO`GN2sQo{ct>MYcGI%l;Ji2iwd^Wqyu&LSSbZIdAXe zC@?GPJ#5bByl>ozJE+wQ6$cn^=aBMCsgDqu8&@ITG0Bx0(8%-%QPPz|;H9DW^~DbG z(!+d3OlCZHQpJpA3O(R9agiiT+2xQ^(%xWIIcG9!JsgbZhL1x|)9tSCCy8i{*^O#m zYG_W}AZXrdg`cv;n%L08u5V`FB*p&gU!UJ)Wh*Imiyy^>2@c&6uXFJM#Cr@U`Zhy7HSUt8_Zx{0J>^-;2rT2 zT^tb}^J6-VCu)IuJUI_KC(2(Y?=;rW*0!0|!{U9#(uehV!O>ed_s1snJC0t7-x+#+ z2l)9ep88S`sTIwQ41Y_w6AK@P2paEsxwUus7<|3edeIu}eGK&CT--$JoEI1Kt=AhM zge}PfMW1+HZ^V`CJhHUiu;U5)WZ7Ny{supPxmUhq_g&Usup1IwuP5T)Qc4iLtaD82 zON#6Ed+6&>@AIz(*j-l#HFnwwKwvq&9)soWGR;DJ-EsE0vD;1nk>E%>>* zLr-2yyXd%v9zt3vvFNa@=ujSUEps1?XRNf~ieD-IXYEs4CdQG#F`|9&$l8>d(O(8EG~` zOGF=AZuVkIosfdVeut%T-X)hSs!x^P{rG#DB4j507k2Ht^2+`Y=xNdQY`2*9w1Swm z5M)EL9g;G`WlFjd$q(F48rbRDvLr-jd$CP1wz4W`_NtgJc*;j`8mHw^q0Dgw((Ve> zFQ`|pJ*>^u%{ZUD@8D*i2HqTzS0R5jaFx(xvD3~ti66T8q~%sNwTnrra@NJMo9%>- zIVYx&4evy3r8+3AB%$(?emrzn#&EwFT2Ve%k&d=?#_38NL`$>t-t7BMiJlh+e1`zC z*j}Am->lpHmrt{Y_80$!U2@7^il)9dc4gKbZ9>+H=;2Z>Hra8Ptjlh<%ScDVb~wzO zV1dzY^?i}(ESBZeT?NHN+zRu}Vm{w?j0M&8@v=QsN+zcdYl?fdY@fywek7VVT-2u- zKA;D`oM7oK2NZ9c3!&$?+0~ZbhNf+SsIE3XXUv)5bc2WEbctBSW^Y1h>*G2I~Z!mjee5i9I`>vzInu5&`rBg}ZX zTWfNPxIw2o=87S*XYIW?Trymk&1iBRvDStR=L0!fqyqzKRboN+rtIHf^Ia3X=kIG? zK>;J6%ipbuPmJC7C3LU2b4^SArB(Jo7%YT`zaaGwnmvAF9H_y_9s7!c6n-}%#SLwC zZPs%q-R%Nl6{FvoP;}pQWpD56C9~`L8l=($3(ICi0h2O340k`^4{?-{9Uz@iTI+xqq zX?N5eK^msF>|id@DVZTN&c~cv6;e8hJmw^6RSPM5>!UbOrA~+}XSp!Q#!#NoE7U5> z!Z7Zf;A&`AQHJr-pZI7Ky&LikDCmh-bv44TL(h%T_2K~^Idy(4ltaBs@_l(mM;>o& z`!jPr;=-M&QqyS1^r0GvM=U~&J5+aZG>-a_af+q3!nzY>EiN2%hV*tM&qS5W=3|vt z6e$`FS>ISI)6*#V9YV_2LiX9oedEHt)bJ&bujc3Pe5{Yu9~pdkV8h+-cDauEeT7X& zEia=Z^5m!E9;nb!&_>G6UeBdfR7d?cF-KT#n;%+^mof`$vYVgsj>PG7))zNWQPYR+ zW~b$`h+3<(_0aS22iHX}xO)@I&v^U3YsM2>>nIWEimO%mGidqqI36eiOCSD%7(q?+ zn@ycdX$JLY)9xzi#zuvlN-xjz!MYtK&U7ugqA|hxtIcYxLcPXU1_< zwgiJ-2hjRd;k#x?l8VDp%g}*@hXK+tsx;RQ9$U)Dj8WP>6qWnlqUZ-b{FTUGxAPOS z`FZEwt>4${d+l!Wf?c-;Lce8KL$hXA^8(lfl)hmXx|}AAvtMz8?0D2SOkQLi)5vqQ zJla!3UX1aVMwOox;B3Rt@~a_8Q_>~GBY+)U^?@8%(3Awo;EZzj(OM;pTN2ZLRX%QhwN?6K;Kt)4qg{q5$U zGy7tjj8_v;AyR`}E8?N+j%V{Vi+23IU}J?+Ia97(M1Ujb<^B@KgavZfoX-g`Pd?4X zkE}B%-uCM0+@k7i7&e>iyd__wB0m18Vd(o>x|+)6h;FLUesoCRXaX~DuRq#3pJYQX z1eYG2#+%g|ngK75i(xiUCT!N9g#0RMZC6NQ%pJuz99jdZ!WKi!-psnmAj2$Wvl$;m zdEblqTu(UM7%9Btv|`lOZt?qO4j(iVyr(8*pu4wj1CUa5EuQ)74`fMcP5|u$0Kmpj z&%F{JQUIX->`#3tH9*nlnyJP`JR?P4iqoD-)b6_Q4LWpvnlD+OYJbnTZ#K%6^i`&> ze}e|B*Y#`1XPd82#%5liTi0C7N|kqWa?fhzdY!xux z0+$1S5AegDOp?@TCGs3O--J{VTQV3|cd@>koX>mw^s*Yd_SUX9(7&^dg76eIJb;#e z4V7=EF0S)|9<@qDPp9w=BFu8Q&f!DWUIMD~Y9@ zc{<6<4(G&)&2@Me?%y+W1Bj6iFa|%^(J#+N2r-^c=eDjdRo^xE^*iQVsRDzpFB`S@ zonvfDc@|~!-SQM^XeCUF)<8}3GEb>;%=p#Dapv@(XNgesdD@LvTTaOszPBE=>E4De ziUTc9N1UXzs&OdI12XgbvSz;uJbaXoCQkOm00L~FOVRI3|CHm^Hb-cuxbb)1Iy?_bP13vUV~~7-E$$lXl73{j6*a4l%LL{b;f|a`Zr>@>VZj zrxw@CsQ{94igCL314|x8){;oFLEsZ>HAg0j9WsMaAelcJ_=hO%i-Fe-tFG$l)zE{1 zEAYc^-czjpe(J_-+R`$lTTIvJmN{+^rrbl_gEo=oxf?NjLGp+odxzel*QbZ1Lk6Q_ zowxGSXy&vT#G6U3-QE2SoAcr{K<4#_kan#lzX(7>&`5Vb*Uq&n`Frl`17X;94}Uf4 z={xUL@H%Y@rDfb4_tlD+GVU_9D>%ct)IOgtQ3hZdx|6+SaWq-!+pL$F9zDd0sK>Fs z>+cztUJX0iY&A6|&;_;Q2D|-B_`r{%d_Do+wA3`u4M3h`qCQrx!u&fm^qzLZmHN27 zKCH1GzEerZ6*_94v`)F&+go=$?8{X$oaNeSOVE+xwmfV<+YrTZQ`%-#P1@{0ouj0w zvO$Usrm;G9=G0gy=kpoON4+VPSnl{q&qCc5tyHt)AYP!OT|Y#)R_V-iz?bA?QEg3@<5S7WYk5WJVv4Hk zE;P;U4Na37ZjK>A$pY62yQ0Is+Ltc`2!`2&YwF~4s3L!PWmZQUvHuQJ-aX;Qo_Fs; zo^Ab*Z!Ce{bnXkWii*SWVBek}qh;lhh%YX5QV}XFWqcAEe~l7qXpdS(#5!_LszWx` zASgc@BE(iZ+U0OwVqKyWuu0HcLAJzCIMwuTd=i$2MwP#GaPk^g4m!&=6uy}>v6I5h zAx=k!b_z9x!zpA`GuTny=A6kU07+nCdMjo2OIplL74mM> zJDr8(%7YA}k= zC;%vQl|l%heUj?#)~$>a`fH|SrJ*>F*PT>p5kkSv^aAluWRh<~MHp(TDt7c(+<}0` z< ztxOB5!=Y<#@M42<5JVz^IeTie)3WDxm4RM4Z3NZQ^=j5X`n-9pf<#(OxoR~z=qIq+ zNR>LJgIZ18hxrpUNcIor^Tfk!gRhRE;e=N2Y?l=6bO-^@yXc7He#k8h)e7`hC9Sw!pjTSez?u${Upyx0NihDo5xBT44^-1&}ldXPea5fBU2;OE|Q-|r+ zF3{Ioz(t%=VAGkk%!#FzG7&$YAfUqME49^S6b$T5Vz8{XlPnwJqX|H4v&XH0?A8X3 zLyyBCAo$s-+k$I}1mJ5SPp{osGViAg3D>7L?cAIBX}UGi*)?kPN_8)kX+G6Gu7^yP zD5)`4uci7H*4dYa!YhTtq;p>>M&rIWKg8I9FUJMa9l0(}uB0B*neQ!bI3I*rx=a-o z`m+!Vp4i?kyl3Iv8(P|6%XQD%>S`24Mz9CKdZ)pgZl>`UR6U%(d;aqs7#!pTUgz~m zB-NK9G9T&Lp|>ptJ+c~GIjZy#LWc7(WIF@Y0lwMxg6Tk%kLszGR>2RGJlXL#qgYpVF=#JyRGHz2>JUHJv+ zz4=lTZ9Qw$zy3hKAn^T~_v@y;AA2d*JgRRC)Yr#Z6IK7Ea=uf%tigpogjv2nyf;N_ zR6yUvg6$33r0q^v%i4LYV;(okX{Ro%FcrfX*-ZAcU|zDLHkMiJrd&_csJ9FaBOFhX zxa*p@P3)yjyFF~cmI`%r#UCMnmMUWyQ6>C1H72wfBiW}q2AyM+<^Yk zjm-S{_k-(F3#GchwjQ|L+_e9z_+OBv26QfkT(wks=k&^2Fo6JG$24o5a7PsU(AN5C z1s-(q)hPY0Fzk_Jy$TPFvmvn(RQoq8VU4y2yg!adn>he(^3=hT7ybe*MqXM7Yeb>u zY(5=Y19Q?w(|k4=q}6&I*tnm|dqhfUMbDSR3A7wZrkjP|_E@|#gp4QwkU z#?z%wcG>or)>$%va^O7LJBzAZP!*~u;>4S5GOTx$B#nypqBmKwqb95UZYR}DPayZ_ ze&jwLN%b;(<@8k=O~nJTFSldu;H(*~V;@JHFx`y{>*SKt)uK?ap^`HgM@&zJwpHeX zAXqx>v0ETRCbai6kBd5;PQLDshqj@J^CkP$W`IsOVGJ49P4kVLdi|JesRm^YpyfNs zC$8*$RzEfW?i3qQz0v>CJz{T_`6JcaEKcp*I*i+km@mR5ARn~m3O6*Y$lx=Dr`$tC zX7M7$@ok-$8XS)uKHB+{?NWfR~@8{EP z$erifyo9Lg_tojME@sS3sXt61oRA8uQjhiSQKZ}o@@Z0OYKB6GD zfo@KQ*`l4Ck-QNkAJFmMOl(R-53|`;1E2(!Dk$CS^khH9Eeo5kv{gLcsc4CeBw_YG zIs&#q4yhS7bUuD7jk+-FKQh@5Wb0{vcDn9*J& z7Hy?{pw_5}=jD+MY}DV)*l0KsHCox8lmp-D3J!?<8jXl`LQ!~U5>JfP@GEP7Z+M1v zYiaZ#)h~^ue`4UVTx_AQywqnqt6}nc2k%Vl>frrQsy z5lR5hGvulpP6JmTi-@;gj)^RCIAcqodn{ZEWHs3IR>cgef^^$OGMT5_U93pCgRsQ* zhHSZ`aJw!2?XmQo;r?dIf8q)|0f-&gueX!>ic|^Tudf6H>tE0k6>gx_A%p;52b`Lw^K6`lF{Ozy=3G&w(4`ajiT@5c%JfB(iu1K<<(+wNjZ zuG*V}$n8nUWe_{%9L+bILJcDp+I_6rThpD8edN$WNL=jmQFLk(dfeXF7BL!XS~qk7 zI^yUNv~)mHK&j40_X4+1*q^ATak)LNx%Y3p4pyC={c}3j$D}N18T3j&)MZXzRqx^C zlA1F|zO^knyyI0@J(i7DoC%r=pR?HVwgR!+UE*37RFLOSa!Mb zl#aX^j$ukcQuxx4210g|ts3~^GtdqgaC5ivYSfLa{8oow=r!u>Ou9L$z%jgSu$QKK zh%dsDI8FKPa*T44JLpe|MRjmgS6O!O#dycXI%FD%M{U0+=}jE;5tFa*o-@T~T8oG> zn$JAknz!gK36^@|ZL?6mTRzX8auUJzIhmJeLgV#4MHA|lL~o|2o=&eZn;!Pt)1=yO zzDGqa#}|06SEJd;8i?vxk-})bA3jD}lLmo{W6g$&YZHVl`@w2&3ceH8+9?;Oxj8iApTKl zOXgaEN-$=_R?DboH+U;|`ye^pk{X|82$~4$l7AVFxe{#Vc_Cg09_k9`uO+N#a|15m z95dT7OeL%1;jq`vcs$LR+&cM;%&s?m$T2jW1qmTSX{rz4{;0zTnI)ee|bV_L_d$@a3F|3T&x??Y`!UWH^*0 zbWaPrwL7jbzOc7FYCl2!d~Ic#BC5-&x^NLKvE4&!iR-4ITRYW_4f+rZxq8};vvm^ED|IHZn@Mf;Z(9>I znPme(7#Nf};rc2{*<02c&By@6-a`)_@3K^?AF1ilRru|g*{1_>w`{Glr8isUgVqv> z1>!eRk4p#6Ygf_wVEN}G7XUH)oV(D>?1m*&BjSL*x!qBn=N);e z5a_XXS%iNbO{1FpA_*T?piu;m}3UGE0BF9Q`CS-v@b6hg<(OTyff z(APkH*F*A$3h%qe+{EL;rWYdtMG24nW|JJ0^$O?%dCIQJ{&;k}!38+!R+Y^HT*))txDc5Q@iHTe*~bqPVJCDmWR533(6X}poaNtmgAit z^pA%xpRYZd@4y*wjU&PJ)MGWV6M#*e*12rW7wfR*ZJ#$CmW@L9(sQ2aKWk^@%aw1M z+1epI0jNE1GZKdJ-`Qt(@*kJ~{>jf&@h-tmt5M%K19!2CX8TB`pvEWeFIvGGNtWD7 zQCL2mcUX(4(fU#N?nUwrx#J^fypzq|gb>r9Cc0q=KvI10TI@`=0#BIA&}1Y@jmLw^~a z{PGze7xm*9z^eHEYGFJBEx+xsBWYY5vor6AxR@ipfwZ=Iji3u|7 zY8k&x?BUc%c6d=hd~bqijvUOX*kFcac|ckd9QlpHyeu39D zFA899m{6nhcAGCmqcZ2}SwCBzmlx!KhwLJv!iruvQVknHw18oM|D>$>gk7ek>lk_kACVzAWLdSEpt)cy+L6>a}lH2?X|= z)AF`V^<7h7K+o&93|QMD5Tm;*?p!?$j zrbXH{a`$c0Z8O*FiTdq^`sfl}ICZvF^)!y_q@1P-?RJ6tv>;88;&1JpPakt%k59jH zj%j?egC@Q4yrmUt>=yHIiewe8inC-)2fbcE&MleqLvk|$1=&^8QK#?*+jyt13V|yC zO!~ONcU6uK4*qyC>ZD?&4)(oqcKjPk@M77VdHB{iif=a|zaDGk-Qu`xy!StY4qFf| zxtxJFym;_c&P)FO%en`aYJGzk88K9w-JkLCV156yi-X`Bm-5rz9hm-;2c0uZnn37J z9|B!D9nea^huW5|ZLYU^nDvJLDTx5UQJusF4Wq)nZ`~K>M&gGI3c%Ql!6ixzh`wF( z48g(sj+|H)9bH9D+?Z>w21V8`X zDU9Ac=o$~q&ecn0?D=Ug56ts!yZES28~xEm{-x7$C;V}1Hx}!e@;94#jF@Qz$l;s5 zpv}#o*VV)67OPC6HQr9d#HglOR*=Tf?m5z;?WJNn3X7dJciS8}+nuIIl$c8lBMgqo zGLYd`ZqTLLzwuVy9V2&3yIKE7-auAM4J!+~uW|WbtI;~y`IQ&pseq%thoHW_tG^|lW+tn6* zb=&F(#R<^M;r1z7L>qunoaIC46wHb?^e~#eyJoF(G>PsxYWre%ka_dl!{9=%5sk}h zQ13wK8;R(TB6SB)+2pCaTx*grC=m@uMk6a*bh9{N$V|&(&6$f)(lbYl>>gYuE{Ow_ zldr_X001VnsWBVpRdFPpG77uxqp_(a;ubxHxq^;R)8-=nX|m^_;`wNXwGO?^_%37U zPVhY23-u;g{M~e?9AZQ%yN7b^wa2HnT4>r4*=OSEl#c^`hwPlf+j^)VO?uURDMqcR@>=SBel)PvM8Z+k7AC)=d5Q9&E*WUw_Tt z1EZfrbhw^tN+_0YXb76UjU;bMANi@CZ^e-qf@#m<0s|rHxxCyT2EyL40q}zH;6{1g z(>zTk_JX9E)4sDL!*D)&br#(<(L)a9lOn1G;@7;mWgZxNg+Vjoou#Aoo0vm~ePF(XL*R9M||D+H{ z7ZFeloiA*Q8n6*YB?*Gcoh)x5g6ixCEkhR%D6<$3)zMdnpH@QLw^mUP$%i$LOaMyh zeCt_%*xXv*BE>g3d?$vG|IwHQwOYCC(z+-F0?uJs(}4Nk-?yQb|ILWwi!b!FylFiwwb{@(r#a{$!84g)&T}ptr3SLGSRCoMJvd7F2v}MUmPYqk@@R`Pfp3=`KO~ z7Ll%?82-KC3*Ar+IDw-&r#*aGXV;`&Ty2?Gu81>8X9B}nv9Rq4os1o#co9{tUbPhH zR!fdj>uCGC)7qa%1l}h7LAscP(vI`?EbXS@0;H|iYRulz2J1O#u$i>^Stm}QmOK4A^3 zc4^8`D@yESPiIH{Eb)&}=fve*q9Qtkw?0sZcFE2*7$)EX;sJD{GMTkq(nETrptkN7 z!SiIBTZsmirrwcFvzF)CG{OZv>0e(&f&TdYMO1vJSxfE1pHT8p)B8qtNs5fE#dh2; z7w)9Z$7LMT0`DICxa~#m8lTuFCAX;g)^N)4YL|4}R%;csaCM7&9kdjOPztacNzt++ zPD3&f8MbF`eiM_^)xb#;2t+$RnR}ypFpZ! zpNmcb%javW&YBnUltuZzIUL5mFkZ13Shf)$PZPp|Htj=@chP(TRePAiGh(ozeQSq$ z<(!TJX65pJ-`17}MnMc=k2ArGauR0K-Rp{y!DOjZ|`p! zVl|7J7jR)--zN)zS`uEv6fny-L5|1`q}^pYW&Qs+Jbo6 z{O4&k1%dTFd41arcFU*8tFcj1-?tdEExl_C|pr#Kqt{3QQ(PEM9e6Yxu0D|ER>{CX#1SG}j zh*ltULS*Sk6a)`fUuS?|A( zGkz?!d$M5uj-hs*_Koa)?zgvoWVo>td=n(rGU+L{NSYOB8APhsNz$4`On(x$?IO^;2v@tAE?fdM=lYP#M$aLg`!oCP zW}yFA&7Nm}rg@+G`R^vG_nj@L_LK;4PF8JsaSHNsFx_B7e6P3i&2)gR7t|6#*t~Q* zf}reU2^-AC<1*SK6uwGus z2W@|Yoa zaqynF^5F3OSPW`fHB;(;e^h6NPR*WNR&qfsv2r0wn$%zSD4d8%9eQ6%2eLoF_a`!6 z&MpQKfJG?DBT(No0HPdVTb~k5# zsNZh%V4kUwxh?!Mnqa_zc&`m z^k}n5*paCK+#2pwP3EU+Yj);5pTf6zd6yjHuh!p81HHa&yH5Ws05=!cf<#QPG$8vN zqWg`tQR}^rx##s96HpbOxC8K$-|d_my$k;u+KsGyw|{0Neds6KOj#o9A+s8`+qN*6 zvstgZlZoDL<=~>oO*g~ixP##d?H{&XTvQ{iN*Hb ze%_B%ajUq}u$@jgvobL#Je?VqpbAD(8h}1h%#jVT%ofaiO|0TQc=^tvjbpiZkNez{ zU>@fF&Odlk54EgZ+=XA7oR6MI!-)HXntgPo`VC7Wao3M|A)ZB;ygJS+ZnyAfsF#c0 zfm{r)N z0$CKE0SO-0)Ti1vd4Kj?^Sz&ht4=Du+MTarD&Z*5Y_41kw-F#MRir~t{E}6>fp+K) zrFog!I+~Z13k{bx>zSSpC2HL#2y&K^3s>qPExt!A#|z0Qb7~OHTSVLG`d_Ki2GihH zUVqJcz64Z~G^!KI>r5{wYHu`Yog)A7q=nhW;3Qi{4FK^p<+JYnmFsaQSc}n(`i~AH zceB}6r%b_@^n8sN3v0v~HhIL8ajHOz5OT8`R$j4LLtSpj=eu_ISb9Z!q(R>Jo}3ZN z&h1;Rq69rmi4(yt#R*h+-bLw^La_}

hPd+ROM0r%{ehsl{{GyR5oGxrOrZ}i9d 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

fdRp(w9jWMiYANgxF5Mk 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

HUx$=|4A3;Yoj-cL1OoX7lTH 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 diff --git a/bundle/package.json b/bundle/package.json index 8432e9931..6adb569ce 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -9,8 +9,10 @@ "depcheck": "node scripts/depcheck.js", "syncdeps": "node scripts/install.js", "build": "node scripts/build.js", - "start": "node scripts/build.js && node dist/bundle/src/start.js", - "start:bundle": "node dist/bundle/src/start.js", + "start": "node scripts/build.js && node --enable-source-maps dist/bundle/src/start.js", + "start:bundle": "node --enable-source-maps dist/bundle/src/start.js", + "start:bundle:dbg": "node --enable-source-maps --inspect dist/bundle/src/start.js", + "start:bundle:vscode-dbg": "npm run build clean logerrors pretty-errors && node --enable-source-maps --inspect dist/bundle/src/start.js", "test": "echo \"Error: no test specified\" && exit 1", "migrate": "cd ../util/ && npm i && node --require ts-node/register node_modules/typeorm/cli.js -f ../util/ormconfig.json migration:run", "tsnode": "npx ts-node --transpile-only -P tsnode.tsconfig.json src/start.ts" @@ -27,28 +29,73 @@ }, "homepage": "https://fosscord.com", "devDependencies": { + "@babel/core": "^7.18.9", + "@babel/preset-env": "^7.18.9", + "@babel/preset-typescript": "^7.15.0", + "@types/amqplib": "^0.8.1", + "@types/bcrypt": "^5.0.0", + "@types/body-parser": "^1.19.0", "@types/dotenv": "^8.2.0", "@types/express": "^4.17.12", + "@types/i18next-node-fs-backend": "^2.1.0", + "@types/jsonwebtoken": "^8.5.8", + "@types/morgan": "^1.9.3", + "@types/multer": "^1.4.7", "@types/node": "^18.0.6", "@types/node-os-utils": "^1.3.0", + "@types/ws": "^8.5.3", + "jest": "^28.1.3", + "jest-expect-message": "^1.0.2", "ts-node": "^10.2.1", + "ts-node-dev": "^2.0.0", "ts-patch": "^2.0.1", - "typescript": "^4.2.3" + "typescript": "^4.2.3", + "typescript-json-schema": "^0.54.0" }, "dependencies": { + "@aws-sdk/client-s3": "^3.137.0", + "@babel/preset-typescript": "^7.15.0", "@fosscord/api": "file:../api", "@fosscord/cdn": "file:../cdn", "@fosscord/gateway": "file:../gateway", "@ovos-media/ts-transform-paths": "^1.7.18-1", "@sentry/node": "^7.7.0", "@sentry/tracing": "^7.7.0", + "@types/node-fetch": "^2.6.2", + "ajv": "8.6.2", + "ajv-formats": "^2.1.1", + "amqplib": "^0.10.1", + "bcrypt": "^5.0.1", + "body-parser": "^1.19.0", + "canvas": "^2.9.3", + "cheerio": "^1.0.0-rc.10", "dotenv": "^16.0.1", + "exif-be-gone": "^1.3.0", "express": "^4.17.1", + "file-type": "16.5", + "form-data": "^4.0.0", + "i18next": "^21.8.14", + "i18next-http-middleware": "^3.1.3", + "i18next-node-fs-backend": "^2.1.3", + "image-size": "^1.0.0", + "jest": "^28.1.3", + "jsonwebtoken": "^8.5.1", + "lambert-server": "^1.2.12", + "missing-native-js-functions": "^1.2.18", + "morgan": "^1.10.0", + "multer": "^1.4.5-lts.1", + "mysql2": "^2.3.3", + "node-2fa": "^2.0.3", "node-fetch": "^2.6.7", "node-os-utils": "^1.3.7", "patch-package": "^6.4.7", + "pg": "^8.7.3", "picocolors": "^1.0.0", + "proxy-agent": "^5.0.0", "reflect-metadata": "^0.1.13", + "sqlite3": "^5.0.11", + "supertest": "^6.1.6", + "typeorm": "^0.3.7", "typescript": "^4.1.2", "ws": "^8.8.1" } diff --git a/cdn/tsconfig.json b/cdn/tsconfig.json index 94cc7b586..85b35f557 100644 --- a/cdn/tsconfig.json +++ b/cdn/tsconfig.json @@ -17,7 +17,7 @@ "declaration": true /* Generates corresponding '.d.ts' file. */, "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, "inlineSourceMap": true /* Emit a single file with source maps instead of having a separate file. */, - // "sourceMap": true /* Generates corresponding '.map' file. */, + "sourceMap": true /* Generates corresponding '.map' file. */, // "outFile": "./", /* Concatenate and emit output to single file. */ "outDir": "./dist/" /* Redirect output structure to the directory. */, "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, diff --git a/gateway/src/events/Connection.ts b/gateway/src/events/Connection.ts index c1bb73b67..508b4741d 100644 --- a/gateway/src/events/Connection.ts +++ b/gateway/src/events/Connection.ts @@ -27,6 +27,21 @@ export async function Connection( socket.on("close", Close); // @ts-ignore socket.on("message", Message); + + if(process.env.WS_LOGEVENTS) + [ + "close", + "error", + "upgrade", + //"message", + "open", + "ping", + "pong", + "unexpected-response" + ].forEach(x=>{ + socket.on(x, y => console.log(x, y)); + }); + console.log(`[Gateway] Connections: ${this.clients.size}`); const { searchParams } = new URL(`http://localhost${request.url}`); diff --git a/gateway/src/events/Message.ts b/gateway/src/events/Message.ts index 313287841..71b6f2069 100644 --- a/gateway/src/events/Message.ts +++ b/gateway/src/events/Message.ts @@ -15,17 +15,33 @@ const PayloadSchema = { $t: String, }; -export async function Message(this: WebSocket, buffer: WS.Data) { +export async function Message(this: WebSocket, buffer: WS.RawData) { // TODO: compression let data: Payload; if (this.encoding === "etf" && buffer instanceof Buffer) data = erlpack.unpack(buffer); - else if (this.encoding === "json" && typeof buffer === "string") - data = JSON.parse(buffer); - else return; + else if (this.encoding === "json") + data = JSON.parse(buffer as unknown as string); //TODO: is this even correct?? seems to work for web clients... + else if(/--debug|--inspect/.test(process.execArgv.join(' '))) { + debugger; + return; + } + else { + console.log("Invalid gateway connection! Use a debugger to inspect!"); + return; + } - check.call(this, PayloadSchema, data); + if(process.env.WS_VERBOSE) + console.log(`[Websocket] Incomming message: ${JSON.stringify(data)}`); + if(data.op !== 1) + check.call(this, PayloadSchema, data); + else { //custom validation for numbers, because heartbeat + if(data.s || data.t || typeof data.d !== "number") { + console.log("Invalid heartbeat..."); + this.close(CLOSECODES.Decode_error); + } + } // @ts-ignore const OPCodeHandler = OPCodeHandlers[data.op]; diff --git a/gateway/src/opcodes/Heartbeat.ts b/gateway/src/opcodes/Heartbeat.ts index 50394130d..42b72d4b7 100644 --- a/gateway/src/opcodes/Heartbeat.ts +++ b/gateway/src/opcodes/Heartbeat.ts @@ -2,7 +2,7 @@ import { Payload, WebSocket } from "@fosscord/gateway"; import { setHeartbeat } from "../util/Heartbeat"; import { Send } from "../util/Send"; -export async function onHeartbeat(this: WebSocket, data: Payload) { +export async function onHeartbeat(this: WebSocket, _data: Payload) { // TODO: validate payload setHeartbeat(this); diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index 13d555597..c6c24fcda 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -83,7 +83,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { // TODO: public user selection }), // save the session and delete it when the websocket is closed - new Session({ + Object.assign(new Session(),{ user_id: this.user_id, session_id: session_id, // TODO: check if status is only one of: online, dnd, offline, idle diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 974769e94..0dbdb5261 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -1,4 +1,4 @@ -import { getPermission, listenEvent, Member, Role } from "@fosscord/util"; +import { getPermission, listenEvent, Member, Role, initDatabase } from "@fosscord/util"; import { LazyRequest } from "../schema/LazyRequest"; import { Send } from "../util/Send"; import { OPCODES } from "../util/Constants"; @@ -15,8 +15,9 @@ async function getMembers(guild_id: string, range: [number, number]) { throw new Error("range is not a valid array"); } // TODO: wait for typeorm to implement ordering for .find queries https://github.com/typeorm/typeorm/issues/2620 + // TODO: rewrite this, released in 0.3.0 - let members = await getRepository(Member) + let members = await (await initDatabase()).getRepository(Member) .createQueryBuilder("member") .where("member.guild_id = :guild_id", { guild_id }) .leftJoinAndSelect("member.roles", "role") diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/gateway/src/opcodes/VoiceStateUpdate.ts index 7f7db9b02..1f7c2f1b5 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/gateway/src/opcodes/VoiceStateUpdate.ts @@ -47,9 +47,9 @@ export async function onVoiceStateUpdate(this: WebSocket, data: Payload) { //The event send by Discord's client on channel leave has both guild_id and channel_id as null if (body.guild_id === null) body.guild_id = voiceState.guild_id; - voiceState.assign(body); + voiceState = Object.assign(voiceState, body); } catch (error) { - voiceState = new VoiceState({ + voiceState = Object.assign(new VoiceState(), { ...body, user_id: this.user_id, deaf: false, diff --git a/gateway/src/util/Send.ts b/gateway/src/util/Send.ts index dbe2e7899..2a28d8e01 100644 --- a/gateway/src/util/Send.ts +++ b/gateway/src/util/Send.ts @@ -7,6 +7,8 @@ try { import { Payload, WebSocket } from "@fosscord/gateway"; export async function Send(socket: WebSocket, data: Payload) { + if(process.env.WS_VERBOSE) + console.log(`[Websocket] Outgoing message: ${JSON.stringify(data)}`); let buffer: Buffer | string; if (socket.encoding === "etf") buffer = erlpack.pack(data); // TODO: encode circular object diff --git a/gateway/tsconfig.json b/gateway/tsconfig.json index 70407c6b0..9f855d333 100644 --- a/gateway/tsconfig.json +++ b/gateway/tsconfig.json @@ -18,7 +18,7 @@ // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ "declaration": true /* Generates corresponding '.d.ts' file. */, "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, - // "sourceMap": true /* Generates corresponding '.map' file. */, + "sourceMap": true /* Generates corresponding '.map' file. */, // "outFile": "./", /* Concatenate and emit output to single file. */ "outDir": "./dist/" /* Redirect output structure to the directory. */, "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, diff --git a/util/src/entities/BaseClass.ts b/util/src/entities/BaseClass.ts index 0cb885fae..1ab75a5a4 100644 --- a/util/src/entities/BaseClass.ts +++ b/util/src/entities/BaseClass.ts @@ -1,11 +1,12 @@ import "reflect-metadata"; -import { BaseEntity, EntityMetadata, ObjectIdColumn, PrimaryColumn, FindOptionsWhere } from "typeorm"; +import { BaseEntity, EntityMetadata, ObjectIdColumn, PrimaryColumn, FindOptionsWhere, Generated, SaveOptions } from "typeorm"; import { Snowflake } from "../util/Snowflake"; export class BaseClassWithoutId extends BaseEntity { constructor(props?: any) { super(); - this.assign(props); + if(props != undefined && props != null && Object.keys(props).length > 0) + this.assign(props); } assign(props: any = {}) { @@ -13,8 +14,11 @@ export class BaseClassWithoutId extends BaseEntity { delete props.opts; delete props.props; // will not include relational properties - - for (const key in props) { + console.warn("WARNING: BaseClass.assign called! This will probably fail!"); + console.warn(this) + Object.assign(this,props); + if(/--debug|--inspect/.test(process.execArgv.join(' '))) debugger; + /*for (const key in props) { // @ts-ignore const setter = this[`set${key.capitalize()}`]; // use setter function if it exists @@ -24,7 +28,7 @@ export class BaseClassWithoutId extends BaseEntity { // @ts-ignore this[key] = props[key]; } - } + }*/ } } @@ -35,8 +39,13 @@ export class BaseClass extends BaseClassWithoutId { id: string; assign(props: any = {}) { - super.assign(props); + super.assign(props); if (!this.id) this.id = Snowflake.generate(); return this; } + + save(options?: SaveOptions | undefined): Promise { + if (!this.id) this.id = Snowflake.generate(); + return super.save(options); + } } diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 5ccb43ce9..a7ca647b4 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -222,7 +222,7 @@ export class Channel extends BaseClass { }; await Promise.all([ - new Channel(channel).save(), + Object.assign(new Channel(),channel).save(), !opts?.skipEventEmit ? emitEvent({ event: "CHANNEL_CREATE", @@ -263,7 +263,8 @@ export class Channel extends BaseClass { if (containsAll(re, channelRecipients)) { if (channel == null) { channel = ur.channel; - await ur.assign({ closed: false }).save(); + ur = Object.assign(ur, { closed: false }); + await ur.save(); } } } @@ -272,7 +273,7 @@ export class Channel extends BaseClass { if (channel == null) { name = trimSpecial(name); - channel = await new Channel({ + channel = await (Object.assign(new Channel(), { name, type, owner_id: type === ChannelType.DM ? undefined : null, // 1:1 DMs are ownerless in fosscord-server @@ -280,9 +281,9 @@ export class Channel extends BaseClass { last_message_id: null, recipients: channelRecipients.map( (x) => - new Recipient({ user_id: x, closed: !(type === ChannelType.GROUP_DM || x === creator_user_id) }) + Object.assign(new Recipient(), { user_id: x, closed: !(type === ChannelType.GROUP_DM || x === creator_user_id) }) ), - }).save(); + }) as Channel).save(); } const channel_dto = await DmChannelDTO.from(channel); diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts index c84ea4aa0..901a5e549 100644 --- a/util/src/entities/Config.ts +++ b/util/src/entities/Config.ts @@ -129,6 +129,7 @@ export interface ConfigValue { requireCaptcha: boolean; }; register: { + defaultRights: string; email: { required: boolean; allowlist: boolean; @@ -349,6 +350,7 @@ export const DefaultConfigOptions: ConfigValue = { minSymbols: 0, }, incrementingDiscriminators: false, + defaultRights: "0" }, regions: { default: "fosscord", diff --git a/util/src/entities/Guild.ts b/util/src/entities/Guild.ts index 328c586ef..058033e8c 100644 --- a/util/src/entities/Guild.ts +++ b/util/src/entities/Guild.ts @@ -285,7 +285,7 @@ export class Guild extends BaseClass { }) { const guild_id = Snowflake.generate(); - const guild = await new Guild({ + const guild: Guild = Object.assign(new Guild(),{ name: body.name || "Fosscord", icon: await handleFile(`/icons/${guild_id}`, body.icon as string), region: Config.get().regions.default, @@ -316,11 +316,12 @@ export class Guild extends BaseClass { welcome_channels: [], }, widget_enabled: true, // NB: don't set it as false to prevent artificial restrictions - }).save(); + }); + await guild.save(); // we have to create the role _after_ the guild because else we would get a "SQLITE_CONSTRAINT: FOREIGN KEY constraint failed" error // TODO: make the @everyone a pseudorole that is dynamically generated at runtime so we can save storage - await new Role({ + let role: Role = Object.assign(new Role(), { id: guild_id, guild_id: guild_id, color: 0, @@ -333,7 +334,8 @@ export class Guild extends BaseClass { position: 0, icon: null, unicode_emoji: null - }).save(); + }); + await role.save(); if (!body.channels || !body.channels.length) body.channels = [{ id: "01", type: 0, name: "general" }]; diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index 7ca50992a..e4aa8331b 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -85,8 +85,8 @@ export class Member extends BaseClassWithoutId { @Column() joined_at: Date; - @Column({ type: "bigint", nullable: true }) - premium_since?: number; + @Column({ nullable: true }) + premium_since?: Date; @Column() deaf: boolean; @@ -161,7 +161,7 @@ export class Member extends BaseClassWithoutId { }), Role.findOneOrFail({ where: { id: role_id, guild_id }, select: ["id"] }), ]); - member.roles.push(new Role({ id: role_id })); + member.roles.push(Object.assign(new Role(), { id: role_id })); await Promise.all([ member.save(), @@ -264,9 +264,9 @@ export class Member extends BaseClassWithoutId { //TODO: check for bugs if(guild.member_count) guild.member_count++; await Promise.all([ - new Member({ + Object.assign(new Member(), { ...member, - roles: [new Role({ id: guild_id })], + roles: [Object.assign(new Role(), { id: guild_id })], // read_state: {}, settings: { channel_overrides: [], diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 7d5dc5a6e..81017c2d9 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -255,7 +255,7 @@ export class User extends BaseClass { // if nsfw_allowed is null/undefined it'll require date_of_birth to set it to true/false const language = req.language === "en" ? "en-US" : req.language || "en-US"; - const user = new User({ + const user = Object.assign(new User(), { created_at: new Date(), username: username, discriminator, @@ -275,7 +275,7 @@ export class User extends BaseClass { disabled: false, deleted: false, email: email, - rights: "0", // TODO: grant rights correctly, as 0 actually stands for no rights at all + rights: Config.get().register.defaultRights, // TODO: grant rights correctly, as 0 actually stands for no rights at all nsfw_allowed: true, // TODO: depending on age public_flags: "0", flags: "0", // TODO: generate @@ -289,6 +289,8 @@ export class User extends BaseClass { notes: {}, }); + console.log("new user") + console.log(user); await user.save(); setImmediate(async () => { diff --git a/util/src/migrations/mariadb/1659921859145-premium_since_as_date.ts b/util/src/migrations/mariadb/1659921859145-premium_since_as_date.ts new file mode 100644 index 000000000..de173cfe6 --- /dev/null +++ b/util/src/migrations/mariadb/1659921859145-premium_since_as_date.ts @@ -0,0 +1,26 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class premiumSinceAsDate1659921859145 implements MigrationInterface { + name = 'premiumSinceAsDate1659921859145' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`members\` DROP COLUMN \`premium_since\` + `); + await queryRunner.query(` + ALTER TABLE \`members\` + ADD \`premium_since\` datetime NULL + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`members\` DROP COLUMN \`premium_since\` + `); + await queryRunner.query(` + ALTER TABLE \`members\` + ADD \`premium_since\` bigint NULL + `); + } + +} diff --git a/util/src/migrations/postgres/1659921826567-premium_since_as_date.ts b/util/src/migrations/postgres/1659921826567-premium_since_as_date.ts new file mode 100644 index 000000000..ac1e2edb7 --- /dev/null +++ b/util/src/migrations/postgres/1659921826567-premium_since_as_date.ts @@ -0,0 +1,26 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class premiumSinceAsDate1659921826567 implements MigrationInterface { + name = 'premiumSinceAsDate1659921826567' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "members" DROP COLUMN "premium_since" + `); + await queryRunner.query(` + ALTER TABLE "members" + ADD "premium_since" TIMESTAMP + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "members" DROP COLUMN "premium_since" + `); + await queryRunner.query(` + ALTER TABLE "members" + ADD "premium_since" bigint + `); + } + +} diff --git a/util/src/migrations/sqlite/1659921722863-premium_since_as_date.ts b/util/src/migrations/sqlite/1659921722863-premium_since_as_date.ts new file mode 100644 index 000000000..788be6257 --- /dev/null +++ b/util/src/migrations/sqlite/1659921722863-premium_since_as_date.ts @@ -0,0 +1,252 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class premiumSinceAsDate1659921722863 implements MigrationInterface { + name = 'premiumSinceAsDate1659921722863' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + CREATE TABLE "temporary_members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar, + CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_28b53062261b996d9c99fa12404" FOREIGN KEY ("id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_members"( + "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + ) + SELECT "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + FROM "members" + `); + await queryRunner.query(` + DROP TABLE "members" + `); + await queryRunner.query(` + ALTER TABLE "temporary_members" + RENAME TO "members" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + CREATE TABLE "temporary_members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" datetime, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar, + CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_28b53062261b996d9c99fa12404" FOREIGN KEY ("id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_members"( + "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + ) + SELECT "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + FROM "members" + `); + await queryRunner.query(` + DROP TABLE "members" + `); + await queryRunner.query(` + ALTER TABLE "temporary_members" + RENAME TO "members" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + ALTER TABLE "members" + RENAME TO "temporary_members" + `); + await queryRunner.query(` + CREATE TABLE "members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar, + CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_28b53062261b996d9c99fa12404" FOREIGN KEY ("id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "members"( + "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + ) + SELECT "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + FROM "temporary_members" + `); + await queryRunner.query(` + DROP TABLE "temporary_members" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + await queryRunner.query(` + DROP INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" + `); + await queryRunner.query(` + ALTER TABLE "members" + RENAME TO "temporary_members" + `); + await queryRunner.query(` + CREATE TABLE "members" ( + "index" integer PRIMARY KEY AUTOINCREMENT NOT NULL, + "id" varchar NOT NULL, + "guild_id" varchar NOT NULL, + "nick" varchar, + "joined_at" datetime NOT NULL, + "premium_since" bigint, + "deaf" boolean NOT NULL, + "mute" boolean NOT NULL, + "pending" boolean NOT NULL, + "settings" text NOT NULL, + "last_message_id" varchar, + "joined_by" varchar, + CONSTRAINT "FK_16aceddd5b89825b8ed6029ad1c" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_28b53062261b996d9c99fa12404" FOREIGN KEY ("id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "members"( + "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + ) + SELECT "index", + "id", + "guild_id", + "nick", + "joined_at", + "premium_since", + "deaf", + "mute", + "pending", + "settings", + "last_message_id", + "joined_by" + FROM "temporary_members" + `); + await queryRunner.query(` + DROP TABLE "temporary_members" + `); + await queryRunner.query(` + CREATE UNIQUE INDEX "IDX_bb2bf9386ac443afbbbf9f12d3" ON "members" ("id", "guild_id") + `); + } + +} diff --git a/util/src/util/BitField.ts b/util/src/util/BitField.ts index fb887e055..9bdbf6d78 100644 --- a/util/src/util/BitField.ts +++ b/util/src/util/BitField.ts @@ -138,6 +138,9 @@ export class BitField { return bit.map((p) => resolve.call(this, p)).reduce((prev, p) => BigInt(prev) | BigInt(p), BigInt(0)); } if (typeof bit === "string" && typeof FLAGS[bit] !== "undefined") return FLAGS[bit]; + if (bit === "0") return BigInt(0); //special case: 0 + if (typeof bit === "string") return BigInt(bit); //last ditch effort... + if(/--debug|--inspect/.test(process.execArgv.join(' '))) debugger; //if you're here, we have an invalid bitfield... if bit is 0, thats fine, I guess... throw new RangeError("BITFIELD_INVALID: " + bit); } } From 3c624cc95a991ccaffe62694e698de4020d48e35 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 20:53:15 +0200 Subject: [PATCH 172/238] Clean up BaseClient assign call --- util/src/entities/BaseClass.ts | 31 +++---------------------------- 1 file changed, 3 insertions(+), 28 deletions(-) diff --git a/util/src/entities/BaseClass.ts b/util/src/entities/BaseClass.ts index 1ab75a5a4..c872e7f18 100644 --- a/util/src/entities/BaseClass.ts +++ b/util/src/entities/BaseClass.ts @@ -3,32 +3,8 @@ import { BaseEntity, EntityMetadata, ObjectIdColumn, PrimaryColumn, FindOptionsW import { Snowflake } from "../util/Snowflake"; export class BaseClassWithoutId extends BaseEntity { - constructor(props?: any) { + constructor() { super(); - if(props != undefined && props != null && Object.keys(props).length > 0) - this.assign(props); - } - - assign(props: any = {}) { - //console.log(`assign (${typeof this})...`) - delete props.opts; - delete props.props; - // will not include relational properties - console.warn("WARNING: BaseClass.assign called! This will probably fail!"); - console.warn(this) - Object.assign(this,props); - if(/--debug|--inspect/.test(process.execArgv.join(' '))) debugger; - /*for (const key in props) { - // @ts-ignore - const setter = this[`set${key.capitalize()}`]; // use setter function if it exists - - if (setter) { - setter.call(this, props[key]); - } else { - // @ts-ignore - this[key] = props[key]; - } - }*/ } } @@ -38,10 +14,9 @@ export class BaseClass extends BaseClassWithoutId { @PrimaryIdColumn() id: string; - assign(props: any = {}) { - super.assign(props); + constructor() { + super(); if (!this.id) this.id = Snowflake.generate(); - return this; } save(options?: SaveOptions | undefined): Promise { From 26293f37a1f7af131507c0bdd490d2e07f1a9ba7 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 22:49:16 +0200 Subject: [PATCH 173/238] Use deep merge everywhere --- api/src/routes/channels/#channel_id/index.ts | 3 +- .../routes/channels/#channel_id/invites.ts | 3 +- .../#channel_id/messages/#message_id/ack.ts | 3 +- .../routes/channels/#channel_id/recipients.ts | 3 +- api/src/routes/guilds/#guild_id/bans.ts | 5 +- api/src/routes/guilds/#guild_id/emojis.ts | 5 +- api/src/routes/guilds/#guild_id/index.ts | 3 +- .../#guild_id/members/#member_id/index.ts | 3 +- .../guilds/#guild_id/roles/#role_id/index.ts | 3 +- .../routes/guilds/#guild_id/roles/index.ts | 3 +- api/src/routes/guilds/#guild_id/stickers.ts | 5 +- api/src/routes/guilds/#guild_id/templates.ts | 7 +- api/src/routes/guilds/#guild_id/vanity-url.ts | 3 +- .../#guild_id/voice-states/#user_id/index.ts | 3 +- .../routes/guilds/#guild_id/widget.json.ts | 3 +- api/src/routes/guilds/templates/index.ts | 5 +- api/src/routes/users/@me/index.ts | 6 +- api/src/routes/users/@me/relationships.ts | 7 +- api/src/util/handlers/Message.ts | 9 +- gateway/src/opcodes/Identify.ts | 5 +- gateway/src/opcodes/VoiceStateUpdate.ts | 5 +- util/src/entities/Channel.ts | 11 +- util/src/entities/Guild.ts | 7 +- util/src/entities/Member.ts | 9 +- util/src/entities/User.ts | 5 +- util/src/util/imports/OrmUtils.ts | 113 ++++++++++++++++++ util/src/util/imports/index.ts | 1 + 27 files changed, 189 insertions(+), 49 deletions(-) create mode 100644 util/src/util/imports/OrmUtils.ts diff --git a/api/src/routes/channels/#channel_id/index.ts b/api/src/routes/channels/#channel_id/index.ts index 4001b8345..68b52be68 100644 --- a/api/src/routes/channels/#channel_id/index.ts +++ b/api/src/routes/channels/#channel_id/index.ts @@ -10,6 +10,7 @@ import { } from "@fosscord/util"; import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); // TODO: delete channel @@ -78,7 +79,7 @@ router.patch("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANN if (payload.icon) payload.icon = await handleFile(`/channel-icons/${channel_id}`, payload.icon); let channel = await Channel.findOneOrFail({ where: { id: channel_id } }); - channel = Object.assign(channel, payload); + channel = OrmUtils.mergeDeep(channel, payload); await Promise.all([ channel.save(), diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index 4e97b275e..a53b1de4c 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -4,6 +4,7 @@ import { route } from "@fosscord/api"; import { random } from "@fosscord/api"; import { Channel, Invite, InviteCreateEvent, emitEvent, User, Guild, PublicInviteRelation } from "@fosscord/util"; import { isTextChannel } from "./messages"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); @@ -33,7 +34,7 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT const expires_at = new Date(req.body.max_age * 1000 + Date.now()); - const invite = await Object.assign(new Invite(),{ + const invite = await OrmUtils.mergeDeep(new Invite(),{ code: random(), temporary: req.body.temporary, uses: 0, diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts index fc2ec4880..c1b8d20f0 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts @@ -1,6 +1,7 @@ import { emitEvent, getPermission, MessageAckEvent, ReadState, Snowflake } from "@fosscord/util"; import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -20,7 +21,7 @@ router.post("/", route({ body: "MessageAcknowledgeSchema" }), async (req: Reques permission.hasThrow("VIEW_CHANNEL"); let read_state = await ReadState.findOne({ where: { user_id: req.user_id, channel_id } }); - if (!read_state) read_state = Object.assign(new ReadState(), { user_id: req.user_id, channel_id }); + if (!read_state) read_state = OrmUtils.mergeDeep(new ReadState(), { user_id: req.user_id, channel_id }) as ReadState; read_state.last_message_id = message_id; await read_state.save(); diff --git a/api/src/routes/channels/#channel_id/recipients.ts b/api/src/routes/channels/#channel_id/recipients.ts index d6e25599d..069212e2a 100644 --- a/api/src/routes/channels/#channel_id/recipients.ts +++ b/api/src/routes/channels/#channel_id/recipients.ts @@ -11,6 +11,7 @@ import { User } from "@fosscord/util"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); @@ -28,7 +29,7 @@ router.put("/:user_id", route({}), async (req: Request, res: Response) => { throw DiscordApiErrors.INVALID_RECIPIENT; //TODO is this the right error? } - channel.recipients!.push(Object.assign(new Recipient(), { channel_id, user_id: user_id })); + channel.recipients!.push(OrmUtils.mergeDeep(new Recipient(), { channel_id, user_id: user_id })); await channel.save(); await emitEvent({ diff --git a/api/src/routes/guilds/#guild_id/bans.ts b/api/src/routes/guilds/#guild_id/bans.ts index 5ff639581..0743687dd 100644 --- a/api/src/routes/guilds/#guild_id/bans.ts +++ b/api/src/routes/guilds/#guild_id/bans.ts @@ -2,6 +2,7 @@ import { Request, Response, Router } from "express"; import { DiscordApiErrors, emitEvent, getPermission, GuildBanAddEvent, GuildBanRemoveEvent, Guild, Ban, User, Member } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { getIpAdress, route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; export interface BanCreateSchema { delete_message_days?: string; @@ -90,7 +91,7 @@ router.put("/:user_id", route({ body: "BanCreateSchema", permission: "BAN_MEMBER const banned_user = await User.getPublicUser(banned_user_id); - const ban = Object.assign(new Ban(),{ + const ban = OrmUtils.mergeDeep(new Ban(),{ user_id: banned_user_id, guild_id: guild_id, ip: getIpAdress(req), @@ -122,7 +123,7 @@ router.put("/@me", route({ body: "BanCreateSchema"}), async (req: Request, res: if (req.permission!.cache.guild?.owner_id === req.params.user_id) throw new HTTPError("You are the guild owner, hence can't ban yourself", 403); - const ban = Object.assign(new Ban(), { + const ban = OrmUtils.mergeDeep(new Ban(), { user_id: req.params.user_id, guild_id: guild_id, ip: getIpAdress(req), diff --git a/api/src/routes/guilds/#guild_id/emojis.ts b/api/src/routes/guilds/#guild_id/emojis.ts index 3e2ed4c20..53a44ec31 100644 --- a/api/src/routes/guilds/#guild_id/emojis.ts +++ b/api/src/routes/guilds/#guild_id/emojis.ts @@ -1,6 +1,7 @@ import { Router, Request, Response } from "express"; import { Config, DiscordApiErrors, emitEvent, Emoji, GuildEmojisUpdateEvent, handleFile, Member, Snowflake, User } from "@fosscord/util"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -50,7 +51,7 @@ router.post("/", route({ body: "EmojiCreateSchema", permission: "MANAGE_EMOJIS_A const user = await User.findOneOrFail({ where: { id: req.user_id } }); body.image = (await handleFile(`/emojis/${id}`, body.image)) as string; - const emoji = await Object.assign(new Emoji(), { + const emoji = await OrmUtils.mergeDeep(new Emoji(), { id: id, guild_id: guild_id, ...body, @@ -80,7 +81,7 @@ router.patch( const { emoji_id, guild_id } = req.params; const body = req.body as EmojiModifySchema; - const emoji = await Object.assign(new Emoji(), { ...body, id: emoji_id, guild_id: guild_id }).save(); + const emoji = await OrmUtils.mergeDeep(new Emoji(), { ...body, id: emoji_id, guild_id: guild_id }).save(); await emitEvent({ event: "GUILD_EMOJIS_UPDATE", diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index 643db7ce2..abece88e4 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -3,6 +3,7 @@ import { DiscordApiErrors, emitEvent, getPermission, getRights, Guild, GuildUpda import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { GuildCreateSchema } from "../index"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -59,7 +60,7 @@ router.patch("/", route({ body: "GuildUpdateSchema"}), async (req: Request, res: relations: ["emojis", "roles", "stickers"] }); // TODO: check if body ids are valid - guild = Object.assign(guild, body); + guild = OrmUtils.mergeDeep(guild, body); //TODO: check this, removed toJSON call const data = JSON.parse(JSON.stringify(guild)); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index eb31ec1d5..824e34a49 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -2,6 +2,7 @@ import { Request, Response, Router } from "express"; import { Member, getPermission, getRights, Role, GuildMemberUpdateEvent, emitEvent, Sticker, Emoji, Rights, Guild } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -31,7 +32,7 @@ router.patch("/", route({ body: "MemberChangeSchema" }), async (req: Request, re permission.hasThrow("MANAGE_ROLES"); if (body.roles.indexOf(everyone.id) === -1) body.roles.push(everyone.id); - member.roles = body.roles.map((x) => Object.assign(new Role(), { id: x })); // foreign key constraint will fail if role doesn't exist + member.roles = body.roles.map((x) => OrmUtils.mergeDeep(new Role(), { id: x })); // foreign key constraint will fail if role doesn't exist } await member.save(); diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index a4b91237e..0482b9ca7 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -3,6 +3,7 @@ import { Role, Member, GuildRoleUpdateEvent, GuildRoleDeleteEvent, emitEvent, ha import { route } from "@fosscord/api"; import { HTTPError } from "@fosscord/util"; import { RoleModifySchema } from "../"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -43,7 +44,7 @@ router.patch("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" } if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); - const role = Object.assign(new Role(), { + const role = OrmUtils.mergeDeep(new Role(), { ...body, id: role_id, guild_id, diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index 7e588d524..6fbb8702a 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -13,6 +13,7 @@ import { } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); @@ -51,7 +52,7 @@ router.post("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }) if (role_count > maxRoles) throw DiscordApiErrors.MAXIMUM_ROLES.withParams(maxRoles); - let role: Role = Object.assign(new Role(),{ + let role: Role = OrmUtils.mergeDeep(new Role(),{ // values before ...body are default and can be overriden position: 0, hoist: false, diff --git a/api/src/routes/guilds/#guild_id/stickers.ts b/api/src/routes/guilds/#guild_id/stickers.ts index c6a5037f7..157ccff40 100644 --- a/api/src/routes/guilds/#guild_id/stickers.ts +++ b/api/src/routes/guilds/#guild_id/stickers.ts @@ -13,6 +13,7 @@ import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; import multer from "multer"; import { HTTPError } from "@fosscord/util"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { @@ -43,7 +44,7 @@ router.post( const id = Snowflake.generate(); const [sticker] = await Promise.all([ - Object.assign(new Sticker(), { + OrmUtils.mergeDeep(new Sticker(), { ...body, guild_id, id, @@ -105,7 +106,7 @@ router.patch( const { guild_id, sticker_id } = req.params; const body = req.body as ModifyGuildStickerSchema; - const sticker = await Object.assign(new Sticker(), { ...body, guild_id, id: sticker_id }).save(); + const sticker = await OrmUtils.mergeDeep(new Sticker(), { ...body, guild_id, id: sticker_id }).save(); await sendStickerUpdateEvent(guild_id); return res.json(sticker); diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/api/src/routes/guilds/#guild_id/templates.ts index edff67171..3d14de415 100644 --- a/api/src/routes/guilds/#guild_id/templates.ts +++ b/api/src/routes/guilds/#guild_id/templates.ts @@ -3,6 +3,7 @@ import { Guild, Template } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { generateCode } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); @@ -47,7 +48,7 @@ router.post("/", route({ body: "TemplateCreateSchema", permission: "MANAGE_GUILD const exists = await Template.findOneOrFail({ where: { id: guild_id } }).catch((e) => {}); if (exists) throw new HTTPError("Template already exists", 400); - const template = await Object.assign(new Template(), { + const template = await OrmUtils.mergeDeep(new Template(), { ...req.body, code: generateCode(), creator_id: req.user_id, @@ -75,7 +76,7 @@ router.put("/:code", route({ permission: "MANAGE_GUILD" }), async (req: Request, const { code, guild_id } = req.params; const guild = await Guild.findOneOrFail({ where: { id: guild_id }, select: TemplateGuildProjection }); - const template = await Object.assign(new Template(), { code, serialized_source_guild: guild }).save(); + const template = await OrmUtils.mergeDeep(new Template(), { code, serialized_source_guild: guild }).save(); res.json(template); }); @@ -84,7 +85,7 @@ router.patch("/:code", route({ body: "TemplateModifySchema", permission: "MANAGE const { code, guild_id } = req.params; const { name, description } = req.body; - const template = await Object.assign(new Template(), { code, name: name, description: description, source_guild_id: guild_id }).save(); + const template = await OrmUtils.mergeDeep(new Template(), { code, name: name, description: description, source_guild_id: guild_id }).save(); res.json(template); }); diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/api/src/routes/guilds/#guild_id/vanity-url.ts index 426559bdc..ac46e18a5 100644 --- a/api/src/routes/guilds/#guild_id/vanity-url.ts +++ b/api/src/routes/guilds/#guild_id/vanity-url.ts @@ -2,6 +2,7 @@ import { Channel, ChannelType, getPermission, Guild, Invite, trimSpecial } from import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; import { HTTPError } from "@fosscord/util"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -47,7 +48,7 @@ router.patch("/", route({ body: "VanityUrlSchema", permission: "MANAGE_GUILD" }) const { id } = await Channel.findOneOrFail({ where: { guild_id, type: ChannelType.GUILD_TEXT } }); - await Object.assign(new Invite(), { + await OrmUtils.mergeDeep(new Invite(), { vanity_url: true, code: code, temporary: false, diff --git a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts index 5900963e9..32d1aadfd 100644 --- a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts +++ b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts @@ -1,6 +1,7 @@ import { Channel, ChannelType, DiscordApiErrors, emitEvent, getPermission, VoiceState, VoiceStateUpdateEvent } from "@fosscord/util"; import { route } from "@fosscord/api"; import { Request, Response, Router } from "express"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); //TODO need more testing when community guild and voice stage channel are working @@ -42,7 +43,7 @@ router.patch("/", route({ body: "VoiceStateUpdateSchema" }), async (req: Request }); if (!voice_state) throw DiscordApiErrors.UNKNOWN_VOICE_STATE; - voice_state = Object.assign(voice_state, body); + voice_state = OrmUtils.mergeDeep(voice_state, body) as VoiceState; const channel = await Channel.findOneOrFail({ where: { guild_id, id: body.channel_id } }); if (channel.type !== ChannelType.GUILD_STAGE_VOICE) { throw DiscordApiErrors.CANNOT_EXECUTE_ON_THIS_CHANNEL_TYPE; diff --git a/api/src/routes/guilds/#guild_id/widget.json.ts b/api/src/routes/guilds/#guild_id/widget.json.ts index b7a93a46b..377394189 100644 --- a/api/src/routes/guilds/#guild_id/widget.json.ts +++ b/api/src/routes/guilds/#guild_id/widget.json.ts @@ -2,6 +2,7 @@ import { Request, Response, Router } from "express"; import { Config, Permissions, Guild, Invite, Channel, Member } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { random, route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); @@ -41,7 +42,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { inviter_id: null }; - invite = await new Invite(body).save(); + invite = await OrmUtils.mergeDeep(new Invite(), body).save(); } // Fetch voice channels, and the @everyone permissions object diff --git a/api/src/routes/guilds/templates/index.ts b/api/src/routes/guilds/templates/index.ts index bb8cc017c..bac4eb8ad 100644 --- a/api/src/routes/guilds/templates/index.ts +++ b/api/src/routes/guilds/templates/index.ts @@ -4,6 +4,7 @@ import { route } from "@fosscord/api"; import { DiscordApiErrors } from "@fosscord/util"; import fetch from "node-fetch"; const router: Router = Router(); +import { OrmUtils } from "@fosscord/util"; export interface GuildTemplateCreateSchema { name: string; @@ -57,13 +58,13 @@ router.post("/:code", route({ body: "GuildTemplateCreateSchema" }), async (req: const guild_id = Snowflake.generate(); const [guild, role] = await Promise.all([ - Object.assign(new Guild(), { + OrmUtils.mergeDeep(new Guild(), { ...body, ...template.serialized_source_guild, id: guild_id, owner_id: req.user_id }).save(), - (Object.assign(new Role(), { + (OrmUtils.mergeDeep(new Role(), { id: guild_id, guild_id: guild_id, color: 0, diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 6a2456d6b..8ab30a8d7 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -2,6 +2,7 @@ import { Router, Request, Response } from "express"; import { User, PrivateUserProjection, emitEvent, UserUpdateEvent, handleFile, FieldErrors } from "@fosscord/util"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; +import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); @@ -32,7 +33,8 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: const body = req.body as UserModifySchema; if (body.avatar) body.avatar = await handleFile(`/avatars/${req.user_id}`, body.avatar as string); - if (body.banner) body.banner = await handleFile(`/banners/${req.user_id}`, body.banner as string);let user = await User.findOneOrFail({ where: { id: req.user_id }, select: [...PrivateUserProjection, "data"] }); + if (body.banner) body.banner = await handleFile(`/banners/${req.user_id}`, body.banner as string); + let user = await User.findOneOrFail({ where: { id: req.user_id }, select: [...PrivateUserProjection, "data"] }); if (body.password) { if (user.data?.hash) { @@ -63,7 +65,7 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: } } - user = Object.assign(user, body); + user = OrmUtils.mergeDeep(user, body); await user.save(); // @ts-ignore diff --git a/api/src/routes/users/@me/relationships.ts b/api/src/routes/users/@me/relationships.ts index 014a5bd20..6e22f4f3a 100644 --- a/api/src/routes/users/@me/relationships.ts +++ b/api/src/routes/users/@me/relationships.ts @@ -12,6 +12,7 @@ import { Router, Response, Request } from "express"; import { HTTPError } from "@fosscord/util"; import { DiscordApiErrors } from "@fosscord/util"; import { route } from "@fosscord/api"; +import { OrmUtils } from "@fosscord/util"; const router = Router(); @@ -140,7 +141,7 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ relationship.type = RelationshipType.blocked; await relationship.save(); } else { - relationship = await Object.assign(new Relationship(), { to_id: id, type: RelationshipType.blocked, from_id: req.user_id }).save(); + relationship = await (OrmUtils.mergeDeep(new Relationship(), { to_id: id, type: RelationshipType.blocked, from_id: req.user_id }) as Relationship).save(); } if (friendRequest && friendRequest.type !== RelationshipType.blocked) { @@ -166,8 +167,8 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ const { maxFriends } = Config.get().limits.user; if (user.relationships.length >= maxFriends) throw DiscordApiErrors.MAXIMUM_FRIENDS.withParams(maxFriends); - let incoming_relationship = Object.assign(new Relationship(), { nickname: undefined, type: RelationshipType.incoming, to: user, from: friend }); - let outgoing_relationship = Object.assign(new Relationship(), { + let incoming_relationship = OrmUtils.mergeDeep(new Relationship(), { nickname: undefined, type: RelationshipType.incoming, to: user, from: friend }); + let outgoing_relationship = OrmUtils.mergeDeep(new Relationship(), { nickname: undefined, type: RelationshipType.outgoing, to: friend, diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 34fb3d05c..0f584c565 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -26,6 +26,7 @@ import { HTTPError } from "@fosscord/util"; import fetch from "node-fetch"; import cheerio from "cheerio"; import { MessageCreateSchema } from "../../routes/channels/#channel_id/messages"; +import { OrmUtils } from "@fosscord/util"; const allow_empty = false; // TODO: check webhook, application, system author, stickers // TODO: embed gifs/videos/images @@ -47,7 +48,7 @@ export async function handleMessage(opts: MessageOptions): Promise { const channel = await Channel.findOneOrFail({ where: { id: opts.channel_id }, relations: ["recipients"] }); if (!channel || !opts.channel_id) throw new HTTPError("Channel not found", 404); - const message = Object.assign(new Message(), { + const message = OrmUtils.mergeDeep(new Message(), { ...opts, sticker_items: opts.sticker_ids?.map((x) => ({ id: x })), guild_id: channel.guild_id, @@ -132,9 +133,9 @@ export async function handleMessage(opts: MessageOptions): Promise { } } - message.mention_channels = mention_channel_ids.map((x) => Object.assign(new Channel(), { id: x })); - message.mention_roles = mention_role_ids.map((x) => Object.assign(new Role(), { id: x })); - message.mentions = mention_user_ids.map((x) => Object.assign(new User(), { id: x })); + message.mention_channels = mention_channel_ids.map((x) => OrmUtils.mergeDeep(new Channel(), { id: x })); + message.mention_roles = mention_role_ids.map((x) => OrmUtils.mergeDeep(new Role(), { id: x })); + message.mentions = mention_user_ids.map((x) => OrmUtils.mergeDeep(new User(), { id: x })); message.mention_everyone = mention_everyone; // TODO: check and put it all in the body diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index c6c24fcda..ca081d02c 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -28,6 +28,7 @@ import { IdentifySchema } from "../schema/Identify"; const experiments: any = []; import { check } from "./instanceOf"; import { Recipient } from "@fosscord/util"; +import { OrmUtils } from "@fosscord/util"; // TODO: user sharding // TODO: check privileged intents, if defined in the config @@ -50,7 +51,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { const session_id = genSessionId(); this.session_id = session_id; //Set the session of the WebSocket object - + const [user, read_states, members, recipients, session, application] = await Promise.all([ User.findOneOrFail({ @@ -83,7 +84,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { // TODO: public user selection }), // save the session and delete it when the websocket is closed - Object.assign(new Session(),{ + await OrmUtils.mergeDeep(new Session(), { user_id: this.user_id, session_id: session_id, // TODO: check if status is only one of: online, dnd, offline, idle diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/gateway/src/opcodes/VoiceStateUpdate.ts index 1f7c2f1b5..d62425f32 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/gateway/src/opcodes/VoiceStateUpdate.ts @@ -12,6 +12,7 @@ import { VoiceState, VoiceStateUpdateEvent, } from "@fosscord/util"; +import { OrmUtils } from "@fosscord/util"; // TODO: check if a voice server is setup // Notice: Bot users respect the voice channel's user limit, if set. When the voice channel is full, you will not receive the Voice State Update or Voice Server Update events in response to your own Voice State Update. Having MANAGE_CHANNELS permission bypasses this limit and allows you to join regardless of the channel being full or not. @@ -47,9 +48,9 @@ export async function onVoiceStateUpdate(this: WebSocket, data: Payload) { //The event send by Discord's client on channel leave has both guild_id and channel_id as null if (body.guild_id === null) body.guild_id = voiceState.guild_id; - voiceState = Object.assign(voiceState, body); + voiceState = OrmUtils.mergeDeep(voiceState, body); } catch (error) { - voiceState = Object.assign(new VoiceState(), { + voiceState = OrmUtils.mergeDeep(new VoiceState(), { ...body, user_id: this.user_id, deaf: false, diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index a7ca647b4..48469103a 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -1,4 +1,5 @@ -import { Column, Entity, JoinColumn, ManyToOne, OneToMany, RelationId } from "typeorm"; +import { Column, Entity, JoinColumn, ManyToOne, OneToMany, RelationId} from "typeorm"; +import { OrmUtils } from "@fosscord/util"; import { BaseClass } from "./BaseClass"; import { Guild } from "./Guild"; import { PublicUserProjection, User } from "./User"; @@ -222,7 +223,7 @@ export class Channel extends BaseClass { }; await Promise.all([ - Object.assign(new Channel(),channel).save(), + OrmUtils.mergeDeep(new Channel(),channel).save(), !opts?.skipEventEmit ? emitEvent({ event: "CHANNEL_CREATE", @@ -263,7 +264,7 @@ export class Channel extends BaseClass { if (containsAll(re, channelRecipients)) { if (channel == null) { channel = ur.channel; - ur = Object.assign(ur, { closed: false }); + ur = OrmUtils.mergeDeep(ur, { closed: false }); await ur.save(); } } @@ -273,7 +274,7 @@ export class Channel extends BaseClass { if (channel == null) { name = trimSpecial(name); - channel = await (Object.assign(new Channel(), { + channel = await (OrmUtils.mergeDeep(new Channel(), { name, type, owner_id: type === ChannelType.DM ? undefined : null, // 1:1 DMs are ownerless in fosscord-server @@ -281,7 +282,7 @@ export class Channel extends BaseClass { last_message_id: null, recipients: channelRecipients.map( (x) => - Object.assign(new Recipient(), { user_id: x, closed: !(type === ChannelType.GROUP_DM || x === creator_user_id) }) + OrmUtils.mergeDeep(new Recipient(), { user_id: x, closed: !(type === ChannelType.GROUP_DM || x === creator_user_id) }) ), }) as Channel).save(); } diff --git a/util/src/entities/Guild.ts b/util/src/entities/Guild.ts index 058033e8c..da8a2c2fb 100644 --- a/util/src/entities/Guild.ts +++ b/util/src/entities/Guild.ts @@ -1,4 +1,5 @@ -import { Column, Entity, JoinColumn, ManyToMany, ManyToOne, OneToMany, OneToOne, RelationId } from "typeorm"; +import { Column, Entity, JoinColumn, ManyToMany, ManyToOne, OneToMany, OneToOne, RelationId} from "typeorm"; +import { OrmUtils } from "@fosscord/util"; import { Config, handleFile, Snowflake } from ".."; import { Ban } from "./Ban"; import { BaseClass } from "./BaseClass"; @@ -285,7 +286,7 @@ export class Guild extends BaseClass { }) { const guild_id = Snowflake.generate(); - const guild: Guild = Object.assign(new Guild(),{ + const guild: Guild = OrmUtils.mergeDeep(new Guild(),{ name: body.name || "Fosscord", icon: await handleFile(`/icons/${guild_id}`, body.icon as string), region: Config.get().regions.default, @@ -321,7 +322,7 @@ export class Guild extends BaseClass { // we have to create the role _after_ the guild because else we would get a "SQLITE_CONSTRAINT: FOREIGN KEY constraint failed" error // TODO: make the @everyone a pseudorole that is dynamically generated at runtime so we can save storage - let role: Role = Object.assign(new Role(), { + let role: Role = OrmUtils.mergeDeep(new Role(), { id: guild_id, guild_id: guild_id, color: 0, diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index e4aa8331b..f0c361d00 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -25,6 +25,7 @@ import { Role } from "./Role"; import { BaseClassWithoutId } from "./BaseClass"; import { Ban, PublicGuildRelations } from "."; import { DiscordApiErrors } from "../util/Constants"; +import { OrmUtils } from "@fosscord/util"; export const MemberPrivateProjection: (keyof Member)[] = [ "id", @@ -161,7 +162,7 @@ export class Member extends BaseClassWithoutId { }), Role.findOneOrFail({ where: { id: role_id, guild_id }, select: ["id"] }), ]); - member.roles.push(Object.assign(new Role(), { id: role_id })); + member.roles.push(OrmUtils.mergeDeep(new Role(), { id: role_id })); await Promise.all([ member.save(), @@ -256,7 +257,7 @@ export class Member extends BaseClassWithoutId { nick: undefined, roles: [guild_id], // @everyone role joined_at: new Date(), - premium_since: (new Date()).getTime(), + premium_since: new Date(), deaf: false, mute: false, pending: false, @@ -264,9 +265,9 @@ export class Member extends BaseClassWithoutId { //TODO: check for bugs if(guild.member_count) guild.member_count++; await Promise.all([ - Object.assign(new Member(), { + OrmUtils.mergeDeep(new Member(), { ...member, - roles: [Object.assign(new Role(), { id: guild_id })], + roles: [OrmUtils.mergeDeep(new Role(), { id: guild_id })], // read_state: {}, settings: { channel_overrides: [], diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 81017c2d9..d023780bf 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -1,4 +1,5 @@ -import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, ManyToMany, OneToMany, RelationId } from "typeorm"; +import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, ManyToMany, OneToMany, RelationId} from "typeorm"; +import { OrmUtils } from "@fosscord/util"; import { BaseClass } from "./BaseClass"; import { BitField } from "../util/BitField"; import { Relationship } from "./Relationship"; @@ -255,7 +256,7 @@ export class User extends BaseClass { // if nsfw_allowed is null/undefined it'll require date_of_birth to set it to true/false const language = req.language === "en" ? "en-US" : req.language || "en-US"; - const user = Object.assign(new User(), { + const user = OrmUtils.mergeDeep(new User(), { created_at: new Date(), username: username, discriminator, diff --git a/util/src/util/imports/OrmUtils.ts b/util/src/util/imports/OrmUtils.ts new file mode 100644 index 000000000..91d88172a --- /dev/null +++ b/util/src/util/imports/OrmUtils.ts @@ -0,0 +1,113 @@ +//source: https://github.com/typeorm/typeorm/blob/master/src/util/OrmUtils.ts +export class OrmUtils { + // Checks if it's an object made by Object.create(null), {} or new Object() + private static isPlainObject(item: any) { + if (item === null || item === undefined) { + return false + } + + return !item.constructor || item.constructor === Object + } + + private static mergeArrayKey( + target: any, + key: number, + value: any, + memo: Map, + ) { + // Have we seen this before? Prevent infinite recursion. + if (memo.has(value)) { + target[key] = memo.get(value) + return + } + + if (value instanceof Promise) { + // Skip promises entirely. + // This is a hold-over from the old code & is because we don't want to pull in + // the lazy fields. Ideally we'd remove these promises via another function first + // but for now we have to do it here. + return + } + + if (!this.isPlainObject(value) && !Array.isArray(value)) { + target[key] = value + return + } + + if (!target[key]) { + target[key] = Array.isArray(value) ? [] : {} + } + + memo.set(value, target[key]) + this.merge(target[key], value, memo) + memo.delete(value) + } + + private static mergeObjectKey( + target: any, + key: string, + value: any, + memo: Map, + ) { + // Have we seen this before? Prevent infinite recursion. + if (memo.has(value)) { + Object.assign(target, { [key]: memo.get(value) }) + return + } + + if (value instanceof Promise) { + // Skip promises entirely. + // This is a hold-over from the old code & is because we don't want to pull in + // the lazy fields. Ideally we'd remove these promises via another function first + // but for now we have to do it here. + return + } + + if (!this.isPlainObject(value) && !Array.isArray(value)) { + Object.assign(target, { [key]: value }) + return + } + + if (!target[key]) { + Object.assign(target, { [key]: value }) + } + + memo.set(value, target[key]) + this.merge(target[key], value, memo) + memo.delete(value) + } + + private static merge( + target: any, + source: any, + memo: Map = new Map(), + ): any { + if (Array.isArray(target) && Array.isArray(source)) { + for (let key = 0; key < source.length; key++) { + this.mergeArrayKey(target, key, source[key], memo) + } + } + else { + for (const key of Object.keys(source)) { + this.mergeObjectKey(target, key, source[key], memo) + } + } + + + } + + /** + * Deep Object.assign. + */ + static mergeDeep(target: any, ...sources: any[]): any { + if (!sources.length) { + return target + } + + for (const source of sources) { + OrmUtils.merge(target, source) + } + + return target + } +} \ No newline at end of file diff --git a/util/src/util/imports/index.ts b/util/src/util/imports/index.ts index 4a4448ba8..18c47a3b9 100644 --- a/util/src/util/imports/index.ts +++ b/util/src/util/imports/index.ts @@ -1,2 +1,3 @@ export * from './Checks'; export * from './HTTPError'; +export * from './OrmUtils'; \ No newline at end of file From 33158d02de721fb617df0f13c95e66ce890a2362 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 22:51:01 +0200 Subject: [PATCH 174/238] Remove todo line that has been implemented. --- api/src/routes/discoverable-guilds.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/api/src/routes/discoverable-guilds.ts b/api/src/routes/discoverable-guilds.ts index 2d1e60b61..35ecf28c2 100644 --- a/api/src/routes/discoverable-guilds.ts +++ b/api/src/routes/discoverable-guilds.ts @@ -11,7 +11,6 @@ router.get("/", route({}), async (req: Request, res: Response) => { let showAllGuilds = Config.get().guild.discovery.showAllGuilds; let configLimit = Config.get().guild.discovery.limit; // ! this only works using SQL querys - // TODO: implement this with default typeorm query // const guilds = await Guild.find({ where: { features: "DISCOVERABLE" } }); //, take: Math.abs(Number(limit)) }); let guilds; if (categories == undefined) { From 597685fd5ce859d99026e49901d3bae6a0c5c891 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 22:52:06 +0200 Subject: [PATCH 175/238] Fix accidental edit in benchmark --- bundle/scripts/benchmark/connections.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bundle/scripts/benchmark/connections.js b/bundle/scripts/benchmark/connections.js index 7e1abc109..661548c38 100644 --- a/bundle/scripts/benchmark/connections.js +++ b/bundle/scripts/benchmark/connections.js @@ -12,7 +12,7 @@ try { } if (!token) { - console.error("TOKEN env let missing"); + console.error("TOKEN env var missing"); process.exit(); } From ee01a689e255bcf8775387b3d5e4e8a6577908a3 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 22:55:14 +0200 Subject: [PATCH 176/238] rename initDatabase to clarify function --- api/src/Server.ts | 4 ++-- cdn/src/Server.ts | 4 ++-- gateway/src/Server.ts | 4 ++-- gateway/src/opcodes/LazyRequest.ts | 4 ++-- util/src/util/Database.ts | 2 +- 5 files changed, 9 insertions(+), 9 deletions(-) diff --git a/api/src/Server.ts b/api/src/Server.ts index f309834b2..136f98145 100644 --- a/api/src/Server.ts +++ b/api/src/Server.ts @@ -1,6 +1,6 @@ import { Server, ServerOptions } from "lambert-server"; import { Authentication, CORS } from "./middlewares/"; -import { Config, initDatabase, initEvent, registerRoutes } from "@fosscord/util"; +import { Config, getOrInitialiseDatabase, initEvent, registerRoutes } from "@fosscord/util"; import { ErrorHandler } from "./middlewares/ErrorHandler"; import { BodyParser } from "./middlewares/BodyParser"; import { Router, Request, Response, NextFunction } from "express"; @@ -32,7 +32,7 @@ export class FosscordServer extends Server { } async start() { - await initDatabase(); + await getOrInitialiseDatabase(); await Config.init(); await initEvent(); await initInstance(); diff --git a/cdn/src/Server.ts b/cdn/src/Server.ts index b8d71fa95..b27d33214 100644 --- a/cdn/src/Server.ts +++ b/cdn/src/Server.ts @@ -1,5 +1,5 @@ import { Server, ServerOptions } from "lambert-server"; -import { Config, initDatabase, registerRoutes } from "@fosscord/util"; +import { Config, getOrInitialiseDatabase, registerRoutes } from "@fosscord/util"; import path from "path"; import avatarsRoute from "./routes/avatars"; import iconsRoute from "./routes/role-icons"; @@ -15,7 +15,7 @@ export class CDNServer extends Server { } async start() { - await initDatabase(); + await getOrInitialiseDatabase(); await Config.init(); this.app.use((req, res, next) => { res.set("Access-Control-Allow-Origin", "*"); diff --git a/gateway/src/Server.ts b/gateway/src/Server.ts index 254820c9b..82fbeba2d 100644 --- a/gateway/src/Server.ts +++ b/gateway/src/Server.ts @@ -1,6 +1,6 @@ import dotenv from "dotenv"; dotenv.config(); -import { closeDatabase, Config, initDatabase, initEvent } from "@fosscord/util"; +import { closeDatabase, Config, getOrInitialiseDatabase, initEvent } from "@fosscord/util"; import ws from "ws"; import { Connection } from "./events/Connection"; import http from "http"; @@ -46,7 +46,7 @@ export class Server { } async start(): Promise { - await initDatabase(); + await getOrInitialiseDatabase(); await Config.init(); await initEvent(); if (!this.server.listening) { diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 0dbdb5261..5ba65cdd7 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -1,4 +1,4 @@ -import { getPermission, listenEvent, Member, Role, initDatabase } from "@fosscord/util"; +import { getPermission, listenEvent, Member, Role, getOrInitialiseDatabase } from "@fosscord/util"; import { LazyRequest } from "../schema/LazyRequest"; import { Send } from "../util/Send"; import { OPCODES } from "../util/Constants"; @@ -17,7 +17,7 @@ async function getMembers(guild_id: string, range: [number, number]) { // TODO: wait for typeorm to implement ordering for .find queries https://github.com/typeorm/typeorm/issues/2620 // TODO: rewrite this, released in 0.3.0 - let members = await (await initDatabase()).getRepository(Member) + let members = await (await getOrInitialiseDatabase()).getRepository(Member) .createQueryBuilder("member") .where("member.guild_id = :guild_id", { guild_id }) .leftJoinAndSelect("member.roles", "role") diff --git a/util/src/util/Database.ts b/util/src/util/Database.ts index d0d39f4c1..84ce473d5 100644 --- a/util/src/util/Database.ts +++ b/util/src/util/Database.ts @@ -15,7 +15,7 @@ import { config } from "dotenv"; let promise: Promise; let dataSource: DataSource; -export async function initDatabase(): Promise { +export async function getOrInitialiseDatabase(): Promise { //if (dataSource) return dataSource; // prevent initalizing multiple times if(dataSource.isInitialized) return dataSource; From aeaa995461e794ebdecf6eb0c67d6745cf1a5300 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 22:57:43 +0200 Subject: [PATCH 177/238] Remove accidental debug logging --- util/src/entities/User.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index d023780bf..3dc8dc961 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -290,8 +290,6 @@ export class User extends BaseClass { notes: {}, }); - console.log("new user") - console.log(user); await user.save(); setImmediate(async () => { From 5bddb3a758d9f74203c4884bde65cc23d2b0d748 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 23:19:06 +0200 Subject: [PATCH 178/238] Fix missing import in refactor --- bundle/src/Server.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/bundle/src/Server.ts b/bundle/src/Server.ts index 71a60d499..81948666f 100644 --- a/bundle/src/Server.ts +++ b/bundle/src/Server.ts @@ -7,7 +7,7 @@ import * as Gateway from "@fosscord/gateway"; import { CDNServer } from "@fosscord/cdn"; import express from "express"; import { green, bold, yellow } from "picocolors"; -import { Config, initDatabase } from "@fosscord/util"; +import { Config, getOrInitialiseDatabase } from "@fosscord/util"; import * as Sentry from "@sentry/node"; import * as Tracing from "@sentry/tracing"; @@ -34,7 +34,7 @@ process.on('SIGTERM', () => { async function main() { server.listen(port); - await initDatabase(); + await getOrInitialiseDatabase(); await Config.init(); // only set endpointPublic, if not already set await Config.set({ From 2dc1046b3eb8a42ad9552808d7811834fddeb188 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 23:23:04 +0200 Subject: [PATCH 179/238] Remove some old test logs that expose info to console --- api/src/routes/auth/login.ts | 1 - api/src/routes/auth/register.ts | 2 -- 2 files changed, 3 deletions(-) diff --git a/api/src/routes/auth/login.ts b/api/src/routes/auth/login.ts index 5df9e2527..daef60566 100644 --- a/api/src/routes/auth/login.ts +++ b/api/src/routes/auth/login.ts @@ -19,7 +19,6 @@ export interface LoginSchema { router.post("/", route({ body: "LoginSchema" }), async (req: Request, res: Response) => { const { login, password, captcha_key, undelete } = req.body as LoginSchema; const email = adjustEmail(login); - console.log("login", email); const config = Config.get(); diff --git a/api/src/routes/auth/register.ts b/api/src/routes/auth/register.ts index 2902c8dd8..2baef98e8 100644 --- a/api/src/routes/auth/register.ts +++ b/api/src/routes/auth/register.ts @@ -166,8 +166,6 @@ router.post("/", route({ body: "RegisterSchema" }), async (req: Request, res: Re await Invite.joinGuild(user.id, body.invite); } - console.log("register", body.email, body.username, ip); - return res.json({ token: await generateToken(user.id) }); }); From 438ed3e4c4296bfa8913c10a5879cee4ae623d7d Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Tue, 9 Aug 2022 23:29:22 +0200 Subject: [PATCH 180/238] Add rights calculator util script --- bundle/scripts/rights.js | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 bundle/scripts/rights.js diff --git a/bundle/scripts/rights.js b/bundle/scripts/rights.js new file mode 100644 index 000000000..89996418b --- /dev/null +++ b/bundle/scripts/rights.js @@ -0,0 +1,36 @@ +const path = require("path"); +const fs = require("fs"); +const { env } = require("process"); +const { execSync } = require("child_process"); +const { argv, stdout, exit } = require("process"); + +const { execIn, getLines, parts } = require("./utils"); + +let lines = fs.readFileSync(path.join(__dirname, "..", "..", "util", "src","util","Rights.ts")).toString() +let lines2 = lines.split("\n"); +let lines3 = lines2.filter(y=>y.includes(": BitFlag(")); +let lines4 = lines3.map(x=>x.split("//")[0].trim()) + +function BitFlag(int) { + return 1n << eval(`${int}n`); +} + +let rights = [] +let maxRights = 0n; +lines4.forEach(x=>{ + maxRights += eval(`rights.${x.replace(':'," = ").replace(",",";")}`) +}) +//max rights... +console.log(`Maximum rights: ${maxRights}`); +//discord rights... +discordRights = maxRights; +discordRights -= rights.SEND_BACKDATED_EVENTS; +discordRights -= rights.MANAGE_GUILD_DIRECTORY; +discordRights -= rights.CREDITABLE; +discordRights -= rights.BYPASS_RATE_LIMITS; +discordRights -= rights.ADD_MEMBERS; +discordRights -= rights.MANAGE_RATE_LIMITS; +discordRights -= rights.OPERATOR; +console.log(`Discord-like rights: ${discordRights}`); + +console.log(lines4) \ No newline at end of file From 7a210b6368a7840fa9b89b8c1c28ce85088760b7 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Tue, 9 Aug 2022 23:32:43 +0200 Subject: [PATCH 181/238] Remove debug log from rights util script --- bundle/scripts/rights.js | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/bundle/scripts/rights.js b/bundle/scripts/rights.js index 89996418b..c363b0c50 100644 --- a/bundle/scripts/rights.js +++ b/bundle/scripts/rights.js @@ -31,6 +31,4 @@ discordRights -= rights.BYPASS_RATE_LIMITS; discordRights -= rights.ADD_MEMBERS; discordRights -= rights.MANAGE_RATE_LIMITS; discordRights -= rights.OPERATOR; -console.log(`Discord-like rights: ${discordRights}`); - -console.log(lines4) \ No newline at end of file +console.log(`Discord-like rights: ${discordRights}`); \ No newline at end of file From 3a5ca274da7575fa64f4ce0bfffc5ed4aa480724 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Tue, 9 Aug 2022 23:42:12 +0200 Subject: [PATCH 182/238] Add index in member query, fixes missing column in query --- util/src/util/Permissions.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/util/src/util/Permissions.ts b/util/src/util/Permissions.ts index d3efb70c1..c7400303e 100644 --- a/util/src/util/Permissions.ts +++ b/util/src/util/Permissions.ts @@ -238,6 +238,7 @@ export async function getPermission( select: [ "id", "roles", + "index", // @ts-ignore ...(opts.member_select || []), ], From 6765bfafa76bbc5a56c1c01da22281d3673f665d Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Tue, 9 Aug 2022 23:44:48 +0200 Subject: [PATCH 183/238] fix(util): util imports --- util/src/entities/Channel.ts | 58 +++++++++++++++++++----------------- util/src/entities/Guild.ts | 10 +++---- util/src/entities/Member.ts | 14 ++++----- util/src/entities/User.ts | 5 ++-- util/src/util/Config.ts | 2 +- util/src/util/index.ts | 4 ++- 6 files changed, 48 insertions(+), 45 deletions(-) diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 48469103a..35f1956c0 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -1,9 +1,9 @@ -import { Column, Entity, JoinColumn, ManyToOne, OneToMany, RelationId} from "typeorm"; -import { OrmUtils } from "@fosscord/util"; +import { Column, Entity, JoinColumn, ManyToOne, OneToMany, RelationId } from "typeorm"; +import { OrmUtils } from "typeorm/util/OrmUtils"; import { BaseClass } from "./BaseClass"; import { Guild } from "./Guild"; import { PublicUserProjection, User } from "./User"; -import { HTTPError } from ".."; +import { HTTPError } from "../util/imports/HTTPError"; import { containsAll, emitEvent, getPermission, Snowflake, trimSpecial, InvisibleCharacters } from "../util"; import { ChannelCreateEvent, ChannelRecipientRemoveEvent } from "../interfaces"; import { Recipient } from "./Recipient"; @@ -35,7 +35,7 @@ export enum ChannelType { KANBAN = 34, // confluence like kanban board VOICELESS_WHITEBOARD = 35, // whiteboard but without voice (whiteboard + voice is the same as stage) CUSTOM_START = 64, // start custom channel types from here - UNHANDLED = 255 // unhandled unowned pass-through channel type + UNHANDLED = 255, // unhandled unowned pass-through channel type } @Entity("channels") @@ -150,7 +150,7 @@ export class Channel extends BaseClass { orphanedRowAction: "delete", }) webhooks?: Webhook[]; - + // TODO: DM channel static async createChannel( channel: Partial, @@ -177,16 +177,14 @@ export class Channel extends BaseClass { throw new HTTPError("Channel name cannot include invalid characters", 403); if (channel.name.match(/\-\-+/g)) - throw new HTTPError("Channel name cannot include multiple adjacent dashes.", 403) + throw new HTTPError("Channel name cannot include multiple adjacent dashes.", 403); - if (channel.name.charAt(0) === "-" || - channel.name.charAt(channel.name.length - 1) === "-") - throw new HTTPError("Channel name cannot start/end with dash.", 403) + if (channel.name.charAt(0) === "-" || channel.name.charAt(channel.name.length - 1) === "-") + throw new HTTPError("Channel name cannot start/end with dash.", 403); } if (!guild.features.includes("ALLOW_UNNAMED_CHANNELS")) { - if (!channel.name) - throw new HTTPError("Channel name cannot be empty.", 403); + if (!channel.name) throw new HTTPError("Channel name cannot be empty.", 403); } } @@ -223,13 +221,13 @@ export class Channel extends BaseClass { }; await Promise.all([ - OrmUtils.mergeDeep(new Channel(),channel).save(), + OrmUtils.mergeDeep(new Channel(), channel).save(), !opts?.skipEventEmit ? emitEvent({ - event: "CHANNEL_CREATE", - data: channel, - guild_id: channel.guild_id, - } as ChannelCreateEvent) + event: "CHANNEL_CREATE", + data: channel, + guild_id: channel.guild_id, + } as ChannelCreateEvent) : Promise.resolve(), ]); @@ -274,17 +272,21 @@ export class Channel extends BaseClass { if (channel == null) { name = trimSpecial(name); - channel = await (OrmUtils.mergeDeep(new Channel(), { - name, - type, - owner_id: type === ChannelType.DM ? undefined : null, // 1:1 DMs are ownerless in fosscord-server - created_at: new Date(), - last_message_id: null, - recipients: channelRecipients.map( - (x) => - OrmUtils.mergeDeep(new Recipient(), { user_id: x, closed: !(type === ChannelType.GROUP_DM || x === creator_user_id) }) - ), - }) as Channel).save(); + channel = await ( + OrmUtils.mergeDeep(new Channel(), { + name, + type, + owner_id: type === ChannelType.DM ? undefined : null, // 1:1 DMs are ownerless in fosscord-server + created_at: new Date(), + last_message_id: null, + recipients: channelRecipients.map((x) => + OrmUtils.mergeDeep(new Recipient(), { + user_id: x, + closed: !(type === ChannelType.GROUP_DM || x === creator_user_id), + }) + ), + }) as Channel + ).save(); } const channel_dto = await DmChannelDTO.from(channel); @@ -301,7 +303,7 @@ export class Channel extends BaseClass { await emitEvent({ event: "CHANNEL_CREATE", data: channel_dto, user_id: creator_user_id }); } - if (recipients.length === 1) return channel_dto; + if (recipients.length === 1) return channel_dto; else return channel_dto.excludedRecipients([creator_user_id]); } diff --git a/util/src/entities/Guild.ts b/util/src/entities/Guild.ts index da8a2c2fb..c314ecb9e 100644 --- a/util/src/entities/Guild.ts +++ b/util/src/entities/Guild.ts @@ -1,5 +1,5 @@ -import { Column, Entity, JoinColumn, ManyToMany, ManyToOne, OneToMany, OneToOne, RelationId} from "typeorm"; -import { OrmUtils } from "@fosscord/util"; +import { Column, Entity, JoinColumn, ManyToMany, ManyToOne, OneToMany, OneToOne, RelationId } from "typeorm"; +import { OrmUtils } from "typeorm/util/OrmUtils"; import { Config, handleFile, Snowflake } from ".."; import { Ban } from "./Ban"; import { BaseClass } from "./BaseClass"; @@ -270,7 +270,7 @@ export class Guild extends BaseClass { @Column({ nullable: true }) nsfw?: boolean; - + // TODO: nested guilds @Column({ nullable: true }) parent?: string; @@ -286,7 +286,7 @@ export class Guild extends BaseClass { }) { const guild_id = Snowflake.generate(); - const guild: Guild = OrmUtils.mergeDeep(new Guild(),{ + const guild: Guild = OrmUtils.mergeDeep(new Guild(), { name: body.name || "Fosscord", icon: await handleFile(`/icons/${guild_id}`, body.icon as string), region: Config.get().regions.default, @@ -334,7 +334,7 @@ export class Guild extends BaseClass { permissions: String("2251804225"), position: 0, icon: null, - unicode_emoji: null + unicode_emoji: null, }); await role.save(); diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index f0c361d00..c356c26d7 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -20,12 +20,12 @@ import { GuildMemberRemoveEvent, GuildMemberUpdateEvent, } from "../interfaces"; -import { HTTPError } from ".."; +import { HTTPError } from "../util/imports/HTTPError"; import { Role } from "./Role"; import { BaseClassWithoutId } from "./BaseClass"; import { Ban, PublicGuildRelations } from "."; import { DiscordApiErrors } from "../util/Constants"; -import { OrmUtils } from "@fosscord/util"; +import { OrmUtils } from "typeorm/util/OrmUtils"; export const MemberPrivateProjection: (keyof Member)[] = [ "id", @@ -71,7 +71,7 @@ export class Member extends BaseClassWithoutId { @Column({ nullable: true }) nick?: string; - + @JoinTable({ name: "member_roles", joinColumn: { name: "index", referencedColumnName: "index" }, @@ -103,14 +103,14 @@ export class Member extends BaseClassWithoutId { @Column({ nullable: true }) last_message_id?: string; - + /** @JoinColumn({ name: "id" }) @ManyToOne(() => User, { onDelete: "DO NOTHING", // do not auto-kick force-joined members just because their joiners left the server }) **/ - @Column({ nullable: true}) + @Column({ nullable: true }) joined_by?: string; // TODO: add this when we have proper read receipts @@ -129,7 +129,7 @@ export class Member extends BaseClassWithoutId { // use promise all to execute all promises at the same time -> save time //TODO: check for bugs - if(guild.member_count) guild.member_count--; + if (guild.member_count) guild.member_count--; return Promise.all([ Member.delete({ id: user_id, @@ -263,7 +263,7 @@ export class Member extends BaseClassWithoutId { pending: false, }; //TODO: check for bugs - if(guild.member_count) guild.member_count++; + if (guild.member_count) guild.member_count++; await Promise.all([ OrmUtils.mergeDeep(new Member(), { ...member, diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 3dc8dc961..7cd6c3d81 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -1,12 +1,11 @@ -import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, ManyToMany, OneToMany, RelationId} from "typeorm"; -import { OrmUtils } from "@fosscord/util"; +import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, OneToMany } from "typeorm"; +import { OrmUtils } from "typeorm/util/OrmUtils"; import { BaseClass } from "./BaseClass"; import { BitField } from "../util/BitField"; import { Relationship } from "./Relationship"; import { ConnectedAccount } from "./ConnectedAccount"; import { Config, FieldErrors, Snowflake, trimSpecial } from ".."; import { Member, Session } from "."; -import { Note } from "./Note"; export enum PublicUserEnum { username, diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index 97a73858a..587e9235b 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -5,7 +5,7 @@ import fs from "fs"; // TODO: yaml instead of json // const overridePath = path.join(process.cwd(), "config.json"); -let config: ConfigValue; +let config: ConfigValue = DefaultConfigOptions; let pairs: ConfigEntity[]; // TODO: use events to inform about config updates diff --git a/util/src/util/index.ts b/util/src/util/index.ts index cfad53f3b..9e6059fa4 100644 --- a/util/src/util/index.ts +++ b/util/src/util/index.ts @@ -1,6 +1,8 @@ export * from "./ApiError"; export * from "./BitField"; export * from "./Token"; +export * from "./imports/HTTPError"; +export * from "./imports/OrmUtils"; //export * from "./Categories"; export * from "./cdn"; export * from "./Config"; @@ -21,4 +23,4 @@ export * from "./Array"; export * from "./TraverseDirectory"; export * from "./InvisibleCharacters"; -export * from "./imports/index" +export * from "./imports/index"; From 9f8aa22b3391dc307cbe17255be3f3b457177886 Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Tue, 9 Aug 2022 23:45:27 +0200 Subject: [PATCH 184/238] wip(util): benchmark --- util/.gitignore | 2 ++ util/scripts/benchmark.js | 22 ++++++++++++++++++++++ 2 files changed, 24 insertions(+) create mode 100644 util/scripts/benchmark.js diff --git a/util/.gitignore b/util/.gitignore index 872637624..768a04259 100644 --- a/util/.gitignore +++ b/util/.gitignore @@ -15,6 +15,8 @@ pids *.seed *.pid.lock +yarn.lock + # Directory for instrumented libs generated by jscoverage/JSCover lib-cov diff --git a/util/scripts/benchmark.js b/util/scripts/benchmark.js new file mode 100644 index 000000000..f4f34e9ef --- /dev/null +++ b/util/scripts/benchmark.js @@ -0,0 +1,22 @@ +const typeorm = require("typeorm"); +const Database = require("../dist/util/Database"); +const Models = require("../dist/entities"); + +function shouldIncludeEntity(name) { + return ![BaseClassWithoutId, PrimaryColumn, BaseClass, PrimaryGeneratedColumn].map((x) => x.name).includes(name); +} + +async function main() { + const db = new typeorm.DataSource({ + driver: "sqlite", + database: ":memory:", + entities: Object.values(Models).filter((x) => x.constructor.name == "Function" && shouldIncludeEntity(x.name)), + }); + await db.initialize(); + + for (var i = 0; i < 100; i++) { + await Models.User.register({ username: "User" + i }); + console.log("registered user " + i); + } +} +main(); From 9a5ccd6a9de2a23dbedb832f4e731db06f0381c5 Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Wed, 10 Aug 2022 00:31:01 +0200 Subject: [PATCH 185/238] fix(util): OrmUtils --- util/scripts/benchmark.js | 12 +++++++++--- util/src/entities/Channel.ts | 2 +- util/src/entities/Guild.ts | 2 +- util/src/entities/Member.ts | 2 +- util/src/entities/User.ts | 6 +++--- 5 files changed, 15 insertions(+), 9 deletions(-) diff --git a/util/scripts/benchmark.js b/util/scripts/benchmark.js index f4f34e9ef..e74351916 100644 --- a/util/scripts/benchmark.js +++ b/util/scripts/benchmark.js @@ -1,22 +1,28 @@ const typeorm = require("typeorm"); -const Database = require("../dist/util/Database"); const Models = require("../dist/entities"); +const { PrimaryColumn } = require("typeorm"); function shouldIncludeEntity(name) { - return ![BaseClassWithoutId, PrimaryColumn, BaseClass, PrimaryGeneratedColumn].map((x) => x.name).includes(name); + return ![Models.BaseClassWithoutId, PrimaryColumn, Models.BaseClass, Models.PrimaryGeneratedColumn] + .map((x) => x?.name) + .includes(name); } async function main() { + console.log("starting"); const db = new typeorm.DataSource({ - driver: "sqlite", + type: "sqlite", database: ":memory:", entities: Object.values(Models).filter((x) => x.constructor.name == "Function" && shouldIncludeEntity(x.name)), + synchronize: true, }); await db.initialize(); + console.log("Initialized database"); for (var i = 0; i < 100; i++) { await Models.User.register({ username: "User" + i }); console.log("registered user " + i); } } + main(); diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 35f1956c0..92940b345 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -1,5 +1,5 @@ import { Column, Entity, JoinColumn, ManyToOne, OneToMany, RelationId } from "typeorm"; -import { OrmUtils } from "typeorm/util/OrmUtils"; +import { OrmUtils } from "../util/imports/OrmUtils"; import { BaseClass } from "./BaseClass"; import { Guild } from "./Guild"; import { PublicUserProjection, User } from "./User"; diff --git a/util/src/entities/Guild.ts b/util/src/entities/Guild.ts index c314ecb9e..77a04350d 100644 --- a/util/src/entities/Guild.ts +++ b/util/src/entities/Guild.ts @@ -1,5 +1,5 @@ import { Column, Entity, JoinColumn, ManyToMany, ManyToOne, OneToMany, OneToOne, RelationId } from "typeorm"; -import { OrmUtils } from "typeorm/util/OrmUtils"; +import { OrmUtils } from "../util/imports/OrmUtils"; import { Config, handleFile, Snowflake } from ".."; import { Ban } from "./Ban"; import { BaseClass } from "./BaseClass"; diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index c356c26d7..d4395e03b 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -25,7 +25,7 @@ import { Role } from "./Role"; import { BaseClassWithoutId } from "./BaseClass"; import { Ban, PublicGuildRelations } from "."; import { DiscordApiErrors } from "../util/Constants"; -import { OrmUtils } from "typeorm/util/OrmUtils"; +import { OrmUtils } from "../util/imports/OrmUtils"; export const MemberPrivateProjection: (keyof Member)[] = [ "id", diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 7cd6c3d81..7e3c74570 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -1,5 +1,5 @@ import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, OneToMany } from "typeorm"; -import { OrmUtils } from "typeorm/util/OrmUtils"; +import { OrmUtils } from "../util/imports/OrmUtils"; import { BaseClass } from "./BaseClass"; import { BitField } from "../util/BitField"; import { Relationship } from "./Relationship"; @@ -245,7 +245,7 @@ export class User extends BaseClass { throw FieldErrors({ username: { code: "USERNAME_TOO_MANY_USERS", - message: req.t("auth:register.USERNAME_TOO_MANY_USERS"), + message: req?.t("auth:register.USERNAME_TOO_MANY_USERS"), }, }); } @@ -253,7 +253,7 @@ export class User extends BaseClass { // TODO: save date_of_birth // appearently discord doesn't save the date of birth and just calculate if nsfw is allowed // if nsfw_allowed is null/undefined it'll require date_of_birth to set it to true/false - const language = req.language === "en" ? "en-US" : req.language || "en-US"; + const language = req?.language === "en" ? "en-US" : req?.language || "en-US"; const user = OrmUtils.mergeDeep(new User(), { created_at: new Date(), From 56322bc2631a36f424ee12fe91df03d3f7989202 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Wed, 10 Aug 2022 02:34:53 +0200 Subject: [PATCH 186/238] Don't use default config as config. --- util/src/util/Config.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index 587e9235b..97a73858a 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -5,7 +5,7 @@ import fs from "fs"; // TODO: yaml instead of json // const overridePath = path.join(process.cwd(), "config.json"); -let config: ConfigValue = DefaultConfigOptions; +let config: ConfigValue; let pairs: ConfigEntity[]; // TODO: use events to inform about config updates From 92b4c5ca355b596f8f9618cace664840c40522bd Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Wed, 10 Aug 2022 04:36:41 +0200 Subject: [PATCH 187/238] Fix heartbeat not accepting d == null --- gateway/src/events/Message.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gateway/src/events/Message.ts b/gateway/src/events/Message.ts index 71b6f2069..7ed1dd067 100644 --- a/gateway/src/events/Message.ts +++ b/gateway/src/events/Message.ts @@ -37,7 +37,7 @@ export async function Message(this: WebSocket, buffer: WS.RawData) { if(data.op !== 1) check.call(this, PayloadSchema, data); else { //custom validation for numbers, because heartbeat - if(data.s || data.t || typeof data.d !== "number") { + if(data.s || data.t || (typeof data.d !== "number" && data.d)) { console.log("Invalid heartbeat..."); this.close(CLOSECODES.Decode_error); } From eb07664e935e56bd744a11c752e6a05aae902035 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Wed, 10 Aug 2022 04:59:32 +0200 Subject: [PATCH 188/238] Make sigterm exit after 3 seconds to resolve hang under systemd --- bundle/src/Server.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/bundle/src/Server.ts b/bundle/src/Server.ts index 81948666f..3ed98b153 100644 --- a/bundle/src/Server.ts +++ b/bundle/src/Server.ts @@ -26,6 +26,7 @@ const gateway = new Gateway.Server({ server, port, production }); //this is what has been added for the /stop API route process.on('SIGTERM', () => { + setTimeout(()=>process.exit(0), 3000) server.close(() => { console.log("Stop API has been successfully POSTed, SIGTERM sent") }) From 4f6e59e936dd9dfc10bebe7ac10dea8c0d96e6ec Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Wed, 10 Aug 2022 02:53:29 -0600 Subject: [PATCH 189/238] Add basic developer panel functionality - doesn't work yet > > > Co-authored-by: TheArcaneBrony --- .gitignore | 4 +- api/client_test/developers.html | 76 +-- api/src/routes/applications/#id/bot/index.ts | 83 +++ api/src/routes/applications/#id/index.ts | 27 + api/src/routes/applications/#id/skus.ts | 11 + api/src/routes/applications/index.ts | 28 +- gateway/src/opcodes/Identify.ts | 2 +- util/src/entities/Application.ts | 116 +++- util/src/entities/User.ts | 2 +- util/src/interfaces/Event.ts | 2 +- .../sqlite/1660110227241-modern_apps.ts | 623 ++++++++++++++++++ .../migrations/sqlite/1660110592990-apps2.ts | 220 +++++++ .../migrations/sqlite/1660110798713-yes.ts | 428 ++++++++++++ .../sqlite/1660112323115-defaults_apps.ts | 428 ++++++++++++ 14 files changed, 1972 insertions(+), 78 deletions(-) create mode 100644 api/src/routes/applications/#id/bot/index.ts create mode 100644 api/src/routes/applications/#id/index.ts create mode 100644 api/src/routes/applications/#id/skus.ts create mode 100644 util/src/migrations/sqlite/1660110227241-modern_apps.ts create mode 100644 util/src/migrations/sqlite/1660110592990-apps2.ts create mode 100644 util/src/migrations/sqlite/1660110798713-yes.ts create mode 100644 util/src/migrations/sqlite/1660112323115-defaults_apps.ts diff --git a/.gitignore b/.gitignore index c4d703d25..98adcd003 100644 --- a/.gitignore +++ b/.gitignore @@ -16,4 +16,6 @@ api/assets/plugins/*.js *.log *.log.ansi -bundle/depclean.* \ No newline at end of file +bundle/depclean.* +*.tmp +tmp/ diff --git a/api/client_test/developers.html b/api/client_test/developers.html index 2a4402d75..87595e779 100644 --- a/api/client_test/developers.html +++ b/api/client_test/developers.html @@ -1,42 +1,44 @@ - - - - - - Discord Test Client Developer Portal - - + + + - -

- - - - - - + +
+ + + + + + + \ No newline at end of file diff --git a/api/src/routes/applications/#id/bot/index.ts b/api/src/routes/applications/#id/bot/index.ts new file mode 100644 index 000000000..82c09c4d1 --- /dev/null +++ b/api/src/routes/applications/#id/bot/index.ts @@ -0,0 +1,83 @@ +import { Request, Response, Router } from "express"; +import { route } from "@fosscord/api"; +import { Application, Config, FieldErrors, generateToken, OrmUtils, Snowflake, trimSpecial, User } from "@fosscord/util"; +import { HTTPError } from "lambert-server"; +import { verifyToken } from "node-2fa"; + +const router: Router = Router(); + +router.post("/", route({}), async (req: Request, res: Response) => { + const app = await Application.findOne({where: {id: req.params.id}}); + if(!app) return res.status(404); + const username = trimSpecial(app.name); + const discriminator = await User.generateDiscriminator(username); + if (!discriminator) { + // We've failed to generate a valid and unused discriminator + throw FieldErrors({ + username: { + code: "USERNAME_TOO_MANY_USERS", + message: req?.t("auth:register.USERNAME_TOO_MANY_USERS"), + }, + }); + } + + const user = OrmUtils.mergeDeep(new User(), { + created_at: new Date(), + username: username, + discriminator, + id: app.id, + bot: true, + system: false, + premium_since: new Date(), + desktop: false, + mobile: false, + premium: true, + premium_type: 2, + bio: app.description, + mfa_enabled: false, + totp_secret: "", + totp_backup_codes: [], + verified: true, + disabled: false, + deleted: false, + email: null, + rights: Config.get().register.defaultRights, + nsfw_allowed: true, + public_flags: "0", + flags: "0", + data: { + hash: null, + valid_tokens_since: new Date(), + }, + settings: {}, + extended_settings: {}, + fingerprints: [], + notes: {}, + }); + await user.save(); + app.bot = user; + await app.save(); + res.send().status(204) +}); + +router.post("/reset", route({}), async (req: Request, res: Response) => { + let bot = await User.findOne({where: {id: req.params.id}}); + let owner = await User.findOne({where: {id: req.user_id}}); + if(!bot) return res.status(404); + if(owner?.totp_secret && (!req.body.code || verifyToken(owner.totp_secret, req.body.code))) { + throw new HTTPError(req.t("auth:login.INVALID_TOTP_CODE"), 60008); + } + bot.data = { hash: undefined, valid_tokens_since: new Date() }; + await bot.save(); + let token = await generateToken(bot.id); + res.json({token}).status(200); +}); + +router.patch("/", route({}), async (req: Request, res: Response) => { + delete req.body.icon; + let app = OrmUtils.mergeDeep(await User.findOne({where: {id: req.params.id}}), req.body); + await app.save(); + res.json(app).status(200); +}); + +export default router; \ No newline at end of file diff --git a/api/src/routes/applications/#id/index.ts b/api/src/routes/applications/#id/index.ts new file mode 100644 index 000000000..be8c3ba4f --- /dev/null +++ b/api/src/routes/applications/#id/index.ts @@ -0,0 +1,27 @@ +import { Request, Response, Router } from "express"; +import { route } from "@fosscord/api"; +import { Application, OrmUtils, Team, trimSpecial, User } from "@fosscord/util"; + +const router: Router = Router(); + +router.get("/", route({}), async (req: Request, res: Response) => { + //TODO + let results = await Application.findOne({where: {id: req.params.id}, relations: ["owner", "bot"] }); + //debugger; + res.json(results).status(200); +}); + +router.patch("/", route({}), async (req: Request, res: Response) => { + delete req.body.icon; + let app = OrmUtils.mergeDeep(await Application.findOne({where: {id: req.params.id}, relations: ["owner", "bot"]}), req.body); + if(app.bot) { + app.bot.bio = req.body.description + app.bot?.save(); + } + if(req.body.tags) app.tags = req.body.tags; + await app.save(); + debugger; + res.json(app).status(200); +}); + +export default router; \ No newline at end of file diff --git a/api/src/routes/applications/#id/skus.ts b/api/src/routes/applications/#id/skus.ts new file mode 100644 index 000000000..5b667f36d --- /dev/null +++ b/api/src/routes/applications/#id/skus.ts @@ -0,0 +1,11 @@ +import { Request, Response, Router } from "express"; +import { route } from "@fosscord/api"; +import { Application, OrmUtils, Team, trimSpecial, User } from "@fosscord/util"; + +const router: Router = Router(); + +router.get("/", route({}), async (req: Request, res: Response) => { + res.json([]).status(200); +}); + +export default router; \ No newline at end of file diff --git a/api/src/routes/applications/index.ts b/api/src/routes/applications/index.ts index 28ce42dae..c9be11310 100644 --- a/api/src/routes/applications/index.ts +++ b/api/src/routes/applications/index.ts @@ -1,11 +1,35 @@ import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; +import { Application, OrmUtils, Team, trimSpecial, User } from "@fosscord/util"; const router: Router = Router(); +export interface ApplicationCreateSchema { + name: string; + team_id?: string | number; +} + router.get("/", route({}), async (req: Request, res: Response) => { //TODO - res.send([]).status(200); + let results = await Application.find({where: {owner: {id: req.user_id}}, relations: ["owner"] }); + res.json(results).status(200); }); -export default router; +router.post("/", route({}), async (req: Request, res: Response) => { + const body = req.body as ApplicationCreateSchema; + const user = await User.findOne({where: {id: req.user_id}}) + if(!user) res.status(420); + let app = OrmUtils.mergeDeep(new Application(), { + name: trimSpecial(body.name), + description: "", + bot_public: true, + bot_require_code_grant: false, + owner: user, + verify_key: "IMPLEMENTME", + flags: "" + }); + await app.save(); + res.json(app).status(200); +}); + +export default router; \ No newline at end of file diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index ca081d02c..03fff7967 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -232,7 +232,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { const d: ReadyEventData = { v: 8, - application: {id: application?.id??'', flags: application?.flags??''}, //TODO: check this code! + application: {id: application?.id??'', flags: application?.flags??0}, //TODO: check this code! user: privateUser, user_settings: user.settings, // @ts-ignore diff --git a/util/src/entities/Application.ts b/util/src/entities/Application.ts index fab3d93ff..283815798 100644 --- a/util/src/entities/Application.ts +++ b/util/src/entities/Application.ts @@ -1,4 +1,4 @@ -import { Column, Entity, JoinColumn, ManyToOne, RelationId } from "typeorm"; +import { Column, Entity, JoinColumn, ManyToOne, OneToOne, RelationId } from "typeorm"; import { BaseClass } from "./BaseClass"; import { Guild } from "./Guild"; import { Team } from "./Team"; @@ -8,21 +8,77 @@ import { User } from "./User"; export class Application extends BaseClass { @Column() name: string; - + @Column({ nullable: true }) icon?: string; - - @Column() + + @Column({ nullable: true }) description: string; - + + @Column({ nullable: true }) + summary: string = ""; + + @Column({ type: "simple-json", nullable: true }) + type?: any; + + @Column() + hook: boolean = true; + + @Column() + bot_public?: boolean = true; + + @Column() + bot_require_code_grant?: boolean = false; + + @Column() + verify_key: string; + + @JoinColumn({ name: "owner_id" }) + @ManyToOne(() => User) + owner: User; + + @Column() + flags: number = 0; + @Column({ type: "simple-array", nullable: true }) - rpc_origins?: string[]; - - @Column() - bot_public: boolean; - - @Column() - bot_require_code_grant: boolean; + redirect_uris: string[] = []; + + @Column({ nullable: true }) + rpc_application_state: number = 0; + + @Column({ nullable: true }) + store_application_state: number = 1; + + @Column({ nullable: true }) + verification_state: number = 1; + + @Column({ nullable: true }) + interactions_endpoint_url?: string; + + @Column({ nullable: true }) + integration_public: boolean = true; + + @Column({ nullable: true }) + integration_require_code_grant: boolean = false; + + @Column({ nullable: true }) + discoverability_state: number = 1; + + @Column({ nullable: true }) + discovery_eligibility_flags: number = 2240; + + @JoinColumn({ name: "bot_user_id" }) + @OneToOne(() => User) + bot?: User; + + @Column({ type: "simple-array", nullable: true }) + tags?: string[]; + + @Column({ nullable: true }) + cover_image?: string; // the application's default rich presence invite cover image hash + + @Column({ type: "simple-json", nullable: true }) + install_params?: {scopes: string[], permissions: string}; @Column({ nullable: true }) terms_of_service_url?: string; @@ -30,15 +86,20 @@ export class Application extends BaseClass { @Column({ nullable: true }) privacy_policy_url?: string; - @JoinColumn({ name: "owner_id" }) - @ManyToOne(() => User) - owner?: User; + //just for us - @Column({ nullable: true }) - summary?: string; + //@Column({ type: "simple-array", nullable: true }) + //rpc_origins?: string[]; + + //@JoinColumn({ name: "guild_id" }) + //@ManyToOne(() => Guild) + //guild?: Guild; // if this application is a game sold, this field will be the guild to which it has been linked - @Column() - verify_key: string; + //@Column({ nullable: true }) + //primary_sku_id?: string; // if this application is a game sold, this field will be the id of the "Game SKU" that is created, + + //@Column({ nullable: true }) + //slug?: string; // if this application is a game sold, this field will be the URL slug that links to the store page @JoinColumn({ name: "team_id" }) @ManyToOne(() => Team, { @@ -46,22 +107,7 @@ export class Application extends BaseClass { }) team?: Team; - @JoinColumn({ name: "guild_id" }) - @ManyToOne(() => Guild) - guild: Guild; // if this application is a game sold, this field will be the guild to which it has been linked - - @Column({ nullable: true }) - primary_sku_id?: string; // if this application is a game sold, this field will be the id of the "Game SKU" that is created, - - @Column({ nullable: true }) - slug?: string; // if this application is a game sold, this field will be the URL slug that links to the store page - - @Column({ nullable: true }) - cover_image?: string; // the application's default rich presence invite cover image hash - - @Column() - flags: string; // the application's public flags -} + } export interface ApplicationCommand { id: string; diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 7e3c74570..a9f00b0d1 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -194,7 +194,7 @@ export class User extends BaseClass { }); } - private static async generateDiscriminator(username: string): Promise { + public static async generateDiscriminator(username: string): Promise { if (Config.get().register.incrementingDiscriminators) { // discriminator will be incrementally generated diff --git a/util/src/interfaces/Event.ts b/util/src/interfaces/Event.ts index 416082eda..f3391c4f7 100644 --- a/util/src/interfaces/Event.ts +++ b/util/src/interfaces/Event.ts @@ -93,7 +93,7 @@ export interface ReadyEventData { }; application?: { id: string; - flags: string; + flags: number; }; merged_members?: PublicMember[][]; // probably all users who the user is in contact with diff --git a/util/src/migrations/sqlite/1660110227241-modern_apps.ts b/util/src/migrations/sqlite/1660110227241-modern_apps.ts new file mode 100644 index 000000000..34c0b4b25 --- /dev/null +++ b/util/src/migrations/sqlite/1660110227241-modern_apps.ts @@ -0,0 +1,623 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class modernApps1660110227241 implements MigrationInterface { + name = 'modernApps1660110227241' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "primary_sku_id" varchar, + "slug" varchar, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "guild_id" varchar, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + ) + SELECT "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text NOT NULL, + "hook" boolean NOT NULL, + "redirect_uris" text NOT NULL, + "rpc_application_state" integer NOT NULL, + "store_application_state" integer NOT NULL, + "verification_state" integer NOT NULL, + "interactions_endpoint_url" varchar NOT NULL, + "integration_public" boolean NOT NULL, + "integration_require_code_grant" boolean NOT NULL, + "discoverability_state" integer NOT NULL, + "discovery_eligibility_flags" integer NOT NULL, + "tags" text NOT NULL, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text NOT NULL, + "hook" boolean NOT NULL, + "redirect_uris" text NOT NULL, + "rpc_application_state" integer NOT NULL, + "store_application_state" integer NOT NULL, + "verification_state" integer NOT NULL, + "interactions_endpoint_url" varchar NOT NULL, + "integration_public" boolean NOT NULL, + "integration_require_code_grant" boolean NOT NULL, + "discoverability_state" integer NOT NULL, + "discovery_eligibility_flags" integer NOT NULL, + "tags" text NOT NULL, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text NOT NULL, + "hook" boolean NOT NULL, + "redirect_uris" text NOT NULL, + "rpc_application_state" integer NOT NULL, + "store_application_state" integer NOT NULL, + "verification_state" integer NOT NULL, + "interactions_endpoint_url" varchar NOT NULL, + "integration_public" boolean NOT NULL, + "integration_require_code_grant" boolean NOT NULL, + "discoverability_state" integer NOT NULL, + "discovery_eligibility_flags" integer NOT NULL, + "tags" text NOT NULL, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "primary_sku_id" varchar, + "slug" varchar, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "guild_id" varchar, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "rpc_origins" text, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "primary_sku_id" varchar, + "slug" varchar, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "guild_id" varchar, + CONSTRAINT "FK_e5bf78cdbbe9ba91062d74c5aba" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + ) + SELECT "id", + "name", + "icon", + "description", + "rpc_origins", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "primary_sku_id", + "slug", + "cover_image", + "flags", + "owner_id", + "team_id", + "guild_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660110592990-apps2.ts b/util/src/migrations/sqlite/1660110592990-apps2.ts new file mode 100644 index 000000000..06f5885d2 --- /dev/null +++ b/util/src/migrations/sqlite/1660110592990-apps2.ts @@ -0,0 +1,220 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class apps21660110592990 implements MigrationInterface { + name = 'apps21660110592990' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar NOT NULL, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text NOT NULL, + "hook" boolean NOT NULL, + "redirect_uris" text NOT NULL, + "rpc_application_state" integer NOT NULL, + "store_application_state" integer NOT NULL, + "verification_state" integer NOT NULL, + "interactions_endpoint_url" varchar NOT NULL, + "integration_public" boolean NOT NULL, + "integration_require_code_grant" boolean NOT NULL, + "discoverability_state" integer NOT NULL, + "discovery_eligibility_flags" integer NOT NULL, + "tags" text NOT NULL, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660110798713-yes.ts b/util/src/migrations/sqlite/1660110798713-yes.ts new file mode 100644 index 000000000..38c6c628e --- /dev/null +++ b/util/src/migrations/sqlite/1660110798713-yes.ts @@ -0,0 +1,428 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class yes1660110798713 implements MigrationInterface { + name = 'yes1660110798713' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text NOT NULL, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660112323115-defaults_apps.ts b/util/src/migrations/sqlite/1660112323115-defaults_apps.ts new file mode 100644 index 000000000..70e300c03 --- /dev/null +++ b/util/src/migrations/sqlite/1660112323115-defaults_apps.ts @@ -0,0 +1,428 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class defaultsApps1660112323115 implements MigrationInterface { + name = 'defaultsApps1660112323115' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" integer NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" varchar NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); + } + +} From 4fe40c2a2016cce4278fbb40093c38145b36e0ea Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Wed, 10 Aug 2022 03:52:03 -0600 Subject: [PATCH 190/238] It works now... I guess Co-authored-by: TheArcaneBrony --- api/src/routes/applications/#id/index.ts | 1 - api/src/routes/applications/index.ts | 2 +- 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/api/src/routes/applications/#id/index.ts b/api/src/routes/applications/#id/index.ts index be8c3ba4f..a16b18a9d 100644 --- a/api/src/routes/applications/#id/index.ts +++ b/api/src/routes/applications/#id/index.ts @@ -7,7 +7,6 @@ const router: Router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { //TODO let results = await Application.findOne({where: {id: req.params.id}, relations: ["owner", "bot"] }); - //debugger; res.json(results).status(200); }); diff --git a/api/src/routes/applications/index.ts b/api/src/routes/applications/index.ts index c9be11310..41ce35b5c 100644 --- a/api/src/routes/applications/index.ts +++ b/api/src/routes/applications/index.ts @@ -11,7 +11,7 @@ export interface ApplicationCreateSchema { router.get("/", route({}), async (req: Request, res: Response) => { //TODO - let results = await Application.find({where: {owner: {id: req.user_id}}, relations: ["owner"] }); + let results = await Application.find({where: {owner: {id: req.user_id}}, relations: ["owner", "bot"] }); res.json(results).status(200); }); From e041945eccbd3f5241e4ef62239d207c180bd466 Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Wed, 10 Aug 2022 04:29:14 -0600 Subject: [PATCH 191/238] I'm probably forgetting a lot of things, but hey, it works --- api/src/routes/applications/#id/index.ts | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/api/src/routes/applications/#id/index.ts b/api/src/routes/applications/#id/index.ts index a16b18a9d..24df2d88d 100644 --- a/api/src/routes/applications/#id/index.ts +++ b/api/src/routes/applications/#id/index.ts @@ -5,7 +5,6 @@ import { Application, OrmUtils, Team, trimSpecial, User } from "@fosscord/util"; const router: Router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { - //TODO let results = await Application.findOne({where: {id: req.params.id}, relations: ["owner", "bot"] }); res.json(results).status(200); }); @@ -23,4 +22,10 @@ router.patch("/", route({}), async (req: Request, res: Response) => { res.json(app).status(200); }); +router.post("/delete", route({}), async (req: Request, res: Response) => { + await Application.delete(req.params.id); + res.send().status(200); +}); + + export default router; \ No newline at end of file From f79baa7b2cb58106ad2ffb69ce6166ce821c5d29 Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Wed, 10 Aug 2022 04:35:10 -0600 Subject: [PATCH 192/238] Whoops, missed one --- api/src/routes/applications/#id/index.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/api/src/routes/applications/#id/index.ts b/api/src/routes/applications/#id/index.ts index 24df2d88d..0aced5822 100644 --- a/api/src/routes/applications/#id/index.ts +++ b/api/src/routes/applications/#id/index.ts @@ -18,7 +18,6 @@ router.patch("/", route({}), async (req: Request, res: Response) => { } if(req.body.tags) app.tags = req.body.tags; await app.save(); - debugger; res.json(app).status(200); }); From 5974acc91e80aae47006ad54808bc83169cd0d86 Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Wed, 10 Aug 2022 04:50:29 -0600 Subject: [PATCH 193/238] Whoops --- api/src/routes/applications/#id/bot/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/applications/#id/bot/index.ts b/api/src/routes/applications/#id/bot/index.ts index 82c09c4d1..a8a24d134 100644 --- a/api/src/routes/applications/#id/bot/index.ts +++ b/api/src/routes/applications/#id/bot/index.ts @@ -74,7 +74,7 @@ router.post("/reset", route({}), async (req: Request, res: Response) => { }); router.patch("/", route({}), async (req: Request, res: Response) => { - delete req.body.icon; + delete req.body.avatar; let app = OrmUtils.mergeDeep(await User.findOne({where: {id: req.params.id}}), req.body); await app.save(); res.json(app).status(200); From 83f7ee2e6177740a7343bb2f197e5e0f5edf7f69 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Wed, 10 Aug 2022 13:24:24 +0200 Subject: [PATCH 194/238] Add migrations --- .../1660130586602-updated-applications.ts | 185 ++++++++ .../1660130561959-updated-applications.ts | 182 ++++++++ .../migrations/sqlite/1660110592990-apps2.ts | 220 --------- .../migrations/sqlite/1660110798713-yes.ts | 428 ------------------ .../sqlite/1660112323115-defaults_apps.ts | 428 ------------------ ... => 1660130536131-updated-applications.ts} | 286 ++++++++++-- 6 files changed, 613 insertions(+), 1116 deletions(-) create mode 100644 util/src/migrations/mariadb/1660130586602-updated-applications.ts create mode 100644 util/src/migrations/postgres/1660130561959-updated-applications.ts delete mode 100644 util/src/migrations/sqlite/1660110592990-apps2.ts delete mode 100644 util/src/migrations/sqlite/1660110798713-yes.ts delete mode 100644 util/src/migrations/sqlite/1660112323115-defaults_apps.ts rename util/src/migrations/sqlite/{1660110227241-modern_apps.ts => 1660130536131-updated-applications.ts} (69%) diff --git a/util/src/migrations/mariadb/1660130586602-updated-applications.ts b/util/src/migrations/mariadb/1660130586602-updated-applications.ts new file mode 100644 index 000000000..ec5744168 --- /dev/null +++ b/util/src/migrations/mariadb/1660130586602-updated-applications.ts @@ -0,0 +1,185 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class updatedApplications1660130586602 implements MigrationInterface { + name = 'updatedApplications1660130586602' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_e5bf78cdbbe9ba91062d74c5aba\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`rpc_origins\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`primary_sku_id\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`slug\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`guild_id\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`type\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`hook\` tinyint NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`redirect_uris\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`rpc_application_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`store_application_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`verification_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`interactions_endpoint_url\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`integration_public\` tinyint NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`integration_require_code_grant\` tinyint NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`discoverability_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`discovery_eligibility_flags\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`tags\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`install_params\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`bot_user_id\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD UNIQUE INDEX \`IDX_2ce5a55796fe4c2f77ece57a64\` (\`bot_user_id\`) + `); + await queryRunner.query(` + ALTER TABLE \`applications\` CHANGE \`description\` \`description\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`flags\` int NOT NULL + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`REL_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` (\`bot_user_id\`) + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_2ce5a55796fe4c2f77ece57a647\` FOREIGN KEY (\`bot_user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_2ce5a55796fe4c2f77ece57a647\` + `); + await queryRunner.query(` + DROP INDEX \`REL_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`flags\` varchar(255) NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` CHANGE \`description\` \`description\` varchar(255) NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP INDEX \`IDX_2ce5a55796fe4c2f77ece57a64\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`bot_user_id\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`install_params\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`tags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`discovery_eligibility_flags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`discoverability_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`integration_require_code_grant\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`integration_public\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`interactions_endpoint_url\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`verification_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`store_application_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`rpc_application_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`redirect_uris\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`hook\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`type\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`guild_id\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`slug\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`primary_sku_id\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`rpc_origins\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_e5bf78cdbbe9ba91062d74c5aba\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/util/src/migrations/postgres/1660130561959-updated-applications.ts b/util/src/migrations/postgres/1660130561959-updated-applications.ts new file mode 100644 index 000000000..8fab54c7c --- /dev/null +++ b/util/src/migrations/postgres/1660130561959-updated-applications.ts @@ -0,0 +1,182 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class updatedApplications1660130561959 implements MigrationInterface { + name = 'updatedApplications1660130561959' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" DROP CONSTRAINT "FK_e5bf78cdbbe9ba91062d74c5aba" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "rpc_origins" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "primary_sku_id" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "slug" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "guild_id" + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "type" text + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "hook" boolean NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "redirect_uris" text + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "rpc_application_state" integer + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "store_application_state" integer + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "verification_state" integer + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "interactions_endpoint_url" character varying + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "integration_public" boolean + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "integration_require_code_grant" boolean + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "discoverability_state" integer + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "discovery_eligibility_flags" integer + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "tags" text + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "install_params" text + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "bot_user_id" character varying + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD CONSTRAINT "UQ_2ce5a55796fe4c2f77ece57a647" UNIQUE ("bot_user_id") + `); + await queryRunner.query(` + ALTER TABLE "applications" + ALTER COLUMN "description" DROP NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "flags" + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "flags" integer NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" DROP CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "flags" + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "flags" character varying NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "applications" + ALTER COLUMN "description" + SET NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP CONSTRAINT "UQ_2ce5a55796fe4c2f77ece57a647" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "bot_user_id" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "install_params" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "tags" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "discovery_eligibility_flags" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "discoverability_state" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "integration_require_code_grant" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "integration_public" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "interactions_endpoint_url" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "verification_state" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "store_application_state" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "rpc_application_state" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "redirect_uris" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "hook" + `); + await queryRunner.query(` + ALTER TABLE "applications" DROP COLUMN "type" + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "guild_id" character varying + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "slug" character varying + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "primary_sku_id" character varying + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD "rpc_origins" text + `); + await queryRunner.query(` + ALTER TABLE "applications" + ADD CONSTRAINT "FK_e5bf78cdbbe9ba91062d74c5aba" FOREIGN KEY ("guild_id") REFERENCES "guilds"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/util/src/migrations/sqlite/1660110592990-apps2.ts b/util/src/migrations/sqlite/1660110592990-apps2.ts deleted file mode 100644 index 06f5885d2..000000000 --- a/util/src/migrations/sqlite/1660110592990-apps2.ts +++ /dev/null @@ -1,220 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class apps21660110592990 implements MigrationInterface { - name = 'apps21660110592990' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - CREATE TABLE "temporary_applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text NOT NULL, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "applications" - `); - await queryRunner.query(` - DROP TABLE "applications" - `); - await queryRunner.query(` - ALTER TABLE "temporary_applications" - RENAME TO "applications" - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "applications" - RENAME TO "temporary_applications" - `); - await queryRunner.query(` - CREATE TABLE "applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar NOT NULL, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text NOT NULL, - "hook" boolean NOT NULL, - "redirect_uris" text NOT NULL, - "rpc_application_state" integer NOT NULL, - "store_application_state" integer NOT NULL, - "verification_state" integer NOT NULL, - "interactions_endpoint_url" varchar NOT NULL, - "integration_public" boolean NOT NULL, - "integration_require_code_grant" boolean NOT NULL, - "discoverability_state" integer NOT NULL, - "discovery_eligibility_flags" integer NOT NULL, - "tags" text NOT NULL, - "install_params" text NOT NULL, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "temporary_applications" - `); - await queryRunner.query(` - DROP TABLE "temporary_applications" - `); - } - -} diff --git a/util/src/migrations/sqlite/1660110798713-yes.ts b/util/src/migrations/sqlite/1660110798713-yes.ts deleted file mode 100644 index 38c6c628e..000000000 --- a/util/src/migrations/sqlite/1660110798713-yes.ts +++ /dev/null @@ -1,428 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class yes1660110798713 implements MigrationInterface { - name = 'yes1660110798713' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - CREATE TABLE "temporary_applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text NOT NULL, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "applications" - `); - await queryRunner.query(` - DROP TABLE "applications" - `); - await queryRunner.query(` - ALTER TABLE "temporary_applications" - RENAME TO "applications" - `); - await queryRunner.query(` - CREATE TABLE "temporary_applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "applications" - `); - await queryRunner.query(` - DROP TABLE "applications" - `); - await queryRunner.query(` - ALTER TABLE "temporary_applications" - RENAME TO "applications" - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "applications" - RENAME TO "temporary_applications" - `); - await queryRunner.query(` - CREATE TABLE "applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text NOT NULL, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "temporary_applications" - `); - await queryRunner.query(` - DROP TABLE "temporary_applications" - `); - await queryRunner.query(` - ALTER TABLE "applications" - RENAME TO "temporary_applications" - `); - await queryRunner.query(` - CREATE TABLE "applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text NOT NULL, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "temporary_applications" - `); - await queryRunner.query(` - DROP TABLE "temporary_applications" - `); - } - -} diff --git a/util/src/migrations/sqlite/1660112323115-defaults_apps.ts b/util/src/migrations/sqlite/1660112323115-defaults_apps.ts deleted file mode 100644 index 70e300c03..000000000 --- a/util/src/migrations/sqlite/1660112323115-defaults_apps.ts +++ /dev/null @@ -1,428 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class defaultsApps1660112323115 implements MigrationInterface { - name = 'defaultsApps1660112323115' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - CREATE TABLE "temporary_applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "applications" - `); - await queryRunner.query(` - DROP TABLE "applications" - `); - await queryRunner.query(` - ALTER TABLE "temporary_applications" - RENAME TO "applications" - `); - await queryRunner.query(` - CREATE TABLE "temporary_applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" integer NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "applications" - `); - await queryRunner.query(` - DROP TABLE "applications" - `); - await queryRunner.query(` - ALTER TABLE "temporary_applications" - RENAME TO "applications" - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "applications" - RENAME TO "temporary_applications" - `); - await queryRunner.query(` - CREATE TABLE "applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "temporary_applications" - `); - await queryRunner.query(` - DROP TABLE "temporary_applications" - `); - await queryRunner.query(` - ALTER TABLE "applications" - RENAME TO "temporary_applications" - `); - await queryRunner.query(` - CREATE TABLE "applications" ( - "id" varchar PRIMARY KEY NOT NULL, - "name" varchar NOT NULL, - "icon" varchar, - "description" varchar, - "bot_public" boolean NOT NULL, - "bot_require_code_grant" boolean NOT NULL, - "terms_of_service_url" varchar, - "privacy_policy_url" varchar, - "summary" varchar, - "verify_key" varchar NOT NULL, - "cover_image" varchar, - "flags" varchar NOT NULL, - "owner_id" varchar, - "team_id" varchar, - "type" text, - "hook" boolean NOT NULL, - "redirect_uris" text, - "rpc_application_state" integer, - "store_application_state" integer, - "verification_state" integer, - "interactions_endpoint_url" varchar, - "integration_public" boolean, - "integration_require_code_grant" boolean, - "discoverability_state" integer, - "discovery_eligibility_flags" integer, - "tags" text, - "install_params" text, - "bot_user_id" varchar, - CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), - CONSTRAINT "FK_2ce5a55796fe4c2f77ece57a647" FOREIGN KEY ("bot_user_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "applications"( - "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - ) - SELECT "id", - "name", - "icon", - "description", - "bot_public", - "bot_require_code_grant", - "terms_of_service_url", - "privacy_policy_url", - "summary", - "verify_key", - "cover_image", - "flags", - "owner_id", - "team_id", - "type", - "hook", - "redirect_uris", - "rpc_application_state", - "store_application_state", - "verification_state", - "interactions_endpoint_url", - "integration_public", - "integration_require_code_grant", - "discoverability_state", - "discovery_eligibility_flags", - "tags", - "install_params", - "bot_user_id" - FROM "temporary_applications" - `); - await queryRunner.query(` - DROP TABLE "temporary_applications" - `); - } - -} diff --git a/util/src/migrations/sqlite/1660110227241-modern_apps.ts b/util/src/migrations/sqlite/1660130536131-updated-applications.ts similarity index 69% rename from util/src/migrations/sqlite/1660110227241-modern_apps.ts rename to util/src/migrations/sqlite/1660130536131-updated-applications.ts index 34c0b4b25..b8cbcc337 100644 --- a/util/src/migrations/sqlite/1660110227241-modern_apps.ts +++ b/util/src/migrations/sqlite/1660130536131-updated-applications.ts @@ -1,7 +1,7 @@ import { MigrationInterface, QueryRunner } from "typeorm"; -export class modernApps1660110227241 implements MigrationInterface { - name = 'modernApps1660110227241' +export class updatedApplications1660130536131 implements MigrationInterface { + name = 'updatedApplications1660130536131' public async up(queryRunner: QueryRunner): Promise { await queryRunner.query(` @@ -152,19 +152,19 @@ export class modernApps1660110227241 implements MigrationInterface { "flags" varchar NOT NULL, "owner_id" varchar, "team_id" varchar, - "type" text NOT NULL, + "type" text, "hook" boolean NOT NULL, - "redirect_uris" text NOT NULL, - "rpc_application_state" integer NOT NULL, - "store_application_state" integer NOT NULL, - "verification_state" integer NOT NULL, - "interactions_endpoint_url" varchar NOT NULL, - "integration_public" boolean NOT NULL, - "integration_require_code_grant" boolean NOT NULL, - "discoverability_state" integer NOT NULL, - "discovery_eligibility_flags" integer NOT NULL, - "tags" text NOT NULL, - "install_params" text NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, "bot_user_id" varchar, CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, @@ -216,7 +216,7 @@ export class modernApps1660110227241 implements MigrationInterface { "id" varchar PRIMARY KEY NOT NULL, "name" varchar NOT NULL, "icon" varchar, - "description" varchar NOT NULL, + "description" varchar, "bot_public" boolean NOT NULL, "bot_require_code_grant" boolean NOT NULL, "terms_of_service_url" varchar, @@ -224,22 +224,125 @@ export class modernApps1660110227241 implements MigrationInterface { "summary" varchar, "verify_key" varchar NOT NULL, "cover_image" varchar, - "flags" varchar NOT NULL, + "flags" integer NOT NULL, "owner_id" varchar, "team_id" varchar, - "type" text NOT NULL, + "type" text, "hook" boolean NOT NULL, - "redirect_uris" text NOT NULL, - "rpc_application_state" integer NOT NULL, - "store_application_state" integer NOT NULL, - "verification_state" integer NOT NULL, - "interactions_endpoint_url" varchar NOT NULL, - "integration_public" boolean NOT NULL, - "integration_require_code_grant" boolean NOT NULL, - "discoverability_state" integer NOT NULL, - "discovery_eligibility_flags" integer NOT NULL, - "tags" text NOT NULL, - "install_params" text NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "applications" + `); + await queryRunner.query(` + DROP TABLE "applications" + `); + await queryRunner.query(` + ALTER TABLE "temporary_applications" + RENAME TO "applications" + `); + await queryRunner.query(` + CREATE TABLE "temporary_applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" integer NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, "bot_user_id" varchar, CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, @@ -318,6 +421,109 @@ export class modernApps1660110227241 implements MigrationInterface { } public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "applications" + RENAME TO "temporary_applications" + `); + await queryRunner.query(` + CREATE TABLE "applications" ( + "id" varchar PRIMARY KEY NOT NULL, + "name" varchar NOT NULL, + "icon" varchar, + "description" varchar, + "bot_public" boolean NOT NULL, + "bot_require_code_grant" boolean NOT NULL, + "terms_of_service_url" varchar, + "privacy_policy_url" varchar, + "summary" varchar, + "verify_key" varchar NOT NULL, + "cover_image" varchar, + "flags" integer NOT NULL, + "owner_id" varchar, + "team_id" varchar, + "type" text, + "hook" boolean NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, + "bot_user_id" varchar, + CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), + CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_e57508958bf92b9d9d25231b5e8" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "applications"( + "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + ) + SELECT "id", + "name", + "icon", + "description", + "bot_public", + "bot_require_code_grant", + "terms_of_service_url", + "privacy_policy_url", + "summary", + "verify_key", + "cover_image", + "flags", + "owner_id", + "team_id", + "type", + "hook", + "redirect_uris", + "rpc_application_state", + "store_application_state", + "verification_state", + "interactions_endpoint_url", + "integration_public", + "integration_require_code_grant", + "discoverability_state", + "discovery_eligibility_flags", + "tags", + "install_params", + "bot_user_id" + FROM "temporary_applications" + `); + await queryRunner.query(` + DROP TABLE "temporary_applications" + `); await queryRunner.query(` ALTER TABLE "applications" RENAME TO "temporary_applications" @@ -338,19 +544,19 @@ export class modernApps1660110227241 implements MigrationInterface { "flags" varchar NOT NULL, "owner_id" varchar, "team_id" varchar, - "type" text NOT NULL, + "type" text, "hook" boolean NOT NULL, - "redirect_uris" text NOT NULL, - "rpc_application_state" integer NOT NULL, - "store_application_state" integer NOT NULL, - "verification_state" integer NOT NULL, - "interactions_endpoint_url" varchar NOT NULL, - "integration_public" boolean NOT NULL, - "integration_require_code_grant" boolean NOT NULL, - "discoverability_state" integer NOT NULL, - "discovery_eligibility_flags" integer NOT NULL, - "tags" text NOT NULL, - "install_params" text NOT NULL, + "redirect_uris" text, + "rpc_application_state" integer, + "store_application_state" integer, + "verification_state" integer, + "interactions_endpoint_url" varchar, + "integration_public" boolean, + "integration_require_code_grant" boolean, + "discoverability_state" integer, + "discovery_eligibility_flags" integer, + "tags" text, + "install_params" text, "bot_user_id" varchar, CONSTRAINT "UQ_b7f6e13565e920916d902e1f431" UNIQUE ("bot_user_id"), CONSTRAINT "FK_a36ed02953077f408d0f3ebc424" FOREIGN KEY ("team_id") REFERENCES "teams" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, From d20a42af18ff641f365bcee2069cb660cc6dbe35 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Wed, 10 Aug 2022 16:07:01 +0200 Subject: [PATCH 195/238] Make teams nullable --- api/src/routes/applications/index.ts | 3 +-- util/src/entities/Application.ts | 1 + .../1660131942703-apps_nullable_team.ts | 18 ++++++++++++++++++ 3 files changed, 20 insertions(+), 2 deletions(-) create mode 100644 util/src/migrations/mariadb/1660131942703-apps_nullable_team.ts diff --git a/api/src/routes/applications/index.ts b/api/src/routes/applications/index.ts index 41ce35b5c..033dcc51e 100644 --- a/api/src/routes/applications/index.ts +++ b/api/src/routes/applications/index.ts @@ -23,10 +23,9 @@ router.post("/", route({}), async (req: Request, res: Response) => { name: trimSpecial(body.name), description: "", bot_public: true, - bot_require_code_grant: false, owner: user, verify_key: "IMPLEMENTME", - flags: "" + flags: 0 }); await app.save(); res.json(app).status(200); diff --git a/util/src/entities/Application.ts b/util/src/entities/Application.ts index 283815798..103f8e843 100644 --- a/util/src/entities/Application.ts +++ b/util/src/entities/Application.ts @@ -104,6 +104,7 @@ export class Application extends BaseClass { @JoinColumn({ name: "team_id" }) @ManyToOne(() => Team, { onDelete: "CASCADE", + nullable: true }) team?: Team; diff --git a/util/src/migrations/mariadb/1660131942703-apps_nullable_team.ts b/util/src/migrations/mariadb/1660131942703-apps_nullable_team.ts new file mode 100644 index 000000000..ac4457725 --- /dev/null +++ b/util/src/migrations/mariadb/1660131942703-apps_nullable_team.ts @@ -0,0 +1,18 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class appsNullableTeam1660131942703 implements MigrationInterface { + name = 'appsNullableTeam1660131942703' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP INDEX \`IDX_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE UNIQUE INDEX \`IDX_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` (\`bot_user_id\`) + `); + } + +} From 0b3903b0980256354b425abf8ea2e7fbea67248a Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Wed, 10 Aug 2022 19:11:04 -0600 Subject: [PATCH 196/238] Invalidate tokens on password change --- api/src/routes/users/@me/index.ts | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 8ab30a8d7..4cf96a8dc 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -2,7 +2,7 @@ import { Router, Request, Response } from "express"; import { User, PrivateUserProjection, emitEvent, UserUpdateEvent, handleFile, FieldErrors } from "@fosscord/util"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; -import { OrmUtils } from "@fosscord/util"; +import { OrmUtils, generateToken } from "@fosscord/util"; const router: Router = Router(); @@ -30,6 +30,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { }); router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: Response) => { + var token = null as any; const body = req.body as UserModifySchema; if (body.avatar) body.avatar = await handleFile(`/avatars/${req.user_id}`, body.avatar as string); @@ -54,6 +55,8 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: }); } user.data.hash = await bcrypt.hash(body.new_password, 12); + user.data.valid_tokens_since = new Date(); + token = await generateToken(user.id) as string; } if(body.username){ @@ -77,8 +80,11 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: user_id: req.user_id, data: user } as UserUpdateEvent); - - res.json(user); + + res.json({ + ...user, + token + }); }); export default router; From c2295a0498628538e93fcbf8fbf164b57ffeb47e Mon Sep 17 00:00:00 2001 From: RealMANI <96433859+ImAaronFR@users.noreply.github.com> Date: Thu, 11 Aug 2022 23:50:08 +0430 Subject: [PATCH 197/238] Update index.ts Adding member field to message gateway --- .../routes/channels/#channel_id/messages/index.ts | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 2fce704b7..2ce7f7b3d 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -245,8 +245,16 @@ router.post( ); } - //Fix for the client bug - delete message.member + //Defining member fields + var member = await Member.findOneOrFail({ where: { id: req.user_id }, relations: ["roles"] }); + member.roles = member.roles.filter((role) => { + return role.id !== role.guild_id; + }).map((role) => { + return role.id; + }); + message.member = member; + delete message.member.last_message_id; + delete message.member.index; await Promise.all([ message.save(), From 443c7d8a1ee81add4b549b00fc27fefe6e50279c Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Fri, 12 Aug 2022 23:28:12 -0600 Subject: [PATCH 198/238] Made nitro stuff make some sense --- api/src/routes/applications/#id/bot/index.ts | 8 ++++---- bundle/package.json | 2 +- util/src/entities/Member.ts | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/api/src/routes/applications/#id/bot/index.ts b/api/src/routes/applications/#id/bot/index.ts index a8a24d134..a51c95263 100644 --- a/api/src/routes/applications/#id/bot/index.ts +++ b/api/src/routes/applications/#id/bot/index.ts @@ -28,13 +28,13 @@ router.post("/", route({}), async (req: Request, res: Response) => { id: app.id, bot: true, system: false, - premium_since: new Date(), + premium_since: 0, desktop: false, mobile: false, - premium: true, - premium_type: 2, + premium: false, + premium_type: 0, bio: app.description, - mfa_enabled: false, + mfa_enabled: true, totp_secret: "", totp_backup_codes: [], verified: true, diff --git a/bundle/package.json b/bundle/package.json index 6adb569ce..b67598b8f 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -99,4 +99,4 @@ "typescript": "^4.1.2", "ws": "^8.8.1" } -} +} \ No newline at end of file diff --git a/util/src/entities/Member.ts b/util/src/entities/Member.ts index d4395e03b..baac58ed7 100644 --- a/util/src/entities/Member.ts +++ b/util/src/entities/Member.ts @@ -257,7 +257,7 @@ export class Member extends BaseClassWithoutId { nick: undefined, roles: [guild_id], // @everyone role joined_at: new Date(), - premium_since: new Date(), + premium_since: null, deaf: false, mute: false, pending: false, From d9760fe9146ba87a8296a566abbb4aa7ab61c750 Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Fri, 12 Aug 2022 23:44:50 -0600 Subject: [PATCH 199/238] Handle avatar uploads --- api/src/routes/applications/#id/bot/index.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/api/src/routes/applications/#id/bot/index.ts b/api/src/routes/applications/#id/bot/index.ts index a51c95263..562c31fef 100644 --- a/api/src/routes/applications/#id/bot/index.ts +++ b/api/src/routes/applications/#id/bot/index.ts @@ -1,6 +1,6 @@ import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; -import { Application, Config, FieldErrors, generateToken, OrmUtils, Snowflake, trimSpecial, User } from "@fosscord/util"; +import { Application, Config, FieldErrors, generateToken, OrmUtils, Snowflake, trimSpecial, User, handleFile } from "@fosscord/util"; import { HTTPError } from "lambert-server"; import { verifyToken } from "node-2fa"; @@ -74,7 +74,7 @@ router.post("/reset", route({}), async (req: Request, res: Response) => { }); router.patch("/", route({}), async (req: Request, res: Response) => { - delete req.body.avatar; + if (req.body.avatar) req.body.avatar = await handleFile(`/avatars/${req.params.id}`, req.body.avatar as string); let app = OrmUtils.mergeDeep(await User.findOne({where: {id: req.params.id}}), req.body); await app.save(); res.json(app).status(200); From 8fb219e2cd40e09fa07e358532e8723ce5c06291 Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Sat, 13 Aug 2022 00:27:24 -0600 Subject: [PATCH 200/238] That don't work --- api/src/routes/channels/#channel_id/messages/index.ts | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 2ce7f7b3d..3b35b6047 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -253,8 +253,9 @@ router.post( return role.id; }); message.member = member; - delete message.member.last_message_id; - delete message.member.index; + // TODO: Figure this out + // delete message.member.last_message_id; + // delete message.member.index; await Promise.all([ message.save(), From c2265af725b96b04826b2c471e8d569834009799 Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Sat, 13 Aug 2022 00:31:32 -0600 Subject: [PATCH 201/238] Hmmmmmm --- api/src/routes/channels/#channel_id/messages/index.ts | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index 3b35b6047..c20574224 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -247,11 +247,12 @@ router.post( //Defining member fields var member = await Member.findOneOrFail({ where: { id: req.user_id }, relations: ["roles"] }); - member.roles = member.roles.filter((role) => { - return role.id !== role.guild_id; - }).map((role) => { - return role.id; - }); + // TODO: This doesn't work either + // member.roles = member.roles.filter((role) => { + // return role.id !== role.guild_id; + // }).map((role) => { + // return role.id; + // }); message.member = member; // TODO: Figure this out // delete message.member.last_message_id; From c1034569d63093fa76a568b0b570f7685cd61e8c Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Sat, 13 Aug 2022 00:36:25 -0600 Subject: [PATCH 202/238] That... Was a bad idea --- api/src/routes/applications/#id/bot/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/routes/applications/#id/bot/index.ts b/api/src/routes/applications/#id/bot/index.ts index 562c31fef..5cae52150 100644 --- a/api/src/routes/applications/#id/bot/index.ts +++ b/api/src/routes/applications/#id/bot/index.ts @@ -28,7 +28,7 @@ router.post("/", route({}), async (req: Request, res: Response) => { id: app.id, bot: true, system: false, - premium_since: 0, + premium_since: null, desktop: false, mobile: false, premium: false, From 78247f0dfc95061b4b0990c820eb86868308517e Mon Sep 17 00:00:00 2001 From: ChrisChrome Date: Sat, 13 Aug 2022 01:02:24 -0600 Subject: [PATCH 203/238] Thats it, thats the fix, thanks erkinalp --- util/src/entities/Channel.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index 92940b345..ade0fb398 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -245,7 +245,7 @@ export class Channel extends BaseClass { } **/ - const type = recipients.length > 1 ? ChannelType.DM : ChannelType.GROUP_DM; + const type = recipients.length > 1 ? ChannelType.GROUP_DM : ChannelType.DM; let channel = null; From de9a6f28e5a06e2727bfa82c38b9f88fcd7bda02 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 13 Aug 2022 20:45:51 +0200 Subject: [PATCH 204/238] Do the funny thing (make user->invite cascade delet) --- util/src/entities/Invite.ts | 13 +- .../1660416072362-InvitersAreDeletable.ts | 56 ++++ .../1660416055566-InvitersAreDeletable.ts | 26 ++ .../1660416010862-InvitersAreDeletable.ts | 246 ++++++++++++++++++ 4 files changed, 336 insertions(+), 5 deletions(-) create mode 100644 util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts create mode 100644 util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts create mode 100644 util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts diff --git a/util/src/entities/Invite.ts b/util/src/entities/Invite.ts index b672caf78..1e0ebe52d 100644 --- a/util/src/entities/Invite.ts +++ b/util/src/entities/Invite.ts @@ -4,19 +4,20 @@ import { BaseClassWithoutId } from "./BaseClass"; import { Channel } from "./Channel"; import { Guild } from "./Guild"; import { User } from "./User"; +import { random } from "@fosscord/api"; export const PublicInviteRelation = ["inviter", "guild", "channel"]; @Entity("invites") export class Invite extends BaseClassWithoutId { @PrimaryColumn() - code: string; + code: string = random(); @Column() - temporary: boolean; + temporary: boolean = true; @Column() - uses: number; + uses: number = 0; @Column() max_uses: number; @@ -25,7 +26,7 @@ export class Invite extends BaseClassWithoutId { max_age: number; @Column() - created_at: Date; + created_at: Date = new Date(); @Column() expires_at: Date; @@ -55,7 +56,9 @@ export class Invite extends BaseClassWithoutId { inviter_id: string; @JoinColumn({ name: "inviter_id" }) - @ManyToOne(() => User) + @ManyToOne(() => User, { + onDelete: "CASCADE" + }) inviter: User; @Column({ nullable: true }) diff --git a/util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts b/util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts new file mode 100644 index 000000000..8374eafbc --- /dev/null +++ b/util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts @@ -0,0 +1,56 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class InvitersAreDeletable1660416072362 implements MigrationInterface { + name = 'InvitersAreDeletable1660416072362' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` + `); + await queryRunner.query(` + DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` + `); + await queryRunner.query(` + CREATE TABLE \`plugin_config\` ( + \`key\` varchar(255) NOT NULL, + \`value\` text NULL, + PRIMARY KEY (\`key\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD \`flags\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD \`default_thread_rate_limit_per_user\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP COLUMN \`default_thread_rate_limit_per_user\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + DROP TABLE \`plugin_config\` + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts b/util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts new file mode 100644 index 000000000..e61013189 --- /dev/null +++ b/util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts @@ -0,0 +1,26 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class InvitersAreDeletable1660416055566 implements MigrationInterface { + name = 'InvitersAreDeletable1660416055566' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts b/util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts new file mode 100644 index 000000000..9b29e119e --- /dev/null +++ b/util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts @@ -0,0 +1,246 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class InvitersAreDeletable1660416010862 implements MigrationInterface { + name = 'InvitersAreDeletable1660416010862' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "invites" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + ALTER TABLE "temporary_invites" + RENAME TO "invites" + `); + await queryRunner.query(` + CREATE TABLE "temporary_invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "invites" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + ALTER TABLE "temporary_invites" + RENAME TO "invites" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "invites" + RENAME TO "temporary_invites" + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "temporary_invites" + `); + await queryRunner.query(` + DROP TABLE "temporary_invites" + `); + await queryRunner.query(` + ALTER TABLE "invites" + RENAME TO "temporary_invites" + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "temporary_invites" + `); + await queryRunner.query(` + DROP TABLE "temporary_invites" + `); + } + +} From 99c40c208296c723f5d1a89d1f6c38564bef5829 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Thu, 11 Aug 2022 18:16:57 +0200 Subject: [PATCH 205/238] Make fosscord read config from json if CONFIG_PATH is set --- util/src/util/Config.ts | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index 97a73858a..925cb2434 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -3,7 +3,7 @@ import path from "path"; import fs from "fs"; // TODO: yaml instead of json -// const overridePath = path.join(process.cwd(), "config.json"); +const overridePath = process.env.CONFIG_PATH ?? ""; let config: ConfigValue; let pairs: ConfigEntity[]; @@ -18,12 +18,14 @@ export const Config = { config = pairsToConfig(pairs); config = (config || {}).merge(DefaultConfigOptions); - // try { - // const overrideConfig = JSON.parse(fs.readFileSync(overridePath, { encoding: "utf8" })); - // config = overrideConfig.merge(config); - // } catch (error) { - // fs.writeFileSync(overridePath, JSON.stringify(config, null, 4)); - // } + if(process.env.CONFIG_PATH) + try { + const overrideConfig = JSON.parse(fs.readFileSync(overridePath, { encoding: "utf8" })); + config = overrideConfig.merge(config); + } catch (error) { + fs.writeFileSync(overridePath, JSON.stringify(config, null, 4)); + } + return this.set(config); }, @@ -50,7 +52,8 @@ function applyConfig(val: ConfigValue) { pair.value = obj; return pair.save(); } - // fs.writeFileSync(overridePath, JSON.stringify(val, null, 4)); + if(process.env.CONFIG_PATH) + fs.writeFileSync(overridePath, JSON.stringify(val, null, 4)); return apply(val); } From 34ca1a8a6c1b195c45f13ebd3b29064a9623af6f Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Thu, 11 Aug 2022 23:11:48 +0200 Subject: [PATCH 206/238] Make ConfigValue a directory, move defaults to those classes instead of a separate object --- gateway/src/opcodes/VoiceStateUpdate.ts | 2 +- util/src/config/Config.ts | 22 + util/src/config/index.ts | 2 + util/src/config/types/ApiConfiguration.ts | 5 + util/src/config/types/ClientConfiguration.ts | 8 + .../src/config/types/DefaultsConfiguration.ts | 5 + .../src/config/types/EndpointConfiguration.ts | 5 + util/src/config/types/GeneralConfiguration.ts | 12 + util/src/config/types/GifConfiguration.ts | 5 + util/src/config/types/GuildConfiguration.ts | 6 + util/src/config/types/KafkaConfiguration.ts | 5 + util/src/config/types/LimitConfigurations.ts | 9 + util/src/config/types/LoginConfiguration.ts | 3 + util/src/config/types/MetricsConfiguration.ts | 3 + .../src/config/types/RabbitMQConfiguration.ts | 3 + util/src/config/types/RegionConfiguration.ts | 16 + .../src/config/types/RegisterConfiguration.ts | 18 + .../src/config/types/SecurityConfiguration.ts | 17 + util/src/config/types/SentryConfiguration.ts | 8 + .../src/config/types/TemplateConfiguration.ts | 6 + util/src/config/types/index.ts | 18 + .../client/ClientReleaseConfiguration.ts | 4 + .../types/subconfigurations/client/index.ts | 1 + .../defaults/GuildDefaults.ts | 8 + .../types/subconfigurations/defaults/index.ts | 1 + .../types/subconfigurations/guild/AutoJoin.ts | 5 + .../subconfigurations/guild/Discovery.ts | 6 + .../types/subconfigurations/guild/index.ts | 2 + .../config/types/subconfigurations/index.ts | 8 + .../subconfigurations/kafka/KafkaBroker.ts | 4 + .../types/subconfigurations/kafka/index.ts | 1 + .../subconfigurations/limits/ChannelLimits.ts | 5 + .../subconfigurations/limits/GuildLimits.ts | 8 + .../subconfigurations/limits/MessageLimits.ts | 8 + .../subconfigurations/limits/RateLimits.ts | 18 + .../subconfigurations/limits/UserLimits.ts | 5 + .../types/subconfigurations/limits/index.ts | 6 + .../limits/ratelimits/Auth.ts | 12 + .../limits/ratelimits/RateLimitOptions.ts | 6 + .../limits/ratelimits/Route.ts | 19 + .../limits/ratelimits/index.ts | 3 + .../types/subconfigurations/region/Region.ts | 12 + .../types/subconfigurations/region/index.ts | 1 + .../subconfigurations/register/DateOfBirth.ts | 4 + .../types/subconfigurations/register/Email.ts | 7 + .../subconfigurations/register/Password.ts | 7 + .../types/subconfigurations/register/index.ts | 3 + .../subconfigurations/security/Captcha.ts | 6 + .../subconfigurations/security/TwoFactor.ts | 3 + .../types/subconfigurations/security/index.ts | 2 + util/src/entities/Config.ts | 406 +----------------- util/src/util/Config.ts | 14 +- 52 files changed, 364 insertions(+), 409 deletions(-) create mode 100644 util/src/config/Config.ts create mode 100644 util/src/config/index.ts create mode 100644 util/src/config/types/ApiConfiguration.ts create mode 100644 util/src/config/types/ClientConfiguration.ts create mode 100644 util/src/config/types/DefaultsConfiguration.ts create mode 100644 util/src/config/types/EndpointConfiguration.ts create mode 100644 util/src/config/types/GeneralConfiguration.ts create mode 100644 util/src/config/types/GifConfiguration.ts create mode 100644 util/src/config/types/GuildConfiguration.ts create mode 100644 util/src/config/types/KafkaConfiguration.ts create mode 100644 util/src/config/types/LimitConfigurations.ts create mode 100644 util/src/config/types/LoginConfiguration.ts create mode 100644 util/src/config/types/MetricsConfiguration.ts create mode 100644 util/src/config/types/RabbitMQConfiguration.ts create mode 100644 util/src/config/types/RegionConfiguration.ts create mode 100644 util/src/config/types/RegisterConfiguration.ts create mode 100644 util/src/config/types/SecurityConfiguration.ts create mode 100644 util/src/config/types/SentryConfiguration.ts create mode 100644 util/src/config/types/TemplateConfiguration.ts create mode 100644 util/src/config/types/index.ts create mode 100644 util/src/config/types/subconfigurations/client/ClientReleaseConfiguration.ts create mode 100644 util/src/config/types/subconfigurations/client/index.ts create mode 100644 util/src/config/types/subconfigurations/defaults/GuildDefaults.ts create mode 100644 util/src/config/types/subconfigurations/defaults/index.ts create mode 100644 util/src/config/types/subconfigurations/guild/AutoJoin.ts create mode 100644 util/src/config/types/subconfigurations/guild/Discovery.ts create mode 100644 util/src/config/types/subconfigurations/guild/index.ts create mode 100644 util/src/config/types/subconfigurations/index.ts create mode 100644 util/src/config/types/subconfigurations/kafka/KafkaBroker.ts create mode 100644 util/src/config/types/subconfigurations/kafka/index.ts create mode 100644 util/src/config/types/subconfigurations/limits/ChannelLimits.ts create mode 100644 util/src/config/types/subconfigurations/limits/GuildLimits.ts create mode 100644 util/src/config/types/subconfigurations/limits/MessageLimits.ts create mode 100644 util/src/config/types/subconfigurations/limits/RateLimits.ts create mode 100644 util/src/config/types/subconfigurations/limits/UserLimits.ts create mode 100644 util/src/config/types/subconfigurations/limits/index.ts create mode 100644 util/src/config/types/subconfigurations/limits/ratelimits/Auth.ts create mode 100644 util/src/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts create mode 100644 util/src/config/types/subconfigurations/limits/ratelimits/Route.ts create mode 100644 util/src/config/types/subconfigurations/limits/ratelimits/index.ts create mode 100644 util/src/config/types/subconfigurations/region/Region.ts create mode 100644 util/src/config/types/subconfigurations/region/index.ts create mode 100644 util/src/config/types/subconfigurations/register/DateOfBirth.ts create mode 100644 util/src/config/types/subconfigurations/register/Email.ts create mode 100644 util/src/config/types/subconfigurations/register/Password.ts create mode 100644 util/src/config/types/subconfigurations/register/index.ts create mode 100644 util/src/config/types/subconfigurations/security/Captcha.ts create mode 100644 util/src/config/types/subconfigurations/security/TwoFactor.ts create mode 100644 util/src/config/types/subconfigurations/security/index.ts diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/gateway/src/opcodes/VoiceStateUpdate.ts index d62425f32..8c430d568 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/gateway/src/opcodes/VoiceStateUpdate.ts @@ -7,12 +7,12 @@ import { emitEvent, Guild, Member, - Region, VoiceServerUpdateEvent, VoiceState, VoiceStateUpdateEvent, } from "@fosscord/util"; import { OrmUtils } from "@fosscord/util"; +import { Region } from "@fosscord/util/src/config"; // TODO: check if a voice server is setup // Notice: Bot users respect the voice channel's user limit, if set. When the voice channel is full, you will not receive the Voice State Update or Voice Server Update events in response to your own Voice State Update. Having MANAGE_CHANNELS permission bypasses this limit and allows you to join regardless of the channel being full or not. diff --git a/util/src/config/Config.ts b/util/src/config/Config.ts new file mode 100644 index 000000000..b703040f7 --- /dev/null +++ b/util/src/config/Config.ts @@ -0,0 +1,22 @@ +import { ApiConfiguration, ClientConfiguration, DefaultsConfiguration, EndpointConfiguration, GeneralConfiguration, GifConfiguration, GuildConfiguration, KafkaConfiguration, LimitsConfiguration, LoginConfiguration, MetricsConfiguration, RabbitMQConfiguration, RegionConfiguration, RegisterConfiguration, SecurityConfiguration, SentryConfiguration, TemplateConfiguration } from "../config"; + +export class ConfigValue { + gateway: EndpointConfiguration = new EndpointConfiguration(); + cdn: EndpointConfiguration = new EndpointConfiguration(); + api: ApiConfiguration = new ApiConfiguration(); + general: GeneralConfiguration = new GeneralConfiguration(); + limits: LimitsConfiguration = new LimitsConfiguration(); + security: SecurityConfiguration = new SecurityConfiguration(); + login: LoginConfiguration = new LoginConfiguration(); + register: RegisterConfiguration = new RegisterConfiguration(); + regions: RegionConfiguration = new RegionConfiguration(); + guild: GuildConfiguration = new GuildConfiguration(); + gif: GifConfiguration = new GifConfiguration(); + rabbitmq: RabbitMQConfiguration = new RabbitMQConfiguration(); + kafka: KafkaConfiguration = new KafkaConfiguration(); + templates: TemplateConfiguration = new TemplateConfiguration(); + client: ClientConfiguration = new ClientConfiguration(); + metrics: MetricsConfiguration = new MetricsConfiguration(); + sentry: SentryConfiguration = new SentryConfiguration(); + defaults: DefaultsConfiguration = new DefaultsConfiguration(); +} \ No newline at end of file diff --git a/util/src/config/index.ts b/util/src/config/index.ts new file mode 100644 index 000000000..0a9b58ae3 --- /dev/null +++ b/util/src/config/index.ts @@ -0,0 +1,2 @@ +export * from "./Config"; +export * from "./types/index"; diff --git a/util/src/config/types/ApiConfiguration.ts b/util/src/config/types/ApiConfiguration.ts new file mode 100644 index 000000000..16b1efbab --- /dev/null +++ b/util/src/config/types/ApiConfiguration.ts @@ -0,0 +1,5 @@ +export class ApiConfiguration { + defaultVersion: string = "9"; + activeVersions: string[] = ["6", "7", "8", "9"]; + useFosscordEnhancements: boolean = true; +} \ No newline at end of file diff --git a/util/src/config/types/ClientConfiguration.ts b/util/src/config/types/ClientConfiguration.ts new file mode 100644 index 000000000..1adda1e20 --- /dev/null +++ b/util/src/config/types/ClientConfiguration.ts @@ -0,0 +1,8 @@ +import { ClientReleaseConfiguration } from "."; + +export class ClientConfiguration { + //classes + releases: ClientReleaseConfiguration = new ClientReleaseConfiguration(); + //base types + useTestClient: boolean = true; +} \ No newline at end of file diff --git a/util/src/config/types/DefaultsConfiguration.ts b/util/src/config/types/DefaultsConfiguration.ts new file mode 100644 index 000000000..c3171a014 --- /dev/null +++ b/util/src/config/types/DefaultsConfiguration.ts @@ -0,0 +1,5 @@ +import { GuildDefaults } from "."; + +export class DefaultsConfiguration { + guild: GuildDefaults = new GuildDefaults(); +} \ No newline at end of file diff --git a/util/src/config/types/EndpointConfiguration.ts b/util/src/config/types/EndpointConfiguration.ts new file mode 100644 index 000000000..87baea31b --- /dev/null +++ b/util/src/config/types/EndpointConfiguration.ts @@ -0,0 +1,5 @@ +export class EndpointConfiguration { + endpointClient: string | null = null; + endpointPrivate: string | null = null; + endpointPublic: string | null = null; +} \ No newline at end of file diff --git a/util/src/config/types/GeneralConfiguration.ts b/util/src/config/types/GeneralConfiguration.ts new file mode 100644 index 000000000..55848b44a --- /dev/null +++ b/util/src/config/types/GeneralConfiguration.ts @@ -0,0 +1,12 @@ +import { Snowflake } from "../../util"; + +export class GeneralConfiguration { + instanceName: string = "Fosscord Instance"; + instanceDescription: string | null = "This is a Fosscord instance made in the pre-release days"; + frontPage: string | null = null; + tosPage: string | null = null; + correspondenceEmail: string | null = "noreply@localhost.local"; + correspondenceUserID: string | null = null; + image: string | null = null; + instanceId: string = Snowflake.generate(); +} \ No newline at end of file diff --git a/util/src/config/types/GifConfiguration.ts b/util/src/config/types/GifConfiguration.ts new file mode 100644 index 000000000..6a2d520dc --- /dev/null +++ b/util/src/config/types/GifConfiguration.ts @@ -0,0 +1,5 @@ +export class GifConfiguration { + enabled: boolean = true; + provider: "tenor" = "tenor"; // more coming soon + apiKey?: string = "LIVDSRZULELA"; +} \ No newline at end of file diff --git a/util/src/config/types/GuildConfiguration.ts b/util/src/config/types/GuildConfiguration.ts new file mode 100644 index 000000000..3d43b3684 --- /dev/null +++ b/util/src/config/types/GuildConfiguration.ts @@ -0,0 +1,6 @@ +import { DiscoveryConfiguration, AutoJoinConfiguration } from "."; + +export class GuildConfiguration { + discovery: DiscoveryConfiguration = new DiscoveryConfiguration(); + autoJoin: AutoJoinConfiguration = new AutoJoinConfiguration(); +} diff --git a/util/src/config/types/KafkaConfiguration.ts b/util/src/config/types/KafkaConfiguration.ts new file mode 100644 index 000000000..7932f49e1 --- /dev/null +++ b/util/src/config/types/KafkaConfiguration.ts @@ -0,0 +1,5 @@ +import { KafkaBroker } from "."; + +export class KafkaConfiguration { + brokers: KafkaBroker[] | null = null; +} \ No newline at end of file diff --git a/util/src/config/types/LimitConfigurations.ts b/util/src/config/types/LimitConfigurations.ts new file mode 100644 index 000000000..bcc2e7e27 --- /dev/null +++ b/util/src/config/types/LimitConfigurations.ts @@ -0,0 +1,9 @@ +import { ChannelLimits, GuildLimits, MessageLimits, RateLimits, UserLimits } from "."; + +export class LimitsConfiguration { + user: UserLimits = new UserLimits(); + guild: GuildLimits = new GuildLimits(); + message: MessageLimits = new MessageLimits(); + channel: ChannelLimits = new ChannelLimits(); + rate: RateLimits = new RateLimits(); +} \ No newline at end of file diff --git a/util/src/config/types/LoginConfiguration.ts b/util/src/config/types/LoginConfiguration.ts new file mode 100644 index 000000000..255c94512 --- /dev/null +++ b/util/src/config/types/LoginConfiguration.ts @@ -0,0 +1,3 @@ +export class LoginConfiguration { + requireCaptcha: boolean = false; +} \ No newline at end of file diff --git a/util/src/config/types/MetricsConfiguration.ts b/util/src/config/types/MetricsConfiguration.ts new file mode 100644 index 000000000..d7cd4937e --- /dev/null +++ b/util/src/config/types/MetricsConfiguration.ts @@ -0,0 +1,3 @@ +export class MetricsConfiguration { + timeout: number = 30000; +} \ No newline at end of file diff --git a/util/src/config/types/RabbitMQConfiguration.ts b/util/src/config/types/RabbitMQConfiguration.ts new file mode 100644 index 000000000..ce4a91236 --- /dev/null +++ b/util/src/config/types/RabbitMQConfiguration.ts @@ -0,0 +1,3 @@ +export class RabbitMQConfiguration { + host: string | null = null; +} \ No newline at end of file diff --git a/util/src/config/types/RegionConfiguration.ts b/util/src/config/types/RegionConfiguration.ts new file mode 100644 index 000000000..09d9271c8 --- /dev/null +++ b/util/src/config/types/RegionConfiguration.ts @@ -0,0 +1,16 @@ +import { Region } from "."; + +export class RegionConfiguration { + default: string = "fosscord"; + useDefaultAsOptimal: boolean = true; + available: Region[] = [ + { + id: "fosscord", + name: "Fosscord", + endpoint: "127.0.0.1:3004", + vip: false, + custom: false, + deprecated: false, + }, + ]; +} \ No newline at end of file diff --git a/util/src/config/types/RegisterConfiguration.ts b/util/src/config/types/RegisterConfiguration.ts new file mode 100644 index 000000000..a0dc97c5d --- /dev/null +++ b/util/src/config/types/RegisterConfiguration.ts @@ -0,0 +1,18 @@ +import { DateOfBirthConfiguration, EmailConfiguration, PasswordConfiguration } from "."; + +export class RegisterConfiguration { + //classes + email: EmailConfiguration = new EmailConfiguration(); + dateOfBirth: DateOfBirthConfiguration = new DateOfBirthConfiguration(); + password: PasswordConfiguration = new PasswordConfiguration(); + //base types + disabled: boolean = false; + requireCaptcha: boolean = true; + requireInvite: boolean = false; + guestsRequireInvite: boolean = true; + allowNewRegistration: boolean = true; + allowMultipleAccounts: boolean = true; + blockProxies: boolean = true; + incrementingDiscriminators: boolean = false; // random otherwise + defaultRights: string = "0"; +} diff --git a/util/src/config/types/SecurityConfiguration.ts b/util/src/config/types/SecurityConfiguration.ts new file mode 100644 index 000000000..405b86aca --- /dev/null +++ b/util/src/config/types/SecurityConfiguration.ts @@ -0,0 +1,17 @@ +import crypto from "crypto"; +import { CaptchaConfiguration, TwoFactorConfiguration } from "."; + +export class SecurityConfiguration { + //classes + captcha: CaptchaConfiguration = new CaptchaConfiguration(); + twoFactor: TwoFactorConfiguration = new TwoFactorConfiguration(); + //base types + autoUpdate: boolean | number = true; + requestSignature: string = crypto.randomBytes(32).toString("base64"); + jwtSecret: string = crypto.randomBytes(256).toString("base64"); + // header to get the real user ip address + // X-Forwarded-For for nginx/reverse proxies + // CF-Connecting-IP for cloudflare + forwadedFor: string | null = null; + ipdataApiKey: string | null = "eca677b284b3bac29eb72f5e496aa9047f26543605efe99ff2ce35c9"; +} diff --git a/util/src/config/types/SentryConfiguration.ts b/util/src/config/types/SentryConfiguration.ts new file mode 100644 index 000000000..836094a1f --- /dev/null +++ b/util/src/config/types/SentryConfiguration.ts @@ -0,0 +1,8 @@ +import { hostname } from "os"; + +export class SentryConfiguration { + enabled: boolean = false; + endpoint: string = "https://05e8e3d005f34b7d97e920ae5870a5e5@sentry.thearcanebrony.net/6"; + traceSampleRate: number = 1.0; + environment: string = hostname(); +} \ No newline at end of file diff --git a/util/src/config/types/TemplateConfiguration.ts b/util/src/config/types/TemplateConfiguration.ts new file mode 100644 index 000000000..4a9aa8f2c --- /dev/null +++ b/util/src/config/types/TemplateConfiguration.ts @@ -0,0 +1,6 @@ +export class TemplateConfiguration { + enabled: boolean = true; + allowTemplateCreation: boolean = true; + allowDiscordTemplates: boolean = true; + allowRaws: boolean = true; +} \ No newline at end of file diff --git a/util/src/config/types/index.ts b/util/src/config/types/index.ts new file mode 100644 index 000000000..608503a0c --- /dev/null +++ b/util/src/config/types/index.ts @@ -0,0 +1,18 @@ +export * from "./ApiConfiguration"; +export * from "./ClientConfiguration"; +export * from "./DefaultsConfiguration"; +export * from "./EndpointConfiguration"; +export * from "./GeneralConfiguration"; +export * from "./GifConfiguration"; +export * from "./GuildConfiguration"; +export * from "./KafkaConfiguration"; +export * from "./LimitConfigurations"; +export * from "./LoginConfiguration"; +export * from "./MetricsConfiguration"; +export * from "./RabbitMQConfiguration"; +export * from "./RegionConfiguration"; +export * from "./RegisterConfiguration"; +export * from "./SecurityConfiguration"; +export * from "./SentryConfiguration"; +export * from "./TemplateConfiguration"; +export * from "./subconfigurations/index"; diff --git a/util/src/config/types/subconfigurations/client/ClientReleaseConfiguration.ts b/util/src/config/types/subconfigurations/client/ClientReleaseConfiguration.ts new file mode 100644 index 000000000..54e7f365d --- /dev/null +++ b/util/src/config/types/subconfigurations/client/ClientReleaseConfiguration.ts @@ -0,0 +1,4 @@ +export class ClientReleaseConfiguration { + useLocalRelease: boolean = true; //TODO + upstreamVersion: string = "0.0.264"; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/client/index.ts b/util/src/config/types/subconfigurations/client/index.ts new file mode 100644 index 000000000..96bbb0ca3 --- /dev/null +++ b/util/src/config/types/subconfigurations/client/index.ts @@ -0,0 +1 @@ +export * from "./ClientReleaseConfiguration"; diff --git a/util/src/config/types/subconfigurations/defaults/GuildDefaults.ts b/util/src/config/types/subconfigurations/defaults/GuildDefaults.ts new file mode 100644 index 000000000..d6ff76972 --- /dev/null +++ b/util/src/config/types/subconfigurations/defaults/GuildDefaults.ts @@ -0,0 +1,8 @@ +export class GuildDefaults { + maxPresences: number = 250000; + maxVideoChannelUsers: number = 200; + afkTimeout: number = 300; + defaultMessageNotifications: number = 1; + explicitContentFilter: number = 0; + test: number = 123; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/defaults/index.ts b/util/src/config/types/subconfigurations/defaults/index.ts new file mode 100644 index 000000000..f40c5cd2f --- /dev/null +++ b/util/src/config/types/subconfigurations/defaults/index.ts @@ -0,0 +1 @@ +export * from "./GuildDefaults"; diff --git a/util/src/config/types/subconfigurations/guild/AutoJoin.ts b/util/src/config/types/subconfigurations/guild/AutoJoin.ts new file mode 100644 index 000000000..47dfe5ec2 --- /dev/null +++ b/util/src/config/types/subconfigurations/guild/AutoJoin.ts @@ -0,0 +1,5 @@ +export class AutoJoinConfiguration { + enabled: boolean = true; + guilds: string[] = []; + canLeave: boolean = true; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/guild/Discovery.ts b/util/src/config/types/subconfigurations/guild/Discovery.ts new file mode 100644 index 000000000..59d8a8aeb --- /dev/null +++ b/util/src/config/types/subconfigurations/guild/Discovery.ts @@ -0,0 +1,6 @@ +export class DiscoveryConfiguration { + showAllGuilds: boolean = false; + useRecommendation: boolean = false; // TODO: Recommendation, privacy concern? + offset: number = 0; + limit: number = 24; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/guild/index.ts b/util/src/config/types/subconfigurations/guild/index.ts new file mode 100644 index 000000000..e9614856e --- /dev/null +++ b/util/src/config/types/subconfigurations/guild/index.ts @@ -0,0 +1,2 @@ +export * from "./AutoJoin"; +export * from "./Discovery"; diff --git a/util/src/config/types/subconfigurations/index.ts b/util/src/config/types/subconfigurations/index.ts new file mode 100644 index 000000000..bfbadc929 --- /dev/null +++ b/util/src/config/types/subconfigurations/index.ts @@ -0,0 +1,8 @@ +export * from "./client/index"; +export * from "./defaults/index"; +export * from "./guild/index"; +export * from "./kafka/index"; +export * from "./limits/index"; +export * from "./region/index"; +export * from "./register/index"; +export * from "./security/index"; diff --git a/util/src/config/types/subconfigurations/kafka/KafkaBroker.ts b/util/src/config/types/subconfigurations/kafka/KafkaBroker.ts new file mode 100644 index 000000000..4f9a5e51c --- /dev/null +++ b/util/src/config/types/subconfigurations/kafka/KafkaBroker.ts @@ -0,0 +1,4 @@ +export interface KafkaBroker { + ip: string; + port: number; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/kafka/index.ts b/util/src/config/types/subconfigurations/kafka/index.ts new file mode 100644 index 000000000..2c6339500 --- /dev/null +++ b/util/src/config/types/subconfigurations/kafka/index.ts @@ -0,0 +1 @@ +export * from "./KafkaBroker"; diff --git a/util/src/config/types/subconfigurations/limits/ChannelLimits.ts b/util/src/config/types/subconfigurations/limits/ChannelLimits.ts new file mode 100644 index 000000000..2f8f94859 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/ChannelLimits.ts @@ -0,0 +1,5 @@ +export class ChannelLimits { + maxPins: number = 500; + maxTopic: number = 1024; + maxWebhooks: number = 100; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/GuildLimits.ts b/util/src/config/types/subconfigurations/limits/GuildLimits.ts new file mode 100644 index 000000000..91ad39ae6 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/GuildLimits.ts @@ -0,0 +1,8 @@ +export class GuildLimits { + maxRoles: number = 1000; + maxEmojis: number = 2000; + maxMembers: number = 25000000; + maxChannels: number = 65535; + maxChannelsInCategory: number = 65535; + hideOfflineMember: number = 3; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/MessageLimits.ts b/util/src/config/types/subconfigurations/limits/MessageLimits.ts new file mode 100644 index 000000000..51576b901 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/MessageLimits.ts @@ -0,0 +1,8 @@ +export class MessageLimits { + maxCharacters: number = 1048576; + maxTTSCharacters: number = 160; + maxReactions: number = 2048; + maxAttachmentSize: number = 1024 * 1024 * 1024; + maxBulkDelete: number = 1000; + maxEmbedDownloadSize: number = 1024 * 1024 * 5; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/RateLimits.ts b/util/src/config/types/subconfigurations/limits/RateLimits.ts new file mode 100644 index 000000000..25e7a1e09 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/RateLimits.ts @@ -0,0 +1,18 @@ +import { RouteRateLimit, RateLimitOptions } from "."; + +export class RateLimits { + disabled: boolean = true; + ip: Omit = { + count: 500, + window: 5 + }; + global: RateLimitOptions = { + count: 250, + window: 5 + }; + error: RateLimitOptions = { + count: 10, + window: 5 + }; + routes: RouteRateLimit; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/UserLimits.ts b/util/src/config/types/subconfigurations/limits/UserLimits.ts new file mode 100644 index 000000000..0d10e0b35 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/UserLimits.ts @@ -0,0 +1,5 @@ +export class UserLimits { + maxGuilds: number = 1048576; + maxUsername: number = 127; + maxFriends: number = 5000; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/index.ts b/util/src/config/types/subconfigurations/limits/index.ts new file mode 100644 index 000000000..0b7304f63 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/index.ts @@ -0,0 +1,6 @@ +export * from "./ChannelLimits"; +export * from "./GuildLimits"; +export * from "./MessageLimits"; +export * from "./RateLimits"; +export * from "./UserLimits"; +export * from "./ratelimits/index"; diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/Auth.ts b/util/src/config/types/subconfigurations/limits/ratelimits/Auth.ts new file mode 100644 index 000000000..df171044a --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/ratelimits/Auth.ts @@ -0,0 +1,12 @@ +import { RateLimitOptions } from "./RateLimitOptions"; + +export class AuthRateLimit { + login: RateLimitOptions = { + count: 5, + window: 60 + }; + register: RateLimitOptions = { + count: 2, + window: 60 * 60 * 12 + }; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts b/util/src/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts new file mode 100644 index 000000000..7089e28ef --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts @@ -0,0 +1,6 @@ +export interface RateLimitOptions { + bot?: number; + count: number; + window: number; + onyIp?: boolean; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/Route.ts b/util/src/config/types/subconfigurations/limits/ratelimits/Route.ts new file mode 100644 index 000000000..3012a8a8d --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/ratelimits/Route.ts @@ -0,0 +1,19 @@ +import { AuthRateLimit } from "."; +import { RateLimitOptions } from "./RateLimitOptions"; + +export class RouteRateLimit { + guild: RateLimitOptions = { + count: 5, + window: 5 + }; + webhook: RateLimitOptions = { + count: 10, + window: 5 + }; + channel: RateLimitOptions = { + count: 10, + window: 5 + }; + auth: AuthRateLimit; + // TODO: rate limit configuration for all routes +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/index.ts b/util/src/config/types/subconfigurations/limits/ratelimits/index.ts new file mode 100644 index 000000000..432eb6011 --- /dev/null +++ b/util/src/config/types/subconfigurations/limits/ratelimits/index.ts @@ -0,0 +1,3 @@ +export * from "./Auth"; +export * from "./RateLimitOptions"; +export * from "./Route"; diff --git a/util/src/config/types/subconfigurations/region/Region.ts b/util/src/config/types/subconfigurations/region/Region.ts new file mode 100644 index 000000000..a8717e1fe --- /dev/null +++ b/util/src/config/types/subconfigurations/region/Region.ts @@ -0,0 +1,12 @@ +export interface Region { + id: string; + name: string; + endpoint: string; + location?: { + latitude: number; + longitude: number; + }; + vip: boolean; + custom: boolean; + deprecated: boolean; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/region/index.ts b/util/src/config/types/subconfigurations/region/index.ts new file mode 100644 index 000000000..2beb8de7f --- /dev/null +++ b/util/src/config/types/subconfigurations/region/index.ts @@ -0,0 +1 @@ +export * from "./Region"; diff --git a/util/src/config/types/subconfigurations/register/DateOfBirth.ts b/util/src/config/types/subconfigurations/register/DateOfBirth.ts new file mode 100644 index 000000000..5a3c4e9de --- /dev/null +++ b/util/src/config/types/subconfigurations/register/DateOfBirth.ts @@ -0,0 +1,4 @@ +export class DateOfBirthConfiguration { + required: boolean = true; + minimum: number = 13; // in years +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/register/Email.ts b/util/src/config/types/subconfigurations/register/Email.ts new file mode 100644 index 000000000..115d49e08 --- /dev/null +++ b/util/src/config/types/subconfigurations/register/Email.ts @@ -0,0 +1,7 @@ +export class EmailConfiguration { + required: boolean = false; + allowlist: boolean = false; + blocklist: boolean = true; + domains: string[] = [];// TODO: efficiently save domain blocklist in database + // domains: fs.readFileSync(__dirname + "/blockedEmailDomains.txt", { encoding: "utf8" }).split("\n"), +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/register/Password.ts b/util/src/config/types/subconfigurations/register/Password.ts new file mode 100644 index 000000000..977473ac4 --- /dev/null +++ b/util/src/config/types/subconfigurations/register/Password.ts @@ -0,0 +1,7 @@ +export class PasswordConfiguration { + required: boolean = false; + minLength: number = 8; + minNumbers: number = 2; + minUpperCase: number =2; + minSymbols: number = 0; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/register/index.ts b/util/src/config/types/subconfigurations/register/index.ts new file mode 100644 index 000000000..d97381200 --- /dev/null +++ b/util/src/config/types/subconfigurations/register/index.ts @@ -0,0 +1,3 @@ +export * from "./DateOfBirth"; +export * from "./Email"; +export * from "./Password"; diff --git a/util/src/config/types/subconfigurations/security/Captcha.ts b/util/src/config/types/subconfigurations/security/Captcha.ts new file mode 100644 index 000000000..ad6aa7629 --- /dev/null +++ b/util/src/config/types/subconfigurations/security/Captcha.ts @@ -0,0 +1,6 @@ +export class CaptchaConfiguration { + enabled: boolean = false; + service: "recaptcha" | "hcaptcha" | null = null; // TODO: hcaptcha, custom + sitekey: string | null = null; + secret: string | null = null; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/security/TwoFactor.ts b/util/src/config/types/subconfigurations/security/TwoFactor.ts new file mode 100644 index 000000000..33a47385f --- /dev/null +++ b/util/src/config/types/subconfigurations/security/TwoFactor.ts @@ -0,0 +1,3 @@ +export class TwoFactorConfiguration { + generateBackupCodes: boolean = true; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/security/index.ts b/util/src/config/types/subconfigurations/security/index.ts new file mode 100644 index 000000000..17619589d --- /dev/null +++ b/util/src/config/types/subconfigurations/security/index.ts @@ -0,0 +1,2 @@ +export * from "./Captcha"; +export * from "./TwoFactor"; diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts index 901a5e549..606fe9013 100644 --- a/util/src/entities/Config.ts +++ b/util/src/entities/Config.ts @@ -1,9 +1,5 @@ import { Column, Entity } from "typeorm"; import { BaseClassWithoutId, PrimaryIdColumn } from "./BaseClass"; -import crypto from "crypto"; -import { Snowflake } from "../util/Snowflake"; -import { SessionsReplace } from ".."; -import { hostname } from "os"; @Entity("config") export class ConfigEntity extends BaseClassWithoutId { @@ -12,404 +8,4 @@ export class ConfigEntity extends BaseClassWithoutId { @Column({ type: "simple-json", nullable: true }) value: number | boolean | null | string | undefined; -} - -export interface RateLimitOptions { - bot?: number; - count: number; - window: number; - onyIp?: boolean; -} - -export interface Region { - id: string; - name: string; - endpoint: string; - location?: { - latitude: number; - longitude: number; - }; - vip: boolean; - custom: boolean; - deprecated: boolean; -} - -export interface KafkaBroker { - ip: string; - port: number; -} - -export interface ConfigValue { - gateway: { - endpointClient: string | null; - endpointPrivate: string | null; - endpointPublic: string | null; - }; - cdn: { - endpointClient: string | null; - endpointPublic: string | null; - endpointPrivate: string | null; - }; - api: { - defaultVersion: string; - activeVersions: string[]; - useFosscordEnhancements: boolean; - }; - general: { - instanceName: string; - instanceDescription: string | null; - frontPage: string | null; - tosPage: string | null; - correspondenceEmail: string | null; - correspondenceUserID: string | null; - image: string | null; - instanceId: string; - }; - limits: { - user: { - maxGuilds: number; - maxUsername: number; - maxFriends: number; - }; - guild: { - maxRoles: number; - maxEmojis: number; - maxMembers: number; - maxChannels: number; - maxChannelsInCategory: number; - hideOfflineMember: number; - }; - message: { - maxCharacters: number; - maxTTSCharacters: number; - maxReactions: number; - maxAttachmentSize: number; - maxBulkDelete: number; - maxEmbedDownloadSize: number; - }; - channel: { - maxPins: number; - maxTopic: number; - maxWebhooks: number; - }; - rate: { - disabled: boolean; - ip: Omit; - global: RateLimitOptions; - error: RateLimitOptions; - routes: { - guild: RateLimitOptions; - webhook: RateLimitOptions; - channel: RateLimitOptions; - auth: { - login: RateLimitOptions; - register: RateLimitOptions; - }; - // TODO: rate limit configuration for all routes - }; - }; - }; - security: { - autoUpdate: boolean | number; - requestSignature: string; - jwtSecret: string; - forwadedFor: string | null; // header to get the real user ip address - captcha: { - enabled: boolean; - service: "recaptcha" | "hcaptcha" | null; // TODO: hcaptcha, custom - sitekey: string | null; - secret: string | null; - }; - ipdataApiKey: string | null; - twoFactor: { - generateBackupCodes: boolean; - }; - }; - login: { - requireCaptcha: boolean; - }; - register: { - defaultRights: string; - email: { - required: boolean; - allowlist: boolean; - blocklist: boolean; - domains: string[]; - }; - dateOfBirth: { - required: boolean; - minimum: number; // in years - }; - disabled: boolean; - requireCaptcha: boolean; - requireInvite: boolean; - guestsRequireInvite: boolean; - allowNewRegistration: boolean; - allowMultipleAccounts: boolean; - blockProxies: boolean; - password: { - required: boolean; - minLength: number; - minNumbers: number; - minUpperCase: number; - minSymbols: number; - }; - incrementingDiscriminators: boolean; // random otherwise - }; - regions: { - default: string; - useDefaultAsOptimal: boolean; - available: Region[]; - }; - guild: { - discovery: { - showAllGuilds: boolean; - useRecommendation: boolean; // TODO: Recommendation, privacy concern? - offset: number; - limit: number; - }; - autoJoin: { - enabled: boolean; - guilds: string[]; - canLeave: boolean; - }; - }; - gif: { - enabled: boolean; - provider: "tenor"; // more coming soon - apiKey?: string; - }; - rabbitmq: { - host: string | null; - }; - kafka: { - brokers: KafkaBroker[] | null; - }; - templates: { - enabled: Boolean; - allowTemplateCreation: Boolean; - allowDiscordTemplates: Boolean; - allowRaws: Boolean; - }, - client: { - useTestClient: Boolean; - releases: { - useLocalRelease: Boolean; //TODO - upstreamVersion: string; - } - }, - metrics: { - timeout: number; - }, - sentry: { - enabled: boolean; - endpoint: string; - traceSampleRate: number; - environment: string; - } -} - -export const DefaultConfigOptions: ConfigValue = { - gateway: { - endpointClient: null, - endpointPrivate: null, - endpointPublic: null, - }, - cdn: { - endpointClient: null, - endpointPrivate: null, - endpointPublic: null, - }, - api: { - defaultVersion: "9", - activeVersions: ["6", "7", "8", "9"], - useFosscordEnhancements: true, - }, - general: { - instanceName: "Fosscord Instance", - instanceDescription: "This is a Fosscord instance made in pre-release days", - frontPage: null, - tosPage: null, - correspondenceEmail: "noreply@localhost.local", - correspondenceUserID: null, - image: null, - instanceId: Snowflake.generate(), - }, - limits: { - user: { - maxGuilds: 1048576, - maxUsername: 127, - maxFriends: 5000, - }, - guild: { - maxRoles: 1000, - maxEmojis: 2000, - maxMembers: 25000000, - maxChannels: 65535, - maxChannelsInCategory: 65535, - hideOfflineMember: 3, - }, - message: { - maxCharacters: 1048576, - maxTTSCharacters: 160, - maxReactions: 2048, - maxAttachmentSize: 1024 * 1024 * 1024, - maxEmbedDownloadSize: 1024 * 1024 * 5, - maxBulkDelete: 1000, - }, - channel: { - maxPins: 500, - maxTopic: 1024, - maxWebhooks: 100, - }, - rate: { - disabled: true, - ip: { - count: 500, - window: 5, - }, - global: { - count: 250, - window: 5, - }, - error: { - count: 10, - window: 5, - }, - routes: { - guild: { - count: 5, - window: 5, - }, - webhook: { - count: 10, - window: 5, - }, - channel: { - count: 10, - window: 5, - }, - auth: { - login: { - count: 5, - window: 60, - }, - register: { - count: 2, - window: 60 * 60 * 12, - }, - }, - }, - }, - }, - security: { - autoUpdate: true, - requestSignature: crypto.randomBytes(32).toString("base64"), - jwtSecret: crypto.randomBytes(256).toString("base64"), - forwadedFor: null, - // forwadedFor: "X-Forwarded-For" // nginx/reverse proxy - // forwadedFor: "CF-Connecting-IP" // cloudflare: - captcha: { - enabled: false, - service: null, - sitekey: null, - secret: null, - }, - ipdataApiKey: "eca677b284b3bac29eb72f5e496aa9047f26543605efe99ff2ce35c9", - twoFactor: { - generateBackupCodes: true, - }, - }, - login: { - requireCaptcha: false, - }, - register: { - email: { - required: false, - allowlist: false, - blocklist: true, - domains: [], // TODO: efficiently save domain blocklist in database - // domains: fs.readFileSync(__dirname + "/blockedEmailDomains.txt", { encoding: "utf8" }).split("\n"), - }, - dateOfBirth: { - required: true, - minimum: 13, - }, - disabled: false, - requireInvite: false, - guestsRequireInvite: true, - requireCaptcha: true, - allowNewRegistration: true, - allowMultipleAccounts: true, - blockProxies: true, - password: { - required: false, - minLength: 8, - minNumbers: 2, - minUpperCase: 2, - minSymbols: 0, - }, - incrementingDiscriminators: false, - defaultRights: "0" - }, - regions: { - default: "fosscord", - useDefaultAsOptimal: true, - available: [ - { - id: "fosscord", - name: "Fosscord", - endpoint: "127.0.0.1:3004", - vip: false, - custom: false, - deprecated: false, - }, - ], - }, - guild: { - discovery: { - showAllGuilds: false, - useRecommendation: false, - offset: 0, - limit: 24, - }, - autoJoin: { - enabled: true, - canLeave: true, - guilds: [], - }, - }, - gif: { - enabled: true, - provider: "tenor", - apiKey: "LIVDSRZULELA", - }, - rabbitmq: { - host: null, - }, - kafka: { - brokers: null, - }, - templates: { - enabled: true, - allowTemplateCreation: true, - allowDiscordTemplates: true, - allowRaws: false - }, - client: { - useTestClient: true, - releases: { - useLocalRelease: true, - upstreamVersion: "0.0.264" - } - }, - metrics: { - timeout: 30000 - }, - sentry: { - enabled: false, - endpoint: "https://05e8e3d005f34b7d97e920ae5870a5e5@sentry.thearcanebrony.net/6", - traceSampleRate: 1.0, - environment: hostname() - } -}; +} \ No newline at end of file diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index 925cb2434..0b55ca4b0 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -1,6 +1,7 @@ -import { ConfigValue, ConfigEntity, DefaultConfigOptions } from "../entities/Config"; -import path from "path"; +import { ConfigEntity } from "../entities/Config"; import fs from "fs"; +import { ConfigValue } from "../config"; +import { OrmUtils } from "."; // TODO: yaml instead of json const overridePath = process.env.CONFIG_PATH ?? ""; @@ -14,9 +15,11 @@ let pairs: ConfigEntity[]; export const Config = { init: async function init() { if (config) return config; + console.log('[Config] Loading configuration...') pairs = await ConfigEntity.find(); config = pairsToConfig(pairs); - config = (config || {}).merge(DefaultConfigOptions); + //config = (config || {}).merge(new ConfigValue()); + config = OrmUtils.mergeDeep(new ConfigValue(), config) if(process.env.CONFIG_PATH) try { @@ -30,6 +33,11 @@ export const Config = { return this.set(config); }, get: function get() { + if(!config) { + if(/--debug|--inspect/.test(process.execArgv.join(' '))) + console.log("Oops.. trying to get config without config existing... Returning defaults... (Is the database still initialising?)"); + return new ConfigValue(); + } return config; }, set: function set(val: Partial) { From 44859db499f080e3a341f3e7fa5e44611fc2f887 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 01:46:42 +0200 Subject: [PATCH 207/238] Push local state... --- api/assets/schemas.json | 13716 +--------------- api/client_test/index.html | 149 +- api/src/routes/auth/register.ts | 1 + api/src/routes/guilds/#guild_id/index.ts | 1 + api/src/routes/users/@me/settings.ts | 4 +- bundle/scripts/db_migrations.sh | 14 +- bundle/scripts/gen_index.js | 34 + bundle/scripts/update_schemas.js | 9 + bundle/scripts/utils.js | 3 +- gateway/src/opcodes/Identify.ts | 7 +- gateway/src/opcodes/VoiceStateUpdate.ts | 5 + .../src/config/types/DefaultsConfiguration.ts | 3 +- .../defaults/UserDefaults.ts | 5 + .../types/subconfigurations/defaults/index.ts | 1 + util/src/entities/Guild.ts | 20 +- util/src/entities/User.ts | 158 +- util/src/entities/UserSettings.ts | 119 + util/src/entities/index.ts | 1 + util/src/interfaces/Event.ts | 4 +- .../mariadb/1660258393551-CodeCleanup3.ts | 232 + .../mariadb/1660260587556-CodeCleanup4.ts | 39 + .../postgres/1660257815436-CodeCleanup2.ts | 59 + .../postgres/1660258372154-CodeCleanup3.ts | 19 + .../postgres/1660260565996-CodeCleanup4.ts | 33 + .../sqlite/1660257576211-CodeCleanup1.ts | 326 + .../sqlite/1660257795259-CodeCleanup2.ts | 572 + .../sqlite/1660258351379-CodeCleanup3.ts | 231 + .../sqlite/1660260539853-CodeCleanup4.ts | 459 + .../sqlite/1660260672914-CodeCleanup4.ts | 459 + 29 files changed, 2865 insertions(+), 13818 deletions(-) create mode 100644 bundle/scripts/gen_index.js create mode 100644 bundle/scripts/update_schemas.js create mode 100644 util/src/config/types/subconfigurations/defaults/UserDefaults.ts create mode 100644 util/src/entities/UserSettings.ts create mode 100644 util/src/migrations/mariadb/1660258393551-CodeCleanup3.ts create mode 100644 util/src/migrations/mariadb/1660260587556-CodeCleanup4.ts create mode 100644 util/src/migrations/postgres/1660257815436-CodeCleanup2.ts create mode 100644 util/src/migrations/postgres/1660258372154-CodeCleanup3.ts create mode 100644 util/src/migrations/postgres/1660260565996-CodeCleanup4.ts create mode 100644 util/src/migrations/sqlite/1660257576211-CodeCleanup1.ts create mode 100644 util/src/migrations/sqlite/1660257795259-CodeCleanup2.ts create mode 100644 util/src/migrations/sqlite/1660258351379-CodeCleanup3.ts create mode 100644 util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts create mode 100644 util/src/migrations/sqlite/1660260672914-CodeCleanup4.ts diff --git a/api/assets/schemas.json b/api/assets/schemas.json index c7aadd986..00819e7cc 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -1,4 +1,103 @@ { + "ts.server.TypingInstallerResponse": { + "type": "object", + "properties": { + "kind": { + "enum": [ + "action::invalidate", + "action::packageInstalled", + "action::set", + "event::beginInstallTypes", + "event::endInstallTypes", + "event::initializationFailed", + "event::typesRegistry" + ], + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "kind" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ts.server.PackageInstalledResponse": { + "type": "object", + "properties": { + "kind": { + "type": "string", + "enum": [ + "action::packageInstalled" + ] + }, + "success": { + "type": "boolean" + }, + "message": { + "type": "string" + }, + "projectName": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "kind", + "message", + "projectName", + "success" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ts.server.InitializationFailedResponse": { + "type": "object", + "properties": { + "kind": { + "type": "string", + "enum": [ + "event::initializationFailed" + ] + }, + "message": { + "type": "string" + }, + "stack": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "kind", + "message" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ts.server.ProjectResponse": { + "type": "object", + "properties": { + "projectName": { + "type": "string" + }, + "kind": { + "enum": [ + "action::invalidate", + "action::packageInstalled", + "action::set", + "event::beginInstallTypes", + "event::endInstallTypes", + "event::initializationFailed", + "event::typesRegistry" + ], + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "kind", + "projectName" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, "MessageCreateSchema": { "type": "object", "properties": { @@ -225,183 +324,6 @@ } }, "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] } }, "$schema": "http://json-schema.org/draft-07/schema#" @@ -424,312 +346,9 @@ }, "additionalProperties": false, "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, "Record": { "type": "object", "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] } }, "$schema": "http://json-schema.org/draft-07/schema#" @@ -761,315 +380,6 @@ "login", "password" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "TotpSchema": { @@ -1099,315 +409,6 @@ "code", "ticket" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "RegisterSchema": { @@ -1444,6 +445,9 @@ }, "captcha_key": { "type": "string" + }, + "promotional_email_opt_in": { + "type": "boolean" } }, "additionalProperties": false, @@ -1451,315 +455,6 @@ "consent", "username" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "ChannelModifySchema": { @@ -1861,140 +556,6 @@ }, "additionalProperties": false, "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, "ChannelPermissionOverwriteType": { "enum": [ 0, @@ -2002,171 +563,6 @@ 2 ], "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] } }, "$schema": "http://json-schema.org/draft-07/schema#" @@ -2203,315 +599,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "MessageAcknowledgeSchema": { @@ -2525,315 +612,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "BulkDeleteSchema": { @@ -2850,315 +628,6 @@ "required": [ "messages" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "ChannelPermissionOverwriteSchema": { @@ -3185,140 +654,6 @@ "type" ], "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, "ChannelPermissionOverwriteType": { "enum": [ 0, @@ -3326,171 +661,6 @@ 2 ], "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] } }, "$schema": "http://json-schema.org/draft-07/schema#" @@ -3510,315 +680,6 @@ "after", "before" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "WebhookCreateSchema": { @@ -3837,315 +698,6 @@ "avatar", "name" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "GatewayBotResponse": { @@ -4188,315 +740,6 @@ "shards", "url" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "GatewayResponse": { @@ -4510,315 +753,6 @@ "required": [ "url" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "BanCreateSchema": { @@ -4832,315 +766,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "BanRegistrySchema": { @@ -5172,315 +797,6 @@ "id", "user_id" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "BanModeratorSchema": { @@ -5509,315 +825,6 @@ "id", "user_id" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "ChannelReorderSchema": { @@ -5843,315 +850,6 @@ "id" ] }, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "EmojiCreateSchema": { @@ -6180,315 +878,6 @@ "required": [ "image" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "EmojiModifySchema": { @@ -6505,315 +894,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "GuildCreateSchema": { @@ -6853,148 +933,6 @@ "name" ], "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, "ChannelModifySchema": { "type": "object", "properties": { @@ -7094,71 +1032,13 @@ }, "additionalProperties": false }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" } }, "$schema": "http://json-schema.org/draft-07/schema#" @@ -7234,315 +1114,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "MemberChangeSchema": { @@ -7556,315 +1127,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "MemberNickChangeSchema": { @@ -7878,315 +1140,6 @@ "required": [ "nick" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "PruneSchema": { @@ -8200,315 +1153,6 @@ "required": [ "days" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "RoleModifySchema": { @@ -8540,315 +1184,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "RolePositionUpdateSchema": { @@ -8869,315 +1204,6 @@ "position" ] }, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "ModifyGuildStickerSchema": { @@ -9202,315 +1228,6 @@ "name", "tags" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "TemplateCreateSchema": { @@ -9527,315 +1244,6 @@ "required": [ "name" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "TemplateModifySchema": { @@ -9852,315 +1260,6 @@ "required": [ "name" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "VanityUrlSchema": { @@ -10173,315 +1272,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "VoiceStateUpdateSchema": { @@ -10514,315 +1304,6 @@ "required": [ "channel_id" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "GuildUpdateWelcomeScreenSchema": { @@ -10862,315 +1343,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "WidgetModifySchema": { @@ -11188,315 +1360,6 @@ "channel_id", "enabled" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "GuildTemplateCreateSchema": { @@ -11516,315 +1379,6 @@ "required": [ "name" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "UserProfileResponse": { @@ -11851,247 +1405,6 @@ "user" ], "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, "UserPublic": { "type": "object", "properties": { @@ -12190,315 +1503,6 @@ "required": [ "object" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "DmChannelCreateSchema": { @@ -12518,315 +1522,6 @@ "required": [ "recipients" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "UserModifySchema": { @@ -12837,6 +1532,9 @@ "maxLength": 100, "type": "string" }, + "discriminator": { + "type": "string" + }, "avatar": { "type": [ "null", @@ -12867,315 +1565,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "MfaCodesSchema": { @@ -13192,315 +1581,6 @@ "required": [ "password" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "TotpDisableSchema": { @@ -13514,347 +1594,11 @@ "required": [ "code" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "TotpEnableSchema": { "type": "object", "properties": { - "username": { - "minLength": 1, - "maxLength": 100, - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "avatar": { - "type": [ - "null", - "string" - ] - }, - "bio": { - "maxLength": 1024, - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": [ - "null", - "string" - ] - }, "password": { "type": "string" }, @@ -13869,315 +1613,6 @@ "required": [ "password" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "RelationshipPutSchema": { @@ -14194,315 +1629,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "RelationshipPostSchema": { @@ -14520,315 +1646,6 @@ "discriminator", "username" ], - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" }, "UserSettingsSchema": { @@ -15004,315 +1821,6 @@ } }, "additionalProperties": false, - "definitions": { - "Embed": { - "type": "object", - "properties": { - "title": { - "type": "string" - }, - "type": { - "enum": [ - "article", - "gifv", - "image", - "link", - "rich", - "video" - ], - "type": "string" - }, - "description": { - "type": "string" - }, - "url": { - "type": "string" - }, - "timestamp": { - "type": "string", - "format": "date-time" - }, - "color": { - "type": "integer" - }, - "footer": { - "type": "object", - "properties": { - "text": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "text" - ] - }, - "image": { - "$ref": "#/definitions/EmbedImage" - }, - "thumbnail": { - "$ref": "#/definitions/EmbedImage" - }, - "video": { - "$ref": "#/definitions/EmbedImage" - }, - "provider": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "author": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "url": { - "type": "string" - }, - "icon_url": { - "type": "string" - }, - "proxy_icon_url": { - "type": "string" - } - }, - "additionalProperties": false - }, - "fields": { - "type": "array", - "items": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "value": { - "type": "string" - }, - "inline": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "value" - ] - } - } - }, - "additionalProperties": false - }, - "EmbedImage": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "proxy_url": { - "type": "string" - }, - "height": { - "type": "integer" - }, - "width": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "Record": { - "type": "object", - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - }, - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, "$schema": "http://json-schema.org/draft-07/schema#" } } \ No newline at end of file diff --git a/api/client_test/index.html b/api/client_test/index.html index f58a4bca5..c35c14d2b 100644 --- a/api/client_test/index.html +++ b/api/client_test/index.html @@ -1,81 +1,84 @@ - - - - Discord Test Client - - - - - - - -
- - - - - - - - - + }, 1000) + + const settings = JSON.parse(localStorage.getItem("UserSettingsStore")); + if (settings && settings.locale.length <= 2) { + // fix client locale wrong and client not loading at all + settings.locale = "en-US"; + localStorage.setItem("UserSettingsStore", JSON.stringify(settings)); + } + + + + + + + + + + \ No newline at end of file diff --git a/api/src/routes/auth/register.ts b/api/src/routes/auth/register.ts index 2baef98e8..5a3d27e97 100644 --- a/api/src/routes/auth/register.ts +++ b/api/src/routes/auth/register.ts @@ -30,6 +30,7 @@ export interface RegisterSchema { date_of_birth?: Date; // "2000-04-03" gift_code_sku_id?: string; captcha_key?: string; + promotional_email_opt_in?: boolean; } router.post("/", route({ body: "RegisterSchema" }), async (req: Request, res: Response) => { diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index abece88e4..8d61f7537 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -21,6 +21,7 @@ export interface GuildUpdateSchema extends Omit { diff --git a/api/src/routes/users/@me/settings.ts b/api/src/routes/users/@me/settings.ts index 70f8a2187..d832575fa 100644 --- a/api/src/routes/users/@me/settings.ts +++ b/api/src/routes/users/@me/settings.ts @@ -10,8 +10,8 @@ router.patch("/", route({ body: "UserSettingsSchema" }), async (req: Request, re const body = req.body as UserSettings; if (body.locale === "en") body.locale = "en-US"; // fix discord client crash on unkown locale - const user = await User.findOneOrFail({ where: { id: req.user_id, bot: false } }); - user.settings = { ...user.settings, ...body }; + const user = await User.findOneOrFail({ where: { id: req.user_id, bot: false }, relations: ["settings"] }); + user.settings = { ...user.settings, ...body } as UserSettings; await user.save(); res.sendStatus(204); diff --git a/bundle/scripts/db_migrations.sh b/bundle/scripts/db_migrations.sh index b0e1131c1..83f15a2ba 100755 --- a/bundle/scripts/db_migrations.sh +++ b/bundle/scripts/db_migrations.sh @@ -1,5 +1,13 @@ #!/bin/sh -read -p "Enter migration filename: " FILENAME + +if [ ! -z "$1" ] +then + FILENAME="$1" + echo "Using filename: $FILENAME" +else + read -p "Enter migration filename: " FILENAME +fi + [ -f ".env" ] && ( mv .env .env.tmp source .env.tmp @@ -8,8 +16,8 @@ read -p "Enter migration filename: " FILENAME make_migration() { echo "Creating migrations for $2" mkdir "../util/src/migrations/$2" - npm run build clean logerrors pretty-errors - THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle +# npm run build clean logerrors pretty-errors +# THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "../util/src/migrations/$2/$FILENAME" -d ../util/src/util/Database.ts -p npm run build clean logerrors pretty-errors THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle diff --git a/bundle/scripts/gen_index.js b/bundle/scripts/gen_index.js new file mode 100644 index 000000000..71c64a9f7 --- /dev/null +++ b/bundle/scripts/gen_index.js @@ -0,0 +1,34 @@ +const path = require("path"); +const fs = require("fs"); +const { execIn, getLines, parts } = require('./utils'); + +if (!process.argv[2] || !fs.existsSync(process.argv[2])) { + console.log("Please pass a directory that exists!"); + process.exit(1); +} +console.log(`// ${process.argv[2]}/index.ts`) +const recurse = process.argv.includes("--recursive") + +const files = fs.readdirSync(process.argv[2]).filter(x => x.endsWith('.ts') && x != 'index.ts'); + +let output = ''; + +files.forEach(x => output += `export * from "./${x.replaceAll('.ts','')}";\n`) + +const dirs = fs.readdirSync(process.argv[2]).filter(x => { + try { + fs.readdirSync(path.join(process.argv[2], x)); + return true; + } catch (e) { + return false; + } +}); +dirs.forEach(x => { + output += `export * from "./${x}/index";\n` +}) +console.log(output); +fs.writeFileSync(path.join(process.argv[2], "index.ts"), output) + +dirs.forEach(x => { + if(recurse) console.log(execIn([process.argv[0], process.argv[1], `"${path.join(process.argv[2], x)}"`, "--recursive"].join(' '), process.cwd())) +}) \ No newline at end of file diff --git a/bundle/scripts/update_schemas.js b/bundle/scripts/update_schemas.js new file mode 100644 index 000000000..516b95920 --- /dev/null +++ b/bundle/scripts/update_schemas.js @@ -0,0 +1,9 @@ +const path = require("path"); +const fs = require("fs"); +const { env } = require("process"); +const { execSync } = require("child_process"); +const { argv, stdout, exit } = require("process"); + +const { execIn, getLines, parts } = require("./utils"); + +execIn("node scripts/generate_schema.js", path.join("..", "..", "api")); \ No newline at end of file diff --git a/bundle/scripts/utils.js b/bundle/scripts/utils.js index bf960532f..f4b1ad7f6 100644 --- a/bundle/scripts/utils.js +++ b/bundle/scripts/utils.js @@ -28,13 +28,14 @@ function copyRecursiveSync(src, dest) { } } -function execIn(cmd, workdir) { +function execIn(cmd, workdir, opts) { try { return execSync(cmd, { cwd: workdir, shell: true, env: process.env, encoding: "utf-8", + ...opts }); } catch (error) { return error.stdout; diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index 03fff7967..4e2755921 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -18,6 +18,7 @@ import { PrivateSessionProjection, MemberPrivateProjection, PresenceUpdateEvent, + UserSettings, } from "@fosscord/util"; import { Send } from "../util/Send"; import { CLOSECODES, OPCODES } from "../util/Constants"; @@ -56,7 +57,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { await Promise.all([ User.findOneOrFail({ where: { id: this.user_id }, - relations: ["relationships", "relationships.to"], + relations: ["relationships", "relationships.to", "settings"], select: [...PrivateUserProjection, "relationships"], }), ReadState.find({ where: { user_id: this.user_id } }), @@ -101,6 +102,10 @@ export async function onIdentify(this: WebSocket, data: Payload) { ]); if (!user) return this.close(CLOSECODES.Authentication_failed); + if (!user.settings) { + user.settings = new UserSettings(); + await user.settings.save(); + } if (!identify.intents) identify.intents = BigInt("0x6ffffffff"); this.intents = new Intents(identify.intents); diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/gateway/src/opcodes/VoiceStateUpdate.ts index 8c430d568..845a75c08 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/gateway/src/opcodes/VoiceStateUpdate.ts @@ -20,6 +20,11 @@ export async function onVoiceStateUpdate(this: WebSocket, data: Payload) { check.call(this, VoiceStateUpdateSchema, data.d); const body = data.d as VoiceStateUpdateSchema; + if(body.guild_id == null) { + console.log(`[Gateway] VoiceStateUpdate called with guild_id == null by user ${this.user_id}!`); + return; + } + let voiceState: VoiceState; try { voiceState = await VoiceState.findOneOrFail({ diff --git a/util/src/config/types/DefaultsConfiguration.ts b/util/src/config/types/DefaultsConfiguration.ts index c3171a014..9b02a5901 100644 --- a/util/src/config/types/DefaultsConfiguration.ts +++ b/util/src/config/types/DefaultsConfiguration.ts @@ -1,5 +1,6 @@ -import { GuildDefaults } from "."; +import { GuildDefaults, UserDefaults } from "."; export class DefaultsConfiguration { guild: GuildDefaults = new GuildDefaults(); + user: UserDefaults = new UserDefaults(); } \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/defaults/UserDefaults.ts b/util/src/config/types/subconfigurations/defaults/UserDefaults.ts new file mode 100644 index 000000000..4481c0119 --- /dev/null +++ b/util/src/config/types/subconfigurations/defaults/UserDefaults.ts @@ -0,0 +1,5 @@ +export class UserDefaults { + premium: boolean = false; + premium_type: number = 2; + verified: boolean = true; +} \ No newline at end of file diff --git a/util/src/config/types/subconfigurations/defaults/index.ts b/util/src/config/types/subconfigurations/defaults/index.ts index f40c5cd2f..50258d1c5 100644 --- a/util/src/config/types/subconfigurations/defaults/index.ts +++ b/util/src/config/types/subconfigurations/defaults/index.ts @@ -1 +1,2 @@ export * from "./GuildDefaults"; +export * from "./UserDefaults"; diff --git a/util/src/entities/Guild.ts b/util/src/entities/Guild.ts index 77a04350d..d146e5776 100644 --- a/util/src/entities/Guild.ts +++ b/util/src/entities/Guild.ts @@ -53,7 +53,7 @@ export class Guild extends BaseClass { afk_channel?: Channel; @Column({ nullable: true }) - afk_timeout?: number; + afk_timeout?: number = Config.get().defaults.guild.afkTimeout; // * commented out -> use owner instead // application id of the guild creator if it is bot-created @@ -71,7 +71,7 @@ export class Guild extends BaseClass { banner?: string; @Column({ nullable: true }) - default_message_notifications?: number; + default_message_notifications?: number = Config.get().defaults.guild.defaultMessageNotifications; @Column({ nullable: true }) description?: string; @@ -80,7 +80,7 @@ export class Guild extends BaseClass { discovery_splash?: string; @Column({ nullable: true }) - explicit_content_filter?: number; + explicit_content_filter?: number = Config.get().defaults.guild.explicitContentFilter; @Column({ type: "simple-array" }) features: string[]; //TODO use enum @@ -96,19 +96,19 @@ export class Guild extends BaseClass { large?: boolean; @Column({ nullable: true }) - max_members?: number; // e.g. default 100.000 + max_members?: number = Config.get().limits.guild.maxMembers; // e.g. default 100.000 @Column({ nullable: true }) - max_presences?: number; + max_presences?: number = Config.get().defaults.guild.maxPresences; @Column({ nullable: true }) - max_video_channel_users?: number; // ? default: 25, is this max 25 streaming or watching + max_video_channel_users?: number = Config.get().defaults.guild.maxVideoChannelUsers; // ? default: 25, is this max 25 streaming or watching @Column({ nullable: true }) - member_count?: number; + member_count?: number = 0; @Column({ nullable: true }) - presence_count?: number; // users online + presence_count?: number = 0; // users online @OneToMany(() => Member, (member: Member) => member.guild, { cascade: true, @@ -278,6 +278,10 @@ export class Guild extends BaseClass { // only for developer portal permissions?: number; + //new guild settings, 11/08/2022: + @Column({ nullable: true }) + premium_progress_bar_enabled: boolean = false; + static async createGuild(body: { name?: string; icon?: string | null; diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index a9f00b0d1..6edcda970 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -1,11 +1,11 @@ -import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, OneToMany } from "typeorm"; +import { Column, Entity, FindOneOptions, FindOptionsSelectByString, JoinColumn, OneToMany, OneToOne } from "typeorm"; import { OrmUtils } from "../util/imports/OrmUtils"; import { BaseClass } from "./BaseClass"; import { BitField } from "../util/BitField"; import { Relationship } from "./Relationship"; import { ConnectedAccount } from "./ConnectedAccount"; import { Config, FieldErrors, Snowflake, trimSpecial } from ".."; -import { Member, Session } from "."; +import { Member, Session, UserSettings } from "."; export enum PublicUserEnum { username, @@ -83,28 +83,28 @@ export class User extends BaseClass { phone?: string; // phone number of the user @Column({ select: false }) - desktop: boolean; // if the user has desktop app installed + desktop: boolean = false; // if the user has desktop app installed @Column({ select: false }) - mobile: boolean; // if the user has mobile app installed + mobile: boolean = false; // if the user has mobile app installed @Column() - premium: boolean; // if user bought individual premium + premium: boolean = Config.get().defaults.user.premium; // if user bought individual premium @Column() - premium_type: number; // individual premium level + premium_type: number = Config.get().defaults.user.premium_type; // individual premium level @Column() - bot: boolean; // if user is bot + bot: boolean = false; // if user is bot @Column() bio: string; // short description of the user (max 190 chars -> should be configurable) @Column() - system: boolean; // shouldn't be used, the api sends this field type true, if the generated message comes from a system generated author + system: boolean = false; // shouldn't be used, the api sends this field type true, if the generated message comes from a system generated author @Column({ select: false }) - nsfw_allowed: boolean; // if the user can do age-restricted actions (NSFW channels/guilds/commands) + nsfw_allowed: boolean = true; // if the user can do age-restricted actions (NSFW channels/guilds/commands) // TODO: depending on age @Column({ select: false }) mfa_enabled: boolean; // if multi factor authentication is enabled @@ -116,31 +116,31 @@ export class User extends BaseClass { totp_last_ticket?: string; @Column() - created_at: Date; // registration date + created_at: Date = new Date(); // registration date @Column({ nullable: true }) - premium_since: Date; // premium date + premium_since: Date = new Date(); // premium date @Column({ select: false }) - verified: boolean; // if the user is offically verified + verified: boolean = Config.get().defaults.user.verified; // if the user is offically verified @Column() - disabled: boolean; // if the account is disabled + disabled: boolean = false; // if the account is disabled @Column() - deleted: boolean; // if the user was deleted + deleted: boolean = false; // if the user was deleted @Column({ nullable: true, select: false }) email?: string; // email of the user @Column() - flags: string; // UserFlags + flags: string = "0"; // UserFlags // TODO: generate @Column() - public_flags: number; + public_flags: number = 0; @Column({ type: "bigint" }) - rights: string; // Rights + rights: string = Config.get().register.defaultRights; // Rights @OneToMany(() => Session, (session: Session) => session.user) sessions: Session[]; @@ -166,17 +166,28 @@ export class User extends BaseClass { }; @Column({ type: "simple-array", select: false }) - fingerprints: string[]; // array of fingerprints -> used to prevent multiple accounts + fingerprints: string[] = []; // array of fingerprints -> used to prevent multiple accounts - @Column({ type: "simple-json", select: false }) + + @OneToOne(()=> UserSettings, { + cascade: true, + orphanedRowAction: "delete", + eager: false + }) + @JoinColumn() settings: UserSettings; // workaround to prevent fossord-unaware clients from deleting settings not used by them @Column({ type: "simple-json", select: false }) - extended_settings: string; + extended_settings: string = "{}"; @Column({ type: "simple-json" }) - notes: { [key: string]: string }; //key is ID of user + notes: { [key: string]: string } = {}; //key is ID of user + + async save(): Promise { + await this.settings.save(); + return this.save(); + } toPublicUser() { const user: any = {}; @@ -256,40 +267,20 @@ export class User extends BaseClass { const language = req?.language === "en" ? "en-US" : req?.language || "en-US"; const user = OrmUtils.mergeDeep(new User(), { - created_at: new Date(), + //required: username: username, discriminator, id: Snowflake.generate(), - bot: false, - system: false, - premium_since: new Date(), - desktop: false, - mobile: false, - premium: true, - premium_type: 2, - bio: "", - mfa_enabled: false, - totp_secret: "", - totp_backup_codes: [], - verified: true, - disabled: false, - deleted: false, email: email, - rights: Config.get().register.defaultRights, // TODO: grant rights correctly, as 0 actually stands for no rights at all - nsfw_allowed: true, // TODO: depending on age - public_flags: "0", - flags: "0", // TODO: generate data: { hash: password, valid_tokens_since: new Date(), }, - settings: { ...defaultSettings, locale: language }, - extended_settings: {}, - fingerprints: [], - notes: {}, + settings: { ...new UserSettings(), locale: language } }); await user.save(); + await user.settings.save(); setImmediate(async () => { if (Config.get().guild.autoJoin.enabled) { @@ -303,85 +294,6 @@ export class User extends BaseClass { } } -export const defaultSettings: UserSettings = { - afk_timeout: 3600, - allow_accessibility_detection: true, - animate_emoji: true, - animate_stickers: 0, - contact_sync_enabled: false, - convert_emoticons: false, - custom_status: null, - default_guilds_restricted: false, - detect_platform_accounts: false, - developer_mode: true, - disable_games_tab: true, - enable_tts_command: false, - explicit_content_filter: 0, - friend_source_flags: { all: true }, - gateway_connected: false, - gif_auto_play: true, - guild_folders: [], - guild_positions: [], - inline_attachment_media: true, - inline_embed_media: true, - locale: "en-US", - message_display_compact: false, - native_phone_integration_enabled: true, - render_embeds: true, - render_reactions: true, - restricted_guilds: [], - show_current_game: true, - status: "online", - stream_notifications_enabled: false, - theme: "dark", - timezone_offset: 0, // TODO: timezone from request -}; - -export interface UserSettings { - afk_timeout: number; - allow_accessibility_detection: boolean; - animate_emoji: boolean; - animate_stickers: number; - contact_sync_enabled: boolean; - convert_emoticons: boolean; - custom_status: { - emoji_id?: string; - emoji_name?: string; - expires_at?: number; - text?: string; - } | null; - default_guilds_restricted: boolean; - detect_platform_accounts: boolean; - developer_mode: boolean; - disable_games_tab: boolean; - enable_tts_command: boolean; - explicit_content_filter: number; - friend_source_flags: { all: boolean }; - gateway_connected: boolean; - gif_auto_play: boolean; - // every top guild is displayed as a "folder" - guild_folders: { - color: number; - guild_ids: string[]; - id: number; - name: string; - }[]; - guild_positions: string[]; // guild ids ordered by position - inline_attachment_media: boolean; - inline_embed_media: boolean; - locale: string; // en_US - message_display_compact: boolean; - native_phone_integration_enabled: boolean; - render_embeds: boolean; - render_reactions: boolean; - restricted_guilds: string[]; - show_current_game: boolean; - status: "online" | "offline" | "dnd" | "idle" | "invisible"; - stream_notifications_enabled: boolean; - theme: "dark" | "white"; // dark - timezone_offset: number; // e.g -60 -} - export const CUSTOM_USER_FLAG_OFFSET = BigInt(1) << BigInt(32); export class UserFlags extends BitField { diff --git a/util/src/entities/UserSettings.ts b/util/src/entities/UserSettings.ts new file mode 100644 index 000000000..ef6f95afa --- /dev/null +++ b/util/src/entities/UserSettings.ts @@ -0,0 +1,119 @@ +import { Column, Entity, JoinColumn } from "typeorm"; +import { BaseClassWithoutId, PrimaryIdColumn } from "."; + +@Entity("user_settings") +export class UserSettings extends BaseClassWithoutId { + @PrimaryIdColumn() + id: string; + + @Column({ nullable: true }) + afk_timeout: number = 3600; + + @Column({ nullable: true }) + allow_accessibility_detection: boolean = true; + + @Column({ nullable: true }) + animate_emoji: boolean = true; + + @Column({ nullable: true }) + animate_stickers: number = 0; + + @Column({ nullable: true }) + contact_sync_enabled: boolean = false; + + @Column({ nullable: true }) + convert_emoticons: boolean = false; + + @Column({ nullable: true, type: "simple-json" }) + custom_status: CustomStatus | null = null; + + @Column({ nullable: true }) + default_guilds_restricted: boolean = false; + + @Column({ nullable: true }) + detect_platform_accounts: boolean = false; + + @Column({ nullable: true }) + developer_mode: boolean = true; + + @Column({ nullable: true }) + disable_games_tab: boolean = true; + + @Column({ nullable: true }) + enable_tts_command: boolean = false; + + @Column({ nullable: true }) + explicit_content_filter: number = 0; + + @Column({ nullable: true, type: "simple-json" }) + friend_source_flags: FriendSourceFlags = { all: true }; + + @Column({ nullable: true }) + gateway_connected: boolean = false; + + @Column({ nullable: true }) + gif_auto_play: boolean = false; + + @Column({ nullable: true, type: "simple-json" }) + guild_folders: GuildFolder[] = []; // every top guild is displayed as a "folder" + + @Column({ nullable: true, type: "simple-json" }) + guild_positions: string[] = []; // guild ids ordered by position + + @Column({ nullable: true }) + inline_attachment_media: boolean = true; + + @Column({ nullable: true }) + inline_embed_media: boolean = true; + + @Column({ nullable: true }) + locale: string = "en-US"; // en_US + + @Column({ nullable: true }) + message_display_compact: boolean = false; + + @Column({ nullable: true }) + native_phone_integration_enabled: boolean = true; + + @Column({ nullable: true }) + render_embeds: boolean = true; + + @Column({ nullable: true }) + render_reactions: boolean = true; + + @Column({ nullable: true, type: "simple-json" }) + restricted_guilds: string[] = []; + + @Column({ nullable: true }) + show_current_game: boolean = true; + + @Column({ nullable: true }) + status: "online" | "offline" | "dnd" | "idle" | "invisible" = "online"; + + @Column({ nullable: true }) + stream_notifications_enabled: boolean = false; + + @Column({ nullable: true }) + theme: "dark" | "white" = "dark"; // dark + + @Column({ nullable: true }) + timezone_offset: number = 0; // e.g -60 +} + +interface CustomStatus { + emoji_id?: string; + emoji_name?: string; + expires_at?: number; + text?: string; +} + +interface GuildFolder { + color: number; + guild_ids: string[]; + id: number; + name: string; +} + +interface FriendSourceFlags { + all: boolean +} \ No newline at end of file diff --git a/util/src/entities/index.ts b/util/src/entities/index.ts index c439a4b76..c6f12022b 100644 --- a/util/src/entities/index.ts +++ b/util/src/entities/index.ts @@ -30,3 +30,4 @@ export * from "./Webhook"; export * from "./ClientRelease"; export * from "./BackupCodes"; export * from "./Note"; +export * from "./UserSettings"; diff --git a/util/src/interfaces/Event.ts b/util/src/interfaces/Event.ts index f3391c4f7..be66c62f0 100644 --- a/util/src/interfaces/Event.ts +++ b/util/src/interfaces/Event.ts @@ -1,4 +1,4 @@ -import { PublicUser, User, UserSettings } from "../entities/User"; +import { PublicUser, User } from "../entities/User"; import { Channel } from "../entities/Channel"; import { Guild } from "../entities/Guild"; import { Member, PublicMember, UserGuildSettings } from "../entities/Member"; @@ -12,7 +12,7 @@ import { Interaction } from "./Interaction"; import { ConnectedAccount } from "../entities/ConnectedAccount"; import { Relationship, RelationshipType } from "../entities/Relationship"; import { Presence } from "./Presence"; -import { Sticker } from ".."; +import { Sticker, UserSettings } from ".."; import { Activity, Status } from "."; export interface Event { diff --git a/util/src/migrations/mariadb/1660258393551-CodeCleanup3.ts b/util/src/migrations/mariadb/1660258393551-CodeCleanup3.ts new file mode 100644 index 000000000..87d075e44 --- /dev/null +++ b/util/src/migrations/mariadb/1660258393551-CodeCleanup3.ts @@ -0,0 +1,232 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup31660258393551 implements MigrationInterface { + name = 'CodeCleanup31660258393551' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_2ce5a55796fe4c2f77ece57a647\` + `); + await queryRunner.query(` + DROP INDEX \`REL_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` + `); + await queryRunner.query(` + CREATE TABLE \`user_settings\` ( + \`id\` varchar(255) NOT NULL, + \`afk_timeout\` int NULL, + \`allow_accessibility_detection\` tinyint NULL, + \`animate_emoji\` tinyint NULL, + \`animate_stickers\` int NULL, + \`contact_sync_enabled\` tinyint NULL, + \`convert_emoticons\` tinyint NULL, + \`custom_status\` text NULL, + \`default_guilds_restricted\` tinyint NULL, + \`detect_platform_accounts\` tinyint NULL, + \`developer_mode\` tinyint NULL, + \`disable_games_tab\` tinyint NULL, + \`enable_tts_command\` tinyint NULL, + \`explicit_content_filter\` int NULL, + \`friend_source_flags\` text NULL, + \`gateway_connected\` tinyint NULL, + \`gif_auto_play\` tinyint NULL, + \`guild_folders\` text NULL, + \`guild_positions\` text NULL, + \`inline_attachment_media\` tinyint NULL, + \`inline_embed_media\` tinyint NULL, + \`locale\` varchar(255) NULL, + \`message_display_compact\` tinyint NULL, + \`native_phone_integration_enabled\` tinyint NULL, + \`render_embeds\` tinyint NULL, + \`render_reactions\` tinyint NULL, + \`restricted_guilds\` text NULL, + \`show_current_game\` tinyint NULL, + \`status\` varchar(255) NULL, + \`stream_notifications_enabled\` tinyint NULL, + \`theme\` varchar(255) NULL, + \`timezone_offset\` int NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP COLUMN \`settings\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`type\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`hook\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`redirect_uris\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`rpc_application_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`store_application_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`verification_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`interactions_endpoint_url\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`integration_public\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`integration_require_code_grant\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`discoverability_state\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`discovery_eligibility_flags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`tags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`install_params\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`bot_user_id\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD \`premium_progress_bar_enabled\` tinyint NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`rpc_origins\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`primary_sku_id\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`slug\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`guild_id\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` CHANGE \`description\` \`description\` varchar(255) NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`flags\` varchar(255) NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_e5bf78cdbbe9ba91062d74c5aba\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_e5bf78cdbbe9ba91062d74c5aba\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`flags\` int NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` CHANGE \`description\` \`description\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`guild_id\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`slug\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`primary_sku_id\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` DROP COLUMN \`rpc_origins\` + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP COLUMN \`premium_progress_bar_enabled\` + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`bot_user_id\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`install_params\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`tags\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`discovery_eligibility_flags\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`discoverability_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`integration_require_code_grant\` tinyint NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`integration_public\` tinyint NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`interactions_endpoint_url\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`verification_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`store_application_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`rpc_application_state\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`redirect_uris\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`hook\` tinyint NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD \`type\` text NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD \`settings\` text NOT NULL + `); + await queryRunner.query(` + DROP TABLE \`user_settings\` + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`REL_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` (\`bot_user_id\`) + `); + await queryRunner.query(` + ALTER TABLE \`applications\` + ADD CONSTRAINT \`FK_2ce5a55796fe4c2f77ece57a647\` FOREIGN KEY (\`bot_user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/util/src/migrations/mariadb/1660260587556-CodeCleanup4.ts b/util/src/migrations/mariadb/1660260587556-CodeCleanup4.ts new file mode 100644 index 000000000..98da67dbf --- /dev/null +++ b/util/src/migrations/mariadb/1660260587556-CodeCleanup4.ts @@ -0,0 +1,39 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup41660260587556 implements MigrationInterface { + name = 'CodeCleanup41660260587556' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`users\` + ADD \`settingsId\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` (\`settingsId\`) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD CONSTRAINT \`FK_76ba283779c8441fd5ff819c8cf\` FOREIGN KEY (\`settingsId\`) REFERENCES \`user_settings\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`users\` DROP FOREIGN KEY \`FK_76ba283779c8441fd5ff819c8cf\` + `); + await queryRunner.query(` + DROP INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP COLUMN \`settingsId\` + `); + } + +} diff --git a/util/src/migrations/postgres/1660257815436-CodeCleanup2.ts b/util/src/migrations/postgres/1660257815436-CodeCleanup2.ts new file mode 100644 index 000000000..511c2f5a4 --- /dev/null +++ b/util/src/migrations/postgres/1660257815436-CodeCleanup2.ts @@ -0,0 +1,59 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup21660257815436 implements MigrationInterface { + name = 'CodeCleanup21660257815436' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "user_settings" ( + "id" character varying NOT NULL, + "afk_timeout" integer, + "allow_accessibility_detection" boolean, + "animate_emoji" boolean, + "animate_stickers" integer, + "contact_sync_enabled" boolean, + "convert_emoticons" boolean, + "custom_status" text, + "default_guilds_restricted" boolean, + "detect_platform_accounts" boolean, + "developer_mode" boolean, + "disable_games_tab" boolean, + "enable_tts_command" boolean, + "explicit_content_filter" integer, + "friend_source_flags" text, + "gateway_connected" boolean, + "gif_auto_play" boolean, + "guild_folders" text, + "guild_positions" text, + "inline_attachment_media" boolean, + "inline_embed_media" boolean, + "locale" character varying, + "message_display_compact" boolean, + "native_phone_integration_enabled" boolean, + "render_embeds" boolean, + "render_reactions" boolean, + "restricted_guilds" text, + "show_current_game" boolean, + "status" character varying, + "stream_notifications_enabled" boolean, + "theme" character varying, + "timezone_offset" integer, + CONSTRAINT "PK_00f004f5922a0744d174530d639" PRIMARY KEY ("id") + ) + `); + await queryRunner.query(` + ALTER TABLE "guilds" + ADD "premium_progress_bar_enabled" boolean + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "guilds" DROP COLUMN "premium_progress_bar_enabled" + `); + await queryRunner.query(` + DROP TABLE "user_settings" + `); + } + +} diff --git a/util/src/migrations/postgres/1660258372154-CodeCleanup3.ts b/util/src/migrations/postgres/1660258372154-CodeCleanup3.ts new file mode 100644 index 000000000..e2823a54c --- /dev/null +++ b/util/src/migrations/postgres/1660258372154-CodeCleanup3.ts @@ -0,0 +1,19 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup31660258372154 implements MigrationInterface { + name = 'CodeCleanup31660258372154' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" DROP COLUMN "settings" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + ADD "settings" text NOT NULL + `); + } + +} diff --git a/util/src/migrations/postgres/1660260565996-CodeCleanup4.ts b/util/src/migrations/postgres/1660260565996-CodeCleanup4.ts new file mode 100644 index 000000000..0aaf7197c --- /dev/null +++ b/util/src/migrations/postgres/1660260565996-CodeCleanup4.ts @@ -0,0 +1,33 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup41660260565996 implements MigrationInterface { + name = 'CodeCleanup41660260565996' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + ADD "settingsId" character varying + `); + await queryRunner.query(` + ALTER TABLE "users" + ADD CONSTRAINT "UQ_76ba283779c8441fd5ff819c8cf" UNIQUE ("settingsId") + `); + await queryRunner.query(` + ALTER TABLE "users" + ADD CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" FOREIGN KEY ("settingsId") REFERENCES "user_settings"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" DROP CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" + `); + await queryRunner.query(` + ALTER TABLE "users" DROP CONSTRAINT "UQ_76ba283779c8441fd5ff819c8cf" + `); + await queryRunner.query(` + ALTER TABLE "users" DROP COLUMN "settingsId" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660257576211-CodeCleanup1.ts b/util/src/migrations/sqlite/1660257576211-CodeCleanup1.ts new file mode 100644 index 000000000..5a61db0d0 --- /dev/null +++ b/util/src/migrations/sqlite/1660257576211-CodeCleanup1.ts @@ -0,0 +1,326 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup11660257576211 implements MigrationInterface { + name = 'CodeCleanup11660257576211' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "user_settings" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_timeout" integer, + "allow_accessibility_detection" boolean, + "animate_emoji" boolean, + "animate_stickers" integer, + "contact_sync_enabled" boolean, + "convert_emoticons" boolean, + "custom_status" text, + "default_guilds_restricted" boolean, + "detect_platform_accounts" boolean, + "developer_mode" boolean, + "disable_games_tab" boolean, + "enable_tts_command" boolean, + "explicit_content_filter" integer, + "friend_source_flags" text, + "gateway_connected" boolean, + "gif_auto_play" boolean, + "guild_folders" text, + "guild_positions" text, + "inline_attachment_media" boolean, + "inline_embed_media" boolean, + "locale" varchar, + "message_display_compact" boolean, + "native_phone_integration_enabled" boolean, + "render_embeds" boolean, + "render_reactions" boolean, + "restricted_guilds" text, + "show_current_game" boolean, + "status" varchar, + "stream_notifications_enabled" boolean, + "theme" varchar, + "timezone_offset" integer + ) + `); + await queryRunner.query(` + CREATE TABLE "temporary_guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + "premium_progress_bar_enabled" boolean NOT NULL, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + FROM "guilds" + `); + await queryRunner.query(` + DROP TABLE "guilds" + `); + await queryRunner.query(` + ALTER TABLE "temporary_guilds" + RENAME TO "guilds" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "guilds" + RENAME TO "temporary_guilds" + `); + await queryRunner.query(` + CREATE TABLE "guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent" + FROM "temporary_guilds" + `); + await queryRunner.query(` + DROP TABLE "temporary_guilds" + `); + await queryRunner.query(` + DROP TABLE "user_settings" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660257795259-CodeCleanup2.ts b/util/src/migrations/sqlite/1660257795259-CodeCleanup2.ts new file mode 100644 index 000000000..536982565 --- /dev/null +++ b/util/src/migrations/sqlite/1660257795259-CodeCleanup2.ts @@ -0,0 +1,572 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup21660257795259 implements MigrationInterface { + name = 'CodeCleanup21660257795259' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + "premium_progress_bar_enabled" boolean NOT NULL, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + FROM "guilds" + `); + await queryRunner.query(` + DROP TABLE "guilds" + `); + await queryRunner.query(` + ALTER TABLE "temporary_guilds" + RENAME TO "guilds" + `); + await queryRunner.query(` + CREATE TABLE "temporary_guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + "premium_progress_bar_enabled" boolean, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + FROM "guilds" + `); + await queryRunner.query(` + DROP TABLE "guilds" + `); + await queryRunner.query(` + ALTER TABLE "temporary_guilds" + RENAME TO "guilds" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "guilds" + RENAME TO "temporary_guilds" + `); + await queryRunner.query(` + CREATE TABLE "guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + "premium_progress_bar_enabled" boolean NOT NULL, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + FROM "temporary_guilds" + `); + await queryRunner.query(` + DROP TABLE "temporary_guilds" + `); + await queryRunner.query(` + ALTER TABLE "guilds" + RENAME TO "temporary_guilds" + `); + await queryRunner.query(` + CREATE TABLE "guilds" ( + "id" varchar PRIMARY KEY NOT NULL, + "afk_channel_id" varchar, + "afk_timeout" integer, + "banner" varchar, + "default_message_notifications" integer, + "description" varchar, + "discovery_splash" varchar, + "explicit_content_filter" integer, + "features" text NOT NULL, + "primary_category_id" integer, + "icon" varchar, + "large" boolean, + "max_members" integer, + "max_presences" integer, + "max_video_channel_users" integer, + "member_count" integer, + "presence_count" integer, + "template_id" varchar, + "mfa_level" integer, + "name" varchar NOT NULL, + "owner_id" varchar, + "preferred_locale" varchar, + "premium_subscription_count" integer, + "premium_tier" integer, + "public_updates_channel_id" varchar, + "rules_channel_id" varchar, + "region" varchar, + "splash" varchar, + "system_channel_id" varchar, + "system_channel_flags" integer, + "unavailable" boolean, + "verification_level" integer, + "welcome_screen" text NOT NULL, + "widget_channel_id" varchar, + "widget_enabled" boolean, + "nsfw_level" integer, + "nsfw" boolean, + "parent" varchar, + "premium_progress_bar_enabled" boolean NOT NULL, + CONSTRAINT "FK_f591a66b8019d87b0fe6c12dad6" FOREIGN KEY ("afk_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_e2a2f873a64a5cf62526de42325" FOREIGN KEY ("template_id") REFERENCES "templates" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_fc1a451727e3643ca572a3bb394" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_8d450b016dc8bec35f36729e4b0" FOREIGN KEY ("public_updates_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_95828668aa333460582e0ca6396" FOREIGN KEY ("rules_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_cfc3d3ad260f8121c95b31a1fce" FOREIGN KEY ("system_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_9d1d665379eefde7876a17afa99" FOREIGN KEY ("widget_channel_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "guilds"( + "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + ) + SELECT "id", + "afk_channel_id", + "afk_timeout", + "banner", + "default_message_notifications", + "description", + "discovery_splash", + "explicit_content_filter", + "features", + "primary_category_id", + "icon", + "large", + "max_members", + "max_presences", + "max_video_channel_users", + "member_count", + "presence_count", + "template_id", + "mfa_level", + "name", + "owner_id", + "preferred_locale", + "premium_subscription_count", + "premium_tier", + "public_updates_channel_id", + "rules_channel_id", + "region", + "splash", + "system_channel_id", + "system_channel_flags", + "unavailable", + "verification_level", + "welcome_screen", + "widget_channel_id", + "widget_enabled", + "nsfw_level", + "nsfw", + "parent", + "premium_progress_bar_enabled" + FROM "temporary_guilds" + `); + await queryRunner.query(` + DROP TABLE "temporary_guilds" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660258351379-CodeCleanup3.ts b/util/src/migrations/sqlite/1660258351379-CodeCleanup3.ts new file mode 100644 index 000000000..13fba6dde --- /dev/null +++ b/util/src/migrations/sqlite/1660258351379-CodeCleanup3.ts @@ -0,0 +1,231 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup31660258351379 implements MigrationInterface { + name = 'CodeCleanup31660258351379' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + FROM "users" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + ALTER TABLE "temporary_users" + RENAME TO "users" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + RENAME TO "temporary_users" + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "settings" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + FROM "temporary_users" + `); + await queryRunner.query(` + DROP TABLE "temporary_users" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts b/util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts new file mode 100644 index 000000000..d3f2a40db --- /dev/null +++ b/util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts @@ -0,0 +1,459 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup41660260539853 implements MigrationInterface { + name = 'CodeCleanup41660260539853' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + FROM "users" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + ALTER TABLE "temporary_users" + RENAME TO "users" + `); + await queryRunner.query(` + CREATE TABLE "temporary_users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId"), + CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" FOREIGN KEY ("settingsId") REFERENCES "user_settings" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + FROM "users" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + ALTER TABLE "temporary_users" + RENAME TO "users" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + RENAME TO "temporary_users" + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId") + ) + `); + await queryRunner.query(` + INSERT INTO "users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + FROM "temporary_users" + `); + await queryRunner.query(` + DROP TABLE "temporary_users" + `); + await queryRunner.query(` + ALTER TABLE "users" + RENAME TO "temporary_users" + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + FROM "temporary_users" + `); + await queryRunner.query(` + DROP TABLE "temporary_users" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660260672914-CodeCleanup4.ts b/util/src/migrations/sqlite/1660260672914-CodeCleanup4.ts new file mode 100644 index 000000000..33f4df035 --- /dev/null +++ b/util/src/migrations/sqlite/1660260672914-CodeCleanup4.ts @@ -0,0 +1,459 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup41660260672914 implements MigrationInterface { + name = 'CodeCleanup41660260672914' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId") + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + FROM "users" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + ALTER TABLE "temporary_users" + RENAME TO "users" + `); + await queryRunner.query(` + CREATE TABLE "temporary_users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId"), + CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" FOREIGN KEY ("settingsId") REFERENCES "user_settings" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + FROM "users" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + ALTER TABLE "temporary_users" + RENAME TO "users" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + RENAME TO "temporary_users" + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId") + ) + `); + await queryRunner.query(` + INSERT INTO "users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + FROM "temporary_users" + `); + await queryRunner.query(` + DROP TABLE "temporary_users" + `); + await queryRunner.query(` + ALTER TABLE "users" + RENAME TO "temporary_users" + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL + ) + `); + await queryRunner.query(` + INSERT INTO "users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes" + FROM "temporary_users" + `); + await queryRunner.query(` + DROP TABLE "temporary_users" + `); + } + +} From 1d52b0d0721094d7f8dfaabddedd9f08a5e456a5 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 03:24:51 +0200 Subject: [PATCH 208/238] Fix updated client stuff... --- api/assets/schemas.json | 162 +++++-- api/src/routes/channels/#channel_id/index.ts | 2 + .../routes/channels/#channel_id/invites.ts | 2 +- .../routes/channels/#channel_id/webhooks.ts | 3 +- api/src/util/handlers/route.ts | 5 + bundle/package.json | 3 +- bundle/scripts/update_schemas.js | 2 +- env-vars.md | 3 +- gateway/src/opcodes/Identify.ts | 3 +- util/src/entities/BaseClass.ts | 2 +- util/src/entities/Channel.ts | 7 + util/src/entities/User.ts | 6 +- .../mariadb/1660265930624-CodeCleanup5.ts | 53 ++ .../postgres/1660265907544-CodeCleanup5.ts | 26 + .../sqlite/1660260539853-CodeCleanup4.ts | 459 ------------------ 15 files changed, 218 insertions(+), 520 deletions(-) create mode 100644 util/src/migrations/mariadb/1660265930624-CodeCleanup5.ts create mode 100644 util/src/migrations/postgres/1660265907544-CodeCleanup5.ts delete mode 100644 util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts diff --git a/api/assets/schemas.json b/api/assets/schemas.json index 00819e7cc..d8576514a 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -552,6 +552,12 @@ }, "default_auto_archive_duration": { "type": "integer" + }, + "flags": { + "type": "integer" + }, + "default_thread_rate_limit_per_user": { + "type": "integer" } }, "additionalProperties": false, @@ -695,7 +701,6 @@ }, "additionalProperties": false, "required": [ - "avatar", "name" ], "$schema": "http://json-schema.org/draft-07/schema#" @@ -1028,6 +1033,12 @@ }, "default_auto_archive_duration": { "type": "integer" + }, + "flags": { + "type": "integer" + }, + "default_thread_rate_limit_per_user": { + "type": "integer" } }, "additionalProperties": false @@ -1094,6 +1105,9 @@ "preferred_locale": { "type": "string" }, + "premium_progress_bar_enabled": { + "type": "boolean" + }, "region": { "type": "string" }, @@ -1651,6 +1665,9 @@ "UserSettingsSchema": { "type": "object", "properties": { + "id": { + "type": "string" + }, "afk_timeout": { "type": "integer" }, @@ -1672,22 +1689,7 @@ "custom_status": { "anyOf": [ { - "type": "object", - "properties": { - "emoji_id": { - "type": "string" - }, - "emoji_name": { - "type": "string" - }, - "expires_at": { - "type": "integer" - }, - "text": { - "type": "string" - } - }, - "additionalProperties": false + "$ref": "#/definitions/CustomStatus" }, { "type": "null" @@ -1713,16 +1715,7 @@ "type": "integer" }, "friend_source_flags": { - "type": "object", - "properties": { - "all": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "all" - ] + "$ref": "#/definitions/FriendSourceFlags" }, "gateway_connected": { "type": "boolean" @@ -1733,31 +1726,7 @@ "guild_folders": { "type": "array", "items": { - "type": "object", - "properties": { - "color": { - "type": "integer" - }, - "guild_ids": { - "type": "array", - "items": { - "type": "string" - } - }, - "id": { - "type": "integer" - }, - "name": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "color", - "guild_ids", - "id", - "name" - ] + "$ref": "#/definitions/GuildFolder" } }, "guild_positions": { @@ -1818,9 +1787,98 @@ }, "timezone_offset": { "type": "integer" + }, + "hasId": { + "description": "Checks if entity has an id.\nIf entity composite compose ids, it will check them all.", + "type": "object", + "additionalProperties": false + }, + "save": { + "description": "Saves current entity in the database.\nIf entity does not exist in the database then inserts, otherwise updates.", + "type": "object", + "additionalProperties": false + }, + "remove": { + "description": "Removes current entity from the database.", + "type": "object", + "additionalProperties": false + }, + "softRemove": { + "description": "Records the delete date of current entity.", + "type": "object", + "additionalProperties": false + }, + "recover": { + "description": "Recovers a given entity in the database.", + "type": "object", + "additionalProperties": false + }, + "reload": { + "description": "Reloads entity data from the database.", + "type": "object", + "additionalProperties": false } }, "additionalProperties": false, + "definitions": { + "CustomStatus": { + "type": "object", + "properties": { + "emoji_id": { + "type": "string" + }, + "emoji_name": { + "type": "string" + }, + "expires_at": { + "type": "integer" + }, + "text": { + "type": "string" + } + }, + "additionalProperties": false + }, + "FriendSourceFlags": { + "type": "object", + "properties": { + "all": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "all" + ] + }, + "GuildFolder": { + "type": "object", + "properties": { + "color": { + "type": "integer" + }, + "guild_ids": { + "type": "array", + "items": { + "type": "string" + } + }, + "id": { + "type": "integer" + }, + "name": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "color", + "guild_ids", + "id", + "name" + ] + } + }, "$schema": "http://json-schema.org/draft-07/schema#" } } \ No newline at end of file diff --git a/api/src/routes/channels/#channel_id/index.ts b/api/src/routes/channels/#channel_id/index.ts index 68b52be68..70c34f051 100644 --- a/api/src/routes/channels/#channel_id/index.ts +++ b/api/src/routes/channels/#channel_id/index.ts @@ -71,6 +71,8 @@ export interface ChannelModifySchema { nsfw?: boolean; rtc_region?: string; default_auto_archive_duration?: number; + flags?: number; + default_thread_rate_limit_per_user?: number; } router.patch("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANNELS" }), async (req: Request, res: Response) => { diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index a53b1de4c..c0279f496 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -36,7 +36,7 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT const invite = await OrmUtils.mergeDeep(new Invite(),{ code: random(), - temporary: req.body.temporary, + temporary: req.body.temporary || true, uses: 0, max_uses: req.body.max_uses, max_age: req.body.max_age, diff --git a/api/src/routes/channels/#channel_id/webhooks.ts b/api/src/routes/channels/#channel_id/webhooks.ts index 8f0e0a7fb..00bf46197 100644 --- a/api/src/routes/channels/#channel_id/webhooks.ts +++ b/api/src/routes/channels/#channel_id/webhooks.ts @@ -12,7 +12,7 @@ export interface WebhookCreateSchema { * @maxLength 80 */ name: string; - avatar: string; + avatar?: string; } //TODO: implement webhooks router.get("/", route({}), async (req: Request, res: Response) => { @@ -36,6 +36,7 @@ router.post("/", route({ body: "WebhookCreateSchema", permission: "MANAGE_WEBHOO if (name === "clyde") throw new HTTPError("Invalid name", 400); // TODO: save webhook in database and send response + res.json(new Webhook()); }); export default router; diff --git a/api/src/util/handlers/route.ts b/api/src/util/handlers/route.ts index eaf7dc91f..f8130f3cb 100644 --- a/api/src/util/handlers/route.ts +++ b/api/src/util/handlers/route.ts @@ -117,6 +117,11 @@ export function route(opts: RouteOptions) { const valid = validate(normalizeBody(req.body)); if (!valid) { const fields: Record = {}; + if(process.env.LOG_INVALID_BODY) { + console.log(`Got invalid request: ${req.method} ${req.originalUrl}`) + console.log(req.body) + validate.errors?.forEach(x => console.log(x.params)) + } validate.errors?.forEach((x) => (fields[x.instancePath.slice(1)] = { code: x.keyword, message: x.message || "" })); throw FieldErrors(fields); } diff --git a/bundle/package.json b/bundle/package.json index b67598b8f..7431a96fa 100644 --- a/bundle/package.json +++ b/bundle/package.json @@ -9,10 +9,11 @@ "depcheck": "node scripts/depcheck.js", "syncdeps": "node scripts/install.js", "build": "node scripts/build.js", + "genschemas": "node scripts/update_schemas.js", "start": "node scripts/build.js && node --enable-source-maps dist/bundle/src/start.js", "start:bundle": "node --enable-source-maps dist/bundle/src/start.js", "start:bundle:dbg": "node --enable-source-maps --inspect dist/bundle/src/start.js", - "start:bundle:vscode-dbg": "npm run build clean logerrors pretty-errors && node --enable-source-maps --inspect dist/bundle/src/start.js", + "start:bundle:vscode-dbg": "npm run genschemas && npm run build clean logerrors pretty-errors && node --enable-source-maps --inspect dist/bundle/src/start.js", "test": "echo \"Error: no test specified\" && exit 1", "migrate": "cd ../util/ && npm i && node --require ts-node/register node_modules/typeorm/cli.js -f ../util/ormconfig.json migration:run", "tsnode": "npx ts-node --transpile-only -P tsnode.tsconfig.json src/start.ts" diff --git a/bundle/scripts/update_schemas.js b/bundle/scripts/update_schemas.js index 516b95920..a018120b9 100644 --- a/bundle/scripts/update_schemas.js +++ b/bundle/scripts/update_schemas.js @@ -6,4 +6,4 @@ const { argv, stdout, exit } = require("process"); const { execIn, getLines, parts } = require("./utils"); -execIn("node scripts/generate_schema.js", path.join("..", "..", "api")); \ No newline at end of file +execIn("node scripts/generate_schema.js", path.join("..", "api")); \ No newline at end of file diff --git a/env-vars.md b/env-vars.md index c24ea1a21..6c56c1844 100644 --- a/env-vars.md +++ b/env-vars.md @@ -14,4 +14,5 @@ |STORAGE\_BUCKET|s3 bucket name|S3 bucket name| |DB\_UNSAFE|any|Ignores migrations for database, enabled if defined| |DB\_VERBOSE|any|Log database queries, enabled if defined| -|DB\_MIGRATE|any|Exit fosscord after connecting to and migrating database, used internally| \ No newline at end of file +|DB\_MIGRATE|any|Exit fosscord after connecting to and migrating database, used internally| +|LOG\_INVALID\_BODY|any|Log request method, path and body if invalid| diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index 4e2755921..ce4385a3a 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -102,8 +102,9 @@ export async function onIdentify(this: WebSocket, data: Payload) { ]); if (!user) return this.close(CLOSECODES.Authentication_failed); - if (!user.settings) { + if (!user.settings) { //settings may not exist after updating... user.settings = new UserSettings(); + user.settings.id = user.id; await user.settings.save(); } diff --git a/util/src/entities/BaseClass.ts b/util/src/entities/BaseClass.ts index c872e7f18..aecc2465f 100644 --- a/util/src/entities/BaseClass.ts +++ b/util/src/entities/BaseClass.ts @@ -1,5 +1,5 @@ import "reflect-metadata"; -import { BaseEntity, EntityMetadata, ObjectIdColumn, PrimaryColumn, FindOptionsWhere, Generated, SaveOptions } from "typeorm"; +import { BaseEntity, ObjectIdColumn, PrimaryColumn, SaveOptions } from "typeorm"; import { Snowflake } from "../util/Snowflake"; export class BaseClassWithoutId extends BaseEntity { diff --git a/util/src/entities/Channel.ts b/util/src/entities/Channel.ts index ade0fb398..a576d7af5 100644 --- a/util/src/entities/Channel.ts +++ b/util/src/entities/Channel.ts @@ -151,6 +151,13 @@ export class Channel extends BaseClass { }) webhooks?: Webhook[]; + @Column({ nullable: true }) + flags?: number = 0; + + @Column({ nullable: true }) + default_thread_rate_limit_per_user?: number = 0; + + // TODO: DM channel static async createChannel( channel: Partial, diff --git a/util/src/entities/User.ts b/util/src/entities/User.ts index 6edcda970..61343e818 100644 --- a/util/src/entities/User.ts +++ b/util/src/entities/User.ts @@ -185,8 +185,10 @@ export class User extends BaseClass { notes: { [key: string]: string } = {}; //key is ID of user async save(): Promise { - await this.settings.save(); - return this.save(); + if(!this.settings) this.settings = new UserSettings(); + this.settings.id = this.id; + //await this.settings.save(); + return super.save(); } toPublicUser() { diff --git a/util/src/migrations/mariadb/1660265930624-CodeCleanup5.ts b/util/src/migrations/mariadb/1660265930624-CodeCleanup5.ts new file mode 100644 index 000000000..04f8e6af4 --- /dev/null +++ b/util/src/migrations/mariadb/1660265930624-CodeCleanup5.ts @@ -0,0 +1,53 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup51660265930624 implements MigrationInterface { + name = 'CodeCleanup51660265930624' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`users\` + ADD \`settingsId\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` (\`settingsId\`) + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD \`flags\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD \`default_thread_rate_limit_per_user\` int NULL + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD CONSTRAINT \`FK_76ba283779c8441fd5ff819c8cf\` FOREIGN KEY (\`settingsId\`) REFERENCES \`user_settings\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`users\` DROP FOREIGN KEY \`FK_76ba283779c8441fd5ff819c8cf\` + `); + await queryRunner.query(` + DROP INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP COLUMN \`default_thread_rate_limit_per_user\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP COLUMN \`settingsId\` + `); + } + +} diff --git a/util/src/migrations/postgres/1660265907544-CodeCleanup5.ts b/util/src/migrations/postgres/1660265907544-CodeCleanup5.ts new file mode 100644 index 000000000..157d686a6 --- /dev/null +++ b/util/src/migrations/postgres/1660265907544-CodeCleanup5.ts @@ -0,0 +1,26 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class CodeCleanup51660265907544 implements MigrationInterface { + name = 'CodeCleanup51660265907544' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "channels" + ADD "flags" integer + `); + await queryRunner.query(` + ALTER TABLE "channels" + ADD "default_thread_rate_limit_per_user" integer + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "channels" DROP COLUMN "default_thread_rate_limit_per_user" + `); + await queryRunner.query(` + ALTER TABLE "channels" DROP COLUMN "flags" + `); + } + +} diff --git a/util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts b/util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts deleted file mode 100644 index d3f2a40db..000000000 --- a/util/src/migrations/sqlite/1660260539853-CodeCleanup4.ts +++ /dev/null @@ -1,459 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class CodeCleanup41660260539853 implements MigrationInterface { - name = 'CodeCleanup41660260539853' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - CREATE TABLE "temporary_users" ( - "id" varchar PRIMARY KEY NOT NULL, - "username" varchar NOT NULL, - "discriminator" varchar NOT NULL, - "avatar" varchar, - "accent_color" integer, - "banner" varchar, - "phone" varchar, - "desktop" boolean NOT NULL, - "mobile" boolean NOT NULL, - "premium" boolean NOT NULL, - "premium_type" integer NOT NULL, - "bot" boolean NOT NULL, - "bio" varchar NOT NULL, - "system" boolean NOT NULL, - "nsfw_allowed" boolean NOT NULL, - "mfa_enabled" boolean NOT NULL, - "totp_secret" varchar, - "totp_last_ticket" varchar, - "created_at" datetime NOT NULL, - "premium_since" datetime, - "verified" boolean NOT NULL, - "disabled" boolean NOT NULL, - "deleted" boolean NOT NULL, - "email" varchar, - "flags" varchar NOT NULL, - "public_flags" integer NOT NULL, - "rights" bigint NOT NULL, - "data" text NOT NULL, - "fingerprints" text NOT NULL, - "extended_settings" text NOT NULL, - "notes" text NOT NULL, - "settingsId" varchar, - CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId") - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_users"( - "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes" - ) - SELECT "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes" - FROM "users" - `); - await queryRunner.query(` - DROP TABLE "users" - `); - await queryRunner.query(` - ALTER TABLE "temporary_users" - RENAME TO "users" - `); - await queryRunner.query(` - CREATE TABLE "temporary_users" ( - "id" varchar PRIMARY KEY NOT NULL, - "username" varchar NOT NULL, - "discriminator" varchar NOT NULL, - "avatar" varchar, - "accent_color" integer, - "banner" varchar, - "phone" varchar, - "desktop" boolean NOT NULL, - "mobile" boolean NOT NULL, - "premium" boolean NOT NULL, - "premium_type" integer NOT NULL, - "bot" boolean NOT NULL, - "bio" varchar NOT NULL, - "system" boolean NOT NULL, - "nsfw_allowed" boolean NOT NULL, - "mfa_enabled" boolean NOT NULL, - "totp_secret" varchar, - "totp_last_ticket" varchar, - "created_at" datetime NOT NULL, - "premium_since" datetime, - "verified" boolean NOT NULL, - "disabled" boolean NOT NULL, - "deleted" boolean NOT NULL, - "email" varchar, - "flags" varchar NOT NULL, - "public_flags" integer NOT NULL, - "rights" bigint NOT NULL, - "data" text NOT NULL, - "fingerprints" text NOT NULL, - "extended_settings" text NOT NULL, - "notes" text NOT NULL, - "settingsId" varchar, - CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId"), - CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" FOREIGN KEY ("settingsId") REFERENCES "user_settings" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_users"( - "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes", - "settingsId" - ) - SELECT "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes", - "settingsId" - FROM "users" - `); - await queryRunner.query(` - DROP TABLE "users" - `); - await queryRunner.query(` - ALTER TABLE "temporary_users" - RENAME TO "users" - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "users" - RENAME TO "temporary_users" - `); - await queryRunner.query(` - CREATE TABLE "users" ( - "id" varchar PRIMARY KEY NOT NULL, - "username" varchar NOT NULL, - "discriminator" varchar NOT NULL, - "avatar" varchar, - "accent_color" integer, - "banner" varchar, - "phone" varchar, - "desktop" boolean NOT NULL, - "mobile" boolean NOT NULL, - "premium" boolean NOT NULL, - "premium_type" integer NOT NULL, - "bot" boolean NOT NULL, - "bio" varchar NOT NULL, - "system" boolean NOT NULL, - "nsfw_allowed" boolean NOT NULL, - "mfa_enabled" boolean NOT NULL, - "totp_secret" varchar, - "totp_last_ticket" varchar, - "created_at" datetime NOT NULL, - "premium_since" datetime, - "verified" boolean NOT NULL, - "disabled" boolean NOT NULL, - "deleted" boolean NOT NULL, - "email" varchar, - "flags" varchar NOT NULL, - "public_flags" integer NOT NULL, - "rights" bigint NOT NULL, - "data" text NOT NULL, - "fingerprints" text NOT NULL, - "extended_settings" text NOT NULL, - "notes" text NOT NULL, - "settingsId" varchar, - CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId") - ) - `); - await queryRunner.query(` - INSERT INTO "users"( - "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes", - "settingsId" - ) - SELECT "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes", - "settingsId" - FROM "temporary_users" - `); - await queryRunner.query(` - DROP TABLE "temporary_users" - `); - await queryRunner.query(` - ALTER TABLE "users" - RENAME TO "temporary_users" - `); - await queryRunner.query(` - CREATE TABLE "users" ( - "id" varchar PRIMARY KEY NOT NULL, - "username" varchar NOT NULL, - "discriminator" varchar NOT NULL, - "avatar" varchar, - "accent_color" integer, - "banner" varchar, - "phone" varchar, - "desktop" boolean NOT NULL, - "mobile" boolean NOT NULL, - "premium" boolean NOT NULL, - "premium_type" integer NOT NULL, - "bot" boolean NOT NULL, - "bio" varchar NOT NULL, - "system" boolean NOT NULL, - "nsfw_allowed" boolean NOT NULL, - "mfa_enabled" boolean NOT NULL, - "totp_secret" varchar, - "totp_last_ticket" varchar, - "created_at" datetime NOT NULL, - "premium_since" datetime, - "verified" boolean NOT NULL, - "disabled" boolean NOT NULL, - "deleted" boolean NOT NULL, - "email" varchar, - "flags" varchar NOT NULL, - "public_flags" integer NOT NULL, - "rights" bigint NOT NULL, - "data" text NOT NULL, - "fingerprints" text NOT NULL, - "extended_settings" text NOT NULL, - "notes" text NOT NULL - ) - `); - await queryRunner.query(` - INSERT INTO "users"( - "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes" - ) - SELECT "id", - "username", - "discriminator", - "avatar", - "accent_color", - "banner", - "phone", - "desktop", - "mobile", - "premium", - "premium_type", - "bot", - "bio", - "system", - "nsfw_allowed", - "mfa_enabled", - "totp_secret", - "totp_last_ticket", - "created_at", - "premium_since", - "verified", - "disabled", - "deleted", - "email", - "flags", - "public_flags", - "rights", - "data", - "fingerprints", - "extended_settings", - "notes" - FROM "temporary_users" - `); - await queryRunner.query(` - DROP TABLE "temporary_users" - `); - } - -} From dd0a6e9709a8b8a8d18b0a8d85c3a2a2b4921ba5 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 10:37:42 +0200 Subject: [PATCH 209/238] Move some invite defaults into class --- api/src/routes/channels/#channel_id/invites.ts | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index c0279f496..f111cf54c 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -35,15 +35,12 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT const expires_at = new Date(req.body.max_age * 1000 + Date.now()); const invite = await OrmUtils.mergeDeep(new Invite(),{ - code: random(), temporary: req.body.temporary || true, - uses: 0, max_uses: req.body.max_uses, max_age: req.body.max_age, expires_at, - created_at: new Date(), guild_id, - channel_id: channel_id, + channel_id, inviter_id: user_id }).save(); //TODO: check this, removed toJSON call @@ -57,7 +54,6 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT }); router.get("/", route({ permission: "MANAGE_CHANNELS" }), async (req: Request, res: Response) => { - const { user_id } = req; const { channel_id } = req.params; const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); From 10bd81274722823f875ba31eaf5fc670bfb22ceb Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 11:36:39 +0200 Subject: [PATCH 210/238] Split schemas into files in util --- api/assets/schemas.json | 2705 ++++++++++------- api/src/routes/auth/login.ts | 11 +- api/src/routes/auth/mfa/totp.ts | 9 +- api/src/routes/auth/register.ts | 29 +- api/src/routes/channels/#channel_id/index.ts | 30 +- .../routes/channels/#channel_id/invites.ts | 12 - .../#channel_id/messages/#message_id/ack.ts | 9 - .../#channel_id/messages/#message_id/index.ts | 4 +- .../#channel_id/messages/bulk-delete.ts | 4 - .../channels/#channel_id/messages/index.ts | 36 +- .../channels/#channel_id/permissions.ts | 7 +- api/src/routes/channels/#channel_id/purge.ts | 7 +- .../routes/channels/#channel_id/webhooks.ts | 8 - api/src/routes/guilds/#guild_id/audit-logs.ts | 3 - api/src/routes/guilds/#guild_id/bans.ts | 24 +- api/src/routes/guilds/#guild_id/channels.ts | 3 +- api/src/routes/guilds/#guild_id/emojis.ts | 14 +- api/src/routes/guilds/#guild_id/index.ts | 20 +- .../routes/guilds/#guild_id/integrations.ts | 1 - .../#guild_id/members/#member_id/index.ts | 6 +- .../#guild_id/members/#member_id/nick.ts | 4 - api/src/routes/guilds/#guild_id/prune.ts | 7 - .../guilds/#guild_id/roles/#role_id/index.ts | 3 +- .../routes/guilds/#guild_id/roles/index.ts | 14 +- api/src/routes/guilds/#guild_id/stickers.ts | 17 +- api/src/routes/guilds/#guild_id/templates.ts | 10 - api/src/routes/guilds/#guild_id/vanity-url.ts | 10 +- .../#guild_id/voice-states/#user_id/index.ts | 14 +- api/src/routes/guilds/#guild_id/webhooks.ts | 1 - .../routes/guilds/#guild_id/welcome_screen.ts | 13 +- api/src/routes/guilds/#guild_id/widget.ts | 7 +- api/src/routes/guilds/index.ts | 16 +- api/src/routes/guilds/templates/index.ts | 9 +- api/src/routes/users/@me/channels.ts | 7 +- api/src/routes/users/@me/index.ts | 21 +- api/src/routes/users/@me/mfa/codes.ts | 7 +- api/src/routes/users/@me/mfa/totp/disable.ts | 6 +- api/src/routes/users/@me/mfa/totp/enable.ts | 8 +- api/src/routes/users/@me/relationships.ts | 9 - api/src/routes/users/@me/settings.ts | 2 - api/src/util/handlers/Message.ts | 3 +- gateway/src/opcodes/Identify.ts | 2 +- gateway/src/opcodes/LazyRequest.ts | 3 +- gateway/src/opcodes/PresenceUpdate.ts | 3 +- gateway/src/opcodes/VoiceStateUpdate.ts | 2 +- gateway/src/schema/VoiceStateUpdateSchema.ts | 15 - util/src/index.ts | 3 +- .../src/schemas/ActivitySchema.ts | 0 util/src/schemas/BanCreateSchema.ts | 5 + util/src/schemas/BanModeratorSchema.ts | 8 + util/src/schemas/BanRegistrySchema.ts | 9 + util/src/schemas/BulkDeleteSchema.ts | 4 + util/src/schemas/ChannelModifySchema.ts | 29 + .../ChannelPermissionOverwriteSchema.ts | 5 + util/src/schemas/DmChannelCreateSchema.ts | 5 + util/src/schemas/EmojiCreateSchema.ts | 7 + util/src/schemas/EmojiModifySchema.ts | 5 + util/src/schemas/GuildCreateSchema.ts | 14 + util/src/schemas/GuildTemplateCreateSchema.ts | 5 + util/src/schemas/GuildUpdateSchema.ts | 18 + .../schemas/GuildUpdateWelcomeScreenSchema.ts | 11 + .../src/schemas/IdentifySchema.ts | 2 +- util/src/schemas/InviteCreateSchema.ts | 12 + .../src/schemas/LazyRequestSchema.ts | 0 util/src/schemas/LoginSchema.ts | 9 + util/src/schemas/MemberChangeSchema.ts | 4 + util/src/schemas/MemberNickChangeSchema.ts | 4 + util/src/schemas/MessageAcknowledgeSchema.ts | 8 + util/src/schemas/MessageCreateSchema.ts | 34 + util/src/schemas/MfaCodesSchema.ts | 5 + util/src/schemas/ModifyGuildStickerSchema.ts | 16 + util/src/schemas/PruneSchema.ts | 7 + util/src/schemas/PurgeSchema.ts | 5 + util/src/schemas/RegisterSchema.ts | 27 + util/src/schemas/RelationshipPostSchema.ts | 5 + util/src/schemas/RelationshipPutSchema.ts | 6 + util/src/schemas/RoleModifySchema.ts | 11 + util/src/schemas/TemplateCreateSchema.ts | 5 + util/src/schemas/TemplateModifySchema.ts | 5 + util/src/schemas/TotpDisableSchema.ts | 4 + util/src/schemas/TotpEnableSchema.ts | 6 + util/src/schemas/TotpSchema.ts | 7 + util/src/schemas/UserModifySchema.ts | 19 + util/src/schemas/UserSettingsSchema.ts | 4 + util/src/schemas/VanityUrlSchema.ts | 8 + util/src/schemas/VoiceStateUpdateSchema.ts | 18 + util/src/schemas/WebhookCreateSchema.ts | 8 + util/src/schemas/WidgetModifySchema.ts | 5 + util/src/schemas/index.ts | 41 + util/src/util/Config.ts | 5 +- 90 files changed, 2045 insertions(+), 1528 deletions(-) delete mode 100644 gateway/src/schema/VoiceStateUpdateSchema.ts rename gateway/src/schema/Activity.ts => util/src/schemas/ActivitySchema.ts (100%) create mode 100644 util/src/schemas/BanCreateSchema.ts create mode 100644 util/src/schemas/BanModeratorSchema.ts create mode 100644 util/src/schemas/BanRegistrySchema.ts create mode 100644 util/src/schemas/BulkDeleteSchema.ts create mode 100644 util/src/schemas/ChannelModifySchema.ts create mode 100644 util/src/schemas/ChannelPermissionOverwriteSchema.ts create mode 100644 util/src/schemas/DmChannelCreateSchema.ts create mode 100644 util/src/schemas/EmojiCreateSchema.ts create mode 100644 util/src/schemas/EmojiModifySchema.ts create mode 100644 util/src/schemas/GuildCreateSchema.ts create mode 100644 util/src/schemas/GuildTemplateCreateSchema.ts create mode 100644 util/src/schemas/GuildUpdateSchema.ts create mode 100644 util/src/schemas/GuildUpdateWelcomeScreenSchema.ts rename gateway/src/schema/Identify.ts => util/src/schemas/IdentifySchema.ts (98%) create mode 100644 util/src/schemas/InviteCreateSchema.ts rename gateway/src/schema/LazyRequest.ts => util/src/schemas/LazyRequestSchema.ts (100%) create mode 100644 util/src/schemas/LoginSchema.ts create mode 100644 util/src/schemas/MemberChangeSchema.ts create mode 100644 util/src/schemas/MemberNickChangeSchema.ts create mode 100644 util/src/schemas/MessageAcknowledgeSchema.ts create mode 100644 util/src/schemas/MessageCreateSchema.ts create mode 100644 util/src/schemas/MfaCodesSchema.ts create mode 100644 util/src/schemas/ModifyGuildStickerSchema.ts create mode 100644 util/src/schemas/PruneSchema.ts create mode 100644 util/src/schemas/PurgeSchema.ts create mode 100644 util/src/schemas/RegisterSchema.ts create mode 100644 util/src/schemas/RelationshipPostSchema.ts create mode 100644 util/src/schemas/RelationshipPutSchema.ts create mode 100644 util/src/schemas/RoleModifySchema.ts create mode 100644 util/src/schemas/TemplateCreateSchema.ts create mode 100644 util/src/schemas/TemplateModifySchema.ts create mode 100644 util/src/schemas/TotpDisableSchema.ts create mode 100644 util/src/schemas/TotpEnableSchema.ts create mode 100644 util/src/schemas/TotpSchema.ts create mode 100644 util/src/schemas/UserModifySchema.ts create mode 100644 util/src/schemas/UserSettingsSchema.ts create mode 100644 util/src/schemas/VanityUrlSchema.ts create mode 100644 util/src/schemas/VoiceStateUpdateSchema.ts create mode 100644 util/src/schemas/WebhookCreateSchema.ts create mode 100644 util/src/schemas/WidgetModifySchema.ts create mode 100644 util/src/schemas/index.ts diff --git a/api/assets/schemas.json b/api/assets/schemas.json index d8576514a..f102f9d02 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -98,6 +98,1176 @@ ], "$schema": "http://json-schema.org/draft-07/schema#" }, + "ActivitySchema": { + "type": "object", + "properties": { + "afk": { + "type": "boolean" + }, + "status": { + "$ref": "#/definitions/Status" + }, + "activities": { + "type": "array", + "items": { + "$ref": "#/definitions/Activity" + } + }, + "since": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "afk", + "status" + ], + "definitions": { + "Status": { + "enum": [ + "dnd", + "idle", + "invisible", + "offline", + "online" + ], + "type": "string" + }, + "Activity": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ActivityType" + }, + "url": { + "type": "string" + }, + "created_at": { + "type": "integer" + }, + "timestamps": { + "type": "object", + "properties": { + "start": { + "type": "integer" + }, + "end": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "end", + "start" + ] + }, + "application_id": { + "type": "string" + }, + "details": { + "type": "string" + }, + "state": { + "type": "string" + }, + "emoji": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "id": { + "type": "string" + }, + "animated": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "animated", + "name" + ] + }, + "party": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "size": { + "type": "array", + "items": [ + { + "type": "integer" + } + ], + "minItems": 1, + "maxItems": 1 + } + }, + "additionalProperties": false + }, + "assets": { + "type": "object", + "properties": { + "large_image": { + "type": "string" + }, + "large_text": { + "type": "string" + }, + "small_image": { + "type": "string" + }, + "small_text": { + "type": "string" + } + }, + "additionalProperties": false + }, + "secrets": { + "type": "object", + "properties": { + "join": { + "type": "string" + }, + "spectate": { + "type": "string" + }, + "match": { + "type": "string" + } + }, + "additionalProperties": false + }, + "instance": { + "type": "boolean" + }, + "flags": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "flags", + "name", + "type" + ] + }, + "ActivityType": { + "enum": [ + 0, + 1, + 2, + 4, + 5 + ], + "type": "number" + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "BanCreateSchema": { + "type": "object", + "properties": { + "delete_message_days": { + "type": "string" + }, + "reason": { + "type": "string" + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "BanModeratorSchema": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "user_id": { + "type": "string" + }, + "guild_id": { + "type": "string" + }, + "executor_id": { + "type": "string" + }, + "reason": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "executor_id", + "guild_id", + "id", + "user_id" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "BanRegistrySchema": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "user_id": { + "type": "string" + }, + "guild_id": { + "type": "string" + }, + "executor_id": { + "type": "string" + }, + "ip": { + "type": "string" + }, + "reason": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "executor_id", + "guild_id", + "id", + "user_id" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "BulkDeleteSchema": { + "type": "object", + "properties": { + "messages": { + "type": "array", + "items": { + "type": "string" + } + } + }, + "additionalProperties": false, + "required": [ + "messages" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + }, + "flags": { + "type": "integer" + }, + "default_thread_rate_limit_per_user": { + "type": "integer" + } + }, + "additionalProperties": false, + "definitions": { + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ChannelPermissionOverwriteSchema": { + "type": "object", + "properties": { + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + }, + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ], + "definitions": { + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "DmChannelCreateSchema": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "recipients": { + "type": "array", + "items": { + "type": "string" + } + } + }, + "additionalProperties": false, + "required": [ + "recipients" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "EmojiCreateSchema": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "image": { + "type": "string" + }, + "require_colons": { + "type": [ + "null", + "boolean" + ] + }, + "roles": { + "type": "array", + "items": { + "type": "string" + } + } + }, + "additionalProperties": false, + "required": [ + "image" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "EmojiModifySchema": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "roles": { + "type": "array", + "items": { + "type": "string" + } + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "GuildCreateSchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "region": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "channels": { + "type": "array", + "items": { + "$ref": "#/definitions/ChannelModifySchema" + } + }, + "guild_template_code": { + "type": "string" + }, + "system_channel_id": { + "type": "string" + }, + "rules_channel_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "name" + ], + "definitions": { + "ChannelModifySchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 100, + "type": "string" + }, + "type": { + "enum": [ + 0, + 1, + 10, + 11, + 12, + 13, + 14, + 15, + 2, + 255, + 3, + 33, + 34, + 35, + 4, + 5, + 6, + 64, + 7, + 8, + 9 + ], + "type": "number" + }, + "topic": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "bitrate": { + "type": "integer" + }, + "user_limit": { + "type": "integer" + }, + "rate_limit_per_user": { + "type": "integer" + }, + "position": { + "type": "integer" + }, + "permission_overwrites": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ChannelPermissionOverwriteType" + }, + "allow": { + "type": "string" + }, + "deny": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "allow", + "deny", + "id", + "type" + ] + } + }, + "parent_id": { + "type": "string" + }, + "id": { + "type": "string" + }, + "nsfw": { + "type": "boolean" + }, + "rtc_region": { + "type": "string" + }, + "default_auto_archive_duration": { + "type": "integer" + }, + "flags": { + "type": "integer" + }, + "default_thread_rate_limit_per_user": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "ChannelPermissionOverwriteType": { + "enum": [ + 0, + 1, + 2 + ], + "type": "number" + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "GuildTemplateCreateSchema": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "avatar": { + "type": [ + "null", + "string" + ] + } + }, + "additionalProperties": false, + "required": [ + "name" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "GuildUpdateSchema": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "banner": { + "type": [ + "null", + "string" + ] + }, + "splash": { + "type": [ + "null", + "string" + ] + }, + "description": { + "type": "string" + }, + "features": { + "type": "array", + "items": { + "type": "string" + } + }, + "verification_level": { + "type": "integer" + }, + "default_message_notifications": { + "type": "integer" + }, + "system_channel_flags": { + "type": "integer" + }, + "explicit_content_filter": { + "type": "integer" + }, + "public_updates_channel_id": { + "type": "string" + }, + "afk_timeout": { + "type": "integer" + }, + "afk_channel_id": { + "type": "string" + }, + "preferred_locale": { + "type": "string" + }, + "premium_progress_bar_enabled": { + "type": "boolean" + }, + "region": { + "type": "string" + }, + "icon": { + "type": [ + "null", + "string" + ] + }, + "guild_template_code": { + "type": "string" + }, + "system_channel_id": { + "type": "string" + }, + "rules_channel_id": { + "type": "string" + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "GuildUpdateWelcomeScreenSchema": { + "type": "object", + "properties": { + "welcome_channels": { + "type": "array", + "items": { + "type": "object", + "properties": { + "channel_id": { + "type": "string" + }, + "description": { + "type": "string" + }, + "emoji_id": { + "type": "string" + }, + "emoji_name": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "channel_id", + "description", + "emoji_name" + ] + } + }, + "enabled": { + "type": "boolean" + }, + "description": { + "type": "string" + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "IdentifySchema": { + "type": "object", + "properties": { + "token": { + "type": "string" + }, + "properties": { + "type": "object", + "properties": { + "os": { + "type": "string" + }, + "os_atch": { + "type": "string" + }, + "browser": { + "type": "string" + }, + "device": { + "type": "string" + }, + "$os": { + "type": "string" + }, + "$browser": { + "type": "string" + }, + "$device": { + "type": "string" + }, + "browser_user_agent": { + "type": "string" + }, + "browser_version": { + "type": "string" + }, + "os_version": { + "type": "string" + }, + "referrer": { + "type": "string" + }, + "referring_domain": { + "type": "string" + }, + "referrer_current": { + "type": "string" + }, + "referring_domain_current": { + "type": "string" + }, + "release_channel": { + "enum": [ + "canary", + "dev", + "ptb", + "stable" + ], + "type": "string" + }, + "client_build_number": { + "type": "integer" + }, + "client_event_source": {}, + "client_version": { + "type": "string" + }, + "system_locale": { + "type": "string" + } + }, + "additionalProperties": false + }, + "intents": { + "type": "bigint" + }, + "presence": { + "$ref": "#/definitions/ActivitySchema" + }, + "compress": { + "type": "boolean" + }, + "large_threshold": { + "type": "integer" + }, + "shard": { + "type": "array", + "items": [ + { + "type": "bigint" + }, + { + "type": "bigint" + } + ], + "minItems": 2, + "maxItems": 2 + }, + "guild_subscriptions": { + "type": "boolean" + }, + "capabilities": { + "type": "integer" + }, + "client_state": { + "type": "object", + "properties": { + "guild_hashes": {}, + "highest_last_message_id": { + "type": "string" + }, + "read_state_version": { + "type": "integer" + }, + "user_guild_settings_version": { + "type": "integer" + }, + "user_settings_version": { + "type": "integer" + } + }, + "additionalProperties": false + }, + "v": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "properties", + "token" + ], + "definitions": { + "ActivitySchema": { + "type": "object", + "properties": { + "afk": { + "type": "boolean" + }, + "status": { + "$ref": "#/definitions/Status" + }, + "activities": { + "type": "array", + "items": { + "$ref": "#/definitions/Activity" + } + }, + "since": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "afk", + "status" + ] + }, + "Status": { + "enum": [ + "dnd", + "idle", + "invisible", + "offline", + "online" + ], + "type": "string" + }, + "Activity": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "$ref": "#/definitions/ActivityType" + }, + "url": { + "type": "string" + }, + "created_at": { + "type": "integer" + }, + "timestamps": { + "type": "object", + "properties": { + "start": { + "type": "integer" + }, + "end": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "end", + "start" + ] + }, + "application_id": { + "type": "string" + }, + "details": { + "type": "string" + }, + "state": { + "type": "string" + }, + "emoji": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "id": { + "type": "string" + }, + "animated": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "animated", + "name" + ] + }, + "party": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "size": { + "type": "array", + "items": [ + { + "type": "integer" + } + ], + "minItems": 1, + "maxItems": 1 + } + }, + "additionalProperties": false + }, + "assets": { + "type": "object", + "properties": { + "large_image": { + "type": "string" + }, + "large_text": { + "type": "string" + }, + "small_image": { + "type": "string" + }, + "small_text": { + "type": "string" + } + }, + "additionalProperties": false + }, + "secrets": { + "type": "object", + "properties": { + "join": { + "type": "string" + }, + "spectate": { + "type": "string" + }, + "match": { + "type": "string" + } + }, + "additionalProperties": false + }, + "instance": { + "type": "boolean" + }, + "flags": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "flags", + "name", + "type" + ] + }, + "ActivityType": { + "enum": [ + 0, + 1, + 2, + 4, + 5 + ], + "type": "number" + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "InviteCreateSchema": { + "type": "object", + "properties": { + "target_user_id": { + "type": "string" + }, + "target_type": { + "type": "string" + }, + "validate": { + "type": "string" + }, + "max_age": { + "type": "integer" + }, + "max_uses": { + "type": "integer" + }, + "temporary": { + "type": "boolean" + }, + "unique": { + "type": "boolean" + }, + "target_user": { + "type": "string" + }, + "target_user_type": { + "type": "integer" + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "LoginSchema": { + "type": "object", + "properties": { + "login": { + "type": "string" + }, + "password": { + "type": "string" + }, + "undelete": { + "type": "boolean" + }, + "captcha_key": { + "type": "string" + }, + "login_source": { + "type": "string" + }, + "gift_code_sku_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "login", + "password" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "MemberChangeSchema": { + "type": "object", + "properties": { + "roles": { + "type": "array", + "items": { + "type": "string" + } + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "MemberNickChangeSchema": { + "type": "object", + "properties": { + "nick": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "nick" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "MessageAcknowledgeSchema": { + "type": "object", + "properties": { + "manual": { + "type": "boolean" + }, + "mention_count": { + "type": "integer" + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, "MessageCreateSchema": { "type": "object", "properties": { @@ -328,86 +1498,73 @@ }, "$schema": "http://json-schema.org/draft-07/schema#" }, - "RouteResponse": { + "MfaCodesSchema": { "type": "object", "properties": { - "status": { - "type": "integer" - }, - "body": { - "type": "array", - "items": { - "type": "string" - } - }, - "headers": { - "$ref": "#/definitions/Record" - } - }, - "additionalProperties": false, - "definitions": { - "Record": { - "type": "object", - "additionalProperties": false - } - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "LoginSchema": { - "type": "object", - "properties": { - "login": { - "type": "string" - }, "password": { "type": "string" }, - "undelete": { + "regenerate": { "type": "boolean" - }, - "captcha_key": { - "type": "string" - }, - "login_source": { - "type": "string" - }, - "gift_code_sku_id": { - "type": "string" } }, "additionalProperties": false, "required": [ - "login", "password" ], "$schema": "http://json-schema.org/draft-07/schema#" }, - "TotpSchema": { + "ModifyGuildStickerSchema": { "type": "object", "properties": { - "code": { + "name": { + "minLength": 2, + "maxLength": 30, "type": "string" }, - "ticket": { + "description": { + "maxLength": 100, "type": "string" }, - "gift_code_sku_id": { - "type": [ - "null", - "string" - ] - }, - "login_source": { - "type": [ - "null", - "string" - ] + "tags": { + "maxLength": 200, + "type": "string" } }, "additionalProperties": false, "required": [ - "code", - "ticket" + "name", + "tags" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "PruneSchema": { + "type": "object", + "properties": { + "days": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "days" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "PurgeSchema": { + "type": "object", + "properties": { + "before": { + "type": "string" + }, + "after": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "after", + "before" ], "$schema": "http://json-schema.org/draft-07/schema#" }, @@ -457,718 +1614,39 @@ ], "$schema": "http://json-schema.org/draft-07/schema#" }, - "ChannelModifySchema": { + "RelationshipPostSchema": { "type": "object", "properties": { - "name": { - "maxLength": 100, + "discriminator": { "type": "string" }, + "username": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "discriminator", + "username" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "RelationshipPutSchema": { + "type": "object", + "properties": { "type": { "enum": [ - 0, 1, - 10, - 11, - 12, - 13, - 14, - 15, 2, - 255, 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - }, - "flags": { - "type": "integer" - }, - "default_thread_rate_limit_per_user": { - "type": "integer" - } - }, - "additionalProperties": false, - "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 + 4 ], "type": "number" } }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "InviteCreateSchema": { - "type": "object", - "properties": { - "target_user_id": { - "type": "string" - }, - "target_type": { - "type": "string" - }, - "validate": { - "type": "string" - }, - "max_age": { - "type": "integer" - }, - "max_uses": { - "type": "integer" - }, - "temporary": { - "type": "boolean" - }, - "unique": { - "type": "boolean" - }, - "target_user": { - "type": "string" - }, - "target_user_type": { - "type": "integer" - } - }, "additionalProperties": false, "$schema": "http://json-schema.org/draft-07/schema#" }, - "MessageAcknowledgeSchema": { - "type": "object", - "properties": { - "manual": { - "type": "boolean" - }, - "mention_count": { - "type": "integer" - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "BulkDeleteSchema": { - "type": "object", - "properties": { - "messages": { - "type": "array", - "items": { - "type": "string" - } - } - }, - "additionalProperties": false, - "required": [ - "messages" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "ChannelPermissionOverwriteSchema": { - "type": "object", - "properties": { - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - }, - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ], - "definitions": { - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - } - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "PurgeSchema": { - "type": "object", - "properties": { - "before": { - "type": "string" - }, - "after": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "after", - "before" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "WebhookCreateSchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 80, - "type": "string" - }, - "avatar": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "name" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GatewayBotResponse": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "shards": { - "type": "integer" - }, - "session_start_limit": { - "type": "object", - "properties": { - "total": { - "type": "integer" - }, - "remaining": { - "type": "integer" - }, - "reset_after": { - "type": "integer" - }, - "max_concurrency": { - "type": "integer" - } - }, - "additionalProperties": false, - "required": [ - "max_concurrency", - "remaining", - "reset_after", - "total" - ] - } - }, - "additionalProperties": false, - "required": [ - "session_start_limit", - "shards", - "url" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GatewayResponse": { - "type": "object", - "properties": { - "url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "url" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "BanCreateSchema": { - "type": "object", - "properties": { - "delete_message_days": { - "type": "string" - }, - "reason": { - "type": "string" - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "BanRegistrySchema": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "user_id": { - "type": "string" - }, - "guild_id": { - "type": "string" - }, - "executor_id": { - "type": "string" - }, - "ip": { - "type": "string" - }, - "reason": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "executor_id", - "guild_id", - "id", - "user_id" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "BanModeratorSchema": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "user_id": { - "type": "string" - }, - "guild_id": { - "type": "string" - }, - "executor_id": { - "type": "string" - }, - "reason": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "executor_id", - "guild_id", - "id", - "user_id" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "ChannelReorderSchema": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "position": { - "type": "integer" - }, - "lock_permissions": { - "type": "boolean" - }, - "parent_id": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "id" - ] - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "EmojiCreateSchema": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "image": { - "type": "string" - }, - "require_colons": { - "type": [ - "null", - "boolean" - ] - }, - "roles": { - "type": "array", - "items": { - "type": "string" - } - } - }, - "additionalProperties": false, - "required": [ - "image" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "EmojiModifySchema": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "roles": { - "type": "array", - "items": { - "type": "string" - } - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GuildCreateSchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "region": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "channels": { - "type": "array", - "items": { - "$ref": "#/definitions/ChannelModifySchema" - } - }, - "guild_template_code": { - "type": "string" - }, - "system_channel_id": { - "type": "string" - }, - "rules_channel_id": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "name" - ], - "definitions": { - "ChannelModifySchema": { - "type": "object", - "properties": { - "name": { - "maxLength": 100, - "type": "string" - }, - "type": { - "enum": [ - 0, - 1, - 10, - 11, - 12, - 13, - 14, - 15, - 2, - 255, - 3, - 33, - 34, - 35, - 4, - 5, - 6, - 64, - 7, - 8, - 9 - ], - "type": "number" - }, - "topic": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "bitrate": { - "type": "integer" - }, - "user_limit": { - "type": "integer" - }, - "rate_limit_per_user": { - "type": "integer" - }, - "position": { - "type": "integer" - }, - "permission_overwrites": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ChannelPermissionOverwriteType" - }, - "allow": { - "type": "string" - }, - "deny": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "allow", - "deny", - "id", - "type" - ] - } - }, - "parent_id": { - "type": "string" - }, - "id": { - "type": "string" - }, - "nsfw": { - "type": "boolean" - }, - "rtc_region": { - "type": "string" - }, - "default_auto_archive_duration": { - "type": "integer" - }, - "flags": { - "type": "integer" - }, - "default_thread_rate_limit_per_user": { - "type": "integer" - } - }, - "additionalProperties": false - }, - "ChannelPermissionOverwriteType": { - "enum": [ - 0, - 1, - 2 - ], - "type": "number" - } - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GuildUpdateSchema": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "banner": { - "type": [ - "null", - "string" - ] - }, - "splash": { - "type": [ - "null", - "string" - ] - }, - "description": { - "type": "string" - }, - "features": { - "type": "array", - "items": { - "type": "string" - } - }, - "verification_level": { - "type": "integer" - }, - "default_message_notifications": { - "type": "integer" - }, - "system_channel_flags": { - "type": "integer" - }, - "explicit_content_filter": { - "type": "integer" - }, - "public_updates_channel_id": { - "type": "string" - }, - "afk_timeout": { - "type": "integer" - }, - "afk_channel_id": { - "type": "string" - }, - "preferred_locale": { - "type": "string" - }, - "premium_progress_bar_enabled": { - "type": "boolean" - }, - "region": { - "type": "string" - }, - "icon": { - "type": [ - "null", - "string" - ] - }, - "guild_template_code": { - "type": "string" - }, - "system_channel_id": { - "type": "string" - }, - "rules_channel_id": { - "type": "string" - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "MemberChangeSchema": { - "type": "object", - "properties": { - "roles": { - "type": "array", - "items": { - "type": "string" - } - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "MemberNickChangeSchema": { - "type": "object", - "properties": { - "nick": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "nick" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "PruneSchema": { - "type": "object", - "properties": { - "days": { - "type": "integer" - } - }, - "additionalProperties": false, - "required": [ - "days" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, "RoleModifySchema": { "type": "object", "properties": { @@ -1200,50 +1678,6 @@ "additionalProperties": false, "$schema": "http://json-schema.org/draft-07/schema#" }, - "RolePositionUpdateSchema": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "position": { - "type": "integer" - } - }, - "additionalProperties": false, - "required": [ - "id", - "position" - ] - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "ModifyGuildStickerSchema": { - "type": "object", - "properties": { - "name": { - "minLength": 2, - "maxLength": 30, - "type": "string" - }, - "description": { - "maxLength": 100, - "type": "string" - }, - "tags": { - "maxLength": 200, - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "name", - "tags" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, "TemplateCreateSchema": { "type": "object", "properties": { @@ -1276,113 +1710,54 @@ ], "$schema": "http://json-schema.org/draft-07/schema#" }, - "VanityUrlSchema": { + "TotpDisableSchema": { "type": "object", "properties": { "code": { - "minLength": 1, - "maxLength": 20, - "type": "string" - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "VoiceStateUpdateSchema": { - "type": "object", - "properties": { - "channel_id": { - "type": "string" - }, - "guild_id": { - "type": "string" - }, - "suppress": { - "type": "boolean" - }, - "request_to_speak_timestamp": { - "type": "string", - "format": "date-time" - }, - "self_mute": { - "type": "boolean" - }, - "self_deaf": { - "type": "boolean" - }, - "self_video": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "channel_id" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GuildUpdateWelcomeScreenSchema": { - "type": "object", - "properties": { - "welcome_channels": { - "type": "array", - "items": { - "type": "object", - "properties": { - "channel_id": { - "type": "string" - }, - "description": { - "type": "string" - }, - "emoji_id": { - "type": "string" - }, - "emoji_name": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "channel_id", - "description", - "emoji_name" - ] - } - }, - "enabled": { - "type": "boolean" - }, - "description": { - "type": "string" - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "WidgetModifySchema": { - "type": "object", - "properties": { - "enabled": { - "type": "boolean" - }, - "channel_id": { "type": "string" } }, "additionalProperties": false, "required": [ - "channel_id", - "enabled" + "code" ], "$schema": "http://json-schema.org/draft-07/schema#" }, - "GuildTemplateCreateSchema": { + "TotpEnableSchema": { "type": "object", "properties": { - "name": { + "password": { "type": "string" }, - "avatar": { + "code": { + "type": "string" + }, + "secret": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "password" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "TotpSchema": { + "type": "object", + "properties": { + "code": { + "type": "string" + }, + "ticket": { + "type": "string" + }, + "gift_code_sku_id": { + "type": [ + "null", + "string" + ] + }, + "login_source": { "type": [ "null", "string" @@ -1391,150 +1766,8 @@ }, "additionalProperties": false, "required": [ - "name" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "UserProfileResponse": { - "type": "object", - "properties": { - "user": { - "$ref": "#/definitions/UserPublic" - }, - "connected_accounts": { - "$ref": "#/definitions/PublicConnectedAccount" - }, - "premium_guild_since": { - "type": "string", - "format": "date-time" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "connected_accounts", - "user" - ], - "definitions": { - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] - }, - "PublicConnectedAccount": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "type": "string" - }, - "verified": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "name", - "type", - "verified" - ] - } - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "UserRelationsResponse": { - "type": "object", - "properties": { - "object": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "username": { - "type": "string" - }, - "avatar": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "public_flags": { - "type": "integer" - } - }, - "additionalProperties": false - } - }, - "additionalProperties": false, - "required": [ - "object" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "DmChannelCreateSchema": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "recipients": { - "type": "array", - "items": { - "type": "string" - } - } - }, - "additionalProperties": false, - "required": [ - "recipients" + "code", + "ticket" ], "$schema": "http://json-schema.org/draft-07/schema#" }, @@ -1581,87 +1814,6 @@ "additionalProperties": false, "$schema": "http://json-schema.org/draft-07/schema#" }, - "MfaCodesSchema": { - "type": "object", - "properties": { - "password": { - "type": "string" - }, - "regenerate": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "password" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "TotpDisableSchema": { - "type": "object", - "properties": { - "code": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "code" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "TotpEnableSchema": { - "type": "object", - "properties": { - "password": { - "type": "string" - }, - "code": { - "type": "string" - }, - "secret": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "password" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "RelationshipPutSchema": { - "type": "object", - "properties": { - "type": { - "enum": [ - 1, - 2, - 3, - 4 - ], - "type": "number" - } - }, - "additionalProperties": false, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "RelationshipPostSchema": { - "type": "object", - "properties": { - "discriminator": { - "type": "string" - }, - "username": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "discriminator", - "username" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, "UserSettingsSchema": { "type": "object", "properties": { @@ -1880,5 +2032,332 @@ } }, "$schema": "http://json-schema.org/draft-07/schema#" + }, + "VanityUrlSchema": { + "type": "object", + "properties": { + "code": { + "minLength": 1, + "maxLength": 20, + "type": "string" + } + }, + "additionalProperties": false, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "VoiceStateUpdateSchema": { + "type": "object", + "properties": { + "channel_id": { + "type": "string" + }, + "guild_id": { + "type": "string" + }, + "suppress": { + "type": "boolean" + }, + "request_to_speak_timestamp": { + "type": "string", + "format": "date-time" + }, + "self_mute": { + "type": "boolean" + }, + "self_deaf": { + "type": "boolean" + }, + "self_video": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "channel_id" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "WebhookCreateSchema": { + "type": "object", + "properties": { + "name": { + "maxLength": 80, + "type": "string" + }, + "avatar": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "name" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "WidgetModifySchema": { + "type": "object", + "properties": { + "enabled": { + "type": "boolean" + }, + "channel_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "channel_id", + "enabled" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "RouteResponse": { + "type": "object", + "properties": { + "status": { + "type": "integer" + }, + "body": { + "type": "array", + "items": { + "type": "string" + } + }, + "headers": { + "$ref": "#/definitions/Record" + } + }, + "additionalProperties": false, + "definitions": { + "Record": { + "type": "object", + "additionalProperties": false + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "GatewayBotResponse": { + "type": "object", + "properties": { + "url": { + "type": "string" + }, + "shards": { + "type": "integer" + }, + "session_start_limit": { + "type": "object", + "properties": { + "total": { + "type": "integer" + }, + "remaining": { + "type": "integer" + }, + "reset_after": { + "type": "integer" + }, + "max_concurrency": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "max_concurrency", + "remaining", + "reset_after", + "total" + ] + } + }, + "additionalProperties": false, + "required": [ + "session_start_limit", + "shards", + "url" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "GatewayResponse": { + "type": "object", + "properties": { + "url": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "url" + ], + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "ChannelReorderSchema": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "position": { + "type": "integer" + }, + "lock_permissions": { + "type": "boolean" + }, + "parent_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "id" + ] + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "RolePositionUpdateSchema": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "position": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "id", + "position" + ] + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "UserProfileResponse": { + "type": "object", + "properties": { + "user": { + "$ref": "#/definitions/UserPublic" + }, + "connected_accounts": { + "$ref": "#/definitions/PublicConnectedAccount" + }, + "premium_guild_since": { + "type": "string", + "format": "date-time" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "connected_accounts", + "user" + ], + "definitions": { + "UserPublic": { + "type": "object", + "properties": { + "username": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "id": { + "type": "string" + }, + "public_flags": { + "type": "integer" + }, + "avatar": { + "type": "string" + }, + "accent_color": { + "type": "integer" + }, + "banner": { + "type": "string" + }, + "bio": { + "type": "string" + }, + "bot": { + "type": "boolean" + }, + "premium_since": { + "type": "string", + "format": "date-time" + } + }, + "additionalProperties": false, + "required": [ + "bio", + "bot", + "discriminator", + "id", + "premium_since", + "public_flags", + "username" + ] + }, + "PublicConnectedAccount": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "type": { + "type": "string" + }, + "verified": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "name", + "type", + "verified" + ] + } + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, + "UserRelationsResponse": { + "type": "object", + "properties": { + "object": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "username": { + "type": "string" + }, + "avatar": { + "type": "string" + }, + "discriminator": { + "type": "string" + }, + "public_flags": { + "type": "integer" + } + }, + "additionalProperties": false + } + }, + "additionalProperties": false, + "required": [ + "object" + ], + "$schema": "http://json-schema.org/draft-07/schema#" } } \ No newline at end of file diff --git a/api/src/routes/auth/login.ts b/api/src/routes/auth/login.ts index daef60566..9fc5924d2 100644 --- a/api/src/routes/auth/login.ts +++ b/api/src/routes/auth/login.ts @@ -1,21 +1,12 @@ import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; -import { Config, User, generateToken, adjustEmail, FieldErrors } from "@fosscord/util"; +import { Config, User, generateToken, adjustEmail, FieldErrors, LoginSchema } from "@fosscord/util"; import crypto from "crypto"; const router: Router = Router(); export default router; -export interface LoginSchema { - login: string; - password: string; - undelete?: boolean; - captcha_key?: string; - login_source?: string; - gift_code_sku_id?: string; -} - router.post("/", route({ body: "LoginSchema" }), async (req: Request, res: Response) => { const { login, password, captcha_key, undelete } = req.body as LoginSchema; const email = adjustEmail(login); diff --git a/api/src/routes/auth/mfa/totp.ts b/api/src/routes/auth/mfa/totp.ts index 255cf8893..421dbafa6 100644 --- a/api/src/routes/auth/mfa/totp.ts +++ b/api/src/routes/auth/mfa/totp.ts @@ -1,17 +1,10 @@ import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; -import { BackupCode, FieldErrors, generateToken, User } from "@fosscord/util"; +import { BackupCode, FieldErrors, generateToken, TotpSchema, User } from "@fosscord/util"; import { verifyToken } from "node-2fa"; import { HTTPError } from "lambert-server"; const router = Router(); -export interface TotpSchema { - code: string, - ticket: string, - gift_code_sku_id?: string | null, - login_source?: string | null, -} - router.post("/", route({ body: "TotpSchema" }), async (req: Request, res: Response) => { const { code, ticket, gift_code_sku_id, login_source } = req.body as TotpSchema; diff --git a/api/src/routes/auth/register.ts b/api/src/routes/auth/register.ts index 5a3d27e97..09366a122 100644 --- a/api/src/routes/auth/register.ts +++ b/api/src/routes/auth/register.ts @@ -1,38 +1,11 @@ import { Request, Response, Router } from "express"; -import { Config, generateToken, Invite, FieldErrors, User, adjustEmail, trimSpecial } from "@fosscord/util"; +import { Config, generateToken, Invite, FieldErrors, User, adjustEmail, trimSpecial, RegisterSchema } from "@fosscord/util"; import { route, getIpAdress, IPAnalysis, isProxy } from "@fosscord/api"; import bcrypt from "bcrypt"; import { HTTPError } from "@fosscord/util"; const router: Router = Router(); -export interface RegisterSchema { - /** - * @minLength 2 - * @maxLength 32 - */ - username: string; - /** - * @minLength 1 - * @maxLength 72 - */ - password?: string; - consent: boolean; - /** - * @TJS-format email - */ - email?: string; - fingerprint?: string; - invite?: string; - /** - * @TJS-type string - */ - date_of_birth?: Date; // "2000-04-03" - gift_code_sku_id?: string; - captcha_key?: string; - promotional_email_opt_in?: boolean; -} - router.post("/", route({ body: "RegisterSchema" }), async (req: Request, res: Response) => { const body = req.body as RegisterSchema; const { register, security } = Config.get(); diff --git a/api/src/routes/channels/#channel_id/index.ts b/api/src/routes/channels/#channel_id/index.ts index 70c34f051..bb8b868ba 100644 --- a/api/src/routes/channels/#channel_id/index.ts +++ b/api/src/routes/channels/#channel_id/index.ts @@ -6,7 +6,8 @@ import { ChannelUpdateEvent, emitEvent, Recipient, - handleFile + handleFile, + ChannelModifySchema } from "@fosscord/util"; import { Request, Response, Router } from "express"; import { route } from "@fosscord/api"; @@ -48,33 +49,6 @@ router.delete("/", route({ permission: "MANAGE_CHANNELS" }), async (req: Request res.send(channel); }); -export interface ChannelModifySchema { - /** - * @maxLength 100 - */ - name?: string; - type?: ChannelType; - topic?: string; - icon?: string | null; - bitrate?: number; - user_limit?: number; - rate_limit_per_user?: number; - position?: number; - permission_overwrites?: { - id: string; - type: ChannelPermissionOverwriteType; - allow: string; - deny: string; - }[]; - parent_id?: string; - id?: string; // is not used (only for guild create) - nsfw?: boolean; - rtc_region?: string; - default_auto_archive_duration?: number; - flags?: number; - default_thread_rate_limit_per_user?: number; -} - router.patch("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANNELS" }), async (req: Request, res: Response) => { let payload = req.body as ChannelModifySchema; const { channel_id } = req.params; diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index f111cf54c..b5c65c0dc 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -8,18 +8,6 @@ import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); -export interface InviteCreateSchema { - target_user_id?: string; - target_type?: string; - validate?: string; // ? what is this - max_age?: number; - max_uses?: number; - temporary?: boolean; - unique?: boolean; - target_user?: string; - target_user_type?: number; -} - router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT_INVITE", right: "CREATE_INVITES" }), async (req: Request, res: Response) => { const { user_id } = req; diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts index c1b8d20f0..041f4d5e3 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts @@ -5,15 +5,6 @@ import { OrmUtils } from "@fosscord/util"; const router = Router(); -// TODO: public read receipts & privacy scoping -// TODO: send read state event to all channel members -// TODO: advance-only notification cursor - -export interface MessageAcknowledgeSchema { - manual?: boolean; - mention_count?: number; -} - router.post("/", route({ body: "MessageAcknowledgeSchema" }), async (req: Request, res: Response) => { const { channel_id, message_id } = req.params; diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts index b3b310d3f..d7e27062c 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/index.ts @@ -12,13 +12,13 @@ import { MessageDeleteEvent, MessageUpdateEvent, Snowflake, - uploadFile + uploadFile, + MessageCreateSchema } from "@fosscord/util"; import { Router, Response, Request } from "express"; import multer from "multer"; import { route } from "@fosscord/api"; import { handleMessage, postHandleMessage } from "@fosscord/api"; -import { MessageCreateSchema } from "../index"; import { HTTPError } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts b/api/src/routes/channels/#channel_id/messages/bulk-delete.ts index 2e40f110d..24a33d2d9 100644 --- a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts +++ b/api/src/routes/channels/#channel_id/messages/bulk-delete.ts @@ -8,10 +8,6 @@ const router: Router = Router(); export default router; -export interface BulkDeleteSchema { - messages: string[]; -} - // should users be able to bulk delete messages or only bots? ANSWER: all users // should this request fail, if you provide messages older than 14 days/invalid ids? ANSWER: NO // https://discord.com/developers/docs/resources/channel#bulk-delete-messages diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/api/src/routes/channels/#channel_id/messages/index.ts index c20574224..9ab0d97df 100644 --- a/api/src/routes/channels/#channel_id/messages/index.ts +++ b/api/src/routes/channels/#channel_id/messages/index.ts @@ -5,7 +5,6 @@ import { ChannelType, Config, DmChannelDTO, - Embed, emitEvent, getPermission, getRights, @@ -13,7 +12,8 @@ import { MessageCreateEvent, Snowflake, uploadFile, - Member + Member, + MessageCreateSchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { handleMessage, postHandleMessage, route } from "@fosscord/api"; @@ -49,38 +49,6 @@ export function isTextChannel(type: ChannelType): boolean { } } -export interface MessageCreateSchema { - type?: number; - content?: string; - nonce?: string; - channel_id?: string; - tts?: boolean; - flags?: string; - embeds?: Embed[]; - embed?: Embed; - // TODO: ^ embed is deprecated in favor of embeds (https://discord.com/developers/docs/resources/channel#message-object) - allowed_mentions?: { - parse?: string[]; - roles?: string[]; - users?: string[]; - replied_user?: boolean; - }; - message_reference?: { - message_id: string; - channel_id: string; - guild_id?: string; - fail_if_not_exists?: boolean; - }; - payload_json?: string; - file?: any; - /** - TODO: we should create an interface for attachments - TODO: OpenWAAO<-->attachment-style metadata conversion - **/ - attachments?: any[]; - sticker_ids?: string[]; -} - // https://discord.com/developers/docs/resources/channel#create-message // get messages router.get("/", async (req: Request, res: Response) => { diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/api/src/routes/channels/#channel_id/permissions.ts index 06a124bb7..34052fe53 100644 --- a/api/src/routes/channels/#channel_id/permissions.ts +++ b/api/src/routes/channels/#channel_id/permissions.ts @@ -1,6 +1,7 @@ import { Channel, ChannelPermissionOverwrite, + ChannelPermissionOverwriteSchema, ChannelPermissionOverwriteType, ChannelUpdateEvent, emitEvent, @@ -10,14 +11,10 @@ import { } from "@fosscord/util"; import { Router, Response, Request } from "express"; import { HTTPError } from "@fosscord/util"; - import { route } from "@fosscord/api"; + const router: Router = Router(); -// TODO: Only permissions your bot has in the guild or channel can be allowed/denied (unless your bot has a MANAGE_ROLES overwrite in the channel) - -export interface ChannelPermissionOverwriteSchema extends ChannelPermissionOverwrite {} - router.put( "/:overwrite_id", route({ body: "ChannelPermissionOverwriteSchema", permission: "MANAGE_ROLES" }), diff --git a/api/src/routes/channels/#channel_id/purge.ts b/api/src/routes/channels/#channel_id/purge.ts index 7ab4ad9a4..1ef6e1d76 100644 --- a/api/src/routes/channels/#channel_id/purge.ts +++ b/api/src/routes/channels/#channel_id/purge.ts @@ -1,4 +1,4 @@ -import { HTTPError } from "@fosscord/util"; +import { HTTPError, PurgeSchema } from "@fosscord/util"; import { route } from "@fosscord/api"; import { isTextChannel } from "./messages"; import { FindManyOptions, Between, Not } from "typeorm"; @@ -10,11 +10,6 @@ const router: Router = Router(); export default router; -export interface PurgeSchema { - before: string; - after: string; -} - /** TODO: apply the delete bit by bit to prevent client and database stress **/ diff --git a/api/src/routes/channels/#channel_id/webhooks.ts b/api/src/routes/channels/#channel_id/webhooks.ts index 00bf46197..b11c8eb97 100644 --- a/api/src/routes/channels/#channel_id/webhooks.ts +++ b/api/src/routes/channels/#channel_id/webhooks.ts @@ -6,14 +6,6 @@ import { isTextChannel } from "./messages/index"; import { DiscordApiErrors } from "@fosscord/util"; const router: Router = Router(); -// TODO: webhooks -export interface WebhookCreateSchema { - /** - * @maxLength 80 - */ - name: string; - avatar?: string; -} //TODO: implement webhooks router.get("/", route({}), async (req: Request, res: Response) => { res.json([]); diff --git a/api/src/routes/guilds/#guild_id/audit-logs.ts b/api/src/routes/guilds/#guild_id/audit-logs.ts index 7b1d00628..b54835fc2 100644 --- a/api/src/routes/guilds/#guild_id/audit-logs.ts +++ b/api/src/routes/guilds/#guild_id/audit-logs.ts @@ -1,8 +1,5 @@ import { Router, Response, Request } from "express"; -import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; -import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); //TODO: implement audit logs diff --git a/api/src/routes/guilds/#guild_id/bans.ts b/api/src/routes/guilds/#guild_id/bans.ts index 0743687dd..3d4053445 100644 --- a/api/src/routes/guilds/#guild_id/bans.ts +++ b/api/src/routes/guilds/#guild_id/bans.ts @@ -1,31 +1,9 @@ import { Request, Response, Router } from "express"; -import { DiscordApiErrors, emitEvent, getPermission, GuildBanAddEvent, GuildBanRemoveEvent, Guild, Ban, User, Member } from "@fosscord/util"; +import { DiscordApiErrors, emitEvent, getPermission, GuildBanAddEvent, GuildBanRemoveEvent, Guild, Ban, User, Member, BanRegistrySchema, BanModeratorSchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { getIpAdress, route } from "@fosscord/api"; import { OrmUtils } from "@fosscord/util"; -export interface BanCreateSchema { - delete_message_days?: string; - reason?: string; -}; - -export interface BanRegistrySchema { - id: string; - user_id: string; - guild_id: string; - executor_id: string; - ip?: string; - reason?: string | undefined; -}; - -export interface BanModeratorSchema { - id: string; - user_id: string; - guild_id: string; - executor_id: string; - reason?: string | undefined; -}; - const router: Router = Router(); /* TODO: Deleting the secrets is just a temporary go-around. Views should be implemented for both safety and better handling. */ diff --git a/api/src/routes/guilds/#guild_id/channels.ts b/api/src/routes/guilds/#guild_id/channels.ts index b952b4748..df1b79242 100644 --- a/api/src/routes/guilds/#guild_id/channels.ts +++ b/api/src/routes/guilds/#guild_id/channels.ts @@ -1,8 +1,7 @@ import { Router, Response, Request } from "express"; -import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; +import { Channel, ChannelUpdateEvent, getPermission, emitEvent, ChannelModifySchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); router.get("/", route({}), async (req: Request, res: Response) => { diff --git a/api/src/routes/guilds/#guild_id/emojis.ts b/api/src/routes/guilds/#guild_id/emojis.ts index 53a44ec31..4bf4bdcd4 100644 --- a/api/src/routes/guilds/#guild_id/emojis.ts +++ b/api/src/routes/guilds/#guild_id/emojis.ts @@ -1,22 +1,10 @@ import { Router, Request, Response } from "express"; -import { Config, DiscordApiErrors, emitEvent, Emoji, GuildEmojisUpdateEvent, handleFile, Member, Snowflake, User } from "@fosscord/util"; +import { Config, DiscordApiErrors, emitEvent, Emoji, EmojiCreateSchema, EmojiModifySchema, GuildEmojisUpdateEvent, handleFile, Member, Snowflake, User } from "@fosscord/util"; import { route } from "@fosscord/api"; import { OrmUtils } from "@fosscord/util"; const router = Router(); -export interface EmojiCreateSchema { - name?: string; - image: string; - require_colons?: boolean | null; - roles?: string[]; -} - -export interface EmojiModifySchema { - name?: string; - roles?: string[]; -} - router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index 8d61f7537..a9712c711 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -1,29 +1,11 @@ import { Request, Response, Router } from "express"; -import { DiscordApiErrors, emitEvent, getPermission, getRights, Guild, GuildUpdateEvent, handleFile, Member } from "@fosscord/util"; +import { DiscordApiErrors, emitEvent, getPermission, getRights, Guild, GuildUpdateEvent, GuildUpdateSchema, handleFile, Member } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { GuildCreateSchema } from "../index"; import { OrmUtils } from "@fosscord/util"; const router = Router(); -export interface GuildUpdateSchema extends Omit { - name?: string; - banner?: string | null; - splash?: string | null; - description?: string; - features?: string[]; - verification_level?: number; - default_message_notifications?: number; - system_channel_flags?: number; - explicit_content_filter?: number; - public_updates_channel_id?: string; - afk_timeout?: number; - afk_channel_id?: string; - preferred_locale?: string; - premium_progress_bar_enabled?: boolean; -} - router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; diff --git a/api/src/routes/guilds/#guild_id/integrations.ts b/api/src/routes/guilds/#guild_id/integrations.ts index 19f685635..906501111 100644 --- a/api/src/routes/guilds/#guild_id/integrations.ts +++ b/api/src/routes/guilds/#guild_id/integrations.ts @@ -2,7 +2,6 @@ import { Router, Response, Request } from "express"; import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); //TODO: implement integrations list diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index 824e34a49..794369d8b 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -1,15 +1,11 @@ import { Request, Response, Router } from "express"; -import { Member, getPermission, getRights, Role, GuildMemberUpdateEvent, emitEvent, Sticker, Emoji, Rights, Guild } from "@fosscord/util"; +import { Member, getPermission, getRights, Role, GuildMemberUpdateEvent, emitEvent, Sticker, Emoji, Rights, Guild, MemberChangeSchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; import { OrmUtils } from "@fosscord/util"; const router = Router(); -export interface MemberChangeSchema { - roles?: string[]; -} - router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id, member_id } = req.params; await Member.IsInGuildOrFail(req.user_id, guild_id); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts b/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts index 4dfae8dac..a6c713332 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts @@ -4,10 +4,6 @@ import { Request, Response, Router } from "express"; const router = Router(); -export interface MemberNickChangeSchema { - nick: string; -} - router.patch("/", route({ body: "MemberNickChangeSchema" }), async (req: Request, res: Response) => { let { guild_id, member_id } = req.params; let permissionString: PermissionResolvable = "MANAGE_NICKNAMES"; diff --git a/api/src/routes/guilds/#guild_id/prune.ts b/api/src/routes/guilds/#guild_id/prune.ts index 01f18ce40..673f022f4 100644 --- a/api/src/routes/guilds/#guild_id/prune.ts +++ b/api/src/routes/guilds/#guild_id/prune.ts @@ -62,13 +62,6 @@ router.get("/", route({}), async (req: Request, res: Response) => { res.send({ pruned: members.length }); }); -export interface PruneSchema { - /** - * @min 0 - */ - days: number; -} - router.post("/", route({ permission: "KICK_MEMBERS", right: "KICK_BAN_MEMBERS" }), async (req: Request, res: Response) => { const days = parseInt(req.body.days); diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index 0482b9ca7..d4422a9c5 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -1,8 +1,7 @@ import { Router, Request, Response } from "express"; -import { Role, Member, GuildRoleUpdateEvent, GuildRoleDeleteEvent, emitEvent, handleFile } from "@fosscord/util"; +import { Role, Member, GuildRoleUpdateEvent, GuildRoleDeleteEvent, emitEvent, handleFile, RoleModifySchema } from "@fosscord/util"; import { route } from "@fosscord/api"; import { HTTPError } from "@fosscord/util"; -import { RoleModifySchema } from "../"; import { OrmUtils } from "@fosscord/util"; const router = Router(); diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index 6fbb8702a..effa4fcde 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -9,7 +9,8 @@ import { emitEvent, Config, DiscordApiErrors, - handleFile + handleFile, + RoleModifySchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; @@ -17,17 +18,6 @@ import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); -export interface RoleModifySchema { - name?: string; - permissions?: string; - color?: number; - hoist?: boolean; // whether the role should be displayed separately in the sidebar - mentionable?: boolean; // whether the role should be mentionable - position?: number; - icon?: string; - unicode_emoji?: string; -} - export type RolePositionUpdateSchema = { id: string; position: number; diff --git a/api/src/routes/guilds/#guild_id/stickers.ts b/api/src/routes/guilds/#guild_id/stickers.ts index 157ccff40..71c9dfcd7 100644 --- a/api/src/routes/guilds/#guild_id/stickers.ts +++ b/api/src/routes/guilds/#guild_id/stickers.ts @@ -3,6 +3,7 @@ import { GuildStickersUpdateEvent, handleFile, Member, + ModifyGuildStickerSchema, Snowflake, Sticker, StickerFormatType, @@ -83,22 +84,6 @@ router.get("/:sticker_id", route({}), async (req: Request, res: Response) => { res.json(await Sticker.findOneOrFail({ where: { guild_id, id: sticker_id } })); }); -export interface ModifyGuildStickerSchema { - /** - * @minLength 2 - * @maxLength 30 - */ - name: string; - /** - * @maxLength 100 - */ - description?: string; - /** - * @maxLength 200 - */ - tags: string; -} - router.patch( "/:sticker_id", route({ body: "ModifyGuildStickerSchema", permission: "MANAGE_EMOJIS_AND_STICKERS" }), diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/api/src/routes/guilds/#guild_id/templates.ts index 3d14de415..9c79692d7 100644 --- a/api/src/routes/guilds/#guild_id/templates.ts +++ b/api/src/routes/guilds/#guild_id/templates.ts @@ -24,16 +24,6 @@ const TemplateGuildProjection: (keyof Guild)[] = [ "icon" ]; -export interface TemplateCreateSchema { - name: string; - description?: string; -} - -export interface TemplateModifySchema { - name: string; - description?: string; -} - router.get("/", route({}), async (req: Request, res: Response) => { const { guild_id } = req.params; diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/api/src/routes/guilds/#guild_id/vanity-url.ts index ac46e18a5..ff92ce8d7 100644 --- a/api/src/routes/guilds/#guild_id/vanity-url.ts +++ b/api/src/routes/guilds/#guild_id/vanity-url.ts @@ -1,4 +1,4 @@ -import { Channel, ChannelType, getPermission, Guild, Invite, trimSpecial } from "@fosscord/util"; +import { Channel, ChannelType, getPermission, Guild, Invite, trimSpecial, VanityUrlSchema } from "@fosscord/util"; import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; import { HTTPError } from "@fosscord/util"; @@ -25,14 +25,6 @@ router.get("/", route({ permission: "MANAGE_GUILD" }), async (req: Request, res: } }); -export interface VanityUrlSchema { - /** - * @minLength 1 - * @maxLength 20 - */ - code?: string; -} - router.patch("/", route({ body: "VanityUrlSchema", permission: "MANAGE_GUILD" }), async (req: Request, res: Response) => { const { guild_id } = req.params; const body = req.body as VanityUrlSchema; diff --git a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts index 32d1aadfd..28a9e8c1c 100644 --- a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts +++ b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts @@ -1,21 +1,9 @@ -import { Channel, ChannelType, DiscordApiErrors, emitEvent, getPermission, VoiceState, VoiceStateUpdateEvent } from "@fosscord/util"; +import { Channel, ChannelType, DiscordApiErrors, emitEvent, getPermission, VoiceState, VoiceStateUpdateEvent, VoiceStateUpdateSchema } from "@fosscord/util"; import { route } from "@fosscord/api"; import { Request, Response, Router } from "express"; import { OrmUtils } from "@fosscord/util"; const router = Router(); -//TODO need more testing when community guild and voice stage channel are working - -export interface VoiceStateUpdateSchema { - channel_id: string; - guild_id?: string; - suppress?: boolean; - request_to_speak_timestamp?: Date; - self_mute?: boolean; - self_deaf?: boolean; - self_video?: boolean; -} - router.patch("/", route({ body: "VoiceStateUpdateSchema" }), async (req: Request, res: Response) => { const body = req.body as VoiceStateUpdateSchema; let { guild_id, user_id } = req.params; diff --git a/api/src/routes/guilds/#guild_id/webhooks.ts b/api/src/routes/guilds/#guild_id/webhooks.ts index 7f5b95928..c8c1eb5c4 100644 --- a/api/src/routes/guilds/#guild_id/webhooks.ts +++ b/api/src/routes/guilds/#guild_id/webhooks.ts @@ -2,7 +2,6 @@ import { Router, Response, Request } from "express"; import { Channel, ChannelUpdateEvent, getPermission, emitEvent } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { ChannelModifySchema } from "../../channels/#channel_id"; const router = Router(); //TODO: implement webhooks diff --git a/api/src/routes/guilds/#guild_id/welcome_screen.ts b/api/src/routes/guilds/#guild_id/welcome_screen.ts index 4093ec1dc..d08300ba0 100644 --- a/api/src/routes/guilds/#guild_id/welcome_screen.ts +++ b/api/src/routes/guilds/#guild_id/welcome_screen.ts @@ -1,21 +1,10 @@ import { Request, Response, Router } from "express"; -import { Guild, getPermission, Snowflake, Member } from "@fosscord/util"; +import { Guild, getPermission, Snowflake, Member, GuildUpdateWelcomeScreenSchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); -export interface GuildUpdateWelcomeScreenSchema { - welcome_channels?: { - channel_id: string; - description: string; - emoji_id?: string; - emoji_name: string; - }[]; - enabled?: boolean; - description?: string; -} - router.get("/", route({}), async (req: Request, res: Response) => { const guild_id = req.params.guild_id; diff --git a/api/src/routes/guilds/#guild_id/widget.ts b/api/src/routes/guilds/#guild_id/widget.ts index 103f84a30..dbb4cc0c8 100644 --- a/api/src/routes/guilds/#guild_id/widget.ts +++ b/api/src/routes/guilds/#guild_id/widget.ts @@ -1,12 +1,7 @@ import { Request, Response, Router } from "express"; -import { Guild } from "@fosscord/util"; +import { Guild, WidgetModifySchema } from "@fosscord/util"; import { route } from "@fosscord/api"; -export interface WidgetModifySchema { - enabled: boolean; // whether the widget is enabled - channel_id: string; // the widget channel id -} - const router: Router = Router(); // https://discord.com/developers/docs/resources/guild#get-guild-widget-settings diff --git a/api/src/routes/guilds/index.ts b/api/src/routes/guilds/index.ts index 64b9454b1..e4d66192b 100644 --- a/api/src/routes/guilds/index.ts +++ b/api/src/routes/guilds/index.ts @@ -1,23 +1,9 @@ import { Router, Request, Response } from "express"; -import { Role, Guild, Snowflake, Config, getRights, Member, Channel, DiscordApiErrors, handleFile } from "@fosscord/util"; +import { Role, Guild, Snowflake, Config, getRights, Member, Channel, DiscordApiErrors, handleFile, GuildCreateSchema } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { ChannelModifySchema } from "../channels/#channel_id"; const router: Router = Router(); -export interface GuildCreateSchema { - /** - * @maxLength 100 - */ - name: string; - region?: string; - icon?: string | null; - channels?: ChannelModifySchema[]; - guild_template_code?: string; - system_channel_id?: string; - rules_channel_id?: string; -} - //TODO: create default channel router.post("/", route({ body: "GuildCreateSchema", right: "CREATE_GUILDS" }), async (req: Request, res: Response) => { diff --git a/api/src/routes/guilds/templates/index.ts b/api/src/routes/guilds/templates/index.ts index bac4eb8ad..3a0de9e8c 100644 --- a/api/src/routes/guilds/templates/index.ts +++ b/api/src/routes/guilds/templates/index.ts @@ -1,15 +1,8 @@ import { Request, Response, Router } from "express"; -import { Template, Guild, Role, Snowflake, Config, User, Member } from "@fosscord/util"; +import { Template, Guild, Role, Snowflake, Config, User, Member, DiscordApiErrors, OrmUtils, GuildTemplateCreateSchema } from "@fosscord/util"; import { route } from "@fosscord/api"; -import { DiscordApiErrors } from "@fosscord/util"; import fetch from "node-fetch"; const router: Router = Router(); -import { OrmUtils } from "@fosscord/util"; - -export interface GuildTemplateCreateSchema { - name: string; - avatar?: string | null; -} router.get("/:code", route({}), async (req: Request, res: Response) => { const { allowDiscordTemplates, allowRaws, enabled } = Config.get().templates; diff --git a/api/src/routes/users/@me/channels.ts b/api/src/routes/users/@me/channels.ts index 78f531e19..ad483529f 100644 --- a/api/src/routes/users/@me/channels.ts +++ b/api/src/routes/users/@me/channels.ts @@ -1,5 +1,5 @@ import { Request, Response, Router } from "express"; -import { Recipient, DmChannelDTO, Channel } from "@fosscord/util"; +import { Recipient, DmChannelDTO, Channel, DmChannelCreateSchema } from "@fosscord/util"; import { route } from "@fosscord/api"; const router: Router = Router(); @@ -12,11 +12,6 @@ router.get("/", route({}), async (req: Request, res: Response) => { res.json(await Promise.all(recipients.map((r) => DmChannelDTO.from(r.channel, [req.user_id])))); }); -export interface DmChannelCreateSchema { - name?: string; - recipients: string[]; -} - router.post("/", route({ body: "DmChannelCreateSchema" }), async (req: Request, res: Response) => { const body = req.body as DmChannelCreateSchema; res.json(await Channel.createDMChannel(body.recipients, req.user_id, body.name)); diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 4cf96a8dc..7d095451d 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -1,30 +1,11 @@ import { Router, Request, Response } from "express"; -import { User, PrivateUserProjection, emitEvent, UserUpdateEvent, handleFile, FieldErrors } from "@fosscord/util"; +import { User, PrivateUserProjection, emitEvent, UserUpdateEvent, handleFile, FieldErrors, UserModifySchema } from "@fosscord/util"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; import { OrmUtils, generateToken } from "@fosscord/util"; const router: Router = Router(); -export interface UserModifySchema { - /** - * @minLength 1 - * @maxLength 100 - */ - username?: string; - discriminator?: string; - avatar?: string | null; - /** - * @maxLength 1024 - */ - bio?: string; - accent_color?: number; - banner?: string | null; - password?: string; - new_password?: string; - code?: string; -} - router.get("/", route({}), async (req: Request, res: Response) => { res.json(await User.findOne({ select: PrivateUserProjection, where: { id: req.user_id } })); }); diff --git a/api/src/routes/users/@me/mfa/codes.ts b/api/src/routes/users/@me/mfa/codes.ts index 75e3e9643..4224a1c05 100644 --- a/api/src/routes/users/@me/mfa/codes.ts +++ b/api/src/routes/users/@me/mfa/codes.ts @@ -1,15 +1,10 @@ import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; -import { BackupCode, Config, FieldErrors, generateMfaBackupCodes, User } from "@fosscord/util"; +import { BackupCode, Config, FieldErrors, generateMfaBackupCodes, MfaCodesSchema, User } from "@fosscord/util"; import bcrypt from "bcrypt"; const router = Router(); -export interface MfaCodesSchema { - password: string; - regenerate?: boolean; -} - // TODO: This route is replaced with users/@me/mfa/codes-verification in newer clients router.post("/", route({ body: "MfaCodesSchema" }), async (req: Request, res: Response) => { diff --git a/api/src/routes/users/@me/mfa/totp/disable.ts b/api/src/routes/users/@me/mfa/totp/disable.ts index 2d385fdaa..2fe9355cb 100644 --- a/api/src/routes/users/@me/mfa/totp/disable.ts +++ b/api/src/routes/users/@me/mfa/totp/disable.ts @@ -2,14 +2,10 @@ import { Router, Request, Response } from "express"; import { route } from "@fosscord/api"; import { verifyToken } from 'node-2fa'; import { HTTPError } from "lambert-server"; -import { User, generateToken, BackupCode } from "@fosscord/util"; +import { User, generateToken, BackupCode, TotpDisableSchema } from "@fosscord/util"; const router = Router(); -export interface TotpDisableSchema { - code: string; -} - router.post("/", route({ body: "TotpDisableSchema" }), async (req: Request, res: Response) => { const body = req.body as TotpDisableSchema; diff --git a/api/src/routes/users/@me/mfa/totp/enable.ts b/api/src/routes/users/@me/mfa/totp/enable.ts index 87f36d558..ac668d1d5 100644 --- a/api/src/routes/users/@me/mfa/totp/enable.ts +++ b/api/src/routes/users/@me/mfa/totp/enable.ts @@ -1,5 +1,5 @@ import { Router, Request, Response } from "express"; -import { User, generateToken, BackupCode, generateMfaBackupCodes, Config } from "@fosscord/util"; +import { User, generateToken, BackupCode, generateMfaBackupCodes, Config, TotpEnableSchema } from "@fosscord/util"; import { route } from "@fosscord/api"; import bcrypt from "bcrypt"; import { HTTPError } from "lambert-server"; @@ -7,12 +7,6 @@ import { verifyToken } from 'node-2fa'; const router = Router(); -export interface TotpEnableSchema { - password: string; - code?: string; - secret?: string; -} - router.post("/", route({ body: "TotpEnableSchema" }), async (req: Request, res: Response) => { const body = req.body as TotpEnableSchema; diff --git a/api/src/routes/users/@me/relationships.ts b/api/src/routes/users/@me/relationships.ts index 6e22f4f3a..f7464b99b 100644 --- a/api/src/routes/users/@me/relationships.ts +++ b/api/src/routes/users/@me/relationships.ts @@ -38,10 +38,6 @@ router.get("/", route({}), async (req: Request, res: Response) => { return res.json(related_users); }); -export interface RelationshipPutSchema { - type?: RelationshipType; -} - router.put("/:id", route({ body: "RelationshipPutSchema" }), async (req: Request, res: Response) => { return await updateRelationship( req, @@ -51,11 +47,6 @@ router.put("/:id", route({ body: "RelationshipPutSchema" }), async (req: Request ); }); -export interface RelationshipPostSchema { - discriminator: string; - username: string; -} - router.post("/", route({ body: "RelationshipPostSchema" }), async (req: Request, res: Response) => { return await updateRelationship( req, diff --git a/api/src/routes/users/@me/settings.ts b/api/src/routes/users/@me/settings.ts index d832575fa..7578d36e3 100644 --- a/api/src/routes/users/@me/settings.ts +++ b/api/src/routes/users/@me/settings.ts @@ -4,8 +4,6 @@ import { route } from "@fosscord/api"; const router = Router(); -export interface UserSettingsSchema extends Partial {} - router.patch("/", route({ body: "UserSettingsSchema" }), async (req: Request, res: Response) => { const body = req.body as UserSettings; if (body.locale === "en") body.locale = "en-US"; // fix discord client crash on unkown locale diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 0f584c565..ff5ece75b 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -21,12 +21,13 @@ import { Webhook, Attachment, Config, + MessageCreateSchema, } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import fetch from "node-fetch"; import cheerio from "cheerio"; -import { MessageCreateSchema } from "../../routes/channels/#channel_id/messages"; import { OrmUtils } from "@fosscord/util"; + const allow_empty = false; // TODO: check webhook, application, system author, stickers // TODO: embed gifs/videos/images diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts index ce4385a3a..e62c15700 100644 --- a/gateway/src/opcodes/Identify.ts +++ b/gateway/src/opcodes/Identify.ts @@ -19,12 +19,12 @@ import { MemberPrivateProjection, PresenceUpdateEvent, UserSettings, + IdentifySchema, } from "@fosscord/util"; import { Send } from "../util/Send"; import { CLOSECODES, OPCODES } from "../util/Constants"; import { genSessionId } from "../util/SessionUtils"; import { setupListener } from "../listener/listener"; -import { IdentifySchema } from "../schema/Identify"; // import experiments from "./experiments.json"; const experiments: any = []; import { check } from "./instanceOf"; diff --git a/gateway/src/opcodes/LazyRequest.ts b/gateway/src/opcodes/LazyRequest.ts index 5ba65cdd7..cd0586de2 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/gateway/src/opcodes/LazyRequest.ts @@ -1,5 +1,4 @@ -import { getPermission, listenEvent, Member, Role, getOrInitialiseDatabase } from "@fosscord/util"; -import { LazyRequest } from "../schema/LazyRequest"; +import { getPermission, listenEvent, Member, Role, getOrInitialiseDatabase, LazyRequest } from "@fosscord/util"; import { Send } from "../util/Send"; import { OPCODES } from "../util/Constants"; import { WebSocket, Payload, handlePresenceUpdate } from "@fosscord/gateway"; diff --git a/gateway/src/opcodes/PresenceUpdate.ts b/gateway/src/opcodes/PresenceUpdate.ts index 415df6eea..f31c91616 100644 --- a/gateway/src/opcodes/PresenceUpdate.ts +++ b/gateway/src/opcodes/PresenceUpdate.ts @@ -1,6 +1,5 @@ import { WebSocket, Payload } from "@fosscord/gateway"; -import { emitEvent, PresenceUpdateEvent, Session, User } from "@fosscord/util"; -import { ActivitySchema } from "../schema/Activity"; +import { ActivitySchema, emitEvent, PresenceUpdateEvent, Session, User } from "@fosscord/util"; import { check } from "./instanceOf"; export async function onPresenceUpdate(this: WebSocket, { d }: Payload) { diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/gateway/src/opcodes/VoiceStateUpdate.ts index 845a75c08..73f73565c 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/gateway/src/opcodes/VoiceStateUpdate.ts @@ -1,4 +1,3 @@ -import { VoiceStateUpdateSchema } from "../schema/VoiceStateUpdateSchema"; import { Payload, WebSocket } from "@fosscord/gateway"; import { genVoiceToken } from "../util/SessionUtils"; import { check } from "./instanceOf"; @@ -10,6 +9,7 @@ import { VoiceServerUpdateEvent, VoiceState, VoiceStateUpdateEvent, + VoiceStateUpdateSchema, } from "@fosscord/util"; import { OrmUtils } from "@fosscord/util"; import { Region } from "@fosscord/util/src/config"; diff --git a/gateway/src/schema/VoiceStateUpdateSchema.ts b/gateway/src/schema/VoiceStateUpdateSchema.ts deleted file mode 100644 index 9efa191e7..000000000 --- a/gateway/src/schema/VoiceStateUpdateSchema.ts +++ /dev/null @@ -1,15 +0,0 @@ -export const VoiceStateUpdateSchema = { - $guild_id: String, - $channel_id: String, - self_mute: Boolean, - self_deaf: Boolean, - self_video: Boolean, -}; - -export interface VoiceStateUpdateSchema { - guild_id?: string; - channel_id?: string; - self_mute: boolean; - self_deaf: boolean; - self_video: boolean; -} diff --git a/util/src/index.ts b/util/src/index.ts index 259d1c97b..daeffd698 100644 --- a/util/src/index.ts +++ b/util/src/index.ts @@ -4,4 +4,5 @@ export * from "./util/index"; export * from "./interfaces/index"; export * from "./entities/index"; export * from "./dtos/index"; -export * from "./util/MFA"; \ No newline at end of file +export * from "./util/MFA"; +export * from "./schemas"; \ No newline at end of file diff --git a/gateway/src/schema/Activity.ts b/util/src/schemas/ActivitySchema.ts similarity index 100% rename from gateway/src/schema/Activity.ts rename to util/src/schemas/ActivitySchema.ts diff --git a/util/src/schemas/BanCreateSchema.ts b/util/src/schemas/BanCreateSchema.ts new file mode 100644 index 000000000..64b029430 --- /dev/null +++ b/util/src/schemas/BanCreateSchema.ts @@ -0,0 +1,5 @@ + +export interface BanCreateSchema { + delete_message_days?: string; + reason?: string; +} diff --git a/util/src/schemas/BanModeratorSchema.ts b/util/src/schemas/BanModeratorSchema.ts new file mode 100644 index 000000000..b497d3199 --- /dev/null +++ b/util/src/schemas/BanModeratorSchema.ts @@ -0,0 +1,8 @@ + +export interface BanModeratorSchema { + id: string; + user_id: string; + guild_id: string; + executor_id: string; + reason?: string | undefined; +} diff --git a/util/src/schemas/BanRegistrySchema.ts b/util/src/schemas/BanRegistrySchema.ts new file mode 100644 index 000000000..661f934f9 --- /dev/null +++ b/util/src/schemas/BanRegistrySchema.ts @@ -0,0 +1,9 @@ + +export interface BanRegistrySchema { + id: string; + user_id: string; + guild_id: string; + executor_id: string; + ip?: string; + reason?: string | undefined; +} diff --git a/util/src/schemas/BulkDeleteSchema.ts b/util/src/schemas/BulkDeleteSchema.ts new file mode 100644 index 000000000..26f883749 --- /dev/null +++ b/util/src/schemas/BulkDeleteSchema.ts @@ -0,0 +1,4 @@ + +export interface BulkDeleteSchema { + messages: string[]; +} diff --git a/util/src/schemas/ChannelModifySchema.ts b/util/src/schemas/ChannelModifySchema.ts new file mode 100644 index 000000000..3cfcf7d22 --- /dev/null +++ b/util/src/schemas/ChannelModifySchema.ts @@ -0,0 +1,29 @@ +import { ChannelPermissionOverwriteType, ChannelType } from ".."; + + +export interface ChannelModifySchema { + /** + * @maxLength 100 + */ + name?: string; + type?: ChannelType; + topic?: string; + icon?: string | null; + bitrate?: number; + user_limit?: number; + rate_limit_per_user?: number; + position?: number; + permission_overwrites?: { + id: string; + type: ChannelPermissionOverwriteType; + allow: string; + deny: string; + }[]; + parent_id?: string; + id?: string; // is not used (only for guild create) + nsfw?: boolean; + rtc_region?: string; + default_auto_archive_duration?: number; + flags?: number; + default_thread_rate_limit_per_user?: number; +} \ No newline at end of file diff --git a/util/src/schemas/ChannelPermissionOverwriteSchema.ts b/util/src/schemas/ChannelPermissionOverwriteSchema.ts new file mode 100644 index 000000000..fe9ba860b --- /dev/null +++ b/util/src/schemas/ChannelPermissionOverwriteSchema.ts @@ -0,0 +1,5 @@ +import { ChannelPermissionOverwrite } from "@fosscord/util"; + +// TODO: Only permissions your bot has in the guild or channel can be allowed/denied (unless your bot has a MANAGE_ROLES overwrite in the channel) + +export interface ChannelPermissionOverwriteSchema extends ChannelPermissionOverwrite { } diff --git a/util/src/schemas/DmChannelCreateSchema.ts b/util/src/schemas/DmChannelCreateSchema.ts new file mode 100644 index 000000000..d5afc6d7c --- /dev/null +++ b/util/src/schemas/DmChannelCreateSchema.ts @@ -0,0 +1,5 @@ + +export interface DmChannelCreateSchema { + name?: string; + recipients: string[]; +} diff --git a/util/src/schemas/EmojiCreateSchema.ts b/util/src/schemas/EmojiCreateSchema.ts new file mode 100644 index 000000000..d50c419cc --- /dev/null +++ b/util/src/schemas/EmojiCreateSchema.ts @@ -0,0 +1,7 @@ + +export interface EmojiCreateSchema { + name?: string; + image: string; + require_colons?: boolean | null; + roles?: string[]; +} diff --git a/util/src/schemas/EmojiModifySchema.ts b/util/src/schemas/EmojiModifySchema.ts new file mode 100644 index 000000000..5529dbd50 --- /dev/null +++ b/util/src/schemas/EmojiModifySchema.ts @@ -0,0 +1,5 @@ + +export interface EmojiModifySchema { + name?: string; + roles?: string[]; +} diff --git a/util/src/schemas/GuildCreateSchema.ts b/util/src/schemas/GuildCreateSchema.ts new file mode 100644 index 000000000..e48551192 --- /dev/null +++ b/util/src/schemas/GuildCreateSchema.ts @@ -0,0 +1,14 @@ +import { ChannelModifySchema } from "."; + +export interface GuildCreateSchema { + /** + * @maxLength 100 + */ + name: string; + region?: string; + icon?: string | null; + channels?: ChannelModifySchema[]; + guild_template_code?: string; + system_channel_id?: string; + rules_channel_id?: string; +} diff --git a/util/src/schemas/GuildTemplateCreateSchema.ts b/util/src/schemas/GuildTemplateCreateSchema.ts new file mode 100644 index 000000000..1579001e7 --- /dev/null +++ b/util/src/schemas/GuildTemplateCreateSchema.ts @@ -0,0 +1,5 @@ + +export interface GuildTemplateCreateSchema { + name: string; + avatar?: string | null; +} diff --git a/util/src/schemas/GuildUpdateSchema.ts b/util/src/schemas/GuildUpdateSchema.ts new file mode 100644 index 000000000..86527cf10 --- /dev/null +++ b/util/src/schemas/GuildUpdateSchema.ts @@ -0,0 +1,18 @@ +import { GuildCreateSchema } from "."; + +export interface GuildUpdateSchema extends Omit { + name?: string; + banner?: string | null; + splash?: string | null; + description?: string; + features?: string[]; + verification_level?: number; + default_message_notifications?: number; + system_channel_flags?: number; + explicit_content_filter?: number; + public_updates_channel_id?: string; + afk_timeout?: number; + afk_channel_id?: string; + preferred_locale?: string; + premium_progress_bar_enabled?: boolean; +} diff --git a/util/src/schemas/GuildUpdateWelcomeScreenSchema.ts b/util/src/schemas/GuildUpdateWelcomeScreenSchema.ts new file mode 100644 index 000000000..b1e36920b --- /dev/null +++ b/util/src/schemas/GuildUpdateWelcomeScreenSchema.ts @@ -0,0 +1,11 @@ + +export interface GuildUpdateWelcomeScreenSchema { + welcome_channels?: { + channel_id: string; + description: string; + emoji_id?: string; + emoji_name: string; + }[]; + enabled?: boolean; + description?: string; +} diff --git a/gateway/src/schema/Identify.ts b/util/src/schemas/IdentifySchema.ts similarity index 98% rename from gateway/src/schema/Identify.ts rename to util/src/schemas/IdentifySchema.ts index 211413212..8f95c6a0c 100644 --- a/gateway/src/schema/Identify.ts +++ b/util/src/schemas/IdentifySchema.ts @@ -1,4 +1,4 @@ -import { ActivitySchema } from "./Activity"; +import { ActivitySchema } from "./ActivitySchema"; export const IdentifySchema = { token: String, diff --git a/util/src/schemas/InviteCreateSchema.ts b/util/src/schemas/InviteCreateSchema.ts new file mode 100644 index 000000000..7f6af3386 --- /dev/null +++ b/util/src/schemas/InviteCreateSchema.ts @@ -0,0 +1,12 @@ + +export interface InviteCreateSchema { + target_user_id?: string; + target_type?: string; + validate?: string; // ? what is this + max_age?: number; + max_uses?: number; + temporary?: boolean; + unique?: boolean; + target_user?: string; + target_user_type?: number; +} diff --git a/gateway/src/schema/LazyRequest.ts b/util/src/schemas/LazyRequestSchema.ts similarity index 100% rename from gateway/src/schema/LazyRequest.ts rename to util/src/schemas/LazyRequestSchema.ts diff --git a/util/src/schemas/LoginSchema.ts b/util/src/schemas/LoginSchema.ts new file mode 100644 index 000000000..358019a8c --- /dev/null +++ b/util/src/schemas/LoginSchema.ts @@ -0,0 +1,9 @@ + +export interface LoginSchema { + login: string; + password: string; + undelete?: boolean; + captcha_key?: string; + login_source?: string; + gift_code_sku_id?: string; +} diff --git a/util/src/schemas/MemberChangeSchema.ts b/util/src/schemas/MemberChangeSchema.ts new file mode 100644 index 000000000..a75c0ea05 --- /dev/null +++ b/util/src/schemas/MemberChangeSchema.ts @@ -0,0 +1,4 @@ + +export interface MemberChangeSchema { + roles?: string[]; +} diff --git a/util/src/schemas/MemberNickChangeSchema.ts b/util/src/schemas/MemberNickChangeSchema.ts new file mode 100644 index 000000000..e6a6a0070 --- /dev/null +++ b/util/src/schemas/MemberNickChangeSchema.ts @@ -0,0 +1,4 @@ + +export interface MemberNickChangeSchema { + nick: string; +} diff --git a/util/src/schemas/MessageAcknowledgeSchema.ts b/util/src/schemas/MessageAcknowledgeSchema.ts new file mode 100644 index 000000000..3f4eb2b62 --- /dev/null +++ b/util/src/schemas/MessageAcknowledgeSchema.ts @@ -0,0 +1,8 @@ +// TODO: public read receipts & privacy scoping +// TODO: send read state event to all channel members +// TODO: advance-only notification cursor + +export interface MessageAcknowledgeSchema { + manual?: boolean; + mention_count?: number; +} diff --git a/util/src/schemas/MessageCreateSchema.ts b/util/src/schemas/MessageCreateSchema.ts new file mode 100644 index 000000000..7b1cc7b99 --- /dev/null +++ b/util/src/schemas/MessageCreateSchema.ts @@ -0,0 +1,34 @@ +import { Embed } from "@fosscord/util"; + + +export interface MessageCreateSchema { + type?: number; + content?: string; + nonce?: string; + channel_id?: string; + tts?: boolean; + flags?: string; + embeds?: Embed[]; + embed?: Embed; + // TODO: ^ embed is deprecated in favor of embeds (https://discord.com/developers/docs/resources/channel#message-object) + allowed_mentions?: { + parse?: string[]; + roles?: string[]; + users?: string[]; + replied_user?: boolean; + }; + message_reference?: { + message_id: string; + channel_id: string; + guild_id?: string; + fail_if_not_exists?: boolean; + }; + payload_json?: string; + file?: any; + /** + TODO: we should create an interface for attachments + TODO: OpenWAAO<-->attachment-style metadata conversion + **/ + attachments?: any[]; + sticker_ids?: string[]; +} diff --git a/util/src/schemas/MfaCodesSchema.ts b/util/src/schemas/MfaCodesSchema.ts new file mode 100644 index 000000000..53230841f --- /dev/null +++ b/util/src/schemas/MfaCodesSchema.ts @@ -0,0 +1,5 @@ + +export interface MfaCodesSchema { + password: string; + regenerate?: boolean; +} diff --git a/util/src/schemas/ModifyGuildStickerSchema.ts b/util/src/schemas/ModifyGuildStickerSchema.ts new file mode 100644 index 000000000..6f24e4cea --- /dev/null +++ b/util/src/schemas/ModifyGuildStickerSchema.ts @@ -0,0 +1,16 @@ + +export interface ModifyGuildStickerSchema { + /** + * @minLength 2 + * @maxLength 30 + */ + name: string; + /** + * @maxLength 100 + */ + description?: string; + /** + * @maxLength 200 + */ + tags: string; +} diff --git a/util/src/schemas/PruneSchema.ts b/util/src/schemas/PruneSchema.ts new file mode 100644 index 000000000..eebac7635 --- /dev/null +++ b/util/src/schemas/PruneSchema.ts @@ -0,0 +1,7 @@ + +export interface PruneSchema { + /** + * @min 0 + */ + days: number; +} diff --git a/util/src/schemas/PurgeSchema.ts b/util/src/schemas/PurgeSchema.ts new file mode 100644 index 000000000..0eeef6f22 --- /dev/null +++ b/util/src/schemas/PurgeSchema.ts @@ -0,0 +1,5 @@ + +export interface PurgeSchema { + before: string; + after: string; +} diff --git a/util/src/schemas/RegisterSchema.ts b/util/src/schemas/RegisterSchema.ts new file mode 100644 index 000000000..e53330d2c --- /dev/null +++ b/util/src/schemas/RegisterSchema.ts @@ -0,0 +1,27 @@ + +export interface RegisterSchema { + /** + * @minLength 2 + * @maxLength 32 + */ + username: string; + /** + * @minLength 1 + * @maxLength 72 + */ + password?: string; + consent: boolean; + /** + * @TJS-format email + */ + email?: string; + fingerprint?: string; + invite?: string; + /** + * @TJS-type string + */ + date_of_birth?: Date; // "2000-04-03" + gift_code_sku_id?: string; + captcha_key?: string; + promotional_email_opt_in?: boolean; +} diff --git a/util/src/schemas/RelationshipPostSchema.ts b/util/src/schemas/RelationshipPostSchema.ts new file mode 100644 index 000000000..400937008 --- /dev/null +++ b/util/src/schemas/RelationshipPostSchema.ts @@ -0,0 +1,5 @@ + +export interface RelationshipPostSchema { + discriminator: string; + username: string; +} diff --git a/util/src/schemas/RelationshipPutSchema.ts b/util/src/schemas/RelationshipPutSchema.ts new file mode 100644 index 000000000..f46966e01 --- /dev/null +++ b/util/src/schemas/RelationshipPutSchema.ts @@ -0,0 +1,6 @@ +import { RelationshipType } from "@fosscord/util"; + + +export interface RelationshipPutSchema { + type?: RelationshipType; +} diff --git a/util/src/schemas/RoleModifySchema.ts b/util/src/schemas/RoleModifySchema.ts new file mode 100644 index 000000000..d08a50222 --- /dev/null +++ b/util/src/schemas/RoleModifySchema.ts @@ -0,0 +1,11 @@ + +export interface RoleModifySchema { + name?: string; + permissions?: string; + color?: number; + hoist?: boolean; // whether the role should be displayed separately in the sidebar + mentionable?: boolean; // whether the role should be mentionable + position?: number; + icon?: string; + unicode_emoji?: string; +} diff --git a/util/src/schemas/TemplateCreateSchema.ts b/util/src/schemas/TemplateCreateSchema.ts new file mode 100644 index 000000000..72c19f681 --- /dev/null +++ b/util/src/schemas/TemplateCreateSchema.ts @@ -0,0 +1,5 @@ + +export interface TemplateCreateSchema { + name: string; + description?: string; +} diff --git a/util/src/schemas/TemplateModifySchema.ts b/util/src/schemas/TemplateModifySchema.ts new file mode 100644 index 000000000..2231a1d2a --- /dev/null +++ b/util/src/schemas/TemplateModifySchema.ts @@ -0,0 +1,5 @@ + +export interface TemplateModifySchema { + name: string; + description?: string; +} diff --git a/util/src/schemas/TotpDisableSchema.ts b/util/src/schemas/TotpDisableSchema.ts new file mode 100644 index 000000000..b73db64e5 --- /dev/null +++ b/util/src/schemas/TotpDisableSchema.ts @@ -0,0 +1,4 @@ + +export interface TotpDisableSchema { + code: string; +} diff --git a/util/src/schemas/TotpEnableSchema.ts b/util/src/schemas/TotpEnableSchema.ts new file mode 100644 index 000000000..44d9ebac5 --- /dev/null +++ b/util/src/schemas/TotpEnableSchema.ts @@ -0,0 +1,6 @@ + +export interface TotpEnableSchema { + password: string; + code?: string; + secret?: string; +} diff --git a/util/src/schemas/TotpSchema.ts b/util/src/schemas/TotpSchema.ts new file mode 100644 index 000000000..fe54735ea --- /dev/null +++ b/util/src/schemas/TotpSchema.ts @@ -0,0 +1,7 @@ + +export interface TotpSchema { + code: string; + ticket: string; + gift_code_sku_id?: string | null; + login_source?: string | null; +} diff --git a/util/src/schemas/UserModifySchema.ts b/util/src/schemas/UserModifySchema.ts new file mode 100644 index 000000000..659f5841d --- /dev/null +++ b/util/src/schemas/UserModifySchema.ts @@ -0,0 +1,19 @@ + +export interface UserModifySchema { + /** + * @minLength 1 + * @maxLength 100 + */ + username?: string; + discriminator?: string; + avatar?: string | null; + /** + * @maxLength 1024 + */ + bio?: string; + accent_color?: number; + banner?: string | null; + password?: string; + new_password?: string; + code?: string; +} diff --git a/util/src/schemas/UserSettingsSchema.ts b/util/src/schemas/UserSettingsSchema.ts new file mode 100644 index 000000000..b497dff23 --- /dev/null +++ b/util/src/schemas/UserSettingsSchema.ts @@ -0,0 +1,4 @@ +import { UserSettings } from "@fosscord/util"; + + +export interface UserSettingsSchema extends Partial { } diff --git a/util/src/schemas/VanityUrlSchema.ts b/util/src/schemas/VanityUrlSchema.ts new file mode 100644 index 000000000..de32695ab --- /dev/null +++ b/util/src/schemas/VanityUrlSchema.ts @@ -0,0 +1,8 @@ + +export interface VanityUrlSchema { + /** + * @minLength 1 + * @maxLength 20 + */ + code?: string; +} diff --git a/util/src/schemas/VoiceStateUpdateSchema.ts b/util/src/schemas/VoiceStateUpdateSchema.ts new file mode 100644 index 000000000..02bb141ba --- /dev/null +++ b/util/src/schemas/VoiceStateUpdateSchema.ts @@ -0,0 +1,18 @@ +export const VoiceStateUpdateSchema = { + $guild_id: String, + $channel_id: String, + self_mute: Boolean, + self_deaf: Boolean, + self_video: Boolean, +}; + +//TODO need more testing when community guild and voice stage channel are working +export interface VoiceStateUpdateSchema { + channel_id: string; + guild_id?: string; + suppress?: boolean; + request_to_speak_timestamp?: Date; + self_mute?: boolean; + self_deaf?: boolean; + self_video?: boolean; +} \ No newline at end of file diff --git a/util/src/schemas/WebhookCreateSchema.ts b/util/src/schemas/WebhookCreateSchema.ts new file mode 100644 index 000000000..12ab18696 --- /dev/null +++ b/util/src/schemas/WebhookCreateSchema.ts @@ -0,0 +1,8 @@ +// TODO: webhooks +export interface WebhookCreateSchema { + /** + * @maxLength 80 + */ + name: string; + avatar?: string; +} diff --git a/util/src/schemas/WidgetModifySchema.ts b/util/src/schemas/WidgetModifySchema.ts new file mode 100644 index 000000000..390efc307 --- /dev/null +++ b/util/src/schemas/WidgetModifySchema.ts @@ -0,0 +1,5 @@ + +export interface WidgetModifySchema { + enabled: boolean; // whether the widget is enabled + channel_id: string; // the widget channel id +} diff --git a/util/src/schemas/index.ts b/util/src/schemas/index.ts new file mode 100644 index 000000000..f54ae8406 --- /dev/null +++ b/util/src/schemas/index.ts @@ -0,0 +1,41 @@ +export * from "./ActivitySchema"; +export * from "./BanCreateSchema"; +export * from "./BanModeratorSchema"; +export * from "./BanRegistrySchema"; +export * from "./BulkDeleteSchema"; +export * from "./ChannelModifySchema"; +export * from "./ChannelPermissionOverwriteSchema"; +export * from "./DmChannelCreateSchema"; +export * from "./EmojiCreateSchema"; +export * from "./EmojiModifySchema"; +export * from "./GuildCreateSchema"; +export * from "./GuildTemplateCreateSchema"; +export * from "./GuildUpdateSchema"; +export * from "./GuildUpdateWelcomeScreenSchema"; +export * from "./IdentifySchema"; +export * from "./InviteCreateSchema"; +export * from "./LazyRequestSchema"; +export * from "./LoginSchema"; +export * from "./MemberChangeSchema"; +export * from "./MemberNickChangeSchema"; +export * from "./MessageAcknowledgeSchema"; +export * from "./MessageCreateSchema"; +export * from "./MfaCodesSchema"; +export * from "./ModifyGuildStickerSchema"; +export * from "./PruneSchema"; +export * from "./PurgeSchema"; +export * from "./RegisterSchema"; +export * from "./RelationshipPostSchema"; +export * from "./RelationshipPutSchema"; +export * from "./RoleModifySchema"; +export * from "./TemplateCreateSchema"; +export * from "./TemplateModifySchema"; +export * from "./TotpDisableSchema"; +export * from "./TotpEnableSchema"; +export * from "./TotpSchema"; +export * from "./UserModifySchema"; +export * from "./UserSettingsSchema"; +export * from "./VanityUrlSchema"; +export * from "./VoiceStateUpdateSchema"; +export * from "./WebhookCreateSchema"; +export * from "./WidgetModifySchema"; diff --git a/util/src/util/Config.ts b/util/src/util/Config.ts index 0b55ca4b0..e0fb2a810 100644 --- a/util/src/util/Config.ts +++ b/util/src/util/Config.ts @@ -60,8 +60,11 @@ function applyConfig(val: ConfigValue) { pair.value = obj; return pair.save(); } - if(process.env.CONFIG_PATH) + if(process.env.CONFIG_PATH) { + if(/--debug|--inspect/.test(process.execArgv.join(' '))) + console.log(`Writing config: ${process.env.CONFIG_PATH}`) fs.writeFileSync(overridePath, JSON.stringify(val, null, 4)); + } return apply(val); } From 1f4ba6395bf96237fd8b638fd70926b887b9c374 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 11:42:34 +0200 Subject: [PATCH 211/238] Forgot some schemas, removed no longer used paths from generate schema script --- api/assets/schemas.json | 563 ++++++------------ api/scripts/generate_schema.js | 5 +- api/src/routes/guilds/#guild_id/channels.ts | 4 +- .../routes/guilds/#guild_id/roles/index.ts | 8 +- util/src/schemas/ChannelReorderSchema.ts | 1 + util/src/schemas/RolePositionUpdateSchema.ts | 4 + util/src/schemas/index.ts | 2 + 7 files changed, 204 insertions(+), 383 deletions(-) create mode 100644 util/src/schemas/ChannelReorderSchema.ts create mode 100644 util/src/schemas/RolePositionUpdateSchema.ts diff --git a/api/assets/schemas.json b/api/assets/schemas.json index f102f9d02..9286b8046 100644 --- a/api/assets/schemas.json +++ b/api/assets/schemas.json @@ -98,175 +98,27 @@ ], "$schema": "http://json-schema.org/draft-07/schema#" }, - "ActivitySchema": { + "RouteResponse": { "type": "object", "properties": { - "afk": { - "type": "boolean" - }, "status": { - "$ref": "#/definitions/Status" + "type": "integer" }, - "activities": { + "body": { "type": "array", "items": { - "$ref": "#/definitions/Activity" + "type": "string" } }, - "since": { - "type": "integer" + "headers": { + "$ref": "#/definitions/Record" } }, "additionalProperties": false, - "required": [ - "afk", - "status" - ], "definitions": { - "Status": { - "enum": [ - "dnd", - "idle", - "invisible", - "offline", - "online" - ], - "type": "string" - }, - "Activity": { + "Record": { "type": "object", - "properties": { - "name": { - "type": "string" - }, - "type": { - "$ref": "#/definitions/ActivityType" - }, - "url": { - "type": "string" - }, - "created_at": { - "type": "integer" - }, - "timestamps": { - "type": "object", - "properties": { - "start": { - "type": "integer" - }, - "end": { - "type": "integer" - } - }, - "additionalProperties": false, - "required": [ - "end", - "start" - ] - }, - "application_id": { - "type": "string" - }, - "details": { - "type": "string" - }, - "state": { - "type": "string" - }, - "emoji": { - "type": "object", - "properties": { - "name": { - "type": "string" - }, - "id": { - "type": "string" - }, - "animated": { - "type": "boolean" - } - }, - "additionalProperties": false, - "required": [ - "animated", - "name" - ] - }, - "party": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "size": { - "type": "array", - "items": [ - { - "type": "integer" - } - ], - "minItems": 1, - "maxItems": 1 - } - }, - "additionalProperties": false - }, - "assets": { - "type": "object", - "properties": { - "large_image": { - "type": "string" - }, - "large_text": { - "type": "string" - }, - "small_image": { - "type": "string" - }, - "small_text": { - "type": "string" - } - }, - "additionalProperties": false - }, - "secrets": { - "type": "object", - "properties": { - "join": { - "type": "string" - }, - "spectate": { - "type": "string" - }, - "match": { - "type": "string" - } - }, - "additionalProperties": false - }, - "instance": { - "type": "boolean" - }, - "flags": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "flags", - "name", - "type" - ] - }, - "ActivityType": { - "enum": [ - 0, - 1, - 2, - 4, - 5 - ], - "type": "number" + "additionalProperties": false } }, "$schema": "http://json-schema.org/draft-07/schema#" @@ -510,6 +362,31 @@ }, "$schema": "http://json-schema.org/draft-07/schema#" }, + "ChannelReorderSchema": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "position": { + "type": "integer" + }, + "lock_permissions": { + "type": "boolean" + }, + "parent_id": { + "type": "string" + } + }, + "additionalProperties": false, + "required": [ + "id" + ] + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, "DmChannelCreateSchema": { "type": "object", "properties": { @@ -1678,6 +1555,26 @@ "additionalProperties": false, "$schema": "http://json-schema.org/draft-07/schema#" }, + "RolePositionUpdateSchema": { + "type": "array", + "items": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "position": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "id", + "position" + ] + }, + "$schema": "http://json-schema.org/draft-07/schema#" + }, "TemplateCreateSchema": { "type": "object", "properties": { @@ -2111,253 +2008,177 @@ ], "$schema": "http://json-schema.org/draft-07/schema#" }, - "RouteResponse": { + "ActivitySchema": { "type": "object", "properties": { - "status": { - "type": "integer" + "afk": { + "type": "boolean" }, - "body": { + "status": { + "$ref": "#/definitions/Status" + }, + "activities": { "type": "array", "items": { - "type": "string" + "$ref": "#/definitions/Activity" } }, - "headers": { - "$ref": "#/definitions/Record" - } - }, - "additionalProperties": false, - "definitions": { - "Record": { - "type": "object", - "additionalProperties": false - } - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GatewayBotResponse": { - "type": "object", - "properties": { - "url": { - "type": "string" - }, - "shards": { + "since": { "type": "integer" - }, - "session_start_limit": { - "type": "object", - "properties": { - "total": { - "type": "integer" - }, - "remaining": { - "type": "integer" - }, - "reset_after": { - "type": "integer" - }, - "max_concurrency": { - "type": "integer" - } - }, - "additionalProperties": false, - "required": [ - "max_concurrency", - "remaining", - "reset_after", - "total" - ] } }, "additionalProperties": false, "required": [ - "session_start_limit", - "shards", - "url" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "GatewayResponse": { - "type": "object", - "properties": { - "url": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "url" - ], - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "ChannelReorderSchema": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "position": { - "type": "integer" - }, - "lock_permissions": { - "type": "boolean" - }, - "parent_id": { - "type": "string" - } - }, - "additionalProperties": false, - "required": [ - "id" - ] - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "RolePositionUpdateSchema": { - "type": "array", - "items": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "position": { - "type": "integer" - } - }, - "additionalProperties": false, - "required": [ - "id", - "position" - ] - }, - "$schema": "http://json-schema.org/draft-07/schema#" - }, - "UserProfileResponse": { - "type": "object", - "properties": { - "user": { - "$ref": "#/definitions/UserPublic" - }, - "connected_accounts": { - "$ref": "#/definitions/PublicConnectedAccount" - }, - "premium_guild_since": { - "type": "string", - "format": "date-time" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "connected_accounts", - "user" + "afk", + "status" ], "definitions": { - "UserPublic": { - "type": "object", - "properties": { - "username": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "id": { - "type": "string" - }, - "public_flags": { - "type": "integer" - }, - "avatar": { - "type": "string" - }, - "accent_color": { - "type": "integer" - }, - "banner": { - "type": "string" - }, - "bio": { - "type": "string" - }, - "bot": { - "type": "boolean" - }, - "premium_since": { - "type": "string", - "format": "date-time" - } - }, - "additionalProperties": false, - "required": [ - "bio", - "bot", - "discriminator", - "id", - "premium_since", - "public_flags", - "username" - ] + "Status": { + "enum": [ + "dnd", + "idle", + "invisible", + "offline", + "online" + ], + "type": "string" }, - "PublicConnectedAccount": { + "Activity": { "type": "object", "properties": { "name": { "type": "string" }, "type": { + "$ref": "#/definitions/ActivityType" + }, + "url": { "type": "string" }, - "verified": { + "created_at": { + "type": "integer" + }, + "timestamps": { + "type": "object", + "properties": { + "start": { + "type": "integer" + }, + "end": { + "type": "integer" + } + }, + "additionalProperties": false, + "required": [ + "end", + "start" + ] + }, + "application_id": { + "type": "string" + }, + "details": { + "type": "string" + }, + "state": { + "type": "string" + }, + "emoji": { + "type": "object", + "properties": { + "name": { + "type": "string" + }, + "id": { + "type": "string" + }, + "animated": { + "type": "boolean" + } + }, + "additionalProperties": false, + "required": [ + "animated", + "name" + ] + }, + "party": { + "type": "object", + "properties": { + "id": { + "type": "string" + }, + "size": { + "type": "array", + "items": [ + { + "type": "integer" + } + ], + "minItems": 1, + "maxItems": 1 + } + }, + "additionalProperties": false + }, + "assets": { + "type": "object", + "properties": { + "large_image": { + "type": "string" + }, + "large_text": { + "type": "string" + }, + "small_image": { + "type": "string" + }, + "small_text": { + "type": "string" + } + }, + "additionalProperties": false + }, + "secrets": { + "type": "object", + "properties": { + "join": { + "type": "string" + }, + "spectate": { + "type": "string" + }, + "match": { + "type": "string" + } + }, + "additionalProperties": false + }, + "instance": { "type": "boolean" + }, + "flags": { + "type": "string" } }, "additionalProperties": false, "required": [ + "flags", "name", - "type", - "verified" + "type" ] + }, + "ActivityType": { + "enum": [ + 0, + 1, + 2, + 4, + 5 + ], + "type": "number" } }, "$schema": "http://json-schema.org/draft-07/schema#" - }, - "UserRelationsResponse": { - "type": "object", - "properties": { - "object": { - "type": "object", - "properties": { - "id": { - "type": "string" - }, - "username": { - "type": "string" - }, - "avatar": { - "type": "string" - }, - "discriminator": { - "type": "string" - }, - "public_flags": { - "type": "integer" - } - }, - "additionalProperties": false - } - }, - "additionalProperties": false, - "required": [ - "object" - ], - "$schema": "http://json-schema.org/draft-07/schema#" } } \ No newline at end of file diff --git a/api/scripts/generate_schema.js b/api/scripts/generate_schema.js index 7a498ad67..1badfd326 100644 --- a/api/scripts/generate_schema.js +++ b/api/scripts/generate_schema.js @@ -48,9 +48,8 @@ function modify(obj) { } function main() { - const files = [ - ...walk(path.join(__dirname, "..", "src", "routes")), - ...walk(path.join(__dirname, "..", "..", "util", "src")), + const files = [ + ...walk(path.join(__dirname, "..", "..", "util", "src", "schemas")), ]; const program = TJS.getProgramFromFiles( files, diff --git a/api/src/routes/guilds/#guild_id/channels.ts b/api/src/routes/guilds/#guild_id/channels.ts index df1b79242..8f2d36436 100644 --- a/api/src/routes/guilds/#guild_id/channels.ts +++ b/api/src/routes/guilds/#guild_id/channels.ts @@ -1,5 +1,5 @@ import { Router, Response, Request } from "express"; -import { Channel, ChannelUpdateEvent, getPermission, emitEvent, ChannelModifySchema } from "@fosscord/util"; +import { Channel, ChannelUpdateEvent, getPermission, emitEvent, ChannelModifySchema, ChannelReorderSchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; const router = Router(); @@ -21,8 +21,6 @@ router.post("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANNE res.status(201).json(channel); }); -export type ChannelReorderSchema = { id: string; position?: number; lock_permissions?: boolean; parent_id?: string }[]; - router.patch("/", route({ body: "ChannelReorderSchema", permission: "MANAGE_CHANNELS" }), async (req: Request, res: Response) => { // changes guild channel position const { guild_id } = req.params; diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index effa4fcde..17f0b5e98 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -10,7 +10,8 @@ import { Config, DiscordApiErrors, handleFile, - RoleModifySchema + RoleModifySchema, + RolePositionUpdateSchema } from "@fosscord/util"; import { HTTPError } from "@fosscord/util"; import { route } from "@fosscord/api"; @@ -18,11 +19,6 @@ import { OrmUtils } from "@fosscord/util"; const router: Router = Router(); -export type RolePositionUpdateSchema = { - id: string; - position: number; -}[]; - router.get("/", route({}), async (req: Request, res: Response) => { const guild_id = req.params.guild_id; diff --git a/util/src/schemas/ChannelReorderSchema.ts b/util/src/schemas/ChannelReorderSchema.ts new file mode 100644 index 000000000..3715f59e1 --- /dev/null +++ b/util/src/schemas/ChannelReorderSchema.ts @@ -0,0 +1 @@ +export type ChannelReorderSchema = { id: string; position?: number; lock_permissions?: boolean; parent_id?: string }[]; \ No newline at end of file diff --git a/util/src/schemas/RolePositionUpdateSchema.ts b/util/src/schemas/RolePositionUpdateSchema.ts new file mode 100644 index 000000000..1019d5043 --- /dev/null +++ b/util/src/schemas/RolePositionUpdateSchema.ts @@ -0,0 +1,4 @@ +export type RolePositionUpdateSchema = { + id: string; + position: number; +}[]; \ No newline at end of file diff --git a/util/src/schemas/index.ts b/util/src/schemas/index.ts index f54ae8406..a15ab4b09 100644 --- a/util/src/schemas/index.ts +++ b/util/src/schemas/index.ts @@ -5,6 +5,7 @@ export * from "./BanRegistrySchema"; export * from "./BulkDeleteSchema"; export * from "./ChannelModifySchema"; export * from "./ChannelPermissionOverwriteSchema"; +export * from "./ChannelReorderSchema"; export * from "./DmChannelCreateSchema"; export * from "./EmojiCreateSchema"; export * from "./EmojiModifySchema"; @@ -28,6 +29,7 @@ export * from "./RegisterSchema"; export * from "./RelationshipPostSchema"; export * from "./RelationshipPutSchema"; export * from "./RoleModifySchema"; +export * from "./RolePositionUpdateSchema"; export * from "./TemplateCreateSchema"; export * from "./TemplateModifySchema"; export * from "./TotpDisableSchema"; From a10891a5a71d24edf86524a2d702251d9f1b69ee Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 12:46:01 +0200 Subject: [PATCH 212/238] Replace deprecated property --- api/src/start.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/api/src/start.ts b/api/src/start.ts index 9ba198e72..98beb1fa8 100644 --- a/api/src/start.ts +++ b/api/src/start.ts @@ -13,7 +13,7 @@ try { console.log("[API] Failed to get thread count! Using 1...") } -if (cluster.isMaster && process.env.NODE_ENV == "production") { +if (cluster.isPrimary && process.env.NODE_ENV == "production") { console.log(`Primary ${process.pid} is running`); // Fork workers. From 0b401956f528c89ec60166c69b0775845c541178 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Wed, 10 Aug 2022 04:31:11 +0200 Subject: [PATCH 213/238] Add template plugin base --- api/src/plugins/example-plugin/index.ts | 0 api/src/plugins/example-plugin/plugin.json | 8 ++++++++ 2 files changed, 8 insertions(+) create mode 100644 api/src/plugins/example-plugin/index.ts create mode 100644 api/src/plugins/example-plugin/plugin.json diff --git a/api/src/plugins/example-plugin/index.ts b/api/src/plugins/example-plugin/index.ts new file mode 100644 index 000000000..e69de29bb diff --git a/api/src/plugins/example-plugin/plugin.json b/api/src/plugins/example-plugin/plugin.json new file mode 100644 index 000000000..8d98276c9 --- /dev/null +++ b/api/src/plugins/example-plugin/plugin.json @@ -0,0 +1,8 @@ +{ + "name": "Fosscord example plugin", + "authors": [ + "The Arcane Brony" + ], + "repository": "https://github.com/fosscord/fosscord-server", + "license": "" +} \ No newline at end of file From b1b9cf7333dca01fd454fedc2b3d6e99066f53b8 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Fri, 12 Aug 2022 23:52:43 +0200 Subject: [PATCH 214/238] Add test plugin --- api/src/plugins/example-plugin/index.ts | 0 bundle/src/Server.ts | 2 + fosscord-server.code-workspace | 37 +++++--- plugins/example-plugin/build.sh | 8 ++ plugins/example-plugin/index.ts | 7 ++ .../example-plugin/plugin.json | 3 +- plugins/example-plugin/tsconfig.json | 85 +++++++++++++++++++ 7 files changed, 130 insertions(+), 12 deletions(-) delete mode 100644 api/src/plugins/example-plugin/index.ts create mode 100755 plugins/example-plugin/build.sh create mode 100644 plugins/example-plugin/index.ts rename {api/src/plugins => plugins}/example-plugin/plugin.json (85%) create mode 100644 plugins/example-plugin/tsconfig.json diff --git a/api/src/plugins/example-plugin/index.ts b/api/src/plugins/example-plugin/index.ts deleted file mode 100644 index e69de29bb..000000000 diff --git a/bundle/src/Server.ts b/bundle/src/Server.ts index 3ed98b153..165ab1212 100644 --- a/bundle/src/Server.ts +++ b/bundle/src/Server.ts @@ -10,6 +10,7 @@ import { green, bold, yellow } from "picocolors"; import { Config, getOrInitialiseDatabase } from "@fosscord/util"; import * as Sentry from "@sentry/node"; import * as Tracing from "@sentry/tracing"; +import { PluginLoader } from "@fosscord/util"; const app = express(); const server = http.createServer(); @@ -94,6 +95,7 @@ async function main() { }); } console.log(`[Server] ${green(`listening on port ${bold(port)}`)}`); + PluginLoader.loadPlugins(); } main().catch(console.error); diff --git a/fosscord-server.code-workspace b/fosscord-server.code-workspace index 7491cb358..4a7440f67 100644 --- a/fosscord-server.code-workspace +++ b/fosscord-server.code-workspace @@ -1,28 +1,43 @@ { "folders": [ - { - "path": "api" - }, - { - "path": "dashboard" - }, { "path": "bundle" }, + { + "path": "api" + }, { "path": "cdn" }, { "path": "gateway" }, - { - "path": "rtc" - }, { "path": "util" }, { - "path": "webrtc" + "path": "plugins" } - ] + ], + "settings": { + "files.exclude": { + ".gitignore": true, + ".npmignore": true, + ".prettierrc": true, + ".vscode": true, + "*.ansi": true, + "benchmarks": true, + "database.db": true, + "files/": true, + "jest": true, + "locales/[!e]*": true, + "locales/e[!n]*": true, + "node_modules": true, + "package-lock.json": true, + "patches": true, + "README.md": true, + "tests/": true, + "tsconfig.tsbuildinfo": true + } + } } diff --git a/plugins/example-plugin/build.sh b/plugins/example-plugin/build.sh new file mode 100755 index 000000000..cf8463edb --- /dev/null +++ b/plugins/example-plugin/build.sh @@ -0,0 +1,8 @@ +#rm -rf dist/ +#mkdir dist +rm -rfv *.js *.js.map +ln -s ../../bundle/node_modules node_modules +mkdir -p ../../node_modules/@fosscord +ln -s ../../util ../../node_modules/@fosscord/util +ln -s ../../api ../../node_modules/@fosscord/api +tsc -p . diff --git a/plugins/example-plugin/index.ts b/plugins/example-plugin/index.ts new file mode 100644 index 000000000..ec1ed7b50 --- /dev/null +++ b/plugins/example-plugin/index.ts @@ -0,0 +1,7 @@ +import { Plugin } from "@fosscord/util" + +export default class TestPlugin extends Plugin { + onPluginLoaded(): void { + console.log("Hello from test plugin! IT WORKS!!!!!!!"); + } +} \ No newline at end of file diff --git a/api/src/plugins/example-plugin/plugin.json b/plugins/example-plugin/plugin.json similarity index 85% rename from api/src/plugins/example-plugin/plugin.json rename to plugins/example-plugin/plugin.json index 8d98276c9..980edbdf0 100644 --- a/api/src/plugins/example-plugin/plugin.json +++ b/plugins/example-plugin/plugin.json @@ -1,8 +1,9 @@ { + "id": "example-plugin", "name": "Fosscord example plugin", "authors": [ "The Arcane Brony" ], "repository": "https://github.com/fosscord/fosscord-server", "license": "" -} \ No newline at end of file +} diff --git a/plugins/example-plugin/tsconfig.json b/plugins/example-plugin/tsconfig.json new file mode 100644 index 000000000..5ff9e607d --- /dev/null +++ b/plugins/example-plugin/tsconfig.json @@ -0,0 +1,85 @@ +{ + "include": ["./**/*.ts"], + "exclude": [], + "compilerOptions": { + + /* Basic Options */ + "incremental": false /* Enable incremental compilation */, + "target": "ESNext" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, + "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, + "lib": [ + "ESNext" + ] /* Specify library files to be included in the compilation. */, + "allowJs": true /* Allow javascript files to be compiled. */, + "checkJs": true /* Report errors in .js files. */, + // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ + "declaration": false /* Generates corresponding '.d.ts' file. */, + "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, + "sourceMap": true /* Generates corresponding '.map' file. */, + // "outFile": "./", /* Concatenate and emit output to single file. */ + "outDir": "./dist/" /* Redirect output structure to the directory. */, + "rootDir": "./" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, + // "composite": true, /* Enable project compilation */ + // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ + // "removeComments": true, /* Do not emit comments to output. */ + // "noEmit": true, /* Do not emit outputs. */ + // "importHelpers": true, /* Import emit helpers from 'tslib'. */ + // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ + // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ + + /* Strict Type-Checking Options */ + "strict": true /* Enable all strict type-checking options. */, + "noImplicitAny": true /* Raise error on expressions and declarations with an implied 'any' type. */, + "strictNullChecks": true /* Enable strict null checks. */, + // "strictFunctionTypes": true, /* Enable strict checking of function types. */ + // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ + "strictPropertyInitialization": false /* Enable strict checking of property initialization in classes. */, + // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ + "alwaysStrict": true /* Parse in strict mode and emit "use strict" for each source file. */, + + /* Additional Checks */ + // "noUnusedLocals": true, /* Report errors on unused locals. */ + // "noUnusedParameters": true, /* Report errors on unused parameters. */ + // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ + // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ + + /* Module Resolution Options */ + "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ + // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ + // "typeRoots": [], /* List of folders to include type definitions from. */ + "types": [ + "node" + ] /* Type declaration files to be included in compilation. */, + // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ + "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, + // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ + // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ + + /* Source Map Options */ + // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ + // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ + // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ + // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ + + /* Experimental Options */ + // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ + // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ + + /* Advanced Options */ + "skipLibCheck": true /* Skip type checking of declaration files. */, + "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */, + "emitDecoratorMetadata": true, + "experimentalDecorators": true, + "resolveJsonModule": true, + "baseUrl": "../../", + "paths": { + "@fosscord/api": ["../../api/src/index"], + "@fosscord/gateway": ["../../gateway/src/index"], + "@fosscord/cdn": ["../../cdn/src/index"], + "@fosscord/util": ["../../util/src/index"] + }, + "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }], + "noEmitHelpers": true, + "importHelpers": true + } +} From 5abd6bb7e010f0ed05b086d45b06bbed76bc5f57 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 13 Aug 2022 00:03:27 +0200 Subject: [PATCH 215/238] try to update build script --- plugins/example-plugin/build.sh | 3 --- plugins/example-plugin/tsconfig.json | 2 +- 2 files changed, 1 insertion(+), 4 deletions(-) diff --git a/plugins/example-plugin/build.sh b/plugins/example-plugin/build.sh index cf8463edb..1b36607b5 100755 --- a/plugins/example-plugin/build.sh +++ b/plugins/example-plugin/build.sh @@ -2,7 +2,4 @@ #mkdir dist rm -rfv *.js *.js.map ln -s ../../bundle/node_modules node_modules -mkdir -p ../../node_modules/@fosscord -ln -s ../../util ../../node_modules/@fosscord/util -ln -s ../../api ../../node_modules/@fosscord/api tsc -p . diff --git a/plugins/example-plugin/tsconfig.json b/plugins/example-plugin/tsconfig.json index 5ff9e607d..7efe9434e 100644 --- a/plugins/example-plugin/tsconfig.json +++ b/plugins/example-plugin/tsconfig.json @@ -71,7 +71,7 @@ "emitDecoratorMetadata": true, "experimentalDecorators": true, "resolveJsonModule": true, - "baseUrl": "../../", + "baseUrl": "../../bundle/dist/", "paths": { "@fosscord/api": ["../../api/src/index"], "@fosscord/gateway": ["../../gateway/src/index"], From 5e86d7ab9c5200d794c3adb2b422d20a2aefd2ce Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 13 Aug 2022 02:00:50 +0200 Subject: [PATCH 216/238] restructure to single project --- api/.dockerignore => .dockerignore | 0 .gitignore | 2 + api/.env.example | 8 - api/.gitignore | 115 - api/.npmignore | 1 - api/.prettierrc | 6 - api/.vscode/api-snippets.code-snippets | 25 - api/.vscode/launch.json | 28 - api/Dockerfile | 12 - api/README.md | 67 - api/babel.config.js | 6 - api/jest/getRouteDescriptions.js | 66 - api/jest/globalSetup.js | 20 - api/jest/setup.js | 2 - api/package-lock.json | Bin 556574 -> 0 bytes api/package.json | 91 - api/tsconfig.json | 75 - {api/assets => assets}/checkLocale.js | 0 {api/client_test => assets}/developers.html | 0 .../dff87c953f43b561d71fbcfe8a93a79a.png | 0 {api/assets => assets}/endpoints.json | 0 {api/assets => assets}/features.json | 0 {api/assets => assets}/fosscord-login.css | 0 {api/assets => assets}/fosscord.css | 0 {api/client_test => assets}/index.html | 2 +- .../inline-plugins/autoRegister.js | 0 .../inline-plugins/fosscord-login.js | 0 {api => assets}/locales/af/auth.json | 0 {api => assets}/locales/af/common.json | 0 {api => assets}/locales/ar/auth.json | 0 {api => assets}/locales/ar/common.json | 0 {api => assets}/locales/arn/auth.json | 0 {api => assets}/locales/arn/common.json | 0 {api => assets}/locales/az/auth.json | 0 {api => assets}/locales/az/common.json | 0 {api => assets}/locales/be/auth.json | 0 {api => assets}/locales/be/common.json | 0 {api => assets}/locales/ber/auth.json | 0 {api => assets}/locales/ber/common.json | 0 {api => assets}/locales/bg/auth.json | 0 {api => assets}/locales/bg/common.json | 0 {api => assets}/locales/bo/auth.json | 0 {api => assets}/locales/bo/common.json | 0 {api => assets}/locales/ca/auth.json | 0 {api => assets}/locales/ca/common.json | 0 {api => assets}/locales/cs/auth.json | 0 {api => assets}/locales/cs/common.json | 0 {api => assets}/locales/da/auth.json | 0 {api => assets}/locales/da/common.json | 0 {api => assets}/locales/de/auth.json | 0 {api => assets}/locales/de/common.json | 0 {api => assets}/locales/el/auth.json | 0 {api => assets}/locales/el/common.json | 0 {api => assets}/locales/en/auth.json | 0 {api => assets}/locales/en/common.json | 0 {api => assets}/locales/eo/auth.json | 0 {api => assets}/locales/eo/common.json | 0 {api => assets}/locales/es/auth.json | 0 {api => assets}/locales/es/common.json | 0 {api => assets}/locales/eu/auth.json | 0 {api => assets}/locales/eu/common.json | 0 {api => assets}/locales/fa/auth.json | 0 {api => assets}/locales/fa/common.json | 0 {api => assets}/locales/fi/auth.json | 0 {api => assets}/locales/fi/common.json | 0 {api => assets}/locales/fr/auth.json | 0 {api => assets}/locales/fr/common.json | 0 {api => assets}/locales/gn/auth.json | 0 {api => assets}/locales/gn/common.json | 0 {api => assets}/locales/ha/auth.json | 0 {api => assets}/locales/ha/common.json | 0 {api => assets}/locales/he/auth.json | 0 {api => assets}/locales/he/common.json | 0 {api => assets}/locales/hi/auth.json | 0 {api => assets}/locales/hi/common.json | 0 {api => assets}/locales/hr/auth.json | 0 {api => assets}/locales/hr/common.json | 0 {api => assets}/locales/hu/auth.json | 0 {api => assets}/locales/hu/common.json | 0 {api => assets}/locales/id/auth.json | 0 {api => assets}/locales/id/common.json | 0 {api => assets}/locales/it/auth.json | 0 {api => assets}/locales/it/common.json | 0 {api => assets}/locales/ja/auth.json | 0 {api => assets}/locales/ja/common.json | 0 {api => assets}/locales/jv/auth.json | 0 {api => assets}/locales/jv/common.json | 0 {api => assets}/locales/kk/auth.json | 0 {api => assets}/locales/kk/common.json | 0 {api => assets}/locales/ko/auth.json | 0 {api => assets}/locales/ko/common.json | 0 {api => assets}/locales/ku/auth.json | 0 {api => assets}/locales/ku/common.json | 0 {api => assets}/locales/la/auth.json | 0 {api => assets}/locales/la/common.json | 0 {api => assets}/locales/lt/auth.json | 0 {api => assets}/locales/lt/common.json | 0 {api => assets}/locales/mi/auth.json | 0 {api => assets}/locales/mi/common.json | 0 {api => assets}/locales/mn/auth.json | 0 {api => assets}/locales/mn/common.json | 0 {api => assets}/locales/mr/auth.json | 0 {api => assets}/locales/mr/common.json | 0 {api => assets}/locales/nl/auth.json | 0 {api => assets}/locales/nl/common.json | 0 {api => assets}/locales/nn/auth.json | 0 {api => assets}/locales/nn/common.json | 0 {api => assets}/locales/no/auth.json | 0 {api => assets}/locales/no/common.json | 0 {api => assets}/locales/pa/auth.json | 0 {api => assets}/locales/pa/common.json | 0 {api => assets}/locales/pl/auth.json | 0 {api => assets}/locales/pl/common.json | 0 {api => assets}/locales/pt/auth.json | 0 {api => assets}/locales/pt/common.json | 0 {api => assets}/locales/qu/auth.json | 0 {api => assets}/locales/qu/common.json | 0 {api => assets}/locales/ro/auth.json | 0 {api => assets}/locales/ro/common.json | 0 {api => assets}/locales/ru/auth.json | 0 {api => assets}/locales/ru/common.json | 0 {api => assets}/locales/sh/auth.json | 0 {api => assets}/locales/sh/common.json | 0 {api => assets}/locales/si/auth.json | 0 {api => assets}/locales/si/common.json | 0 {api => assets}/locales/sk/auth.json | 0 {api => assets}/locales/sk/common.json | 0 {api => assets}/locales/sr/auth.json | 0 {api => assets}/locales/sr/common.json | 0 {api => assets}/locales/sv/auth.json | 0 {api => assets}/locales/sv/common.json | 0 {api => assets}/locales/sw/auth.json | 0 {api => assets}/locales/sw/common.json | 0 {api => assets}/locales/ta/auth.json | 0 {api => assets}/locales/ta/common.json | 0 {api => assets}/locales/te/auth.json | 0 {api => assets}/locales/te/common.json | 0 {api => assets}/locales/tl/auth.json | 0 {api => assets}/locales/tl/common.json | 0 {api => assets}/locales/tr/auth.json | 0 {api => assets}/locales/tr/common.json | 0 {api => assets}/locales/ug/auth.json | 0 {api => assets}/locales/ug/common.json | 0 {api => assets}/locales/uk/auth.json | 0 {api => assets}/locales/uk/common.json | 0 {api => assets}/locales/ur/auth.json | 0 {api => assets}/locales/ur/common.json | 0 {api => assets}/locales/vec/auth.json | 0 {api => assets}/locales/vec/common.json | 0 {api => assets}/locales/vi/auth.json | 0 {api => assets}/locales/vi/common.json | 0 {api => assets}/locales/zh/auth.json | 0 {api => assets}/locales/zh/common.json | 0 {api/assets => assets}/openapi.json | Bin {api/assets => assets}/plugins/.gitkeep | 0 .../preload-plugins/.gitkeep | 0 {api/assets => assets}/schemas.json | Bin 63992 -> 40574 bytes {api/assets => assets}/user.css | 0 {api/assets => assets}/widget/banner1.png | Bin {api/assets => assets}/widget/banner2.png | Bin {api/assets => assets}/widget/banner3.png | Bin {api/assets => assets}/widget/banner4.png | Bin {api/assets => assets}/widget/shield.png | Bin bundle/.prettierrc | 4 - bundle/.vscode/launch.json | 35 - bundle/package-lock.json | Bin 702083 -> 0 bytes bundle/package.json | 103 - bundle/src/stats.ts | 43 - bundle/tsnode.tsconfig.json | 15 - cdn/.env.example | 3 - cdn/.gitignore | 7 - cdn/.swcrc | 17 - cdn/Dockerfile | 7 - cdn/README.md | 112 - cdn/jest/setup.js | 2 - cdn/package-lock.json | Bin 500189 -> 0 bytes cdn/package.json | 54 - cdn/tsconfig.json | 81 - dashboard/README.md | 12 - dashboard/package-lock.json | Bin 88 -> 0 bytes dashboard/package.json | 23 - dashboard/src/index.ts | 0 gateway/.env.example | 4 - gateway/.gitignore | 107 - gateway/.swcrc | 16 - gateway/.vscode/launch.json | 17 - gateway/Dockerfile | 14 - gateway/README.md | 42 - gateway/package-lock.json | Bin 540153 -> 0 bytes gateway/package.json | 35 - gateway/tsconfig.json | 84 - package-lock.json | Bin 794026 -> 838348 bytes package.json | 94 +- {api/patches => patches}/ajv+8.6.2.patch | 0 .../typescript-json-schema+0.54.0.patch | 0 rtc/.gitignore | 145 - rtc/.npmignore | 1 - rtc/.prettierrc | 5 - rtc/CMakeLists.txt | 16 - rtc/README.md | 18 - rtc/config.json | 1 - rtc/src/main.cpp | 47 - rtc/src/mongoStub.cpp | 84 - rtc/src/mongoStub.hpp | 41 - rtc/src/rtcPeerHandler.cpp | 83 - rtc/src/rtcPeerHandler.hpp | 32 - rtc/src/rtcServer.hpp | 0 {util/scripts => scripts}/benchmark.js | 0 .../benchmark/connections.js | 0 .../scripts => scripts}/benchmark/index.js | 0 .../scripts => scripts}/benchmark/users.js | 0 {bundle/scripts => scripts}/build.js | 11 +- {bundle/scripts => scripts}/db_migrations.sh | 0 {bundle/scripts => scripts}/depcheck.js | 0 {bundle/scripts => scripts}/depclean.js | 0 {api/scripts => scripts}/droptables.sql | 0 {bundle/scripts => scripts}/gen_index.js | 0 {api/scripts => scripts}/generate_openapi.js | 0 {api/scripts => scripts}/generate_schema.js | 2 +- {bundle/scripts => scripts}/install.js | 0 .../scripts => scripts}/migrate_db_engine.js | 0 {bundle/scripts => scripts}/rights.js | 0 .../scripts => scripts}/stresstest/.gitignore | 0 .../stresstest/accounts.json.example | 0 .../stresstest/config.json.example | 0 {api/scripts => scripts}/stresstest/index.js | 0 .../stresstest/package-lock.json | Bin .../stresstest/package.json | 0 .../stresstest/src/login/index.js | 2 +- .../stresstest/src/message/send.js | 0 .../stresstest/src/register/index.js | 0 {bundle/scripts => scripts}/update_schemas.js | 0 {bundle/scripts => scripts}/utils.js | 0 {bundle/src => src}/Server.ts | 4 +- {api/src => src/api}/Server.ts | 0 {api/src => src/api}/global.d.ts | 0 {api/src => src/api}/index.ts | 0 .../api}/middlewares/Authentication.ts | 0 .../src => src/api}/middlewares/BodyParser.ts | 0 {api/src => src/api}/middlewares/CORS.ts | 0 .../api}/middlewares/ErrorHandler.ts | 0 {api/src => src/api}/middlewares/RateLimit.ts | 0 .../src => src/api}/middlewares/TestClient.ts | 16 +- .../api}/middlewares/Translation.ts | 6 +- {api/src => src/api}/middlewares/index.ts | 0 {api/src => src/api}/routes/-/healthz.ts | 0 {api/src => src/api}/routes/-/readyz.ts | 0 .../routes/applications/#id/entitlements.ts | 0 .../api}/routes/applications/detectable.ts | 0 .../api}/routes/applications/index.ts | 0 .../api}/routes/auth/location-metadata.ts | 0 {api/src => src/api}/routes/auth/login.ts | 0 {api/src => src/api}/routes/auth/mfa/totp.ts | 0 {api/src => src/api}/routes/auth/register.ts | 0 .../routes/channels/#channel_id/followers.ts | 0 .../api}/routes/channels/#channel_id/index.ts | 0 .../routes/channels/#channel_id/invites.ts | 0 .../#channel_id/messages/#message_id/ack.ts | 0 .../messages/#message_id/crosspost.ts | 0 .../#channel_id/messages/#message_id/index.ts | 0 .../messages/#message_id/reactions.ts | 0 .../#channel_id/messages/bulk-delete.ts | 2 +- .../channels/#channel_id/messages/index.ts | 0 .../channels/#channel_id/permissions.ts | 0 .../api}/routes/channels/#channel_id/pins.ts | 0 .../api}/routes/channels/#channel_id/purge.ts | 0 .../routes/channels/#channel_id/recipients.ts | 0 .../routes/channels/#channel_id/typing.ts | 0 .../routes/channels/#channel_id/webhooks.ts | 0 .../api}/routes/discoverable-guilds.ts | 0 {api/src => src/api}/routes/discovery.ts | 0 {api/src => src/api}/routes/downloads.ts | 0 {api/src => src/api}/routes/experiments.ts | 0 {api/src => src/api}/routes/gateway/bot.ts | 0 {api/src => src/api}/routes/gateway/index.ts | 0 {api/src => src/api}/routes/gifs/search.ts | 0 .../api}/routes/gifs/trending-gifs.ts | 0 {api/src => src/api}/routes/gifs/trending.ts | 0 .../api}/routes/guild-recommendations.ts | 0 .../routes/guilds/#guild_id/audit-logs.ts | 0 .../api}/routes/guilds/#guild_id/bans.ts | 0 .../api}/routes/guilds/#guild_id/channels.ts | 0 .../api}/routes/guilds/#guild_id/delete.ts | 0 .../#guild_id/discovery-requirements.ts | 0 .../api}/routes/guilds/#guild_id/emojis.ts | 0 .../api}/routes/guilds/#guild_id/index.ts | 0 .../routes/guilds/#guild_id/integrations.ts | 0 .../api}/routes/guilds/#guild_id/invites.ts | 0 .../#guild_id/members/#member_id/index.ts | 0 .../#guild_id/members/#member_id/nick.ts | 0 .../#member_id/roles/#role_id/index.ts | 0 .../routes/guilds/#guild_id/members/index.ts | 0 .../api}/routes/guilds/#guild_id/premium.ts | 0 .../api}/routes/guilds/#guild_id/prune.ts | 0 .../api}/routes/guilds/#guild_id/regions.ts | 0 .../guilds/#guild_id/roles/#role_id/index.ts | 0 .../routes/guilds/#guild_id/roles/index.ts | 0 .../api}/routes/guilds/#guild_id/stickers.ts | 0 .../api}/routes/guilds/#guild_id/templates.ts | 0 .../routes/guilds/#guild_id/vanity-url.ts | 0 .../#guild_id/voice-states/#user_id/index.ts | 0 .../api}/routes/guilds/#guild_id/webhooks.ts | 0 .../routes/guilds/#guild_id/welcome_screen.ts | 0 .../routes/guilds/#guild_id/widget.json.ts | 0 .../routes/guilds/#guild_id/widget.png.ts | 2 +- .../api}/routes/guilds/#guild_id/widget.ts | 0 {api/src => src/api}/routes/guilds/index.ts | 0 .../api}/routes/guilds/templates/index.ts | 0 {api/src => src/api}/routes/invites/index.ts | 0 {api/src => src/api}/routes/oauth2/tokens.ts | 0 .../api}/routes/outbound-promotions.ts | 0 .../routes/partners/#guild_id/requirements.ts | 0 {api/src => src/api}/routes/ping.ts | 0 .../api}/routes/policies/instance/domains.ts | 0 .../api}/routes/policies/instance/index.ts | 0 .../api}/routes/policies/instance/limits.ts | 0 .../scheduled-maintenances/upcoming_json.ts | 0 {api/src => src/api}/routes/science.ts | 0 .../src => src/api}/routes/stage-instances.ts | 0 .../api}/routes/sticker-packs/index.ts | 0 .../api}/routes/stickers/#sticker_id/index.ts | 0 {api/src => src/api}/routes/stop.ts | 0 .../store/published-listings/applications.ts | 0 .../applications/#id/subscription-plans.ts | 0 .../routes/store/published-listings/skus.ts | 0 .../skus/#sku_id/subscription-plans.ts | 0 {api/src => src/api}/routes/teams.ts | 0 .../api}/routes/template.ts.disabled | 0 {api/src => src/api}/routes/track.ts | 0 {api/src => src/api}/routes/updates.ts | 0 .../src => src/api}/routes/users/#id/index.ts | 0 .../api}/routes/users/#id/profile.ts | 0 .../api}/routes/users/#id/relationships.ts | 0 .../@me/activities/statistics/applications.ts | 0 .../routes/users/@me/affinities/guilds.ts | 0 .../api}/routes/users/@me/affinities/users.ts | 0 .../@me/applications/#app_id/entitlements.ts | 0 .../routes/users/@me/billing/country-code.ts | 0 .../users/@me/billing/payment-sources.ts | 0 .../routes/users/@me/billing/subscriptions.ts | 0 .../api}/routes/users/@me/channels.ts | 0 .../api}/routes/users/@me/connections.ts | 0 .../api}/routes/users/@me/delete.ts | 0 .../api}/routes/users/@me/devices.ts | 0 .../api}/routes/users/@me/disable.ts | 0 .../api}/routes/users/@me/email-settings.ts | 0 .../api}/routes/users/@me/entitlements.ts | 0 .../api}/routes/users/@me/guilds.ts | 0 .../@me/guilds/premium/subscription-slots.ts | 0 .../src => src/api}/routes/users/@me/index.ts | 0 .../api}/routes/users/@me/library.ts | 0 .../api}/routes/users/@me/mfa/codes.ts | 0 .../api}/routes/users/@me/mfa/totp/disable.ts | 0 .../api}/routes/users/@me/mfa/totp/enable.ts | 0 .../src => src/api}/routes/users/@me/notes.ts | 0 .../api}/routes/users/@me/relationships.ts | 0 .../api}/routes/users/@me/settings.ts | 0 {api/src => src/api}/routes/voice/regions.ts | 0 {api/src => src/api}/start.ts | 2 +- .../api}/util/entities/AssetCacheItem.ts | 0 .../util/entities/blockedEmailDomains.txt | 0 .../util/entities/trustedEmailDomains.txt | 0 .../src => src/api}/util/handlers/Instance.ts | 0 {api/src => src/api}/util/handlers/Message.ts | 0 {api/src => src/api}/util/handlers/Voice.ts | 0 {api/src => src/api}/util/handlers/route.ts | 2 +- {api/src => src/api}/util/index.ts | 0 {api/src => src/api}/util/utility/Base64.ts | 0 .../api}/util/utility/RandomInviteID.ts | 0 {api/src => src/api}/util/utility/String.ts | 0 .../src => src/api}/util/utility/ipAddress.ts | 0 .../api}/util/utility/passwordStrength.ts | 0 {cdn/src => src/cdn}/Server.ts | 0 {cdn/src => src/cdn}/index.ts | 0 {cdn/src => src/cdn}/routes/attachments.ts | 0 {cdn/src => src/cdn}/routes/avatars.ts | 0 {cdn/src => src/cdn}/routes/external.ts | 0 {cdn/src => src/cdn}/routes/ping.ts | 0 {cdn/src => src/cdn}/routes/role-icons.ts | 0 {cdn/src => src/cdn}/start.ts | 0 {cdn/src => src/cdn}/util/FileStorage.ts | 0 {cdn/src => src/cdn}/util/S3Storage.ts | 0 {cdn/src => src/cdn}/util/Storage.ts | 0 {cdn/src => src/cdn}/util/index.ts | 0 {cdn/src => src/cdn}/util/multer.ts | 0 {gateway/src => src/gateway}/Server.ts | 0 {gateway/src => src/gateway}/events/Close.ts | 0 .../src => src/gateway}/events/Connection.ts | 0 .../src => src/gateway}/events/Message.ts | 3 +- {gateway/src => src/gateway}/index.ts | 0 .../src => src/gateway}/listener/listener.ts | 0 .../src => src/gateway}/opcodes/Heartbeat.ts | 0 src/gateway/opcodes/Identify.ts | 298 + .../gateway}/opcodes/LazyRequest.ts | 2 +- .../gateway}/opcodes/PresenceUpdate.ts | 0 .../gateway}/opcodes/RequestGuildMembers.ts | 0 .../src => src/gateway}/opcodes/Resume.ts | 0 .../gateway}/opcodes/VoiceStateUpdate.ts | 2 +- .../gateway}/opcodes/experiments.json | 0 {gateway/src => src/gateway}/opcodes/index.ts | 0 .../src => src/gateway}/opcodes/instanceOf.ts | 0 {gateway/src => src/gateway}/start.ts | 0 .../src => src/gateway}/util/Constants.ts | 0 .../src => src/gateway}/util/Heartbeat.ts | 0 {gateway/src => src/gateway}/util/Send.ts | 0 .../src => src/gateway}/util/SessionUtils.ts | 0 .../src => src/gateway}/util/WebSocket.ts | 4 +- {gateway/src => src/gateway}/util/index.ts | 0 {bundle/src => src}/start.ts | 0 src/stats.ts | 24 + {util/src => src/util}/config/Config.ts | 2 +- {util/src => src/util}/config/index.ts | 0 .../util}/config/types/ApiConfiguration.ts | 0 .../util}/config/types/ClientConfiguration.ts | 0 .../config/types/DefaultsConfiguration.ts | 0 .../config/types/EndpointConfiguration.ts | 0 .../config/types/GeneralConfiguration.ts | 0 .../util}/config/types/GifConfiguration.ts | 0 .../util}/config/types/GuildConfiguration.ts | 0 .../util}/config/types/KafkaConfiguration.ts | 0 .../util}/config/types/LimitConfigurations.ts | 0 .../util}/config/types/LoginConfiguration.ts | 0 .../config/types/MetricsConfiguration.ts | 0 .../config/types/RabbitMQConfiguration.ts | 0 .../util}/config/types/RegionConfiguration.ts | 0 .../config/types/RegisterConfiguration.ts | 0 .../config/types/SecurityConfiguration.ts | 0 .../util}/config/types/SentryConfiguration.ts | 0 .../config/types/TemplateConfiguration.ts | 0 {util/src => src/util}/config/types/index.ts | 0 .../client/ClientReleaseConfiguration.ts | 0 .../types/subconfigurations/client/index.ts | 0 .../defaults/GuildDefaults.ts | 0 .../defaults/UserDefaults.ts | 0 .../types/subconfigurations/defaults/index.ts | 0 .../types/subconfigurations/guild/AutoJoin.ts | 0 .../subconfigurations/guild/Discovery.ts | 0 .../types/subconfigurations/guild/index.ts | 0 .../config/types/subconfigurations/index.ts | 0 .../subconfigurations/kafka/KafkaBroker.ts | 0 .../types/subconfigurations/kafka/index.ts | 0 .../subconfigurations/limits/ChannelLimits.ts | 0 .../subconfigurations/limits/GuildLimits.ts | 0 .../subconfigurations/limits/MessageLimits.ts | 0 .../subconfigurations/limits/RateLimits.ts | 0 .../subconfigurations/limits/UserLimits.ts | 0 .../types/subconfigurations/limits/index.ts | 0 .../limits/ratelimits/Auth.ts | 0 .../limits/ratelimits/RateLimitOptions.ts | 0 .../limits/ratelimits/Route.ts | 2 +- .../limits/ratelimits/index.ts | 0 .../types/subconfigurations/region/Region.ts | 0 .../types/subconfigurations/region/index.ts | 0 .../subconfigurations/register/DateOfBirth.ts | 0 .../types/subconfigurations/register/Email.ts | 0 .../subconfigurations/register/Password.ts | 0 .../types/subconfigurations/register/index.ts | 0 .../subconfigurations/security/Captcha.ts | 0 .../subconfigurations/security/TwoFactor.ts | 0 .../types/subconfigurations/security/index.ts | 0 {util/src => src/util}/dtos/DmChannelDTO.ts | 0 {util/src => src/util}/dtos/UserDTO.ts | 0 {util/src => src/util}/dtos/index.ts | 0 .../src => src/util}/entities/Application.ts | 0 {util/src => src/util}/entities/Attachment.ts | 0 {util/src => src/util}/entities/AuditLog.ts | 0 .../src => src/util}/entities/BackupCodes.ts | 0 {util/src => src/util}/entities/Ban.ts | 0 {util/src => src/util}/entities/BaseClass.ts | 0 {util/src => src/util}/entities/Categories.ts | 0 {util/src => src/util}/entities/Channel.ts | 0 .../util}/entities/ClientRelease.ts | 0 {util/src => src/util}/entities/Config.ts | 0 .../util}/entities/ConnectedAccount.ts | 0 {util/src => src/util}/entities/Emoji.ts | 0 {util/src => src/util}/entities/Encryption.ts | 0 {util/src => src/util}/entities/Group.ts | 0 {util/src => src/util}/entities/Guild.ts | 0 {util/src => src/util}/entities/Invite.ts | 0 {util/src => src/util}/entities/Member.ts | 0 {util/src => src/util}/entities/Message.ts | 0 {util/src => src/util}/entities/Migration.ts | 0 {util/src => src/util}/entities/Note.ts | 0 {util/src => src/util}/entities/RateLimit.ts | 0 {util/src => src/util}/entities/ReadState.ts | 0 {util/src => src/util}/entities/Recipient.ts | 0 .../src => src/util}/entities/Relationship.ts | 0 {util/src => src/util}/entities/Role.ts | 0 {util/src => src/util}/entities/Session.ts | 0 {util/src => src/util}/entities/Sticker.ts | 0 .../src => src/util}/entities/StickerPack.ts | 0 {util/src => src/util}/entities/Team.ts | 0 {util/src => src/util}/entities/TeamMember.ts | 0 {util/src => src/util}/entities/Template.ts | 0 {util/src => src/util}/entities/User.ts | 0 {util/src => src/util}/entities/UserGroup.ts | 0 .../src => src/util}/entities/UserSettings.ts | 0 {util/src => src/util}/entities/VoiceState.ts | 0 {util/src => src/util}/entities/Webhook.ts | 0 {util/src => src/util}/entities/index.ts | 0 {util/src => src/util}/index.ts | 1 + {util/src => src/util}/interfaces/Activity.ts | 0 {util/src => src/util}/interfaces/Event.ts | 0 .../util}/interfaces/Interaction.ts | 0 {util/src => src/util}/interfaces/Presence.ts | 0 {util/src => src/util}/interfaces/Status.ts | 0 {util/src => src/util}/interfaces/index.ts | 0 .../mariadb/1659901151025-initial.ts | 0 .../1659921859145-premium_since_as_date.ts | 0 .../mariadb/1660258393551-CodeCleanup3.ts | 0 .../mariadb/1660260587556-CodeCleanup4.ts | 0 .../mariadb/1660265930624-CodeCleanup5.ts | 0 .../postgres/1659899687168-initial.ts | 0 .../1659921826567-premium_since_as_date.ts | 0 .../postgres/1660257815436-CodeCleanup2.ts | 0 .../postgres/1660258372154-CodeCleanup3.ts | 0 .../postgres/1660260565996-CodeCleanup4.ts | 0 .../postgres/1660265907544-CodeCleanup5.ts | 0 .../sqlite/1659899662635-initial.ts | 0 .../1659921722863-premium_since_as_date.ts | 0 .../sqlite/1660257576211-CodeCleanup1.ts | 0 .../sqlite/1660257795259-CodeCleanup2.ts | 0 .../sqlite/1660258351379-CodeCleanup3.ts | 0 .../sqlite/1660260672914-CodeCleanup4.ts | 0 .../util}/schemas/ActivitySchema.ts | 0 .../util}/schemas/BanCreateSchema.ts | 0 .../util}/schemas/BanModeratorSchema.ts | 0 .../util}/schemas/BanRegistrySchema.ts | 0 .../util}/schemas/BulkDeleteSchema.ts | 0 .../util}/schemas/ChannelModifySchema.ts | 0 .../ChannelPermissionOverwriteSchema.ts | 0 .../util}/schemas/ChannelReorderSchema.ts | 0 .../util}/schemas/DmChannelCreateSchema.ts | 0 .../util}/schemas/EmojiCreateSchema.ts | 0 .../util}/schemas/EmojiModifySchema.ts | 0 .../util}/schemas/GuildCreateSchema.ts | 0 .../schemas/GuildTemplateCreateSchema.ts | 0 .../util}/schemas/GuildUpdateSchema.ts | 0 .../schemas/GuildUpdateWelcomeScreenSchema.ts | 0 .../util}/schemas/IdentifySchema.ts | 8 +- .../util}/schemas/InviteCreateSchema.ts | 0 .../util}/schemas/LazyRequestSchema.ts | 0 {util/src => src/util}/schemas/LoginSchema.ts | 0 .../util}/schemas/MemberChangeSchema.ts | 0 .../util}/schemas/MemberNickChangeSchema.ts | 0 .../util}/schemas/MessageAcknowledgeSchema.ts | 0 .../util}/schemas/MessageCreateSchema.ts | 0 .../util}/schemas/MfaCodesSchema.ts | 0 .../util}/schemas/ModifyGuildStickerSchema.ts | 0 {util/src => src/util}/schemas/PruneSchema.ts | 0 {util/src => src/util}/schemas/PurgeSchema.ts | 0 .../util}/schemas/RegisterSchema.ts | 0 .../util}/schemas/RelationshipPostSchema.ts | 0 .../util}/schemas/RelationshipPutSchema.ts | 0 .../util}/schemas/RoleModifySchema.ts | 0 .../util}/schemas/RolePositionUpdateSchema.ts | 0 .../util}/schemas/TemplateCreateSchema.ts | 0 .../util}/schemas/TemplateModifySchema.ts | 0 .../util}/schemas/TotpDisableSchema.ts | 0 .../util}/schemas/TotpEnableSchema.ts | 0 {util/src => src/util}/schemas/TotpSchema.ts | 0 .../util}/schemas/UserModifySchema.ts | 0 .../util}/schemas/UserSettingsSchema.ts | 0 .../util}/schemas/VanityUrlSchema.ts | 0 .../util}/schemas/VoiceStateUpdateSchema.ts | 0 .../util}/schemas/WebhookCreateSchema.ts | 0 .../util}/schemas/WidgetModifySchema.ts | 0 {util/src => src/util}/schemas/index.ts | 0 {util/src => src/util}/util/ApiError.ts | 0 {util/src => src/util}/util/Array.ts | 0 {util/src => src/util}/util/AutoUpdate.ts | 0 {util/src => src/util}/util/BitField.ts | 0 {util/src => src/util}/util/Categories.ts | 0 {util/src => src/util}/util/Config.ts | 0 {util/src => src/util}/util/Constants.ts | 0 {util/src => src/util}/util/Database.ts | 0 {util/src => src/util}/util/Email.ts | 0 {util/src => src/util}/util/Event.ts | 0 {util/src => src/util}/util/FieldError.ts | 0 {util/src => src/util}/util/Intents.ts | 0 .../util}/util/InvisibleCharacters.ts | 0 {util/src => src/util}/util/MFA.ts | 0 {util/src => src/util}/util/MessageFlags.ts | 0 {util/src => src/util}/util/Permissions.ts | 0 {util/src => src/util}/util/RabbitMQ.ts | 0 {util/src => src/util}/util/Regex.ts | 0 {util/src => src/util}/util/Rights.ts | 0 {util/src => src/util}/util/Snowflake.ts | 0 {util/src => src/util}/util/String.ts | 0 {util/src => src/util}/util/Token.ts | 0 .../util}/util/TraverseDirectory.ts | 0 {util/src => src/util}/util/cdn.ts | 0 {util/src => src/util}/util/imports/Checks.ts | 0 .../util}/util/imports/HTTPError.ts | 0 .../src => src/util}/util/imports/OrmUtils.ts | 0 {util/src => src/util}/util/imports/index.ts | 0 {util/src => src/util}/util/index.ts | 0 {util/tests => tests}/User.test.js | 0 {cdn/tests => tests}/antman.jpg | Bin {cdn/tests => tests}/cdn_endpoints.test.js | 0 {cdn/tests => tests}/filestorage.test.js | 0 {api/tests => tests}/routes.test.ts | 0 .../tests => tests}/routes/auth/login.test.js | 0 .../routes/auth/register.test.js | 0 {api/tests => tests}/routes/ping.test.js | 0 {util/tests => tests}/setupJest.js | 0 bundle/tsconfig.json => tsconfig.json | 14 +- util/.gitignore | 110 - util/.npmignore | 1 - util/.prettierrc | 5 - util/.vscode/launch.json | 27 - util/README.md | 29 - util/package-lock.json | Bin 460763 -> 0 bytes util/package.json | 59 - util/tsconfig.json | 73 - webrtc/.DS_Store | Bin 6148 -> 0 bytes webrtc/.gitignore | 104 - webrtc/README.md | 3 - webrtc/package-lock.json | Bin 25101 -> 0 bytes webrtc/package.json | 24 - webrtc/src/Server.ts | 46 - webrtc/src/index.ts | 0 webrtc/src/start.ts | 3 - webrtc/src/test.ts | 8 - webrtc/tsconfig.json | 72 - yarn.lock | 6802 +++++++++++++++++ 626 files changed, 7256 insertions(+), 2449 deletions(-) rename api/.dockerignore => .dockerignore (100%) delete mode 100644 api/.env.example delete mode 100644 api/.gitignore delete mode 100644 api/.npmignore delete mode 100644 api/.prettierrc delete mode 100644 api/.vscode/api-snippets.code-snippets delete mode 100644 api/.vscode/launch.json delete mode 100644 api/Dockerfile delete mode 100644 api/README.md delete mode 100644 api/babel.config.js delete mode 100644 api/jest/getRouteDescriptions.js delete mode 100644 api/jest/globalSetup.js delete mode 100644 api/jest/setup.js delete mode 100644 api/package-lock.json delete mode 100644 api/package.json delete mode 100644 api/tsconfig.json rename {api/assets => assets}/checkLocale.js (100%) rename {api/client_test => assets}/developers.html (100%) rename {api/assets => assets}/dff87c953f43b561d71fbcfe8a93a79a.png (100%) rename {api/assets => assets}/endpoints.json (100%) rename {api/assets => assets}/features.json (100%) rename {api/assets => assets}/fosscord-login.css (100%) rename {api/assets => assets}/fosscord.css (100%) rename {api/client_test => assets}/index.html (98%) rename {api/assets => assets}/inline-plugins/autoRegister.js (100%) rename {api/assets => assets}/inline-plugins/fosscord-login.js (100%) rename {api => assets}/locales/af/auth.json (100%) rename {api => assets}/locales/af/common.json (100%) rename {api => assets}/locales/ar/auth.json (100%) rename {api => assets}/locales/ar/common.json (100%) rename {api => assets}/locales/arn/auth.json (100%) rename {api => assets}/locales/arn/common.json (100%) rename {api => assets}/locales/az/auth.json (100%) rename {api => assets}/locales/az/common.json (100%) rename {api => assets}/locales/be/auth.json (100%) rename {api => assets}/locales/be/common.json (100%) rename {api => assets}/locales/ber/auth.json (100%) rename {api => assets}/locales/ber/common.json (100%) rename {api => assets}/locales/bg/auth.json (100%) rename {api => assets}/locales/bg/common.json (100%) rename {api => assets}/locales/bo/auth.json (100%) rename {api => assets}/locales/bo/common.json (100%) rename {api => assets}/locales/ca/auth.json (100%) rename {api => assets}/locales/ca/common.json (100%) rename {api => assets}/locales/cs/auth.json (100%) rename {api => assets}/locales/cs/common.json (100%) rename {api => assets}/locales/da/auth.json (100%) rename {api => assets}/locales/da/common.json (100%) rename {api => assets}/locales/de/auth.json (100%) rename {api => assets}/locales/de/common.json (100%) rename {api => assets}/locales/el/auth.json (100%) rename {api => assets}/locales/el/common.json (100%) rename {api => assets}/locales/en/auth.json (100%) rename {api => assets}/locales/en/common.json (100%) rename {api => assets}/locales/eo/auth.json (100%) rename {api => assets}/locales/eo/common.json (100%) rename {api => assets}/locales/es/auth.json (100%) rename {api => assets}/locales/es/common.json (100%) rename {api => assets}/locales/eu/auth.json (100%) rename {api => assets}/locales/eu/common.json (100%) rename {api => assets}/locales/fa/auth.json (100%) rename {api => assets}/locales/fa/common.json (100%) rename {api => assets}/locales/fi/auth.json (100%) rename {api => assets}/locales/fi/common.json (100%) rename {api => assets}/locales/fr/auth.json (100%) rename {api => assets}/locales/fr/common.json (100%) rename {api => assets}/locales/gn/auth.json (100%) rename {api => assets}/locales/gn/common.json (100%) rename {api => assets}/locales/ha/auth.json (100%) rename {api => assets}/locales/ha/common.json (100%) rename {api => assets}/locales/he/auth.json (100%) rename {api => assets}/locales/he/common.json (100%) rename {api => assets}/locales/hi/auth.json (100%) rename {api => assets}/locales/hi/common.json (100%) rename {api => assets}/locales/hr/auth.json (100%) rename {api => assets}/locales/hr/common.json (100%) rename {api => assets}/locales/hu/auth.json (100%) rename {api => assets}/locales/hu/common.json (100%) rename {api => assets}/locales/id/auth.json (100%) rename {api => assets}/locales/id/common.json (100%) rename {api => assets}/locales/it/auth.json (100%) rename {api => assets}/locales/it/common.json (100%) rename {api => assets}/locales/ja/auth.json (100%) rename {api => assets}/locales/ja/common.json (100%) rename {api => assets}/locales/jv/auth.json (100%) rename {api => assets}/locales/jv/common.json (100%) rename {api => assets}/locales/kk/auth.json (100%) rename {api => assets}/locales/kk/common.json (100%) rename {api => assets}/locales/ko/auth.json (100%) rename {api => assets}/locales/ko/common.json (100%) rename {api => assets}/locales/ku/auth.json (100%) rename {api => assets}/locales/ku/common.json (100%) rename {api => assets}/locales/la/auth.json (100%) rename {api => assets}/locales/la/common.json (100%) rename {api => assets}/locales/lt/auth.json (100%) rename {api => assets}/locales/lt/common.json (100%) rename {api => assets}/locales/mi/auth.json (100%) rename {api => assets}/locales/mi/common.json (100%) rename {api => assets}/locales/mn/auth.json (100%) rename {api => assets}/locales/mn/common.json (100%) rename {api => assets}/locales/mr/auth.json (100%) rename {api => assets}/locales/mr/common.json (100%) rename {api => assets}/locales/nl/auth.json (100%) rename {api => assets}/locales/nl/common.json (100%) rename {api => assets}/locales/nn/auth.json (100%) rename {api => assets}/locales/nn/common.json (100%) rename {api => assets}/locales/no/auth.json (100%) rename {api => assets}/locales/no/common.json (100%) rename {api => assets}/locales/pa/auth.json (100%) rename {api => assets}/locales/pa/common.json (100%) rename {api => assets}/locales/pl/auth.json (100%) rename {api => assets}/locales/pl/common.json (100%) rename {api => assets}/locales/pt/auth.json (100%) rename {api => assets}/locales/pt/common.json (100%) rename {api => assets}/locales/qu/auth.json (100%) rename {api => assets}/locales/qu/common.json (100%) rename {api => assets}/locales/ro/auth.json (100%) rename {api => assets}/locales/ro/common.json (100%) rename {api => assets}/locales/ru/auth.json (100%) rename {api => assets}/locales/ru/common.json (100%) rename {api => assets}/locales/sh/auth.json (100%) rename {api => assets}/locales/sh/common.json (100%) rename {api => assets}/locales/si/auth.json (100%) rename {api => assets}/locales/si/common.json (100%) rename {api => assets}/locales/sk/auth.json (100%) rename {api => assets}/locales/sk/common.json (100%) rename {api => assets}/locales/sr/auth.json (100%) rename {api => assets}/locales/sr/common.json (100%) rename {api => assets}/locales/sv/auth.json (100%) rename {api => assets}/locales/sv/common.json (100%) rename {api => assets}/locales/sw/auth.json (100%) rename {api => assets}/locales/sw/common.json (100%) rename {api => assets}/locales/ta/auth.json (100%) rename {api => assets}/locales/ta/common.json (100%) rename {api => assets}/locales/te/auth.json (100%) rename {api => assets}/locales/te/common.json (100%) rename {api => assets}/locales/tl/auth.json (100%) rename {api => assets}/locales/tl/common.json (100%) rename {api => assets}/locales/tr/auth.json (100%) rename {api => assets}/locales/tr/common.json (100%) rename {api => assets}/locales/ug/auth.json (100%) rename {api => assets}/locales/ug/common.json (100%) rename {api => assets}/locales/uk/auth.json (100%) rename {api => assets}/locales/uk/common.json (100%) rename {api => assets}/locales/ur/auth.json (100%) rename {api => assets}/locales/ur/common.json (100%) rename {api => assets}/locales/vec/auth.json (100%) rename {api => assets}/locales/vec/common.json (100%) rename {api => assets}/locales/vi/auth.json (100%) rename {api => assets}/locales/vi/common.json (100%) rename {api => assets}/locales/zh/auth.json (100%) rename {api => assets}/locales/zh/common.json (100%) rename {api/assets => assets}/openapi.json (100%) rename {api/assets => assets}/plugins/.gitkeep (100%) rename {api/assets => assets}/preload-plugins/.gitkeep (100%) rename {api/assets => assets}/schemas.json (63%) rename {api/assets => assets}/user.css (100%) rename {api/assets => assets}/widget/banner1.png (100%) rename {api/assets => assets}/widget/banner2.png (100%) rename {api/assets => assets}/widget/banner3.png (100%) rename {api/assets => assets}/widget/banner4.png (100%) rename {api/assets => assets}/widget/shield.png (100%) delete mode 100644 bundle/.prettierrc delete mode 100644 bundle/.vscode/launch.json delete mode 100644 bundle/package-lock.json delete mode 100644 bundle/package.json delete mode 100644 bundle/src/stats.ts delete mode 100644 bundle/tsnode.tsconfig.json delete mode 100644 cdn/.env.example delete mode 100644 cdn/.gitignore delete mode 100644 cdn/.swcrc delete mode 100644 cdn/Dockerfile delete mode 100644 cdn/README.md delete mode 100644 cdn/jest/setup.js delete mode 100644 cdn/package-lock.json delete mode 100644 cdn/package.json delete mode 100644 cdn/tsconfig.json delete mode 100644 dashboard/README.md delete mode 100644 dashboard/package-lock.json delete mode 100644 dashboard/package.json delete mode 100644 dashboard/src/index.ts delete mode 100644 gateway/.env.example delete mode 100644 gateway/.gitignore delete mode 100644 gateway/.swcrc delete mode 100644 gateway/.vscode/launch.json delete mode 100644 gateway/Dockerfile delete mode 100644 gateway/README.md delete mode 100644 gateway/package-lock.json delete mode 100644 gateway/package.json delete mode 100644 gateway/tsconfig.json rename {api/patches => patches}/ajv+8.6.2.patch (100%) rename {api/patches => patches}/typescript-json-schema+0.54.0.patch (100%) delete mode 100644 rtc/.gitignore delete mode 100644 rtc/.npmignore delete mode 100644 rtc/.prettierrc delete mode 100644 rtc/CMakeLists.txt delete mode 100644 rtc/README.md delete mode 100644 rtc/config.json delete mode 100644 rtc/src/main.cpp delete mode 100644 rtc/src/mongoStub.cpp delete mode 100644 rtc/src/mongoStub.hpp delete mode 100644 rtc/src/rtcPeerHandler.cpp delete mode 100644 rtc/src/rtcPeerHandler.hpp delete mode 100644 rtc/src/rtcServer.hpp rename {util/scripts => scripts}/benchmark.js (100%) rename {bundle/scripts => scripts}/benchmark/connections.js (100%) rename {bundle/scripts => scripts}/benchmark/index.js (100%) rename {bundle/scripts => scripts}/benchmark/users.js (100%) rename {bundle/scripts => scripts}/build.js (77%) rename {bundle/scripts => scripts}/db_migrations.sh (100%) rename {bundle/scripts => scripts}/depcheck.js (100%) rename {bundle/scripts => scripts}/depclean.js (100%) rename {api/scripts => scripts}/droptables.sql (100%) rename {bundle/scripts => scripts}/gen_index.js (100%) rename {api/scripts => scripts}/generate_openapi.js (100%) rename {api/scripts => scripts}/generate_schema.js (96%) rename {bundle/scripts => scripts}/install.js (100%) rename {util/scripts => scripts}/migrate_db_engine.js (100%) rename {bundle/scripts => scripts}/rights.js (100%) rename {api/scripts => scripts}/stresstest/.gitignore (100%) rename {api/scripts => scripts}/stresstest/accounts.json.example (100%) rename {api/scripts => scripts}/stresstest/config.json.example (100%) rename {api/scripts => scripts}/stresstest/index.js (100%) rename {api/scripts => scripts}/stresstest/package-lock.json (100%) rename {api/scripts => scripts}/stresstest/package.json (100%) rename {api/scripts => scripts}/stresstest/src/login/index.js (91%) rename {api/scripts => scripts}/stresstest/src/message/send.js (100%) rename {api/scripts => scripts}/stresstest/src/register/index.js (100%) rename {bundle/scripts => scripts}/update_schemas.js (100%) rename {bundle/scripts => scripts}/utils.js (100%) rename {bundle/src => src}/Server.ts (97%) rename {api/src => src/api}/Server.ts (100%) rename {api/src => src/api}/global.d.ts (100%) rename {api/src => src/api}/index.ts (100%) rename {api/src => src/api}/middlewares/Authentication.ts (100%) rename {api/src => src/api}/middlewares/BodyParser.ts (100%) rename {api/src => src/api}/middlewares/CORS.ts (100%) rename {api/src => src/api}/middlewares/ErrorHandler.ts (100%) rename {api/src => src/api}/middlewares/RateLimit.ts (100%) rename {api/src => src/api}/middlewares/TestClient.ts (89%) rename {api/src => src/api}/middlewares/Translation.ts (84%) rename {api/src => src/api}/middlewares/index.ts (100%) rename {api/src => src/api}/routes/-/healthz.ts (100%) rename {api/src => src/api}/routes/-/readyz.ts (100%) rename {api/src => src/api}/routes/applications/#id/entitlements.ts (100%) rename {api/src => src/api}/routes/applications/detectable.ts (100%) rename {api/src => src/api}/routes/applications/index.ts (100%) rename {api/src => src/api}/routes/auth/location-metadata.ts (100%) rename {api/src => src/api}/routes/auth/login.ts (100%) rename {api/src => src/api}/routes/auth/mfa/totp.ts (100%) rename {api/src => src/api}/routes/auth/register.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/followers.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/index.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/invites.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/messages/#message_id/ack.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/messages/#message_id/crosspost.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/messages/#message_id/index.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/messages/#message_id/reactions.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/messages/bulk-delete.ts (95%) rename {api/src => src/api}/routes/channels/#channel_id/messages/index.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/permissions.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/pins.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/purge.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/recipients.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/typing.ts (100%) rename {api/src => src/api}/routes/channels/#channel_id/webhooks.ts (100%) rename {api/src => src/api}/routes/discoverable-guilds.ts (100%) rename {api/src => src/api}/routes/discovery.ts (100%) rename {api/src => src/api}/routes/downloads.ts (100%) rename {api/src => src/api}/routes/experiments.ts (100%) rename {api/src => src/api}/routes/gateway/bot.ts (100%) rename {api/src => src/api}/routes/gateway/index.ts (100%) rename {api/src => src/api}/routes/gifs/search.ts (100%) rename {api/src => src/api}/routes/gifs/trending-gifs.ts (100%) rename {api/src => src/api}/routes/gifs/trending.ts (100%) rename {api/src => src/api}/routes/guild-recommendations.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/audit-logs.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/bans.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/channels.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/delete.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/discovery-requirements.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/emojis.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/integrations.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/invites.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/members/#member_id/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/members/#member_id/nick.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/members/#member_id/roles/#role_id/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/members/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/premium.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/prune.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/regions.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/roles/#role_id/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/roles/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/stickers.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/templates.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/vanity-url.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/voice-states/#user_id/index.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/webhooks.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/welcome_screen.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/widget.json.ts (100%) rename {api/src => src/api}/routes/guilds/#guild_id/widget.png.ts (97%) rename {api/src => src/api}/routes/guilds/#guild_id/widget.ts (100%) rename {api/src => src/api}/routes/guilds/index.ts (100%) rename {api/src => src/api}/routes/guilds/templates/index.ts (100%) rename {api/src => src/api}/routes/invites/index.ts (100%) rename {api/src => src/api}/routes/oauth2/tokens.ts (100%) rename {api/src => src/api}/routes/outbound-promotions.ts (100%) rename {api/src => src/api}/routes/partners/#guild_id/requirements.ts (100%) rename {api/src => src/api}/routes/ping.ts (100%) rename {api/src => src/api}/routes/policies/instance/domains.ts (100%) rename {api/src => src/api}/routes/policies/instance/index.ts (100%) rename {api/src => src/api}/routes/policies/instance/limits.ts (100%) rename {api/src => src/api}/routes/scheduled-maintenances/upcoming_json.ts (100%) rename {api/src => src/api}/routes/science.ts (100%) rename {api/src => src/api}/routes/stage-instances.ts (100%) rename {api/src => src/api}/routes/sticker-packs/index.ts (100%) rename {api/src => src/api}/routes/stickers/#sticker_id/index.ts (100%) rename {api/src => src/api}/routes/stop.ts (100%) rename {api/src => src/api}/routes/store/published-listings/applications.ts (100%) rename {api/src => src/api}/routes/store/published-listings/applications/#id/subscription-plans.ts (100%) rename {api/src => src/api}/routes/store/published-listings/skus.ts (100%) rename {api/src => src/api}/routes/store/published-listings/skus/#sku_id/subscription-plans.ts (100%) rename {api/src => src/api}/routes/teams.ts (100%) rename {api/src => src/api}/routes/template.ts.disabled (100%) rename {api/src => src/api}/routes/track.ts (100%) rename {api/src => src/api}/routes/updates.ts (100%) rename {api/src => src/api}/routes/users/#id/index.ts (100%) rename {api/src => src/api}/routes/users/#id/profile.ts (100%) rename {api/src => src/api}/routes/users/#id/relationships.ts (100%) rename {api/src => src/api}/routes/users/@me/activities/statistics/applications.ts (100%) rename {api/src => src/api}/routes/users/@me/affinities/guilds.ts (100%) rename {api/src => src/api}/routes/users/@me/affinities/users.ts (100%) rename {api/src => src/api}/routes/users/@me/applications/#app_id/entitlements.ts (100%) rename {api/src => src/api}/routes/users/@me/billing/country-code.ts (100%) rename {api/src => src/api}/routes/users/@me/billing/payment-sources.ts (100%) rename {api/src => src/api}/routes/users/@me/billing/subscriptions.ts (100%) rename {api/src => src/api}/routes/users/@me/channels.ts (100%) rename {api/src => src/api}/routes/users/@me/connections.ts (100%) rename {api/src => src/api}/routes/users/@me/delete.ts (100%) rename {api/src => src/api}/routes/users/@me/devices.ts (100%) rename {api/src => src/api}/routes/users/@me/disable.ts (100%) rename {api/src => src/api}/routes/users/@me/email-settings.ts (100%) rename {api/src => src/api}/routes/users/@me/entitlements.ts (100%) rename {api/src => src/api}/routes/users/@me/guilds.ts (100%) rename {api/src => src/api}/routes/users/@me/guilds/premium/subscription-slots.ts (100%) rename {api/src => src/api}/routes/users/@me/index.ts (100%) rename {api/src => src/api}/routes/users/@me/library.ts (100%) rename {api/src => src/api}/routes/users/@me/mfa/codes.ts (100%) rename {api/src => src/api}/routes/users/@me/mfa/totp/disable.ts (100%) rename {api/src => src/api}/routes/users/@me/mfa/totp/enable.ts (100%) rename {api/src => src/api}/routes/users/@me/notes.ts (100%) rename {api/src => src/api}/routes/users/@me/relationships.ts (100%) rename {api/src => src/api}/routes/users/@me/settings.ts (100%) rename {api/src => src/api}/routes/voice/regions.ts (100%) rename {api/src => src/api}/start.ts (92%) rename {api/src => src/api}/util/entities/AssetCacheItem.ts (100%) rename {api/src => src/api}/util/entities/blockedEmailDomains.txt (100%) rename {api/src => src/api}/util/entities/trustedEmailDomains.txt (100%) rename {api/src => src/api}/util/handlers/Instance.ts (100%) rename {api/src => src/api}/util/handlers/Message.ts (100%) rename {api/src => src/api}/util/handlers/Voice.ts (100%) rename {api/src => src/api}/util/handlers/route.ts (97%) rename {api/src => src/api}/util/index.ts (100%) rename {api/src => src/api}/util/utility/Base64.ts (100%) rename {api/src => src/api}/util/utility/RandomInviteID.ts (100%) rename {api/src => src/api}/util/utility/String.ts (100%) rename {api/src => src/api}/util/utility/ipAddress.ts (100%) rename {api/src => src/api}/util/utility/passwordStrength.ts (100%) rename {cdn/src => src/cdn}/Server.ts (100%) rename {cdn/src => src/cdn}/index.ts (100%) rename {cdn/src => src/cdn}/routes/attachments.ts (100%) rename {cdn/src => src/cdn}/routes/avatars.ts (100%) rename {cdn/src => src/cdn}/routes/external.ts (100%) rename {cdn/src => src/cdn}/routes/ping.ts (100%) rename {cdn/src => src/cdn}/routes/role-icons.ts (100%) rename {cdn/src => src/cdn}/start.ts (100%) rename {cdn/src => src/cdn}/util/FileStorage.ts (100%) rename {cdn/src => src/cdn}/util/S3Storage.ts (100%) rename {cdn/src => src/cdn}/util/Storage.ts (100%) rename {cdn/src => src/cdn}/util/index.ts (100%) rename {cdn/src => src/cdn}/util/multer.ts (100%) rename {gateway/src => src/gateway}/Server.ts (100%) rename {gateway/src => src/gateway}/events/Close.ts (100%) rename {gateway/src => src/gateway}/events/Connection.ts (100%) rename {gateway/src => src/gateway}/events/Message.ts (94%) rename {gateway/src => src/gateway}/index.ts (100%) rename {gateway/src => src/gateway}/listener/listener.ts (100%) rename {gateway/src => src/gateway}/opcodes/Heartbeat.ts (100%) create mode 100644 src/gateway/opcodes/Identify.ts rename {gateway/src => src/gateway}/opcodes/LazyRequest.ts (98%) rename {gateway/src => src/gateway}/opcodes/PresenceUpdate.ts (100%) rename {gateway/src => src/gateway}/opcodes/RequestGuildMembers.ts (100%) rename {gateway/src => src/gateway}/opcodes/Resume.ts (100%) rename {gateway/src => src/gateway}/opcodes/VoiceStateUpdate.ts (98%) rename {gateway/src => src/gateway}/opcodes/experiments.json (100%) rename {gateway/src => src/gateway}/opcodes/index.ts (100%) rename {gateway/src => src/gateway}/opcodes/instanceOf.ts (100%) rename {gateway/src => src/gateway}/start.ts (100%) rename {gateway/src => src/gateway}/util/Constants.ts (100%) rename {gateway/src => src/gateway}/util/Heartbeat.ts (100%) rename {gateway/src => src/gateway}/util/Send.ts (100%) rename {gateway/src => src/gateway}/util/SessionUtils.ts (100%) rename {gateway/src => src/gateway}/util/WebSocket.ts (92%) rename {gateway/src => src/gateway}/util/index.ts (100%) rename {bundle/src => src}/start.ts (100%) create mode 100644 src/stats.ts rename {util/src => src/util}/config/Config.ts (95%) rename {util/src => src/util}/config/index.ts (100%) rename {util/src => src/util}/config/types/ApiConfiguration.ts (100%) rename {util/src => src/util}/config/types/ClientConfiguration.ts (100%) rename {util/src => src/util}/config/types/DefaultsConfiguration.ts (100%) rename {util/src => src/util}/config/types/EndpointConfiguration.ts (100%) rename {util/src => src/util}/config/types/GeneralConfiguration.ts (100%) rename {util/src => src/util}/config/types/GifConfiguration.ts (100%) rename {util/src => src/util}/config/types/GuildConfiguration.ts (100%) rename {util/src => src/util}/config/types/KafkaConfiguration.ts (100%) rename {util/src => src/util}/config/types/LimitConfigurations.ts (100%) rename {util/src => src/util}/config/types/LoginConfiguration.ts (100%) rename {util/src => src/util}/config/types/MetricsConfiguration.ts (100%) rename {util/src => src/util}/config/types/RabbitMQConfiguration.ts (100%) rename {util/src => src/util}/config/types/RegionConfiguration.ts (100%) rename {util/src => src/util}/config/types/RegisterConfiguration.ts (100%) rename {util/src => src/util}/config/types/SecurityConfiguration.ts (100%) rename {util/src => src/util}/config/types/SentryConfiguration.ts (100%) rename {util/src => src/util}/config/types/TemplateConfiguration.ts (100%) rename {util/src => src/util}/config/types/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/client/ClientReleaseConfiguration.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/client/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/defaults/GuildDefaults.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/defaults/UserDefaults.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/defaults/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/guild/AutoJoin.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/guild/Discovery.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/guild/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/kafka/KafkaBroker.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/kafka/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/ChannelLimits.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/GuildLimits.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/MessageLimits.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/RateLimits.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/UserLimits.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/ratelimits/Auth.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/limits/ratelimits/Route.ts (90%) rename {util/src => src/util}/config/types/subconfigurations/limits/ratelimits/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/region/Region.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/region/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/register/DateOfBirth.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/register/Email.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/register/Password.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/register/index.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/security/Captcha.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/security/TwoFactor.ts (100%) rename {util/src => src/util}/config/types/subconfigurations/security/index.ts (100%) rename {util/src => src/util}/dtos/DmChannelDTO.ts (100%) rename {util/src => src/util}/dtos/UserDTO.ts (100%) rename {util/src => src/util}/dtos/index.ts (100%) rename {util/src => src/util}/entities/Application.ts (100%) rename {util/src => src/util}/entities/Attachment.ts (100%) rename {util/src => src/util}/entities/AuditLog.ts (100%) rename {util/src => src/util}/entities/BackupCodes.ts (100%) rename {util/src => src/util}/entities/Ban.ts (100%) rename {util/src => src/util}/entities/BaseClass.ts (100%) rename {util/src => src/util}/entities/Categories.ts (100%) rename {util/src => src/util}/entities/Channel.ts (100%) rename {util/src => src/util}/entities/ClientRelease.ts (100%) rename {util/src => src/util}/entities/Config.ts (100%) rename {util/src => src/util}/entities/ConnectedAccount.ts (100%) rename {util/src => src/util}/entities/Emoji.ts (100%) rename {util/src => src/util}/entities/Encryption.ts (100%) rename {util/src => src/util}/entities/Group.ts (100%) rename {util/src => src/util}/entities/Guild.ts (100%) rename {util/src => src/util}/entities/Invite.ts (100%) rename {util/src => src/util}/entities/Member.ts (100%) rename {util/src => src/util}/entities/Message.ts (100%) rename {util/src => src/util}/entities/Migration.ts (100%) rename {util/src => src/util}/entities/Note.ts (100%) rename {util/src => src/util}/entities/RateLimit.ts (100%) rename {util/src => src/util}/entities/ReadState.ts (100%) rename {util/src => src/util}/entities/Recipient.ts (100%) rename {util/src => src/util}/entities/Relationship.ts (100%) rename {util/src => src/util}/entities/Role.ts (100%) rename {util/src => src/util}/entities/Session.ts (100%) rename {util/src => src/util}/entities/Sticker.ts (100%) rename {util/src => src/util}/entities/StickerPack.ts (100%) rename {util/src => src/util}/entities/Team.ts (100%) rename {util/src => src/util}/entities/TeamMember.ts (100%) rename {util/src => src/util}/entities/Template.ts (100%) rename {util/src => src/util}/entities/User.ts (100%) rename {util/src => src/util}/entities/UserGroup.ts (100%) rename {util/src => src/util}/entities/UserSettings.ts (100%) rename {util/src => src/util}/entities/VoiceState.ts (100%) rename {util/src => src/util}/entities/Webhook.ts (100%) rename {util/src => src/util}/entities/index.ts (100%) rename {util/src => src/util}/index.ts (76%) rename {util/src => src/util}/interfaces/Activity.ts (100%) rename {util/src => src/util}/interfaces/Event.ts (100%) rename {util/src => src/util}/interfaces/Interaction.ts (100%) rename {util/src => src/util}/interfaces/Presence.ts (100%) rename {util/src => src/util}/interfaces/Status.ts (100%) rename {util/src => src/util}/interfaces/index.ts (100%) rename {util/src => src/util}/migrations/mariadb/1659901151025-initial.ts (100%) rename {util/src => src/util}/migrations/mariadb/1659921859145-premium_since_as_date.ts (100%) rename {util/src => src/util}/migrations/mariadb/1660258393551-CodeCleanup3.ts (100%) rename {util/src => src/util}/migrations/mariadb/1660260587556-CodeCleanup4.ts (100%) rename {util/src => src/util}/migrations/mariadb/1660265930624-CodeCleanup5.ts (100%) rename {util/src => src/util}/migrations/postgres/1659899687168-initial.ts (100%) rename {util/src => src/util}/migrations/postgres/1659921826567-premium_since_as_date.ts (100%) rename {util/src => src/util}/migrations/postgres/1660257815436-CodeCleanup2.ts (100%) rename {util/src => src/util}/migrations/postgres/1660258372154-CodeCleanup3.ts (100%) rename {util/src => src/util}/migrations/postgres/1660260565996-CodeCleanup4.ts (100%) rename {util/src => src/util}/migrations/postgres/1660265907544-CodeCleanup5.ts (100%) rename {util/src => src/util}/migrations/sqlite/1659899662635-initial.ts (100%) rename {util/src => src/util}/migrations/sqlite/1659921722863-premium_since_as_date.ts (100%) rename {util/src => src/util}/migrations/sqlite/1660257576211-CodeCleanup1.ts (100%) rename {util/src => src/util}/migrations/sqlite/1660257795259-CodeCleanup2.ts (100%) rename {util/src => src/util}/migrations/sqlite/1660258351379-CodeCleanup3.ts (100%) rename {util/src => src/util}/migrations/sqlite/1660260672914-CodeCleanup4.ts (100%) rename {util/src => src/util}/schemas/ActivitySchema.ts (100%) rename {util/src => src/util}/schemas/BanCreateSchema.ts (100%) rename {util/src => src/util}/schemas/BanModeratorSchema.ts (100%) rename {util/src => src/util}/schemas/BanRegistrySchema.ts (100%) rename {util/src => src/util}/schemas/BulkDeleteSchema.ts (100%) rename {util/src => src/util}/schemas/ChannelModifySchema.ts (100%) rename {util/src => src/util}/schemas/ChannelPermissionOverwriteSchema.ts (100%) rename {util/src => src/util}/schemas/ChannelReorderSchema.ts (100%) rename {util/src => src/util}/schemas/DmChannelCreateSchema.ts (100%) rename {util/src => src/util}/schemas/EmojiCreateSchema.ts (100%) rename {util/src => src/util}/schemas/EmojiModifySchema.ts (100%) rename {util/src => src/util}/schemas/GuildCreateSchema.ts (100%) rename {util/src => src/util}/schemas/GuildTemplateCreateSchema.ts (100%) rename {util/src => src/util}/schemas/GuildUpdateSchema.ts (100%) rename {util/src => src/util}/schemas/GuildUpdateWelcomeScreenSchema.ts (100%) rename {util/src => src/util}/schemas/IdentifySchema.ts (93%) rename {util/src => src/util}/schemas/InviteCreateSchema.ts (100%) rename {util/src => src/util}/schemas/LazyRequestSchema.ts (100%) rename {util/src => src/util}/schemas/LoginSchema.ts (100%) rename {util/src => src/util}/schemas/MemberChangeSchema.ts (100%) rename {util/src => src/util}/schemas/MemberNickChangeSchema.ts (100%) rename {util/src => src/util}/schemas/MessageAcknowledgeSchema.ts (100%) rename {util/src => src/util}/schemas/MessageCreateSchema.ts (100%) rename {util/src => src/util}/schemas/MfaCodesSchema.ts (100%) rename {util/src => src/util}/schemas/ModifyGuildStickerSchema.ts (100%) rename {util/src => src/util}/schemas/PruneSchema.ts (100%) rename {util/src => src/util}/schemas/PurgeSchema.ts (100%) rename {util/src => src/util}/schemas/RegisterSchema.ts (100%) rename {util/src => src/util}/schemas/RelationshipPostSchema.ts (100%) rename {util/src => src/util}/schemas/RelationshipPutSchema.ts (100%) rename {util/src => src/util}/schemas/RoleModifySchema.ts (100%) rename {util/src => src/util}/schemas/RolePositionUpdateSchema.ts (100%) rename {util/src => src/util}/schemas/TemplateCreateSchema.ts (100%) rename {util/src => src/util}/schemas/TemplateModifySchema.ts (100%) rename {util/src => src/util}/schemas/TotpDisableSchema.ts (100%) rename {util/src => src/util}/schemas/TotpEnableSchema.ts (100%) rename {util/src => src/util}/schemas/TotpSchema.ts (100%) rename {util/src => src/util}/schemas/UserModifySchema.ts (100%) rename {util/src => src/util}/schemas/UserSettingsSchema.ts (100%) rename {util/src => src/util}/schemas/VanityUrlSchema.ts (100%) rename {util/src => src/util}/schemas/VoiceStateUpdateSchema.ts (100%) rename {util/src => src/util}/schemas/WebhookCreateSchema.ts (100%) rename {util/src => src/util}/schemas/WidgetModifySchema.ts (100%) rename {util/src => src/util}/schemas/index.ts (100%) rename {util/src => src/util}/util/ApiError.ts (100%) rename {util/src => src/util}/util/Array.ts (100%) rename {util/src => src/util}/util/AutoUpdate.ts (100%) rename {util/src => src/util}/util/BitField.ts (100%) rename {util/src => src/util}/util/Categories.ts (100%) rename {util/src => src/util}/util/Config.ts (100%) rename {util/src => src/util}/util/Constants.ts (100%) rename {util/src => src/util}/util/Database.ts (100%) rename {util/src => src/util}/util/Email.ts (100%) rename {util/src => src/util}/util/Event.ts (100%) rename {util/src => src/util}/util/FieldError.ts (100%) rename {util/src => src/util}/util/Intents.ts (100%) rename {util/src => src/util}/util/InvisibleCharacters.ts (100%) rename {util/src => src/util}/util/MFA.ts (100%) rename {util/src => src/util}/util/MessageFlags.ts (100%) rename {util/src => src/util}/util/Permissions.ts (100%) rename {util/src => src/util}/util/RabbitMQ.ts (100%) rename {util/src => src/util}/util/Regex.ts (100%) rename {util/src => src/util}/util/Rights.ts (100%) rename {util/src => src/util}/util/Snowflake.ts (100%) rename {util/src => src/util}/util/String.ts (100%) rename {util/src => src/util}/util/Token.ts (100%) rename {util/src => src/util}/util/TraverseDirectory.ts (100%) rename {util/src => src/util}/util/cdn.ts (100%) rename {util/src => src/util}/util/imports/Checks.ts (100%) rename {util/src => src/util}/util/imports/HTTPError.ts (100%) rename {util/src => src/util}/util/imports/OrmUtils.ts (100%) rename {util/src => src/util}/util/imports/index.ts (100%) rename {util/src => src/util}/util/index.ts (100%) rename {util/tests => tests}/User.test.js (100%) rename {cdn/tests => tests}/antman.jpg (100%) rename {cdn/tests => tests}/cdn_endpoints.test.js (100%) rename {cdn/tests => tests}/filestorage.test.js (100%) rename {api/tests => tests}/routes.test.ts (100%) rename {api/tests => tests}/routes/auth/login.test.js (100%) rename {api/tests => tests}/routes/auth/register.test.js (100%) rename {api/tests => tests}/routes/ping.test.js (100%) rename {util/tests => tests}/setupJest.js (100%) rename bundle/tsconfig.json => tsconfig.json (92%) delete mode 100644 util/.gitignore delete mode 100644 util/.npmignore delete mode 100644 util/.prettierrc delete mode 100644 util/.vscode/launch.json delete mode 100644 util/README.md delete mode 100644 util/package-lock.json delete mode 100644 util/package.json delete mode 100644 util/tsconfig.json delete mode 100644 webrtc/.DS_Store delete mode 100644 webrtc/.gitignore delete mode 100644 webrtc/README.md delete mode 100644 webrtc/package-lock.json delete mode 100644 webrtc/package.json delete mode 100644 webrtc/src/Server.ts delete mode 100644 webrtc/src/index.ts delete mode 100644 webrtc/src/start.ts delete mode 100644 webrtc/src/test.ts delete mode 100644 webrtc/tsconfig.json create mode 100644 yarn.lock diff --git a/api/.dockerignore b/.dockerignore similarity index 100% rename from api/.dockerignore rename to .dockerignore diff --git a/.gitignore b/.gitignore index 98adcd003..e9f3f39c9 100644 --- a/.gitignore +++ b/.gitignore @@ -19,3 +19,5 @@ api/assets/plugins/*.js bundle/depclean.* *.tmp tmp/ + +assets/cache/ \ No newline at end of file diff --git a/api/.env.example b/api/.env.example deleted file mode 100644 index 5974f6286..000000000 --- a/api/.env.example +++ /dev/null @@ -1,8 +0,0 @@ -MONGO_URL=mongodb://localhost/fosscord -PORT=3001 -PRODUCTION=TRUE -THREADS=# automatically use all available cores, only available if production = true -#LOG_REQUESTS= -# only log 200 and 204: LOG_REQUESTS=200 204 -# log everything except 200 and 204: LOG_REQUESTS=-200 204 -# log all requests: LOG_REQUESTS=- \ No newline at end of file diff --git a/api/.gitignore b/api/.gitignore deleted file mode 100644 index 662816b93..000000000 --- a/api/.gitignore +++ /dev/null @@ -1,115 +0,0 @@ -# Logs -logs -*.log -npm-debug.log* -yarn-debug.log* -yarn-error.log* -lerna-debug.log* - -# Diagnostic reports (https://nodejs.org/api/report.html) -report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json - -# Runtime data -pids -*.pid -*.seed -*.pid.lock - -# Directory for instrumented libs generated by jscoverage/JSCover -lib-cov - -# Coverage directory used by tools like istanbul -coverage -*.lcov - -# nyc test coverage -.nyc_output - -# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) -.grunt - -# Bower dependency directory (https://bower.io/) -bower_components - -# node-waf configuration -.lock-wscript - -# Compiled binary addons (https://nodejs.org/api/addons.html) -build/Release - -# Dependency directories -node_modules/ -jspm_packages/ - -# TypeScript v1 declaration files -typings/ - -# TypeScript cache -*.tsbuildinfo - -# Optional npm cache directory -.npm - -# Optional eslint cache -.eslintcache - -# Microbundle cache -.rpt2_cache/ -.rts2_cache_cjs/ -.rts2_cache_es/ -.rts2_cache_umd/ - -# Optional REPL history -.node_repl_history - -# Output of 'npm pack' -*.tgz - -# Yarn Integrity file -.yarn-integrity - -# dotenv environment variables file -.env -.env.test - -# parcel-bundler cache (https://parceljs.org/) -.cache - -# Next.js build output -.next - -# Nuxt.js build / generate output -.nuxt -dist -build - -# Gatsby files -.cache/ -# Comment in the public line in if your project uses Gatsby and *not* Next.js -# https://nextjs.org/blog/next-9-1#public-directory-support -# public - -# vuepress build output -.vuepress/dist - -# Serverless directories -.serverless/ - -# FuseBox cache -.fusebox/ - -# DynamoDB Local files -.dynamodb/ - -# TernJS port file -.tern-port - -.DS_STORE -src/ready.json - -# Docker -.docker/config/* -!.docker/config/.keep - -# fosscord -*.db \ No newline at end of file diff --git a/api/.npmignore b/api/.npmignore deleted file mode 100644 index 05a9d0cf2..000000000 --- a/api/.npmignore +++ /dev/null @@ -1 +0,0 @@ -!dist/ \ No newline at end of file diff --git a/api/.prettierrc b/api/.prettierrc deleted file mode 100644 index 8a2c607fc..000000000 --- a/api/.prettierrc +++ /dev/null @@ -1,6 +0,0 @@ -{ - "tabWidth": 4, - "useTabs": true, - "printWidth": 140, - "trailingComma": "none" -} diff --git a/api/.vscode/api-snippets.code-snippets b/api/.vscode/api-snippets.code-snippets deleted file mode 100644 index ef4b6386a..000000000 --- a/api/.vscode/api-snippets.code-snippets +++ /dev/null @@ -1,25 +0,0 @@ -{ - "API Router": { - "scope": "javascript,typescript", - "prefix": "router", - "body": [ - "import { Router, Response, Request } from \"express\";", - "import { route } from \"@fosscord/api\";", - "", - "const router = Router();", - "", - "router.get(\"/\", route({}), (req: Request, res: Response) => {", - "\tres.json({});", - "});", - "", - "export default router;" - ], - "description": "A basic API router setup for a blank route." - }, - "Route": { - "scope": "typescript", - "prefix": "route", - "body": ["router.get(\"$1\", route({}), (req: Request, res: Response) => {", "\t$2", "});"], - "description": "An API endpoint" - } -} diff --git a/api/.vscode/launch.json b/api/.vscode/launch.json deleted file mode 100644 index 221931ee8..000000000 --- a/api/.vscode/launch.json +++ /dev/null @@ -1,28 +0,0 @@ -{ - // 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": [ - { - "sourceMaps": true, - "type": "node", - "request": "launch", - "name": "Launch Server", - "program": "${workspaceFolder}/dist/start.js", - "preLaunchTask": "tsc: build - tsconfig.json", - "outFiles": ["${workspaceFolder}/dist/**/*.js"], - "envFile": "${workspaceFolder}/.env" - }, - { - "name": "Debug current file", - "program": "${file}", - "request": "launch", - "skipFiles": ["/**"], - "runtimeArgs": ["--nolazy", "-r", "ts-node/register/transpile-only"], - "preLaunchTask": "tsc: build - tsconfig.json", - "type": "node", - "resolveSourceMapLocations": ["${workspaceFolder}/**", "!**/node_modules/**"] - } - ] -} diff --git a/api/Dockerfile b/api/Dockerfile deleted file mode 100644 index 08d15f72a..000000000 --- a/api/Dockerfile +++ /dev/null @@ -1,12 +0,0 @@ -FROM node:lts-alpine -# needed for native packages (bcrypt, canvas) -RUN apk add --no-cache make gcc g++ python cairo-dev jpeg-dev pango-dev giflib-dev -WORKDIR /usr/src/fosscord-server -COPY package.json . -COPY package-lock.json . -RUN npm rebuild bcrypt --build-from-source && npm install canvas --build-from-source -RUN npm install -COPY . . -EXPOSE 3001 -RUN npm run build-docker -CMD ["node", "dist/start.js"] diff --git a/api/README.md b/api/README.md deleted file mode 100644 index 62349972b..000000000 --- a/api/README.md +++ /dev/null @@ -1,67 +0,0 @@ -

- -

-

Fosscord HTTP API Server

- -
- -## [About](https://github.com/fosscord/fosscord-server/wiki) - -This repository contains the Fosscord HTTP API Server - -## Bug Tracker - -[Project Board](https://fosscord.notion.site/2c7fe9e73f9842d3bab3a4912dedd091) - -## API - -We use [express](https://expressjs.com/) for the HTTP Server and -[lambert-server](https://www.npmjs.com/package/lambert-server) for route handling and body validation (customized). - -## Contribution - -You should be familiar with: - -- [Git](https://git-scm.com/) -- [NodeJS](https://nodejs.org/) -- [TypeScript](https://www.typescriptlang.org/) -- [MongoDB/mongoose](http://mongoosejs.com/) - -and the other technologies we use - -### Getting Started - -Clone the Repository: - -```bash -git clone https://github.com/fosscord/fosscord-server -cd fosscord-server -``` - -#### Install (dev)dependencies: - -```bash -npm install -npm install --only=dev -``` - -#### Starting: - -``` -npm start -``` - -#### Debugging: - -**Vscode:** -The Launch file configuration is in `./vscode/launch.json`, -so you can just debug the server by pressing `F5` or the `> Launch Server` button diff --git a/api/babel.config.js b/api/babel.config.js deleted file mode 100644 index 45ab8ad8b..000000000 --- a/api/babel.config.js +++ /dev/null @@ -1,6 +0,0 @@ -module.exports = { - presets: [ - ["@babel/preset-env", { targets: { node: "current" } }], - ["@babel/preset-typescript", { allowDeclareFields: true }] - ] -}; diff --git a/api/jest/getRouteDescriptions.js b/api/jest/getRouteDescriptions.js deleted file mode 100644 index 4f8d2e75e..000000000 --- a/api/jest/getRouteDescriptions.js +++ /dev/null @@ -1,66 +0,0 @@ -const { traverseDirectory } = require("lambert-server"); -const path = require("path"); -const express = require("express"); -const RouteUtility = require("../dist/util/route"); -const Router = express.Router; - -/** - * Some documentation. - * - * @type {Map} - */ -const routes = new Map(); -let currentPath = ""; -let currentFile = ""; -const methods = ["get", "post", "put", "delete", "patch"]; - -function registerPath(file, method, prefix, path, ...args) { - const urlPath = prefix + path; - const sourceFile = file.replace("/dist/", "/src/").replace(".js", ".ts"); - const opts = args.find((x) => typeof x === "object"); - if (opts) { - routes.set(urlPath + "|" + method, opts); // @ts-ignore - opts.file = sourceFile; - // console.log(method, urlPath, opts); - } else { - console.log(`${sourceFile}\nrouter.${method}("${path}") is missing the "route()" description middleware\n`); - } -} - -function routeOptions(opts) { - return opts; -} - -// @ts-ignore -RouteUtility.route = routeOptions; - -express.Router = (opts) => { - const path = currentPath; - const file = currentFile; - const router = Router(opts); - - for (const method of methods) { - router[method] = registerPath.bind(null, file, method, path); - } - - return router; -}; - -module.exports = function getRouteDescriptions() { - const root = path.join(__dirname, "..", "dist", "routes", "/"); - traverseDirectory({ dirname: root, recursive: true }, (file) => { - currentFile = file; - let path = file.replace(root.slice(0, -1), ""); - path = path.split(".").slice(0, -1).join("."); // trancate .js/.ts file extension of path - path = path.replaceAll("#", ":").replaceAll("\\", "/"); // replace # with : for path parameters and windows paths with slashes - if (path.endsWith("/index")) path = path.slice(0, "/index".length * -1); // delete index from path - currentPath = path; - - try { - require(file); - } catch (error) { - console.error("error loading file " + file, error); - } - }); - return routes; -}; diff --git a/api/jest/globalSetup.js b/api/jest/globalSetup.js deleted file mode 100644 index 520aa0e2e..000000000 --- a/api/jest/globalSetup.js +++ /dev/null @@ -1,20 +0,0 @@ -const { Config, initDatabase } = require("@fosscord/util"); -const fs = require("fs"); -const path = require("path"); -const { FosscordServer } = require("../dist/Server"); -const Server = new FosscordServer({ port: 3001 }); -global.server = Server; -module.exports = async () => { - try { - fs.unlinkSync(path.join(process.cwd(), "database.db")); - } catch {} - - await initDatabase(); - await Config.init(); - Config.get().limits.rate.disabled = true; - return await Server.start(); -}; - -// afterAll(async () => { -// return await Server.stop(); -// }); diff --git a/api/jest/setup.js b/api/jest/setup.js deleted file mode 100644 index abc485ae3..000000000 --- a/api/jest/setup.js +++ /dev/null @@ -1,2 +0,0 @@ -jest.spyOn(global.console, "log").mockImplementation(() => jest.fn()); -jest.spyOn(global.console, "info").mockImplementation(() => jest.fn()); diff --git a/api/package-lock.json b/api/package-lock.json deleted file mode 100644 index bb7f725f90e4ca61cb3f7ff15ed1c020e95a3651..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 556574 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

&fayLqFtD%<)%BIBbST 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 diff --git a/api/package.json b/api/package.json deleted file mode 100644 index 1fa85884b..000000000 --- a/api/package.json +++ /dev/null @@ -1,91 +0,0 @@ -{ - "name": "@fosscord/api", - "version": "1.0.0", - "description": "This repository contains the HTTP API Server", - "main": "dist/index.js", - "types": "src/index.ts", - "scripts": { - "test:only": "npx jest --coverage --verbose --forceExit ./tests", - "test:routes": "npx jest --coverage --verbose --forceExit ./routes.test.ts", - "test": "npm run build && npm run test:only", - "test:watch": "npx jest --watch", - "start": "npm run build && node dist/start", - "build": "npx tsc -p .", - "dev": "npx tsnd --respawn src/start.ts", - "patch": "npx ts-patch install -s && npx patch-package", - "postinstall": "npm run patch", - "generate:docs": "node scripts/generate_openapi", - "generate:schema": "node scripts/generate_schema" - }, - "repository": { - "type": "git", - "url": "git+https://github.com/fosscord/fosscord-server.git" - }, - "keywords": [ - "discord", - "fosscord", - "fosscord-server", - "fosscord-api", - "discord open source", - "discord-open-source" - ], - "author": "Fosscord", - "license": "AGPL-3.0-only", - "bugs": { - "url": "https://github.com/fosscord/fosscord-server/issues" - }, - "homepage": "https://fosscord.com", - "devDependencies": { - "@babel/core": "^7.18.9", - "@babel/preset-env": "^7.18.9", - "@babel/preset-typescript": "^7.15.0", - "@types/bcrypt": "^5.0.0", - "@types/express": "^4.17.9", - "@types/i18next-node-fs-backend": "^2.1.0", - "@types/morgan": "^1.9.3", - "@types/multer": "^1.4.5", - "@types/node": "^18.0.6", - "jest": "^28.1.3", - "jest-expect-message": "^1.0.2", - "ts-node-dev": "^2.0.0", - "typescript": "^4.4.2", - "typescript-json-schema": "^0.54.0" - }, - "dependencies": { - "@babel/preset-typescript": "^7.15.0", - "@fosscord/util": "file:../util", - "ajv": "8.6.2", - "ajv-formats": "^2.1.1", - "bcrypt": "^5.0.1", - "body-parser": "^1.19.0", - "canvas": "^2.9.3", - "cheerio": "^1.0.0-rc.10", - "dotenv": "^16.0.1", - "express": "^4.17.1", - "i18next": "^21.8.14", - "i18next-http-middleware": "^3.1.3", - "i18next-node-fs-backend": "^2.1.3", - "image-size": "^1.0.0", - "lambert-server": "^1.2.12", - "missing-native-js-functions": "^1.2.18", - "morgan": "^1.10.0", - "multer": "^1.4.5-lts.1", - "node-2fa": "^2.0.3", - "node-fetch": "^2.6.7", - "patch-package": "^6.4.7", - "picocolors": "^1.0.0", - "proxy-agent": "^5.0.0", - "supertest": "^6.1.6", - "typeorm": "^0.3.7" - }, - "jest": { - "setupFiles": [ - "/jest/setup.js" - ], - "setupFilesAfterEnv": [ - "jest-expect-message" - ], - "globalSetup": "/jest/globalSetup.js", - "verbose": true - } -} diff --git a/api/tsconfig.json b/api/tsconfig.json deleted file mode 100644 index 80fca16df..000000000 --- a/api/tsconfig.json +++ /dev/null @@ -1,75 +0,0 @@ -{ - "exclude": ["node_modules"], - "include": ["src/**/*.ts"], - "compilerOptions": { - /* Visit https://aka.ms/tsconfig.json to read more about this file */ - - /* Basic Options */ - "incremental": false /* Enable incremental compilation */, - "target": "ESNext" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, - "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, - "lib": ["ES2021"] /* Specify library files to be included in the compilation. */, - "allowJs": true /* Allow javascript files to be compiled. */, - "checkJs": true /* Report errors in .js files. */, - // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ - "declaration": true /* Generates corresponding '.d.ts' file. */, - "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, - "sourceMap": true /* Generates corresponding '.map' file. */, - // "outFile": "./", /* Concatenate and emit output to single file. */ - "outDir": "./dist/" /* Redirect output structure to the directory. */, - "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, - // "composite": true, /* Enable project compilation */ - // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ - // "removeComments": true, /* Do not emit comments to output. */ - // "noEmit": true, /* Do not emit outputs. */ - // "importHelpers": true, /* Import emit helpers from 'tslib'. */ - // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ - // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ - - /* Strict Type-Checking Options */ - "strict": true /* Enable all strict type-checking options. */, - "noImplicitAny": true /* Raise error on expressions and declarations with an implied 'any' type. */, - "strictNullChecks": true /* Enable strict null checks. */, - // "strictFunctionTypes": true, /* Enable strict checking of function types. */ - // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ - "strictPropertyInitialization": false /* Enable strict checking of property initialization in classes. */, - // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ - "alwaysStrict": true /* Parse in strict mode and emit "use strict" for each source file. */, - - /* Additional Checks */ - // "noUnusedLocals": true, /* Report errors on unused locals. */ - // "noUnusedParameters": true, /* Report errors on unused parameters. */ - // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ - // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ - - /* Module Resolution Options */ - // "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ - // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ - // "typeRoots": [], /* List of folders to include type definitions from. */ - "types": ["node"] /* Type declaration files to be included in compilation. */, - // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ - "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, - // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ - // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ - - /* Source Map Options */ - // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ - // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ - // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ - // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ - - /* Experimental Options */ - // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ - // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ - - /* Advanced Options */ - "skipLibCheck": true /* Skip type checking of declaration files. */, - "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */, - "baseUrl": ".", - "paths": { - "@fosscord/api": ["src/index"] - }, - "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }], - "experimentalDecorators": true - } -} diff --git a/api/assets/checkLocale.js b/assets/checkLocale.js similarity index 100% rename from api/assets/checkLocale.js rename to assets/checkLocale.js diff --git a/api/client_test/developers.html b/assets/developers.html similarity index 100% rename from api/client_test/developers.html rename to assets/developers.html diff --git a/api/assets/dff87c953f43b561d71fbcfe8a93a79a.png b/assets/dff87c953f43b561d71fbcfe8a93a79a.png similarity index 100% rename from api/assets/dff87c953f43b561d71fbcfe8a93a79a.png rename to assets/dff87c953f43b561d71fbcfe8a93a79a.png diff --git a/api/assets/endpoints.json b/assets/endpoints.json similarity index 100% rename from api/assets/endpoints.json rename to assets/endpoints.json diff --git a/api/assets/features.json b/assets/features.json similarity index 100% rename from api/assets/features.json rename to assets/features.json diff --git a/api/assets/fosscord-login.css b/assets/fosscord-login.css similarity index 100% rename from api/assets/fosscord-login.css rename to assets/fosscord-login.css diff --git a/api/assets/fosscord.css b/assets/fosscord.css similarity index 100% rename from api/assets/fosscord.css rename to assets/fosscord.css diff --git a/api/client_test/index.html b/assets/index.html similarity index 98% rename from api/client_test/index.html rename to assets/index.html index c35c14d2b..64a2bdbff 100644 --- a/api/client_test/index.html +++ b/assets/index.html @@ -20,7 +20,7 @@ window.GLOBAL_ENV = { API_ENDPOINT: "/api", API_VERSION: 9, - GATEWAY_ENDPOINT: `${location.protocol === "https:" ? "wss://" : "ws://"}${location.hostname}:3002`, + GATEWAY_ENDPOINT: `${location.protocol === "https:" ? "wss://" : "ws://"}${location.host}`, WEBAPP_ENDPOINT: "", CDN_HOST: `${location.hostname}:3003`, ASSET_ENDPOINT: "", diff --git a/api/assets/inline-plugins/autoRegister.js b/assets/inline-plugins/autoRegister.js similarity index 100% rename from api/assets/inline-plugins/autoRegister.js rename to assets/inline-plugins/autoRegister.js diff --git a/api/assets/inline-plugins/fosscord-login.js b/assets/inline-plugins/fosscord-login.js similarity index 100% rename from api/assets/inline-plugins/fosscord-login.js rename to assets/inline-plugins/fosscord-login.js diff --git a/api/locales/af/auth.json b/assets/locales/af/auth.json similarity index 100% rename from api/locales/af/auth.json rename to assets/locales/af/auth.json diff --git a/api/locales/af/common.json b/assets/locales/af/common.json similarity index 100% rename from api/locales/af/common.json rename to assets/locales/af/common.json diff --git a/api/locales/ar/auth.json b/assets/locales/ar/auth.json similarity index 100% rename from api/locales/ar/auth.json rename to assets/locales/ar/auth.json diff --git a/api/locales/ar/common.json b/assets/locales/ar/common.json similarity index 100% rename from api/locales/ar/common.json rename to assets/locales/ar/common.json diff --git a/api/locales/arn/auth.json b/assets/locales/arn/auth.json similarity index 100% rename from api/locales/arn/auth.json rename to assets/locales/arn/auth.json diff --git a/api/locales/arn/common.json b/assets/locales/arn/common.json similarity index 100% rename from api/locales/arn/common.json rename to assets/locales/arn/common.json diff --git a/api/locales/az/auth.json b/assets/locales/az/auth.json similarity index 100% rename from api/locales/az/auth.json rename to assets/locales/az/auth.json diff --git a/api/locales/az/common.json b/assets/locales/az/common.json similarity index 100% rename from api/locales/az/common.json rename to assets/locales/az/common.json diff --git a/api/locales/be/auth.json b/assets/locales/be/auth.json similarity index 100% rename from api/locales/be/auth.json rename to assets/locales/be/auth.json diff --git a/api/locales/be/common.json b/assets/locales/be/common.json similarity index 100% rename from api/locales/be/common.json rename to assets/locales/be/common.json diff --git a/api/locales/ber/auth.json b/assets/locales/ber/auth.json similarity index 100% rename from api/locales/ber/auth.json rename to assets/locales/ber/auth.json diff --git a/api/locales/ber/common.json b/assets/locales/ber/common.json similarity index 100% rename from api/locales/ber/common.json rename to assets/locales/ber/common.json diff --git a/api/locales/bg/auth.json b/assets/locales/bg/auth.json similarity index 100% rename from api/locales/bg/auth.json rename to assets/locales/bg/auth.json diff --git a/api/locales/bg/common.json b/assets/locales/bg/common.json similarity index 100% rename from api/locales/bg/common.json rename to assets/locales/bg/common.json diff --git a/api/locales/bo/auth.json b/assets/locales/bo/auth.json similarity index 100% rename from api/locales/bo/auth.json rename to assets/locales/bo/auth.json diff --git a/api/locales/bo/common.json b/assets/locales/bo/common.json similarity index 100% rename from api/locales/bo/common.json rename to assets/locales/bo/common.json diff --git a/api/locales/ca/auth.json b/assets/locales/ca/auth.json similarity index 100% rename from api/locales/ca/auth.json rename to assets/locales/ca/auth.json diff --git a/api/locales/ca/common.json b/assets/locales/ca/common.json similarity index 100% rename from api/locales/ca/common.json rename to assets/locales/ca/common.json diff --git a/api/locales/cs/auth.json b/assets/locales/cs/auth.json similarity index 100% rename from api/locales/cs/auth.json rename to assets/locales/cs/auth.json diff --git a/api/locales/cs/common.json b/assets/locales/cs/common.json similarity index 100% rename from api/locales/cs/common.json rename to assets/locales/cs/common.json diff --git a/api/locales/da/auth.json b/assets/locales/da/auth.json similarity index 100% rename from api/locales/da/auth.json rename to assets/locales/da/auth.json diff --git a/api/locales/da/common.json b/assets/locales/da/common.json similarity index 100% rename from api/locales/da/common.json rename to assets/locales/da/common.json diff --git a/api/locales/de/auth.json b/assets/locales/de/auth.json similarity index 100% rename from api/locales/de/auth.json rename to assets/locales/de/auth.json diff --git a/api/locales/de/common.json b/assets/locales/de/common.json similarity index 100% rename from api/locales/de/common.json rename to assets/locales/de/common.json diff --git a/api/locales/el/auth.json b/assets/locales/el/auth.json similarity index 100% rename from api/locales/el/auth.json rename to assets/locales/el/auth.json diff --git a/api/locales/el/common.json b/assets/locales/el/common.json similarity index 100% rename from api/locales/el/common.json rename to assets/locales/el/common.json diff --git a/api/locales/en/auth.json b/assets/locales/en/auth.json similarity index 100% rename from api/locales/en/auth.json rename to assets/locales/en/auth.json diff --git a/api/locales/en/common.json b/assets/locales/en/common.json similarity index 100% rename from api/locales/en/common.json rename to assets/locales/en/common.json diff --git a/api/locales/eo/auth.json b/assets/locales/eo/auth.json similarity index 100% rename from api/locales/eo/auth.json rename to assets/locales/eo/auth.json diff --git a/api/locales/eo/common.json b/assets/locales/eo/common.json similarity index 100% rename from api/locales/eo/common.json rename to assets/locales/eo/common.json diff --git a/api/locales/es/auth.json b/assets/locales/es/auth.json similarity index 100% rename from api/locales/es/auth.json rename to assets/locales/es/auth.json diff --git a/api/locales/es/common.json b/assets/locales/es/common.json similarity index 100% rename from api/locales/es/common.json rename to assets/locales/es/common.json diff --git a/api/locales/eu/auth.json b/assets/locales/eu/auth.json similarity index 100% rename from api/locales/eu/auth.json rename to assets/locales/eu/auth.json diff --git a/api/locales/eu/common.json b/assets/locales/eu/common.json similarity index 100% rename from api/locales/eu/common.json rename to assets/locales/eu/common.json diff --git a/api/locales/fa/auth.json b/assets/locales/fa/auth.json similarity index 100% rename from api/locales/fa/auth.json rename to assets/locales/fa/auth.json diff --git a/api/locales/fa/common.json b/assets/locales/fa/common.json similarity index 100% rename from api/locales/fa/common.json rename to assets/locales/fa/common.json diff --git a/api/locales/fi/auth.json b/assets/locales/fi/auth.json similarity index 100% rename from api/locales/fi/auth.json rename to assets/locales/fi/auth.json diff --git a/api/locales/fi/common.json b/assets/locales/fi/common.json similarity index 100% rename from api/locales/fi/common.json rename to assets/locales/fi/common.json diff --git a/api/locales/fr/auth.json b/assets/locales/fr/auth.json similarity index 100% rename from api/locales/fr/auth.json rename to assets/locales/fr/auth.json diff --git a/api/locales/fr/common.json b/assets/locales/fr/common.json similarity index 100% rename from api/locales/fr/common.json rename to assets/locales/fr/common.json diff --git a/api/locales/gn/auth.json b/assets/locales/gn/auth.json similarity index 100% rename from api/locales/gn/auth.json rename to assets/locales/gn/auth.json diff --git a/api/locales/gn/common.json b/assets/locales/gn/common.json similarity index 100% rename from api/locales/gn/common.json rename to assets/locales/gn/common.json diff --git a/api/locales/ha/auth.json b/assets/locales/ha/auth.json similarity index 100% rename from api/locales/ha/auth.json rename to assets/locales/ha/auth.json diff --git a/api/locales/ha/common.json b/assets/locales/ha/common.json similarity index 100% rename from api/locales/ha/common.json rename to assets/locales/ha/common.json diff --git a/api/locales/he/auth.json b/assets/locales/he/auth.json similarity index 100% rename from api/locales/he/auth.json rename to assets/locales/he/auth.json diff --git a/api/locales/he/common.json b/assets/locales/he/common.json similarity index 100% rename from api/locales/he/common.json rename to assets/locales/he/common.json diff --git a/api/locales/hi/auth.json b/assets/locales/hi/auth.json similarity index 100% rename from api/locales/hi/auth.json rename to assets/locales/hi/auth.json diff --git a/api/locales/hi/common.json b/assets/locales/hi/common.json similarity index 100% rename from api/locales/hi/common.json rename to assets/locales/hi/common.json diff --git a/api/locales/hr/auth.json b/assets/locales/hr/auth.json similarity index 100% rename from api/locales/hr/auth.json rename to assets/locales/hr/auth.json diff --git a/api/locales/hr/common.json b/assets/locales/hr/common.json similarity index 100% rename from api/locales/hr/common.json rename to assets/locales/hr/common.json diff --git a/api/locales/hu/auth.json b/assets/locales/hu/auth.json similarity index 100% rename from api/locales/hu/auth.json rename to assets/locales/hu/auth.json diff --git a/api/locales/hu/common.json b/assets/locales/hu/common.json similarity index 100% rename from api/locales/hu/common.json rename to assets/locales/hu/common.json diff --git a/api/locales/id/auth.json b/assets/locales/id/auth.json similarity index 100% rename from api/locales/id/auth.json rename to assets/locales/id/auth.json diff --git a/api/locales/id/common.json b/assets/locales/id/common.json similarity index 100% rename from api/locales/id/common.json rename to assets/locales/id/common.json diff --git a/api/locales/it/auth.json b/assets/locales/it/auth.json similarity index 100% rename from api/locales/it/auth.json rename to assets/locales/it/auth.json diff --git a/api/locales/it/common.json b/assets/locales/it/common.json similarity index 100% rename from api/locales/it/common.json rename to assets/locales/it/common.json diff --git a/api/locales/ja/auth.json b/assets/locales/ja/auth.json similarity index 100% rename from api/locales/ja/auth.json rename to assets/locales/ja/auth.json diff --git a/api/locales/ja/common.json b/assets/locales/ja/common.json similarity index 100% rename from api/locales/ja/common.json rename to assets/locales/ja/common.json diff --git a/api/locales/jv/auth.json b/assets/locales/jv/auth.json similarity index 100% rename from api/locales/jv/auth.json rename to assets/locales/jv/auth.json diff --git a/api/locales/jv/common.json b/assets/locales/jv/common.json similarity index 100% rename from api/locales/jv/common.json rename to assets/locales/jv/common.json diff --git a/api/locales/kk/auth.json b/assets/locales/kk/auth.json similarity index 100% rename from api/locales/kk/auth.json rename to assets/locales/kk/auth.json diff --git a/api/locales/kk/common.json b/assets/locales/kk/common.json similarity index 100% rename from api/locales/kk/common.json rename to assets/locales/kk/common.json diff --git a/api/locales/ko/auth.json b/assets/locales/ko/auth.json similarity index 100% rename from api/locales/ko/auth.json rename to assets/locales/ko/auth.json diff --git a/api/locales/ko/common.json b/assets/locales/ko/common.json similarity index 100% rename from api/locales/ko/common.json rename to assets/locales/ko/common.json diff --git a/api/locales/ku/auth.json b/assets/locales/ku/auth.json similarity index 100% rename from api/locales/ku/auth.json rename to assets/locales/ku/auth.json diff --git a/api/locales/ku/common.json b/assets/locales/ku/common.json similarity index 100% rename from api/locales/ku/common.json rename to assets/locales/ku/common.json diff --git a/api/locales/la/auth.json b/assets/locales/la/auth.json similarity index 100% rename from api/locales/la/auth.json rename to assets/locales/la/auth.json diff --git a/api/locales/la/common.json b/assets/locales/la/common.json similarity index 100% rename from api/locales/la/common.json rename to assets/locales/la/common.json diff --git a/api/locales/lt/auth.json b/assets/locales/lt/auth.json similarity index 100% rename from api/locales/lt/auth.json rename to assets/locales/lt/auth.json diff --git a/api/locales/lt/common.json b/assets/locales/lt/common.json similarity index 100% rename from api/locales/lt/common.json rename to assets/locales/lt/common.json diff --git a/api/locales/mi/auth.json b/assets/locales/mi/auth.json similarity index 100% rename from api/locales/mi/auth.json rename to assets/locales/mi/auth.json diff --git a/api/locales/mi/common.json b/assets/locales/mi/common.json similarity index 100% rename from api/locales/mi/common.json rename to assets/locales/mi/common.json diff --git a/api/locales/mn/auth.json b/assets/locales/mn/auth.json similarity index 100% rename from api/locales/mn/auth.json rename to assets/locales/mn/auth.json diff --git a/api/locales/mn/common.json b/assets/locales/mn/common.json similarity index 100% rename from api/locales/mn/common.json rename to assets/locales/mn/common.json diff --git a/api/locales/mr/auth.json b/assets/locales/mr/auth.json similarity index 100% rename from api/locales/mr/auth.json rename to assets/locales/mr/auth.json diff --git a/api/locales/mr/common.json b/assets/locales/mr/common.json similarity index 100% rename from api/locales/mr/common.json rename to assets/locales/mr/common.json diff --git a/api/locales/nl/auth.json b/assets/locales/nl/auth.json similarity index 100% rename from api/locales/nl/auth.json rename to assets/locales/nl/auth.json diff --git a/api/locales/nl/common.json b/assets/locales/nl/common.json similarity index 100% rename from api/locales/nl/common.json rename to assets/locales/nl/common.json diff --git a/api/locales/nn/auth.json b/assets/locales/nn/auth.json similarity index 100% rename from api/locales/nn/auth.json rename to assets/locales/nn/auth.json diff --git a/api/locales/nn/common.json b/assets/locales/nn/common.json similarity index 100% rename from api/locales/nn/common.json rename to assets/locales/nn/common.json diff --git a/api/locales/no/auth.json b/assets/locales/no/auth.json similarity index 100% rename from api/locales/no/auth.json rename to assets/locales/no/auth.json diff --git a/api/locales/no/common.json b/assets/locales/no/common.json similarity index 100% rename from api/locales/no/common.json rename to assets/locales/no/common.json diff --git a/api/locales/pa/auth.json b/assets/locales/pa/auth.json similarity index 100% rename from api/locales/pa/auth.json rename to assets/locales/pa/auth.json diff --git a/api/locales/pa/common.json b/assets/locales/pa/common.json similarity index 100% rename from api/locales/pa/common.json rename to assets/locales/pa/common.json diff --git a/api/locales/pl/auth.json b/assets/locales/pl/auth.json similarity index 100% rename from api/locales/pl/auth.json rename to assets/locales/pl/auth.json diff --git a/api/locales/pl/common.json b/assets/locales/pl/common.json similarity index 100% rename from api/locales/pl/common.json rename to assets/locales/pl/common.json diff --git a/api/locales/pt/auth.json b/assets/locales/pt/auth.json similarity index 100% rename from api/locales/pt/auth.json rename to assets/locales/pt/auth.json diff --git a/api/locales/pt/common.json b/assets/locales/pt/common.json similarity index 100% rename from api/locales/pt/common.json rename to assets/locales/pt/common.json diff --git a/api/locales/qu/auth.json b/assets/locales/qu/auth.json similarity index 100% rename from api/locales/qu/auth.json rename to assets/locales/qu/auth.json diff --git a/api/locales/qu/common.json b/assets/locales/qu/common.json similarity index 100% rename from api/locales/qu/common.json rename to assets/locales/qu/common.json diff --git a/api/locales/ro/auth.json b/assets/locales/ro/auth.json similarity index 100% rename from api/locales/ro/auth.json rename to assets/locales/ro/auth.json diff --git a/api/locales/ro/common.json b/assets/locales/ro/common.json similarity index 100% rename from api/locales/ro/common.json rename to assets/locales/ro/common.json diff --git a/api/locales/ru/auth.json b/assets/locales/ru/auth.json similarity index 100% rename from api/locales/ru/auth.json rename to assets/locales/ru/auth.json diff --git a/api/locales/ru/common.json b/assets/locales/ru/common.json similarity index 100% rename from api/locales/ru/common.json rename to assets/locales/ru/common.json diff --git a/api/locales/sh/auth.json b/assets/locales/sh/auth.json similarity index 100% rename from api/locales/sh/auth.json rename to assets/locales/sh/auth.json diff --git a/api/locales/sh/common.json b/assets/locales/sh/common.json similarity index 100% rename from api/locales/sh/common.json rename to assets/locales/sh/common.json diff --git a/api/locales/si/auth.json b/assets/locales/si/auth.json similarity index 100% rename from api/locales/si/auth.json rename to assets/locales/si/auth.json diff --git a/api/locales/si/common.json b/assets/locales/si/common.json similarity index 100% rename from api/locales/si/common.json rename to assets/locales/si/common.json diff --git a/api/locales/sk/auth.json b/assets/locales/sk/auth.json similarity index 100% rename from api/locales/sk/auth.json rename to assets/locales/sk/auth.json diff --git a/api/locales/sk/common.json b/assets/locales/sk/common.json similarity index 100% rename from api/locales/sk/common.json rename to assets/locales/sk/common.json diff --git a/api/locales/sr/auth.json b/assets/locales/sr/auth.json similarity index 100% rename from api/locales/sr/auth.json rename to assets/locales/sr/auth.json diff --git a/api/locales/sr/common.json b/assets/locales/sr/common.json similarity index 100% rename from api/locales/sr/common.json rename to assets/locales/sr/common.json diff --git a/api/locales/sv/auth.json b/assets/locales/sv/auth.json similarity index 100% rename from api/locales/sv/auth.json rename to assets/locales/sv/auth.json diff --git a/api/locales/sv/common.json b/assets/locales/sv/common.json similarity index 100% rename from api/locales/sv/common.json rename to assets/locales/sv/common.json diff --git a/api/locales/sw/auth.json b/assets/locales/sw/auth.json similarity index 100% rename from api/locales/sw/auth.json rename to assets/locales/sw/auth.json diff --git a/api/locales/sw/common.json b/assets/locales/sw/common.json similarity index 100% rename from api/locales/sw/common.json rename to assets/locales/sw/common.json diff --git a/api/locales/ta/auth.json b/assets/locales/ta/auth.json similarity index 100% rename from api/locales/ta/auth.json rename to assets/locales/ta/auth.json diff --git a/api/locales/ta/common.json b/assets/locales/ta/common.json similarity index 100% rename from api/locales/ta/common.json rename to assets/locales/ta/common.json diff --git a/api/locales/te/auth.json b/assets/locales/te/auth.json similarity index 100% rename from api/locales/te/auth.json rename to assets/locales/te/auth.json diff --git a/api/locales/te/common.json b/assets/locales/te/common.json similarity index 100% rename from api/locales/te/common.json rename to assets/locales/te/common.json diff --git a/api/locales/tl/auth.json b/assets/locales/tl/auth.json similarity index 100% rename from api/locales/tl/auth.json rename to assets/locales/tl/auth.json diff --git a/api/locales/tl/common.json b/assets/locales/tl/common.json similarity index 100% rename from api/locales/tl/common.json rename to assets/locales/tl/common.json diff --git a/api/locales/tr/auth.json b/assets/locales/tr/auth.json similarity index 100% rename from api/locales/tr/auth.json rename to assets/locales/tr/auth.json diff --git a/api/locales/tr/common.json b/assets/locales/tr/common.json similarity index 100% rename from api/locales/tr/common.json rename to assets/locales/tr/common.json diff --git a/api/locales/ug/auth.json b/assets/locales/ug/auth.json similarity index 100% rename from api/locales/ug/auth.json rename to assets/locales/ug/auth.json diff --git a/api/locales/ug/common.json b/assets/locales/ug/common.json similarity index 100% rename from api/locales/ug/common.json rename to assets/locales/ug/common.json diff --git a/api/locales/uk/auth.json b/assets/locales/uk/auth.json similarity index 100% rename from api/locales/uk/auth.json rename to assets/locales/uk/auth.json diff --git a/api/locales/uk/common.json b/assets/locales/uk/common.json similarity index 100% rename from api/locales/uk/common.json rename to assets/locales/uk/common.json diff --git a/api/locales/ur/auth.json b/assets/locales/ur/auth.json similarity index 100% rename from api/locales/ur/auth.json rename to assets/locales/ur/auth.json diff --git a/api/locales/ur/common.json b/assets/locales/ur/common.json similarity index 100% rename from api/locales/ur/common.json rename to assets/locales/ur/common.json diff --git a/api/locales/vec/auth.json b/assets/locales/vec/auth.json similarity index 100% rename from api/locales/vec/auth.json rename to assets/locales/vec/auth.json diff --git a/api/locales/vec/common.json b/assets/locales/vec/common.json similarity index 100% rename from api/locales/vec/common.json rename to assets/locales/vec/common.json diff --git a/api/locales/vi/auth.json b/assets/locales/vi/auth.json similarity index 100% rename from api/locales/vi/auth.json rename to assets/locales/vi/auth.json diff --git a/api/locales/vi/common.json b/assets/locales/vi/common.json similarity index 100% rename from api/locales/vi/common.json rename to assets/locales/vi/common.json diff --git a/api/locales/zh/auth.json b/assets/locales/zh/auth.json similarity index 100% rename from api/locales/zh/auth.json rename to assets/locales/zh/auth.json diff --git a/api/locales/zh/common.json b/assets/locales/zh/common.json similarity index 100% rename from api/locales/zh/common.json rename to assets/locales/zh/common.json diff --git a/api/assets/openapi.json b/assets/openapi.json similarity index 100% rename from api/assets/openapi.json rename to assets/openapi.json diff --git a/api/assets/plugins/.gitkeep b/assets/plugins/.gitkeep similarity index 100% rename from api/assets/plugins/.gitkeep rename to assets/plugins/.gitkeep diff --git a/api/assets/preload-plugins/.gitkeep b/assets/preload-plugins/.gitkeep similarity index 100% rename from api/assets/preload-plugins/.gitkeep rename to assets/preload-plugins/.gitkeep diff --git a/api/assets/schemas.json b/assets/schemas.json similarity index 63% rename from api/assets/schemas.json rename to assets/schemas.json index 9286b8046125efc39a921add6ee7f867c11ba1bb..0fe3dfa122a0f1ba5315ee66660ce2b4ab18fa29 100644 GIT binary patch delta 222 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 Y*uJ`o6QG{`)(zMH5ppSLQl< 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%0A~ejJ>e<=Br=oI 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

fdRp(w9jWMiYANgxF5Mk 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

HUx$=|4A3;Yoj-cL1OoX7lTH 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 { - // const [cpuUsed, memory, network] = await Promise.all([ - // osu.cpu.usage(), - // osu.mem.info(), - // osu.netstat.inOut(), - // ]); - // let networkUsage = ""; - // if (typeof network === "object") { - // networkUsage = `| [Network]: in ${network.total.inputMb}mb | out ${network.total.outputMb}mb`; - // } - - // console.log( - // `[CPU] ${cpuUsed.toPrecision(3)}% | [Memory] ${Math.round( - // process.memoryUsage().rss / 1024 / 1024 - // )}mb/${memory.totalMemMb.toFixed(0)}mb ${networkUsage}` - // ); - // }, 1000 * 60 * 5); -} diff --git a/bundle/tsnode.tsconfig.json b/bundle/tsnode.tsconfig.json deleted file mode 100644 index 422d336c6..000000000 --- a/bundle/tsnode.tsconfig.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "extends": "./tsconfig.json", - "ts-node": { - "transpileOnly": true, - "preferTsExts": true, - "require": ["tsconfig-paths/register"], - "compiler": "typescript-cached-transpile", - }, - "compilerOptions": { - "rootDir": "../", - "baseUrl": "../", - "sourceRoot": "../", - "sourceMap": true, - } -} \ No newline at end of file diff --git a/cdn/.env.example b/cdn/.env.example deleted file mode 100644 index b5e011f17..000000000 --- a/cdn/.env.example +++ /dev/null @@ -1,3 +0,0 @@ -STORAGE_LOCATION=files/ -STORAGE_PROVIDER=file -PORT=3003 \ No newline at end of file diff --git a/cdn/.gitignore b/cdn/.gitignore deleted file mode 100644 index 14dd53b59..000000000 --- a/cdn/.gitignore +++ /dev/null @@ -1,7 +0,0 @@ -.vscode/ -node_modules/ -.DS_Store -.env -dist/ -files/ -coverage/ \ No newline at end of file diff --git a/cdn/.swcrc b/cdn/.swcrc deleted file mode 100644 index ab5311941..000000000 --- a/cdn/.swcrc +++ /dev/null @@ -1,17 +0,0 @@ -{ - "module": { - "type": "commonjs" - }, - "jsc": { - "parser": { - "syntax": "typescript", - "decorators": true - }, - "target": "es2021", - "baseUrl": ".", - "paths": { - "@fosscord/cdn/": ["src/index"], - "@fosscord/cdn/*": ["src/*"] - } - } -} diff --git a/cdn/Dockerfile b/cdn/Dockerfile deleted file mode 100644 index d9ad78f49..000000000 --- a/cdn/Dockerfile +++ /dev/null @@ -1,7 +0,0 @@ -FROM node:lts-alpine -WORKDIR /usr/src/fosscord-cdn -COPY package.json . -RUN npm install -COPY . . -EXPOSE 3003 -CMD ["node", "dist/"] \ No newline at end of file diff --git a/cdn/README.md b/cdn/README.md deleted file mode 100644 index 7d8e99b05..000000000 --- a/cdn/README.md +++ /dev/null @@ -1,112 +0,0 @@ -# Fosscord-CDN - -CDN for Fosscord - -## Run localy: - -``` -npm i -node dist/ -``` - -## Endpoints: - -### POST `/attachments/` - -``` -Content-Type: form-data - -attachment: File (binary-data) -``` - -##### Returns: - -``` -{ - "success": boolean, // true - "message": string, // "attachment uploaded" - "id": snowflake, // "794183329158135808" - "filename": string // "lakdoiauej.png" -} -``` - -### GET `/attachments//` - -``` -requests image from database with given and -``` - -##### Returns: - -``` -Content-Type: image/ -Image -``` - -### DELETE `/attachments//` - -``` -deletes database entry -``` - -##### Returns: - -``` -Content-Type: application/json - -{ - "success": true, - "message": "attachment deleted" -} -``` - -


- -_(endpoints for crawler):_ - -### POST `/external` - -``` -requests crawling of `og:`metadata and the download of the `og:image` property --------- -Content-Type: application/json - -body: -{"url": URL} // "https://discord.com" -``` - -##### Returns: - -``` -Content-Type: application/json - -{ - "id": string, // "aHR0cHM6Ly9kaXNjb3JkLmNvbQ==" - "ogTitle": string, // "Discord | Your Place to Talk and Hang Out" - "ogDescription": string, // "Discord is the easiest way to talk over voice, video, and text. Talk, chat, hang out, and stay close with your friends and communities." - "cachedImage": string, // "/external/aHR0cHM6Ly9kaXNjb3JkLmNvbQ==/discord.png" - "ogUrl": string, // "https://discord.com/" - "ogType": string // "website" -} -``` - -### GET `/external//` - -- requests cached crawled image - -``` -url-params: - :id // aHR0cHM6Ly9kaXNjb3JkLmNvbQ== - :filename // discord.png -``` - -``` -/external/aHR0cHM6Ly9kaXNjb3JkLmNvbQ==/discord.png -``` - -##### Returns: - -``` -Content-Type: image/ -Image -``` diff --git a/cdn/jest/setup.js b/cdn/jest/setup.js deleted file mode 100644 index abc485ae3..000000000 --- a/cdn/jest/setup.js +++ /dev/null @@ -1,2 +0,0 @@ -jest.spyOn(global.console, "log").mockImplementation(() => jest.fn()); -jest.spyOn(global.console, "info").mockImplementation(() => jest.fn()); diff --git a/cdn/package-lock.json b/cdn/package-lock.json deleted file mode 100644 index 08d49abfbd3f17649e393d1e0e985eda082ba7f9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 500189 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

i%fU^zXZ_fjiFODX1-5})d^b+;&`8 z9u_UUVh>IhSDRAN%5N|A!NOWv|CiC#pROb16q);U^D{ca8R(f_&hOvT5qzy-6?CyW zUpY9|(MA|P#v|*1d*x1pg8I4<*Ib^~JGa_ijEw4bR3;As*Ck7i?v+_ircS$Tdq zxT8i?b_p+Rb~~+$Hu&f8B~%&1aQP&i^FCrz8|fqED}#E*Z1zEd+E>{O*3iKCsw2x& zuT~$GakA4>b}P0dlH<+6v|36>=KOiFJD2yZ#_`}RjB1zAmC7_MFa^%0T81&5oamOh zt!)o0s)dau2fLv5fx#b(c4UFx71;5G;%#sUAIs!OGN6yRe$MM4%=$ReP@89Hxg&9Wj zu%nj8GOa9Hm?oM-RXfz%)oHX}Y#F{0xZPUKAjkbir#Hi;a?i0>%&0|g)+-MJYV%2> z)$2I3Q>7{Gt1I8Daj#sVsrw5iN<*r>4W^0^qPBlr ze$YSjfF9)m{o`|bbcxfx64Ut7nfMQJ0$o8qv*y)@34gw7Fl^|hQP|yVb^SDL4ObmW zsTiHpLO$9>3J>^^#IFm5-INPNTdLFEVL=v*!juq{<(Rh^&ppxYRYxVurJ}T!q6R}9 zip$G->Qv?nr{~b??kn%62=limx~}3n+mhx^t7h7I6(6L<2L0@GZXpluF%XVP*&F1G;*uOg>ZR9tx6F z5BMlk^zWkzKJjFx&XPZn0Kxl`5gxpLkKm@A&NP6Le1WEwOGB3#N!D(Jm1W0gHLhl? z`Xz=54v;kOiV9?$nVZd+B_jS56#E_hu$`S$rFzuIv&C2n2F1|WLc^oYdp?C12F*FN zb2aty&#^si(?&X~27VrZeImXt`+Fa?KjWN9VP5bW z(?NpNSB@E&ZV0p90{T>x7xHp3E;O+E$XV=11y6HmXuI81YR!TYSqohpL7vidRS5i1 zU9Ss=!D`-Uu4;oO43b!@Y*WS-8$(@;x7(KoC!*Jf78Er4J=YLk0rfrF7xF3ar>vAsOb}eNoL

a{!2 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

- -

-

Fosscord WebSocket Gateway Server

- -

- - - - -

- -## [About](https://github.com/fosscord/fosscord-gateway/wiki) - -Fosscord is **f**ree **o**pen **s**ource **s**oftware compatible to dis**cord**. It is a selfhostable Chat, Voice and Video platform similar to Slack, Rocket.chat and Discord-compatible. - -- Discord-compatible -- Selfhostable -- Open Source -- Configurable -- Secure -- Decentralized -- Extendable -- Themeable - -logo by [@nwlandas](https://twitter.com/nwlandas) - -## Installation - -_it is in development and not yet finished_ - -## Support - -https://discord.gg/ZrnGQP6p3d - -if we are finished we'll host our own support server. - -## Contribute - -This project is only possible by volunteers like you and me, your contribution is very much appreciated 🥺. - -If you want to make this project reality and and you would like to contribute then [read the wiki](https://github.com/fosscord/fosscord-gateway/wiki) first. diff --git a/gateway/package-lock.json b/gateway/package-lock.json deleted file mode 100644 index cbad96dc2f057faa4bb38657fbe9b4dd994bc00b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 540153 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

W$fp-WP$RM~)uStCAjpHFzulj$-Ea;K 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 delta 15447 zcmdseXLy!X((rZnn%;Y%7n9IIT4*BDf+9*MbR;AZ5EMn?u2`tSM>C>=;8GPN7-a-S zf-9^AAru9q1yMjs2uK&mJLlX_3(LCx`mXPNx%lzir_7l%GiQ2sywT+S&oUC9HI3BV z>2K`IT&L2nX`Ogs}b3H%DWKSM7HT#)VHZj=snf@RgxFaUGszRE(lFL=sTBVlD z4yskM*;ph?1Oaw`BUC|}s(dWdS2_$^BG!ZQLvjJLN#oq4GD>j`!ongn&gsofU%kcI!H4cWg6N8n7IgvE1t^1^#m7HV!}0J6wTZzFXw+J+j;C;I2O;heHOa<-uMGc#f=21>d>VDdB_5sNwzcQN*{=M-|`L&KqhS zJpZ}6*S9t18&&iXCb6VEOcGpeheo{iqvgun7g|y)qWh=Bzz8U`1g+$q?*|BOUa3M| zSGQfix^9n*L~V_BM}R}?g~rgUN)3U`8;V}CXir~(W+Pmgrz4>KI<2Q`%WUE?+jo19 zQS#NkD8V&&aKuMHexvYZ$>lm+_*4vm=lkg~CCP_Jm=3>aM?F`;1=W>xD#119QooX{ zQ%{I&Cjr)6dAn0x88=74yI*QSCC{Bv1cofl*Lv( z0~M|Ha4g=gsT@mozks3>T0+T%%3d?ga^uu}%wdW!~%u#WnR<*PAm!T!m*k!n&Gzv}^I5)o#3VaMwO9#Z7n5 z1!2olA&l*KUFZS-6olo~v2YE(77TMgk~l#62msu#t>IX~{71K=3jErxZg!f$Wrasc)< zgk24oL_k(&VF4a&CJ>F;PWA}}r!*D57^nvng$m&-bLe5R8)A7&VY=agp91+02v0(y zt=pK~NwAzHwEZV9z|Aie!|}p{Lbz{<17+SSAp&7PQ`Cqf$tKBg%Sx$~bArofB@Jrt7?^!o$|o+>ne zq_4HQP<)P9QW;F2J?9DUK>quJiSbE#2jQL|XgV0bOV*RQytTn4Lxjx(7>cB!b)2

4VnI|PVV4jA$G#CRGHbZiI~EDSns}61 z8zifDz&V;M-Eg+y59nqok>0ftuxqP)(rf4(OmO~gA%NSmC!B@xdxc-PU=vab+*z(C zW5XBqJ`%&FJItOZCWBrnEQ2BCLg?KH@v$IHJjTr*A+(cr3Bj=Bd*K=<3dfAEq9K(V zB0n7Y#J}Sh1^MN|O=fQ0D4sbk-0-4^0VjlQ0&MQ1MBuewgm(o_j7=wn7r7MyMq4a6 zEnITm6~9$bk=`HLza))uuAFvFFrc7FKf~k~XMy4 zhL44L<(PSIJ1{R?G`+$+q9{_l?v)cajEt#w%d!HrE6k6UK?$M_cVfib?2%z|ocOlD z4H{O&i>b~}pr2_FuwDy+X^G-RuBd?TTenrH1>Yu#}b-=)1gpMp@%}{<79JU`-rkf!}66tD^pyzuEj%HPcZ zd^$qB?1M)u0-$$@Y~cBk;$$6L(N)J9!AruZKXvSCWifr;76w zxSb=$ZI~|B6JS(lB@%l-FB(F~Gf#~lH$HpXsQZTJO->&*F()66&ok(?7pP5=GyiQe zd&Kzk`}i{Ybsy|*E7yE9tJ6b`bGmjK-LmtfK9eVQY1*h!R{sXQ`jRo}-n3;-({8!F zavO~w(J?P$+@m=;-3RpV+T+PlPd?t|v92A`yY-qlVQO}6_Yryh$3NOMzvDBHJo)GY zJ^FO+k_Wk6)I6aX9POeez*FO-q{w?C0|&+`>5x@SF+ypcqCoNec74bU5hGwxSM^0a zP#~tNFlV+HO-B4;ZKDyGH4KY>AMYWiJld*dMvI4Y9_uisZ?oo2r}k~o`H4}_Jld@H z13j~zm@w_>etE;Ebbeq$uMT7TH)uAkbMp?3bDnAPMCbhGlg8wZex~!}oNj#@w0N*p zi@Xu(ox66LHf{7%ttLJ(wUw*U&}5u8N9?08ZHpv~LCmuahlqwoD;x-7jP20>t$&F3 zOP)8XV$}+9hUln;j5T6RwYRt(X(-7176$=+Ci-b^`i!n_SjYoqV?NbDpDKQ~UMv)$ z;)oOu)5HD%)d_y(dReD^5#kGaNqNYL^-uXiOUgBE)!k6Ni zBp7&FOm;2W6M=~*#2q5PY2Zom4-E>(SRqhpt1YoZg_tj*a9w;}bTsX*%}N6N>!$dd zw(jbq(k3d~8YAIq{$}ObUSW^NlmE zKSoBvo!N3!(E{U57+R_X;Qk$ zP||QmZ7Do}o6NTFilI=t+K{2V*ibO3sgy*H+-@-vXEc{C3QXBVR@ISD5><6oIt|Nh3w32f2NF5OxfcNEr>4 z4hA@HSf3!BcKm*dQ+2qpUup#9Z%P4}ohv;eLgkNAEM%1_O<)*W;ZQM2`WZr|N~f5d zVf@olyv~0ODv(Y}4(;=MDXB33Md=r2(wIF~aM4Vuzs-(|!i3kPK+z#=d7-3Wzt^P~ zM3{b1jKEt(($@yR=;tw6zM2MT(?gukwCfMJOgbS zk#U&$3Q>Ky=|t4M;vojK5qieQa}b?Km%;7aVq-yCBuX(U+v|8W$1Ve?uB( z`lJ|V$nrP=uc~rwa?lO=q=Q8HYOy8c-%yM<3grg4)|6X#LP)|6DkJ0oNLxsH{Q7Yr z1O~4l_Vtc*#!OfmBroB{gt-V)gXMk9WQAj1sJzS*YkPr^9Z(@DOb+zDZzSl^0<=vf zF-?n--*9%Hik1iaTrSLwmDh=I=OTqM@8_FMi@q1Q`1M?QD1odU(^gf9@GRB%w4&EADoytDZRk?ut?xB!Lgoi@8oV>ZEQih8C}iE4 zA*Z_)Ds79b=4WjOK9tphd4`_kRAyayIApevuR3lHU*U7Q2-jM0r;$I=9Uz&l<>Op& zuv8OLs%fSpx5!dVj&>!U0=a!*3{M%8=9sx6r9u3BTgVziDGv%fG~C%y-sJXjE4vYW z{oTXuz=quP<+FFum&U3bG3BHk+J#7))m?VGheUk^3bSMxzV9Lb!sLr^D-m7C#Mh$<32O5`W`R`*gU-Qhq> zs`jX|fwsop9fo<<#@x*nzS!ru@O6L8luvosz@zj?y#Hl+tUG=nPeKC>6q2F#50nOx zUzPLtjGIBZbBXemv*a^e#gVV@3TF$xKTrP1b0Ovzc%pa~{cOizm-BkVflE9Gvi5cP zvZEYmHr5aEf;UN#<;|tr51vmN!WSzi|AR=o>P?brmZ##u7z^j&oijpBT({TkP3~B# zJR0(sRMV`q?e3S)hOk^$D759X^wU48r7`!*CtT{nj+KN)!7}+*k1G9uAAt|9kSRIG zUVd?=+S7sLqjlCg*@gkDiBc@n$FXH14txCw&g6G!KTkz4WbOV8NBryapp!}HZxWzOc0B@DbLDe}0 zo^eX5`>FEmqAhZ~-@%?$fj+ij`ImAH!7+%pYbpI4NVC48(gAbWGlnX}%I_$U%lL#s zD&|{4c>{5fcUch3h!$@+Nf96TvVX}(iY8N}SGq$s;PBU^X<6o+sOifuCBeKoW;9s0 zg-9Istvuf?hP30Vmyoz*r|hHx90@%4Em5iZ>t;tp`R)V!h4Xbjo|YbDF2+9joJRr^ zVTNqYfy#OEXzcx?ta;8pNaXtZrWg-PV(cdHg=*D;U1Q0++i^f1>Uc%W5reEWLWB0* zZBXf)c!%xm*WGNVvADYtim@!P#!Hmz9YI?9Sd0|}S$mBLD6W*V`7M1n~E(@-=~{;I$j_?}if;@JQ-{ssv(|q^z(U?yx~@7o<>N z!4nN%hbR}B9OIEtJS<%Rvv?E{xzN{ug@-9V&v)|K1@(?2crZy8|@y1T2mf+jgv`qQK z4``R&%6EeA8*Uu1lAz!q@#~SjN-uXvR^F9j_%lB$j*9O0H06qJ9kvWeUMjVN#KVdK zQAeyh&KaJd+8M8N^sezZAoA9Lq{E7if;s1vzv~Xe*IrW$OuVX0N?LJ~c@6wj)5l1}u%&)D~hZIL{nXCa>y88HGdv&ekQ+PKE=1*Ij+d4{u!9Q+-6{_YQto9pV?u;f8)H=}lfw2ue~D zQGHw`FN;U3{y|_}T+(0tl9gn_@uflP0s%L@C%rCU)nHZfw>$J54RaeQ(NMlflA(C0 z`UQXTvxlkUodKz{~nLabvShSy~$j1)ms*yNopsflxAx~YR z@N5QIAwdQ++in9()~G53A0YB)y3|IVShz0SdP?QVOpKVS4p$xBv1qy~3-Ea-DzWAt zB-QoX^Xexx92&B3$XY^|IQyP@(s|e1_>_J@Nu4K_sd*v{*rvu~dZ~IO7(d*r))T!c zDV9aribsA_*XqoTp|mkj);2 z#8rXb)&LF@*D|@0`Ek{I1l(s00ix(iyGQyx>z0KPKP?5EwRan+6CjD@_ZW6b^YjTcBZr*M!k*t~FNqv6)+z9) zgD$_Y4~(Zxp!i;gcnY=wB^Rpb9Ck$-^6v$B*BQLK1pui9pc_2^_Z4}4A2Rk5S>O5I zf_Hz?$m?OmXGpU{kgEKd0&G1&M5tUUbac(X)B_3!3mOhGg#@w_=d_kcMeQLe4!>z% zGURur0^QJ6q!=3{iczo?{_nVHm2Z*l3t*BSEfLDh+fCr24MJB`oZ8w zKxUGVw4sYo*LRG2b6TmGh*b{=H3jH#k>v3n_<^T&Ak=R+($T%{ePD8gp2XS(g8owr z!3Pd`s~?55t(EV9yKlfc3;J+!HU;V`pkN?IPs03Yof69YAu;;!8KjwXH)i?CdiQ%Z z93V9ur1o(((j(x7|Hqx@wq}BU!J)8c!q*W%mbh)ce$~qWzrKK3Pf~*cZknifl)SxU z=}&sfIX|ceemIn%^YrZ{@n!_5pD(!95AT~g7jn&$eL|GYvt5j26 zRO#9BtsVvaSE@sx{x?<>Z0#&k>HHO&s%R_K6bM?S#=`Hf*fG#Y-RS7b}Uq`QfoojYBkPPB!k$xoks_4eSVq2Z}+i%HWsapZkQ+k~TpzglMla&-B9JJr8hvxf*G6T6;Rc z7`UE@gN-j^mo zfS?t@jfHlCheohN&_ZzNEPI1OvORIaeIv6cXTyT;=xy}~Fl!af)uZ9%0CO;`u4zWW zTHP29Tb5JmZb*jpJL(JU+5&#@meEvz(xayKzd&v^cQd7{QCbY^=9w^liQ*~0GWL83vI%!@OR7Z{> zWgoebXP?oJJIW~Y53>hPULy6&jNtOv0k&*5f8mCF!}EGK0guhI>xqn_9R-+CsH-6U zUH{oJv>8iHUyloU*(A>YZMz26Xo{7oj`Euy3~EBjg`f{i0}5Br2{Q}z)3BqP7K-y1 z=w$B5MWC*SVlxI!7kf5b0~79vRPNFjxRozM23c#0qt#g>O2%J8Nrl+=^s|nZrH+vl z?Dh|x45Y_jN`>Opx&f89gyvYbOs8Ohn@)ZlB?RAeuPh9-oCXqP4J2-yyxJGbMRAY7 z9VVt#e^DJ$P7M@)b*vKyN6j8(|D6egH|vhaWygx=y=YoU9v7LcU7zU@%=xmR{{bZg zN{=W_Tp2%be~h|x5=3gLr4{(@7IsJW(>3hJU^rH)|L!2dJj4xO>QrI9azwujH;(Fe z965?9*U4%#s^GBW`VzxAnQrLqvRH^^XLWL3IeoahNNpJ@FryEp;Og}exknksERuHz z>&plP+7$>(D)if2B9L|tG#T`kl+@CraN13svX{N?=rJ2^>xvsZ(=14>739Lv${6r= zSpaoePzB(uuHmLCeUDa@OH#!?SKeOF;y%&ukpPa9LzFqapi;8`WWZpoS#ar@swM&zLRH+Q$4Aqa15Mc z+z@c;^G1pYs|t*BxaYHg9|YYJ4c;Yv-(F?}*c?4*|0sFF1=*A+ zq#lT10g?tA;dtXC;}-$Xe{4)t*mDU5YJJFpfu9rkj&3qu)C{ki1Jns|60-kkobVv= z#Zq$Tc6OI;L**voOu;rovjEDBa}Lv%?>1sY+_~52VnK~###u}(H+~af;8ts3PQFGTbVdX+oe5hxfQaz_iQ8vnFo5V_2de zmVI8AuE9RRyzYRj5Y1sazZvFR=ITG`buiCSfV$})(xcEb(7fVYff^pj)$VI);kYZ< z+)f$8Dby#jIl^ozL)$p>G&YMjhe)=UMq@@zh9}<<eyw zH}f~YYj-$lB^TLhI>z-h`>HtO5%X_4h72;v*?C}yc@A0)Gt04Fws}SZX(at|$Dj2q zEOzvq*F?e7!Sb99V@#46E+YR5rdq(zDA~gPV@(PR|0uKr+-|_TIi`U@<4tPw;7co$ zj6m#>W0Lt{-?(LhS=-Ml0~Pvn7&il9><`q>T0dUC=)5KBWgrE9-#5gQ#m|{Fpe)h~ zgVq!2CIlx8xKX4|hE~#lb}eA;v*uY20trNY0ls+K=m0&>TPv3%_;) zq;>=98TnI}#qC4h%f$+JjyOGwaOKLyM@KUCq26|ZXa59sH#Iq~*WWNta^h_O^VR=? z7CB;k&olc>3vN9opK^#vMR|9~j6}Gle+>wxuQpA8UU{m9vyd1TE_$>;_WL^hWzaa; z?X{8fRTHUJp2;C@obr(5+kX-nc}9saOyg~wNVKA~Iti4G4Y#wOZU1H7<}aV)y7MzL0Smu2Py9s; z!(P&(UW-uRe3^NZ6P|gd3apzaw{~Rwu{|Uc90#t-suhg~{fRjEB$+*i2H4{Wdths7 zn&CL(sQIA3WG9!K7kp2IH#c}Iy-)nf5&ja_^{jcxkJ2nhfR!l!CgR{(HZe2vw)yMb zVE}BJV_oEfSa8)06kz&xy$u8Ec_~2;Stnq^Kzh$yLR;J4lRtv^ zWNW|Ql18J&nwXJd&D3#QJ!`pv)0$Y+^R%&<<(M>}(qA+LcP0aQxw&QP_+zHkhL`EbGo(8fTOQl$6?nS)^*%p zWCPt@oGow=Mmw;+wm)+J$Z_zFsn(nnO`M{;`Bcf6FY68&v zHlghgo*LU;;y~vgEneTN0aV(16XK^D23*>2U11w)AeHy_i}WXvgbxpvD-K(AeCJ@| zQA_jtOglzY@SRJu2G%*O&?{xYfJ$>zl^!P<_`-2Q*C7J8VN|7?D!}q2I~*JSYJ~`} z>a=x?p9oZ!YlJ`jX0?l=4`|+i8d%TQBQ~Ogt z)_mK-u7rhc?Fxt4R9CC-gb(y9s;IsFyW=OtWZHY&UVA`iyI8{SyV|BV%aA?KjDfhv z)w3u(WH+WlE_3Oribi4a^q2KWSfv?BP>E)?+u?+6o1#TSYkDZ|@EEF&$d3B){jmy;M>ky~XZfnatHR J>Hl=|e*o`pKc@fy diff --git a/package.json b/package.json index 8488ff28b..95dbb6597 100644 --- a/package.json +++ b/package.json @@ -1,17 +1,101 @@ { - "name": "fosscord-server", + "name": "@fosscord/server", "version": "1.0.0", - "description": "A Fosscord server written in Node.js", - "workspaces": ["api", "cdn", "gateway"], - "scripts": {}, + "description": "", + "main": "src/start.js", + "scripts": { + "setup": "npm install --omit optional && ts-patch install -s && patch-package && npm run build", + "depclean": "node scripts/depclean.js", + "depcheck": "node scripts/depcheck.js", + "syncdeps": "node scripts/install.js", + "build": "node scripts/build.js", + "postinstall": "patch-package", + "genschemas": "node scripts/generate_schemas.js", + "start": "node scripts/build.js && node --enable-source-maps dist/start.js", + "start:bundle": "node --enable-source-maps dist/start.js", + "start:bundle:dbg": "node --enable-source-maps --inspect dist/start.js", + "start:bundle:vscode-dbg": "npm run build clean logerrors pretty-errors && node --enable-source-maps --inspect dist/start.js", + "migrate": "cd ../util/ && npm i && node --require ts-node/register node_modules/typeorm/cli.js -f ../util/ormconfig.json migration:run", + "tsnode": "npx ts-node --transpile-only -P tsnode.tsconfig.json src/start.ts" + }, "repository": { "type": "git", "url": "git+https://github.com/fosscord/fosscord-server.git" }, + "keywords": [], "author": "Fosscord", "license": "AGPL-3.0-only", "bugs": { "url": "https://github.com/fosscord/fosscord-server/issues" }, - "homepage": "https://fosscord.com" + "homepage": "https://fosscord.com", + "devDependencies": { + "@babel/core": "^7.18.9", + "@babel/preset-env": "^7.18.9", + "@babel/preset-typescript": "^7.15.0", + "@types/amqplib": "^0.8.1", + "@types/bcrypt": "^5.0.0", + "@types/body-parser": "^1.19.0", + "@types/dotenv": "^8.2.0", + "@types/express": "^4.17.12", + "@types/i18next-node-fs-backend": "^2.1.0", + "@types/jsonwebtoken": "^8.5.8", + "@types/morgan": "^1.9.3", + "@types/multer": "^1.4.7", + "@types/node": "^18.0.6", + "@types/node-os-utils": "^1.3.0", + "@types/ws": "^8.5.3", + "jest": "^28.1.3", + "jest-expect-message": "^1.0.2", + "supertest": "^6.1.6", + "ts-node": "^10.2.1", + "ts-node-dev": "^2.0.0", + "ts-patch": "^2.0.2", + "typescript": "^4.2.3", + "typescript-json-schema": "^0.54.0" + }, + "dependencies": { + "@aws-sdk/client-s3": "^3.137.0", + "@babel/preset-typescript": "^7.15.0", + "@ovos-media/ts-transform-paths": "^1.7.18-1", + "@sentry/node": "^7.7.0", + "@sentry/tracing": "^7.7.0", + "@types/node-fetch": "^2.6.2", + "ajv": "^8.11.0", + "ajv-formats": "^2.1.1", + "amqplib": "^0.10.1", + "bcrypt": "^5.0.1", + "body-parser": "^1.19.0", + "canvas": "^2.9.3", + "cheerio": "^1.0.0-rc.10", + "dotenv": "^16.0.1", + "exif-be-gone": "^1.3.0", + "express": "^4.17.1", + "file-type": "16.5", + "form-data": "^4.0.0", + "i18next": "^21.8.14", + "i18next-http-middleware": "^3.1.3", + "i18next-node-fs-backend": "^2.1.3", + "image-size": "^1.0.0", + "jest": "^28.1.3", + "jsonwebtoken": "^8.5.1", + "lambert-server": "^1.2.12", + "missing-native-js-functions": "^1.2.18", + "morgan": "^1.10.0", + "multer": "^1.4.5-lts.1", + "node-2fa": "^2.0.3", + "node-fetch": "^2.6.7", + "patch-package": "^6.4.7", + "picocolors": "^1.0.0", + "proxy-agent": "^5.0.0", + "reflect-metadata": "^0.1.13", + "typeorm": "^0.3.7", + "typescript": "^4.1.2", + "ws": "^8.8.1" + }, + "optionalDependencies": { + "mysql2": "^2.3.3", + "pg": "^8.7.3", + "sqlite3": "^5.0.11" + } } diff --git a/api/patches/ajv+8.6.2.patch b/patches/ajv+8.6.2.patch similarity index 100% rename from api/patches/ajv+8.6.2.patch rename to patches/ajv+8.6.2.patch diff --git a/api/patches/typescript-json-schema+0.54.0.patch b/patches/typescript-json-schema+0.54.0.patch similarity index 100% rename from api/patches/typescript-json-schema+0.54.0.patch rename to patches/typescript-json-schema+0.54.0.patch diff --git a/rtc/.gitignore b/rtc/.gitignore deleted file mode 100644 index f14b45488..000000000 --- a/rtc/.gitignore +++ /dev/null @@ -1,145 +0,0 @@ -# Logs -logs -*.log -npm-debug.log* -yarn-debug.log* -yarn-error.log* -lerna-debug.log* - -# Diagnostic reports (https://nodejs.org/api/report.html) -report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json - -# Runtime data -pids -*.pid -*.seed -*.pid.lock - -# Directory for instrumented libs generated by jscoverage/JSCover -lib-cov - -# Coverage directory used by tools like istanbul -coverage -*.lcov - -# nyc test coverage -.nyc_output - -# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) -.grunt - -# Bower dependency directory (https://bower.io/) -bower_components - -# node-waf configuration -.lock-wscript - -# Compiled binary addons (https://nodejs.org/api/addons.html) -build/Release - -# Dependency directories -node_modules/ -jspm_packages/ - -# TypeScript v1 declaration files -typings/ - -# TypeScript cache -*.tsbuildinfo - -# Optional npm cache directory -.npm - -# Optional eslint cache -.eslintcache - -# Microbundle cache -.rpt2_cache/ -.rts2_cache_cjs/ -.rts2_cache_es/ -.rts2_cache_umd/ - -# Optional REPL history -.node_repl_history - -# Output of 'npm pack' -*.tgz - -# Yarn Integrity file -.yarn-integrity - -# dotenv environment variables file -.env -.env.test - -# parcel-bundler cache (https://parceljs.org/) -.cache - -# Next.js build output -.next - -# Nuxt.js build / generate output -.nuxt - -# Gatsby files -.cache/ -# Comment in the public line in if your project uses Gatsby and *not* Next.js -# https://nextjs.org/blog/next-9-1#public-directory-support -# public - -# vuepress build output -.vuepress/dist - -# Serverless directories -.serverless/ - -# FuseBox cache -.fusebox/ - -# DynamoDB Local files -.dynamodb/ - -# TernJS port file -.tern-port -.DS_Store - -# Compiled TypeScript code -dist/ -# Prerequisites -*.d - -# Compiled Object files -*.slo -*.lo -*.o -*.obj - -# Precompiled Headers -*.gch -*.pch - -# Compiled Dynamic libraries -*.so -*.dylib -*.dll - -# Fortran module files -*.mod -*.smod - -# Compiled Static libraries -*.lai -*.la -*.a -*.lib - -# Executables -*.o - -# Protobuffer builds -*.pb.cc -*.pb.h - -# Directories -build/ -.vscode/ diff --git a/rtc/.npmignore b/rtc/.npmignore deleted file mode 100644 index 05a9d0cf2..000000000 --- a/rtc/.npmignore +++ /dev/null @@ -1 +0,0 @@ -!dist/ \ No newline at end of file diff --git a/rtc/.prettierrc b/rtc/.prettierrc deleted file mode 100644 index d569c548e..000000000 --- a/rtc/.prettierrc +++ /dev/null @@ -1,5 +0,0 @@ -{ - "tabWidth": 4, - "useTabs": true, - "printWidth": 120 -} diff --git a/rtc/CMakeLists.txt b/rtc/CMakeLists.txt deleted file mode 100644 index 2cf5c0a6d..000000000 --- a/rtc/CMakeLists.txt +++ /dev/null @@ -1,16 +0,0 @@ -cmake_minimum_required(VERSION 3.2) -project(fosscord-media) - -set(CMAKE_CXX_STANDARD 17) - -find_package(Threads REQUIRED) - -find_package(mongocxx REQUIRED) -find_package(Boost REQUIRED) - - -file(GLOB SourceFiles ${PROJECT_SOURCE_DIR}/src/*.cpp) -#include_directories("bsoncxx/v_noabi/bsoncxx/") -add_executable(${CMAKE_PROJECT_NAME} ${SourceFiles}) - -target_link_libraries(${CMAKE_PROJECT_NAME} datachannel mongo::mongocxx_shared Boost::boost) \ No newline at end of file diff --git a/rtc/README.md b/rtc/README.md deleted file mode 100644 index ee452adf3..000000000 --- a/rtc/README.md +++ /dev/null @@ -1,18 +0,0 @@ -# Fosscord-media - -A Fosscord media (voice and video) server - -## Installation - -### Prerequisites - -- Install the [libdatachannel](https://github.com/paullouisageneau/libdatachannel) library -- Install the [libmongocxx](http://mongocxx.org/mongocxx-v3/installation/) driver and its requirements - -### Building - -```bash -$ cmake -$ cd build -$ make -``` diff --git a/rtc/config.json b/rtc/config.json deleted file mode 100644 index 0967ef424..000000000 --- a/rtc/config.json +++ /dev/null @@ -1 +0,0 @@ -{} diff --git a/rtc/src/main.cpp b/rtc/src/main.cpp deleted file mode 100644 index 372eaa008..000000000 --- a/rtc/src/main.cpp +++ /dev/null @@ -1,47 +0,0 @@ -// $$$$$$\ $$\ -// $$ __$$\ $$ | -// $$ / \__|$$$$$$\ $$$$$$$\ $$$$$$$\ $$$$$$$\ $$$$$$\ $$$$$$\ $$$$$$$ | -// $$$$\ $$ __$$\ $$ _____|$$ _____|$$ _____|$$ __$$\ $$ __$$\ $$ __$$ | -// $$ _| $$ / $$ |\$$$$$$\ \$$$$$$\ $$ / $$ / $$ |$$ | \__|$$ / $$ | -// $$ | $$ | $$ | \____$$\ \____$$\ $$ | $$ | $$ |$$ | $$ | $$ | -// $$ | \$$$$$$ |$$$$$$$ |$$$$$$$ |\$$$$$$$\ \$$$$$$ |$$ | \$$$$$$$ | -// \__| \______/ \_______/ \_______/ \_______| \______/ \__| \_______| -// -// -// -// $$\ $$$$$$\ -// \__| $$ __$$\ -// $$\ $$\ $$$$$$\ $$\ $$$$$$$\ $$$$$$\ $$ / \__| $$$$$$\ $$$$$$\ $$\ $$\ $$$$$$\ $$$$$$\ -// \$$\ $$ |$$ __$$\ $$ |$$ _____|$$ __$$\ \$$$$$$\ $$ __$$\ $$ __$$\\$$\ $$ |$$ __$$\ $$ __$$\ -// \$$\$$ / $$ / $$ |$$ |$$ / $$$$$$$$ | \____$$\ $$$$$$$$ |$$ | \__|\$$\$$ / $$$$$$$$ |$$ | \__| -// \$$$ / $$ | $$ |$$ |$$ | $$ ____|$$\ $$ |$$ ____|$$ | \$$$ / $$ ____|$$ | -// \$ / \$$$$$$ |$$ |\$$$$$$$\ \$$$$$$$\ \$$$$$$ |\$$$$$$$\ $$ | \$ / \$$$$$$$\ $$ | -// \_/ \______/ \__| \_______| \_______| \______/ \_______|\__| \_/ \_______|\__| -// -// -// - -#include "rtcPeerHandler.hpp" //Handle peer connection requests -#include "mongoStub.hpp" //Handle communication with the MongoDB server - -int main(int argc, char **argv){ - - auto commsHandler = std::make_shared(); - auto mongoHandler = std::make_unique(); - - mongocxx::options::change_stream options; - //voiceEvents collection watcher - mongocxx::change_stream colCs = mongoHandler->getCol().watch(options); - - std::cout << "Server created and listening for events" << std::endl; - - //Check for new messages in the collection - for (;;){ - std::vector t = mongoHandler->getNewMessages(&colCs); - for(auto &i : t){ - std::cout << "[" << i.eventName << "] " << std::endl; - } - } - - return 0; -} \ No newline at end of file diff --git a/rtc/src/mongoStub.cpp b/rtc/src/mongoStub.cpp deleted file mode 100644 index ccd2abda3..000000000 --- a/rtc/src/mongoStub.cpp +++ /dev/null @@ -1,84 +0,0 @@ -#include "mongoStub.hpp" - -mongoStub::mongoStub() { - if (this->client) { - this->db = client["fosscord"]; - - if (this->db) { - this->col = db["events"]; - - } else { - std::cout << "db not found"; - exit(-1); - } - } else { - std::cout << "Client couldn't be initialized"; - exit(-1); - } -} - -// Too slow for my liking -std::vector mongoStub::getNewMessages( - mongocxx::change_stream* colCs) { - std::vector retVec; - - for (auto&& event : *colCs) { - mongoStub::mongoMessage returnValue; - - std::cout << bsoncxx::to_json(event) << std::endl; - - // Only listen to insert events (to avoid "precondition failed: data" - // exception) - if (event["operationType"].get_utf8().value.to_string() != "insert") { - continue; - } - - std::string evName = event["fullDocument"]["event"].get_utf8().value.to_string(); - - if(evName.substr(0, 7)=="VSERVER"){ continue; } //Ignore the event if it's been emited by a voice server - - if (evName == "UDP_CONNECTION") { - handleUdpRequest( - event["fullDocument"]["data"]["d"]["address"].get_utf8().value.to_string(), - event["fullDocument"]["data"]["d"]["port"].get_int32().value, - event["fullDocument"]["data"]["d"]["mode"].get_utf8().value.to_string() - ); - - } else if (evName == "VOICE_REQUEST") { - //TODO - continue; - } - - returnValue.eventName = evName; - retVec.push_back(returnValue); - } - - return retVec; -} - - -void mongoStub::handleUdpRequest(std::string address, int port, std::string mode) { - using bsoncxx::builder::basic::kvp; - using bsoncxx::builder::basic::sub_array; - using bsoncxx::builder::basic::sub_document; - - auto builder = bsoncxx::builder::basic::document{}; - - //Handle UDP socket stuff (later tho) - - builder.append(kvp("event", "VSERVER_UDP_RESPONSE")); - builder.append(kvp("op", "4")); - builder.append(kvp("d", [](sub_document subdoc) { - subdoc.append(kvp("mode", "CRYPT_MODE")), - subdoc.append(kvp("secret_key", [](sub_array subarr) { - subarr.append(1, 2, 3, 5); // HOW DO I GEN A SKEY? - })); - })); - - - bsoncxx::stdx::optional r= col.insert_one(builder.view()); -} - -void mongoStub::handleVoiceRequest() { - //Is this really needed? idk -} \ No newline at end of file diff --git a/rtc/src/mongoStub.hpp b/rtc/src/mongoStub.hpp deleted file mode 100644 index 2809142f7..000000000 --- a/rtc/src/mongoStub.hpp +++ /dev/null @@ -1,41 +0,0 @@ -#ifndef MONGOSTUB_HPP -#define MONGOSTUB_HPP - -#include -#include -#include -#include -#include -#include -#include -#include -#include - - -class mongoStub{ - public: - mongoStub(); - - struct mongoMessage{ - std::string eventName; - std::vector data; - }; - - std::vector getNewMessages(mongocxx::change_stream* colCs); - - mongocxx::collection getCol() const { return col; } - - - - private: - mongocxx::instance instance; - mongocxx::client client{mongocxx::uri{}}; - mongocxx::database db; - mongocxx::collection col; - mongocxx::change_stream* colCs = nullptr; - - void handleUdpRequest(std::string address, int port, std::string mode); - void handleVoiceRequest(); -}; - -#endif diff --git a/rtc/src/rtcPeerHandler.cpp b/rtc/src/rtcPeerHandler.cpp deleted file mode 100644 index 9bfc64665..000000000 --- a/rtc/src/rtcPeerHandler.cpp +++ /dev/null @@ -1,83 +0,0 @@ -#include "rtcPeerHandler.hpp" - -rtcPeerHandler::rtcPeerHandler() { - rtc::InitLogger(rtc::LogLevel::Verbose, NULL); -} - -void rtcPeerHandler::initiateConnection(std::string peerIP, int peerPort) { - // Socket connection between client and server - SOCKET sock = socket(AF_INET, SOCK_DGRAM, 0); - sockaddr_in addr; - addr.sin_addr.s_addr = inet_addr(peerIP.c_str()); - addr.sin_port = htons(peerPort); - addr.sin_family = AF_INET; - - rtc::Configuration conf; - conf.enableIceTcp = false; - conf.disableAutoNegotiation = false; - - auto pc = std::make_shared(conf); - - rtc::Description::Audio media("audio", - rtc::Description::Direction::SendRecv); - media.addOpusCodec(96); - media.setBitrate(64); - - auto track = pc->addTrack(media); - - // auto session = std::make_shared(); - - // track->setMediaHandler(session); - - rtc::Reliability rtcRel; - rtcRel.unordered = true; - rtcRel.type = rtc::Reliability::Type::Timed; - rtcRel.rexmit = 500; - - rtc::DataChannelInit rtcConf; - rtcConf.reliability = rtcRel; - rtcConf.negotiated = false; - - pc->onStateChange([](rtc::PeerConnection::State state) { - std::cout << "State: " << state << std::endl; - if (state == rtc::PeerConnection::State::Disconnected || - state == rtc::PeerConnection::State::Failed || - state == rtc::PeerConnection::State::Closed) { - // remove disconnected client - } - }); - - pc->onGatheringStateChange([](rtc::PeerConnection::GatheringState state) { - std::cout << "Gathering State: " << state << std::endl; - }); - - /*std::tuple addAudio( - - const std::shared_ptr pc, - const uint8_t payloadType, const uint32_t ssrc, const std::string cname, - const std::string msid, const std::function onOpen) { - auto audio = Description::Audio(cname); - audio.addOpusCodec(payloadType); - audio.addSSRC(ssrc, cname, msid, cname); - auto track = pc->addTrack(audio); - // create RTP configuration - auto rtpConfig = make_shared( - ssrc, cname, payloadType, OpusRtpPacketizer::defaultClockRate); - // create packetizer - auto packetizer = make_shared(rtpConfig); - // create opus handler - auto opusHandler = make_shared(packetizer); - - // add RTCP SR handler - auto srReporter = make_shared(rtpConfig); - opusHandler->addToChain(srReporter); - - // set handler - track->setMediaHandler(opusHandler); - track->onOpen(onOpen); - auto trackData = make_shared(track, srReporter); - return trackData; - }*/ - - pc->createDataChannel("Fosscord voice connection", rtcConf); -} diff --git a/rtc/src/rtcPeerHandler.hpp b/rtc/src/rtcPeerHandler.hpp deleted file mode 100644 index 3ba32a832..000000000 --- a/rtc/src/rtcPeerHandler.hpp +++ /dev/null @@ -1,32 +0,0 @@ -#include "libdatachannel/rtc.hpp" -#include -#include -#include "nlohmann/json.hpp" -#include - -#ifdef _WIN32 -#include -#else -#include -typedef int SOCKET; -#endif - -using json = nlohmann::json; - -#ifndef RTCPEERHANDLER -#define RTCPEERHANDLER -class rtcPeerHandler{ -public: - rtcPeerHandler(); - void initiateConnection(std::string peerIP, int peerPort); - - struct client - { - std::shared_ptr pc; - std::shared_ptr dc; - }; - -private: - std::map clients; -}; -#endif \ No newline at end of file diff --git a/rtc/src/rtcServer.hpp b/rtc/src/rtcServer.hpp deleted file mode 100644 index e69de29bb..000000000 diff --git a/util/scripts/benchmark.js b/scripts/benchmark.js similarity index 100% rename from util/scripts/benchmark.js rename to scripts/benchmark.js diff --git a/bundle/scripts/benchmark/connections.js b/scripts/benchmark/connections.js similarity index 100% rename from bundle/scripts/benchmark/connections.js rename to scripts/benchmark/connections.js diff --git a/bundle/scripts/benchmark/index.js b/scripts/benchmark/index.js similarity index 100% rename from bundle/scripts/benchmark/index.js rename to scripts/benchmark/index.js diff --git a/bundle/scripts/benchmark/users.js b/scripts/benchmark/users.js similarity index 100% rename from bundle/scripts/benchmark/users.js rename to scripts/benchmark/users.js diff --git a/bundle/scripts/build.js b/scripts/build.js similarity index 77% rename from bundle/scripts/build.js rename to scripts/build.js index f53a22233..49353c877 100644 --- a/bundle/scripts/build.js +++ b/scripts/build.js @@ -1,9 +1,8 @@ const { execSync } = require("child_process"); const path = require("path"); const fs = require("fs"); -const { getSystemErrorMap } = require("util"); const { argv, stdout, exit } = require("process"); -const { copyRecursiveSync, execIn, parts } = require('./utils'); +const { execIn, parts } = require('./utils'); if(argv.includes("help")) { console.log(`Fosscord build script help: @@ -44,14 +43,6 @@ console.log(`[${++i}/${steps}] Checking if dependencies were installed correctly if(!fs.existsSync(path.join(__dirname, "..", "node_modules", "exif-be-gone", "index.js"))) execIn("npm run build", path.join(__dirname, "..", "node_modules", "exif-be-gone")); -console.log(`[${++i}/${steps}] Copying src files...`); -copyRecursiveSync(path.join(__dirname, "..", "..", "api", "assets"), path.join(__dirname, "..", "dist", "api", "assets")); -copyRecursiveSync(path.join(__dirname, "..", "..", "api", "client_test"), path.join(__dirname, "..", "dist", "api", "client_test")); -copyRecursiveSync(path.join(__dirname, "..", "..", "api", "locales"), path.join(__dirname, "..", "dist", "api", "locales")); -parts.forEach((a) => { - copyRecursiveSync("../" + a + "/src", "dist/" + a + "/src"); - if (verbose) console.log(`Copied ${"../" + a + "/dist"} -> ${"dist/" + a + "/src"}!`); -}); if (!argv.includes("copyonly")) { console.log(`[${++i}/${steps}] Compiling src files ...`); diff --git a/bundle/scripts/db_migrations.sh b/scripts/db_migrations.sh similarity index 100% rename from bundle/scripts/db_migrations.sh rename to scripts/db_migrations.sh diff --git a/bundle/scripts/depcheck.js b/scripts/depcheck.js similarity index 100% rename from bundle/scripts/depcheck.js rename to scripts/depcheck.js diff --git a/bundle/scripts/depclean.js b/scripts/depclean.js similarity index 100% rename from bundle/scripts/depclean.js rename to scripts/depclean.js diff --git a/api/scripts/droptables.sql b/scripts/droptables.sql similarity index 100% rename from api/scripts/droptables.sql rename to scripts/droptables.sql diff --git a/bundle/scripts/gen_index.js b/scripts/gen_index.js similarity index 100% rename from bundle/scripts/gen_index.js rename to scripts/gen_index.js diff --git a/api/scripts/generate_openapi.js b/scripts/generate_openapi.js similarity index 100% rename from api/scripts/generate_openapi.js rename to scripts/generate_openapi.js diff --git a/api/scripts/generate_schema.js b/scripts/generate_schema.js similarity index 96% rename from api/scripts/generate_schema.js rename to scripts/generate_schema.js index 1badfd326..6925df5d2 100644 --- a/api/scripts/generate_schema.js +++ b/scripts/generate_schema.js @@ -49,7 +49,7 @@ function modify(obj) { function main() { const files = [ - ...walk(path.join(__dirname, "..", "..", "util", "src", "schemas")), + ...walk(path.join(__dirname, "..", "src", "util", "schemas")), ]; const program = TJS.getProgramFromFiles( files, diff --git a/bundle/scripts/install.js b/scripts/install.js similarity index 100% rename from bundle/scripts/install.js rename to scripts/install.js diff --git a/util/scripts/migrate_db_engine.js b/scripts/migrate_db_engine.js similarity index 100% rename from util/scripts/migrate_db_engine.js rename to scripts/migrate_db_engine.js diff --git a/bundle/scripts/rights.js b/scripts/rights.js similarity index 100% rename from bundle/scripts/rights.js rename to scripts/rights.js diff --git a/api/scripts/stresstest/.gitignore b/scripts/stresstest/.gitignore similarity index 100% rename from api/scripts/stresstest/.gitignore rename to scripts/stresstest/.gitignore diff --git a/api/scripts/stresstest/accounts.json.example b/scripts/stresstest/accounts.json.example similarity index 100% rename from api/scripts/stresstest/accounts.json.example rename to scripts/stresstest/accounts.json.example diff --git a/api/scripts/stresstest/config.json.example b/scripts/stresstest/config.json.example similarity index 100% rename from api/scripts/stresstest/config.json.example rename to scripts/stresstest/config.json.example diff --git a/api/scripts/stresstest/index.js b/scripts/stresstest/index.js similarity index 100% rename from api/scripts/stresstest/index.js rename to scripts/stresstest/index.js diff --git a/api/scripts/stresstest/package-lock.json b/scripts/stresstest/package-lock.json similarity index 100% rename from api/scripts/stresstest/package-lock.json rename to scripts/stresstest/package-lock.json diff --git a/api/scripts/stresstest/package.json b/scripts/stresstest/package.json similarity index 100% rename from api/scripts/stresstest/package.json rename to scripts/stresstest/package.json diff --git a/api/scripts/stresstest/src/login/index.js b/scripts/stresstest/src/login/index.js similarity index 91% rename from api/scripts/stresstest/src/login/index.js rename to scripts/stresstest/src/login/index.js index ab6c9719e..b153550e8 100644 --- a/api/scripts/stresstest/src/login/index.js +++ b/scripts/stresstest/src/login/index.js @@ -1,6 +1,6 @@ const fetch = require("node-fetch"); const fs = require("fs"); -let config = require("./../../config.json"); +let config = require("../../config.json"); module.exports = login; async function login(account) { let body = { diff --git a/api/scripts/stresstest/src/message/send.js b/scripts/stresstest/src/message/send.js similarity index 100% rename from api/scripts/stresstest/src/message/send.js rename to scripts/stresstest/src/message/send.js diff --git a/api/scripts/stresstest/src/register/index.js b/scripts/stresstest/src/register/index.js similarity index 100% rename from api/scripts/stresstest/src/register/index.js rename to scripts/stresstest/src/register/index.js diff --git a/bundle/scripts/update_schemas.js b/scripts/update_schemas.js similarity index 100% rename from bundle/scripts/update_schemas.js rename to scripts/update_schemas.js diff --git a/bundle/scripts/utils.js b/scripts/utils.js similarity index 100% rename from bundle/scripts/utils.js rename to scripts/utils.js diff --git a/bundle/src/Server.ts b/src/Server.ts similarity index 97% rename from bundle/src/Server.ts rename to src/Server.ts index 165ab1212..4d5d64229 100644 --- a/bundle/src/Server.ts +++ b/src/Server.ts @@ -10,7 +10,7 @@ import { green, bold, yellow } from "picocolors"; import { Config, getOrInitialiseDatabase } from "@fosscord/util"; import * as Sentry from "@sentry/node"; import * as Tracing from "@sentry/tracing"; -import { PluginLoader } from "@fosscord/util"; +// import { PluginLoader } from "@fosscord/util"; const app = express(); const server = http.createServer(); @@ -95,7 +95,7 @@ async function main() { }); } console.log(`[Server] ${green(`listening on port ${bold(port)}`)}`); - PluginLoader.loadPlugins(); + // PluginLoader.loadPlugins(); } main().catch(console.error); diff --git a/api/src/Server.ts b/src/api/Server.ts similarity index 100% rename from api/src/Server.ts rename to src/api/Server.ts diff --git a/api/src/global.d.ts b/src/api/global.d.ts similarity index 100% rename from api/src/global.d.ts rename to src/api/global.d.ts diff --git a/api/src/index.ts b/src/api/index.ts similarity index 100% rename from api/src/index.ts rename to src/api/index.ts diff --git a/api/src/middlewares/Authentication.ts b/src/api/middlewares/Authentication.ts similarity index 100% rename from api/src/middlewares/Authentication.ts rename to src/api/middlewares/Authentication.ts diff --git a/api/src/middlewares/BodyParser.ts b/src/api/middlewares/BodyParser.ts similarity index 100% rename from api/src/middlewares/BodyParser.ts rename to src/api/middlewares/BodyParser.ts diff --git a/api/src/middlewares/CORS.ts b/src/api/middlewares/CORS.ts similarity index 100% rename from api/src/middlewares/CORS.ts rename to src/api/middlewares/CORS.ts diff --git a/api/src/middlewares/ErrorHandler.ts b/src/api/middlewares/ErrorHandler.ts similarity index 100% rename from api/src/middlewares/ErrorHandler.ts rename to src/api/middlewares/ErrorHandler.ts diff --git a/api/src/middlewares/RateLimit.ts b/src/api/middlewares/RateLimit.ts similarity index 100% rename from api/src/middlewares/RateLimit.ts rename to src/api/middlewares/RateLimit.ts diff --git a/api/src/middlewares/TestClient.ts b/src/api/middlewares/TestClient.ts similarity index 89% rename from api/src/middlewares/TestClient.ts rename to src/api/middlewares/TestClient.ts index 4fe631cb5..a47ff396e 100644 --- a/api/src/middlewares/TestClient.ts +++ b/src/api/middlewares/TestClient.ts @@ -7,11 +7,13 @@ import { Config } from "@fosscord/util"; import { AssetCacheItem } from "../util/entities/AssetCacheItem" import { green } from "picocolors"; +const AssetsPath = path.join(__dirname, "..", "..", "..", "assets") + export default function TestClient(app: Application) { const agent = new ProxyAgent(); //build client page - let html = fs.readFileSync(path.join(__dirname, "..", "..", "client_test", "index.html"), { encoding: "utf8" }); + let html = fs.readFileSync(path.join(AssetsPath, "index.html"), { encoding: "utf8" }); html = applyEnv(html); html = applyInlinePlugins(html); html = applyPlugins(html); @@ -19,7 +21,7 @@ export default function TestClient(app: Application) { //load asset cache let newAssetCache: Map = new Map(); - let assetCacheDir = path.join(__dirname, "..", "..", "assets", "cache"); + let assetCacheDir = path.join(AssetsPath, "cache"); if(process.env.ASSET_CACHE_DIR) assetCacheDir = process.env.ASSET_CACHE_DIR @@ -32,7 +34,7 @@ export default function TestClient(app: Application) { newAssetCache = new Map(Object.entries(JSON.parse(rawdata.toString()))); } - app.use("/assets", express.static(path.join(__dirname, "..", "..", "assets"))); + app.use("/assets", express.static(path.join(AssetsPath))); app.get("/assets/:file", async (req: Request, res: Response) => { delete req.headers.host; let response: FetchResponse; @@ -113,7 +115,7 @@ function applyEnv(html: string): string { function applyPlugins(html: string): string { // plugins - let files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "plugins")); + let files = fs.readdirSync(path.join(AssetsPath, "plugins")); let plugins = ""; files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); return html.replaceAll("", plugins); @@ -121,7 +123,7 @@ function applyPlugins(html: string): string { function applyInlinePlugins(html: string): string{ // inline plugins - let files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "inline-plugins")); + let files = fs.readdirSync(path.join(AssetsPath, "inline-plugins")); let plugins = ""; files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n\n`; }); return html.replaceAll("", plugins); @@ -129,9 +131,9 @@ function applyInlinePlugins(html: string): string{ function applyPreloadPlugins(html: string): string{ //preload plugins - let files = fs.readdirSync(path.join(__dirname, "..", "..", "assets", "preload-plugins")); + let files = fs.readdirSync(path.join(AssetsPath, "preload-plugins")); let plugins = ""; - files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); + files.forEach(x =>{if(x.endsWith(".js")) plugins += `\n`; }); return html.replaceAll("", plugins); } diff --git a/api/src/middlewares/Translation.ts b/src/api/middlewares/Translation.ts similarity index 84% rename from api/src/middlewares/Translation.ts rename to src/api/middlewares/Translation.ts index baabf2210..64b03bf86 100644 --- a/api/src/middlewares/Translation.ts +++ b/src/api/middlewares/Translation.ts @@ -6,8 +6,8 @@ import i18nextBackend from "i18next-node-fs-backend"; import { Router } from "express"; export async function initTranslation(router: Router) { - const languages = fs.readdirSync(path.join(__dirname, "..", "..", "locales")); - const namespaces = fs.readdirSync(path.join(__dirname, "..", "..", "locales", "en")); + const languages = fs.readdirSync(path.join(__dirname, "..", "..", "..", "assets", "locales")); + const namespaces = fs.readdirSync(path.join(__dirname, "..", "..", "..", "assets", "locales", "en")); const ns = namespaces.filter((x) => x.endsWith(".json")).map((x) => x.slice(0, x.length - 5)); await i18next @@ -19,7 +19,7 @@ export async function initTranslation(router: Router) { fallbackLng: "en", ns, backend: { - loadPath: __dirname + "/../../locales/{{lng}}/{{ns}}.json" + loadPath: __dirname + "/../../../assets/locales/{{lng}}/{{ns}}.json" }, load: "all" }); diff --git a/api/src/middlewares/index.ts b/src/api/middlewares/index.ts similarity index 100% rename from api/src/middlewares/index.ts rename to src/api/middlewares/index.ts diff --git a/api/src/routes/-/healthz.ts b/src/api/routes/-/healthz.ts similarity index 100% rename from api/src/routes/-/healthz.ts rename to src/api/routes/-/healthz.ts diff --git a/api/src/routes/-/readyz.ts b/src/api/routes/-/readyz.ts similarity index 100% rename from api/src/routes/-/readyz.ts rename to src/api/routes/-/readyz.ts diff --git a/api/src/routes/applications/#id/entitlements.ts b/src/api/routes/applications/#id/entitlements.ts similarity index 100% rename from api/src/routes/applications/#id/entitlements.ts rename to src/api/routes/applications/#id/entitlements.ts diff --git a/api/src/routes/applications/detectable.ts b/src/api/routes/applications/detectable.ts similarity index 100% rename from api/src/routes/applications/detectable.ts rename to src/api/routes/applications/detectable.ts diff --git a/api/src/routes/applications/index.ts b/src/api/routes/applications/index.ts similarity index 100% rename from api/src/routes/applications/index.ts rename to src/api/routes/applications/index.ts diff --git a/api/src/routes/auth/location-metadata.ts b/src/api/routes/auth/location-metadata.ts similarity index 100% rename from api/src/routes/auth/location-metadata.ts rename to src/api/routes/auth/location-metadata.ts diff --git a/api/src/routes/auth/login.ts b/src/api/routes/auth/login.ts similarity index 100% rename from api/src/routes/auth/login.ts rename to src/api/routes/auth/login.ts diff --git a/api/src/routes/auth/mfa/totp.ts b/src/api/routes/auth/mfa/totp.ts similarity index 100% rename from api/src/routes/auth/mfa/totp.ts rename to src/api/routes/auth/mfa/totp.ts diff --git a/api/src/routes/auth/register.ts b/src/api/routes/auth/register.ts similarity index 100% rename from api/src/routes/auth/register.ts rename to src/api/routes/auth/register.ts diff --git a/api/src/routes/channels/#channel_id/followers.ts b/src/api/routes/channels/#channel_id/followers.ts similarity index 100% rename from api/src/routes/channels/#channel_id/followers.ts rename to src/api/routes/channels/#channel_id/followers.ts diff --git a/api/src/routes/channels/#channel_id/index.ts b/src/api/routes/channels/#channel_id/index.ts similarity index 100% rename from api/src/routes/channels/#channel_id/index.ts rename to src/api/routes/channels/#channel_id/index.ts diff --git a/api/src/routes/channels/#channel_id/invites.ts b/src/api/routes/channels/#channel_id/invites.ts similarity index 100% rename from api/src/routes/channels/#channel_id/invites.ts rename to src/api/routes/channels/#channel_id/invites.ts diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts b/src/api/routes/channels/#channel_id/messages/#message_id/ack.ts similarity index 100% rename from api/src/routes/channels/#channel_id/messages/#message_id/ack.ts rename to src/api/routes/channels/#channel_id/messages/#message_id/ack.ts diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/crosspost.ts b/src/api/routes/channels/#channel_id/messages/#message_id/crosspost.ts similarity index 100% rename from api/src/routes/channels/#channel_id/messages/#message_id/crosspost.ts rename to src/api/routes/channels/#channel_id/messages/#message_id/crosspost.ts diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/index.ts b/src/api/routes/channels/#channel_id/messages/#message_id/index.ts similarity index 100% rename from api/src/routes/channels/#channel_id/messages/#message_id/index.ts rename to src/api/routes/channels/#channel_id/messages/#message_id/index.ts diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts b/src/api/routes/channels/#channel_id/messages/#message_id/reactions.ts similarity index 100% rename from api/src/routes/channels/#channel_id/messages/#message_id/reactions.ts rename to src/api/routes/channels/#channel_id/messages/#message_id/reactions.ts diff --git a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts b/src/api/routes/channels/#channel_id/messages/bulk-delete.ts similarity index 95% rename from api/src/routes/channels/#channel_id/messages/bulk-delete.ts rename to src/api/routes/channels/#channel_id/messages/bulk-delete.ts index 24a33d2d9..af44b5228 100644 --- a/api/src/routes/channels/#channel_id/messages/bulk-delete.ts +++ b/src/api/routes/channels/#channel_id/messages/bulk-delete.ts @@ -13,7 +13,7 @@ export default router; // https://discord.com/developers/docs/resources/channel#bulk-delete-messages router.post("/", route({ body: "BulkDeleteSchema" }), async (req: Request, res: Response) => { const { channel_id } = req.params; - const channel = await Channel.findOneByOrFail({ id: channel_id }); + const channel = await Channel.findOneOrFail({where:{ id: channel_id} }); if (!channel.guild_id) throw new HTTPError("Can't bulk delete dm channel messages", 400); const rights = await getRights(req.user_id); diff --git a/api/src/routes/channels/#channel_id/messages/index.ts b/src/api/routes/channels/#channel_id/messages/index.ts similarity index 100% rename from api/src/routes/channels/#channel_id/messages/index.ts rename to src/api/routes/channels/#channel_id/messages/index.ts diff --git a/api/src/routes/channels/#channel_id/permissions.ts b/src/api/routes/channels/#channel_id/permissions.ts similarity index 100% rename from api/src/routes/channels/#channel_id/permissions.ts rename to src/api/routes/channels/#channel_id/permissions.ts diff --git a/api/src/routes/channels/#channel_id/pins.ts b/src/api/routes/channels/#channel_id/pins.ts similarity index 100% rename from api/src/routes/channels/#channel_id/pins.ts rename to src/api/routes/channels/#channel_id/pins.ts diff --git a/api/src/routes/channels/#channel_id/purge.ts b/src/api/routes/channels/#channel_id/purge.ts similarity index 100% rename from api/src/routes/channels/#channel_id/purge.ts rename to src/api/routes/channels/#channel_id/purge.ts diff --git a/api/src/routes/channels/#channel_id/recipients.ts b/src/api/routes/channels/#channel_id/recipients.ts similarity index 100% rename from api/src/routes/channels/#channel_id/recipients.ts rename to src/api/routes/channels/#channel_id/recipients.ts diff --git a/api/src/routes/channels/#channel_id/typing.ts b/src/api/routes/channels/#channel_id/typing.ts similarity index 100% rename from api/src/routes/channels/#channel_id/typing.ts rename to src/api/routes/channels/#channel_id/typing.ts diff --git a/api/src/routes/channels/#channel_id/webhooks.ts b/src/api/routes/channels/#channel_id/webhooks.ts similarity index 100% rename from api/src/routes/channels/#channel_id/webhooks.ts rename to src/api/routes/channels/#channel_id/webhooks.ts diff --git a/api/src/routes/discoverable-guilds.ts b/src/api/routes/discoverable-guilds.ts similarity index 100% rename from api/src/routes/discoverable-guilds.ts rename to src/api/routes/discoverable-guilds.ts diff --git a/api/src/routes/discovery.ts b/src/api/routes/discovery.ts similarity index 100% rename from api/src/routes/discovery.ts rename to src/api/routes/discovery.ts diff --git a/api/src/routes/downloads.ts b/src/api/routes/downloads.ts similarity index 100% rename from api/src/routes/downloads.ts rename to src/api/routes/downloads.ts diff --git a/api/src/routes/experiments.ts b/src/api/routes/experiments.ts similarity index 100% rename from api/src/routes/experiments.ts rename to src/api/routes/experiments.ts diff --git a/api/src/routes/gateway/bot.ts b/src/api/routes/gateway/bot.ts similarity index 100% rename from api/src/routes/gateway/bot.ts rename to src/api/routes/gateway/bot.ts diff --git a/api/src/routes/gateway/index.ts b/src/api/routes/gateway/index.ts similarity index 100% rename from api/src/routes/gateway/index.ts rename to src/api/routes/gateway/index.ts diff --git a/api/src/routes/gifs/search.ts b/src/api/routes/gifs/search.ts similarity index 100% rename from api/src/routes/gifs/search.ts rename to src/api/routes/gifs/search.ts diff --git a/api/src/routes/gifs/trending-gifs.ts b/src/api/routes/gifs/trending-gifs.ts similarity index 100% rename from api/src/routes/gifs/trending-gifs.ts rename to src/api/routes/gifs/trending-gifs.ts diff --git a/api/src/routes/gifs/trending.ts b/src/api/routes/gifs/trending.ts similarity index 100% rename from api/src/routes/gifs/trending.ts rename to src/api/routes/gifs/trending.ts diff --git a/api/src/routes/guild-recommendations.ts b/src/api/routes/guild-recommendations.ts similarity index 100% rename from api/src/routes/guild-recommendations.ts rename to src/api/routes/guild-recommendations.ts diff --git a/api/src/routes/guilds/#guild_id/audit-logs.ts b/src/api/routes/guilds/#guild_id/audit-logs.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/audit-logs.ts rename to src/api/routes/guilds/#guild_id/audit-logs.ts diff --git a/api/src/routes/guilds/#guild_id/bans.ts b/src/api/routes/guilds/#guild_id/bans.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/bans.ts rename to src/api/routes/guilds/#guild_id/bans.ts diff --git a/api/src/routes/guilds/#guild_id/channels.ts b/src/api/routes/guilds/#guild_id/channels.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/channels.ts rename to src/api/routes/guilds/#guild_id/channels.ts diff --git a/api/src/routes/guilds/#guild_id/delete.ts b/src/api/routes/guilds/#guild_id/delete.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/delete.ts rename to src/api/routes/guilds/#guild_id/delete.ts diff --git a/api/src/routes/guilds/#guild_id/discovery-requirements.ts b/src/api/routes/guilds/#guild_id/discovery-requirements.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/discovery-requirements.ts rename to src/api/routes/guilds/#guild_id/discovery-requirements.ts diff --git a/api/src/routes/guilds/#guild_id/emojis.ts b/src/api/routes/guilds/#guild_id/emojis.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/emojis.ts rename to src/api/routes/guilds/#guild_id/emojis.ts diff --git a/api/src/routes/guilds/#guild_id/index.ts b/src/api/routes/guilds/#guild_id/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/index.ts rename to src/api/routes/guilds/#guild_id/index.ts diff --git a/api/src/routes/guilds/#guild_id/integrations.ts b/src/api/routes/guilds/#guild_id/integrations.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/integrations.ts rename to src/api/routes/guilds/#guild_id/integrations.ts diff --git a/api/src/routes/guilds/#guild_id/invites.ts b/src/api/routes/guilds/#guild_id/invites.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/invites.ts rename to src/api/routes/guilds/#guild_id/invites.ts diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/src/api/routes/guilds/#guild_id/members/#member_id/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/members/#member_id/index.ts rename to src/api/routes/guilds/#guild_id/members/#member_id/index.ts diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/nick.ts b/src/api/routes/guilds/#guild_id/members/#member_id/nick.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/members/#member_id/nick.ts rename to src/api/routes/guilds/#guild_id/members/#member_id/nick.ts diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/roles/#role_id/index.ts b/src/api/routes/guilds/#guild_id/members/#member_id/roles/#role_id/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/members/#member_id/roles/#role_id/index.ts rename to src/api/routes/guilds/#guild_id/members/#member_id/roles/#role_id/index.ts diff --git a/api/src/routes/guilds/#guild_id/members/index.ts b/src/api/routes/guilds/#guild_id/members/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/members/index.ts rename to src/api/routes/guilds/#guild_id/members/index.ts diff --git a/api/src/routes/guilds/#guild_id/premium.ts b/src/api/routes/guilds/#guild_id/premium.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/premium.ts rename to src/api/routes/guilds/#guild_id/premium.ts diff --git a/api/src/routes/guilds/#guild_id/prune.ts b/src/api/routes/guilds/#guild_id/prune.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/prune.ts rename to src/api/routes/guilds/#guild_id/prune.ts diff --git a/api/src/routes/guilds/#guild_id/regions.ts b/src/api/routes/guilds/#guild_id/regions.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/regions.ts rename to src/api/routes/guilds/#guild_id/regions.ts diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/src/api/routes/guilds/#guild_id/roles/#role_id/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/roles/#role_id/index.ts rename to src/api/routes/guilds/#guild_id/roles/#role_id/index.ts diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/src/api/routes/guilds/#guild_id/roles/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/roles/index.ts rename to src/api/routes/guilds/#guild_id/roles/index.ts diff --git a/api/src/routes/guilds/#guild_id/stickers.ts b/src/api/routes/guilds/#guild_id/stickers.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/stickers.ts rename to src/api/routes/guilds/#guild_id/stickers.ts diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/src/api/routes/guilds/#guild_id/templates.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/templates.ts rename to src/api/routes/guilds/#guild_id/templates.ts diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/src/api/routes/guilds/#guild_id/vanity-url.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/vanity-url.ts rename to src/api/routes/guilds/#guild_id/vanity-url.ts diff --git a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts b/src/api/routes/guilds/#guild_id/voice-states/#user_id/index.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts rename to src/api/routes/guilds/#guild_id/voice-states/#user_id/index.ts diff --git a/api/src/routes/guilds/#guild_id/webhooks.ts b/src/api/routes/guilds/#guild_id/webhooks.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/webhooks.ts rename to src/api/routes/guilds/#guild_id/webhooks.ts diff --git a/api/src/routes/guilds/#guild_id/welcome_screen.ts b/src/api/routes/guilds/#guild_id/welcome_screen.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/welcome_screen.ts rename to src/api/routes/guilds/#guild_id/welcome_screen.ts diff --git a/api/src/routes/guilds/#guild_id/widget.json.ts b/src/api/routes/guilds/#guild_id/widget.json.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/widget.json.ts rename to src/api/routes/guilds/#guild_id/widget.json.ts diff --git a/api/src/routes/guilds/#guild_id/widget.png.ts b/src/api/routes/guilds/#guild_id/widget.png.ts similarity index 97% rename from api/src/routes/guilds/#guild_id/widget.png.ts rename to src/api/routes/guilds/#guild_id/widget.png.ts index ec0ac85cc..a61d938d8 100644 --- a/api/src/routes/guilds/#guild_id/widget.png.ts +++ b/src/api/routes/guilds/#guild_id/widget.png.ts @@ -34,7 +34,7 @@ router.get("/", route({}), async (req: Request, res: Response) => { const sizeOf = require("image-size"); // TODO: Widget style templates need Fosscord branding - const source = path.join(__dirname, "..", "..", "..", "..", "assets", "widget", `${style}.png`); + const source = path.join(__dirname, "..", "..", "..", "..", "..", "assets", "widget", `${style}.png`); if (!fs.existsSync(source)) { throw new HTTPError("Widget template does not exist.", 400); } diff --git a/api/src/routes/guilds/#guild_id/widget.ts b/src/api/routes/guilds/#guild_id/widget.ts similarity index 100% rename from api/src/routes/guilds/#guild_id/widget.ts rename to src/api/routes/guilds/#guild_id/widget.ts diff --git a/api/src/routes/guilds/index.ts b/src/api/routes/guilds/index.ts similarity index 100% rename from api/src/routes/guilds/index.ts rename to src/api/routes/guilds/index.ts diff --git a/api/src/routes/guilds/templates/index.ts b/src/api/routes/guilds/templates/index.ts similarity index 100% rename from api/src/routes/guilds/templates/index.ts rename to src/api/routes/guilds/templates/index.ts diff --git a/api/src/routes/invites/index.ts b/src/api/routes/invites/index.ts similarity index 100% rename from api/src/routes/invites/index.ts rename to src/api/routes/invites/index.ts diff --git a/api/src/routes/oauth2/tokens.ts b/src/api/routes/oauth2/tokens.ts similarity index 100% rename from api/src/routes/oauth2/tokens.ts rename to src/api/routes/oauth2/tokens.ts diff --git a/api/src/routes/outbound-promotions.ts b/src/api/routes/outbound-promotions.ts similarity index 100% rename from api/src/routes/outbound-promotions.ts rename to src/api/routes/outbound-promotions.ts diff --git a/api/src/routes/partners/#guild_id/requirements.ts b/src/api/routes/partners/#guild_id/requirements.ts similarity index 100% rename from api/src/routes/partners/#guild_id/requirements.ts rename to src/api/routes/partners/#guild_id/requirements.ts diff --git a/api/src/routes/ping.ts b/src/api/routes/ping.ts similarity index 100% rename from api/src/routes/ping.ts rename to src/api/routes/ping.ts diff --git a/api/src/routes/policies/instance/domains.ts b/src/api/routes/policies/instance/domains.ts similarity index 100% rename from api/src/routes/policies/instance/domains.ts rename to src/api/routes/policies/instance/domains.ts diff --git a/api/src/routes/policies/instance/index.ts b/src/api/routes/policies/instance/index.ts similarity index 100% rename from api/src/routes/policies/instance/index.ts rename to src/api/routes/policies/instance/index.ts diff --git a/api/src/routes/policies/instance/limits.ts b/src/api/routes/policies/instance/limits.ts similarity index 100% rename from api/src/routes/policies/instance/limits.ts rename to src/api/routes/policies/instance/limits.ts diff --git a/api/src/routes/scheduled-maintenances/upcoming_json.ts b/src/api/routes/scheduled-maintenances/upcoming_json.ts similarity index 100% rename from api/src/routes/scheduled-maintenances/upcoming_json.ts rename to src/api/routes/scheduled-maintenances/upcoming_json.ts diff --git a/api/src/routes/science.ts b/src/api/routes/science.ts similarity index 100% rename from api/src/routes/science.ts rename to src/api/routes/science.ts diff --git a/api/src/routes/stage-instances.ts b/src/api/routes/stage-instances.ts similarity index 100% rename from api/src/routes/stage-instances.ts rename to src/api/routes/stage-instances.ts diff --git a/api/src/routes/sticker-packs/index.ts b/src/api/routes/sticker-packs/index.ts similarity index 100% rename from api/src/routes/sticker-packs/index.ts rename to src/api/routes/sticker-packs/index.ts diff --git a/api/src/routes/stickers/#sticker_id/index.ts b/src/api/routes/stickers/#sticker_id/index.ts similarity index 100% rename from api/src/routes/stickers/#sticker_id/index.ts rename to src/api/routes/stickers/#sticker_id/index.ts diff --git a/api/src/routes/stop.ts b/src/api/routes/stop.ts similarity index 100% rename from api/src/routes/stop.ts rename to src/api/routes/stop.ts diff --git a/api/src/routes/store/published-listings/applications.ts b/src/api/routes/store/published-listings/applications.ts similarity index 100% rename from api/src/routes/store/published-listings/applications.ts rename to src/api/routes/store/published-listings/applications.ts diff --git a/api/src/routes/store/published-listings/applications/#id/subscription-plans.ts b/src/api/routes/store/published-listings/applications/#id/subscription-plans.ts similarity index 100% rename from api/src/routes/store/published-listings/applications/#id/subscription-plans.ts rename to src/api/routes/store/published-listings/applications/#id/subscription-plans.ts diff --git a/api/src/routes/store/published-listings/skus.ts b/src/api/routes/store/published-listings/skus.ts similarity index 100% rename from api/src/routes/store/published-listings/skus.ts rename to src/api/routes/store/published-listings/skus.ts diff --git a/api/src/routes/store/published-listings/skus/#sku_id/subscription-plans.ts b/src/api/routes/store/published-listings/skus/#sku_id/subscription-plans.ts similarity index 100% rename from api/src/routes/store/published-listings/skus/#sku_id/subscription-plans.ts rename to src/api/routes/store/published-listings/skus/#sku_id/subscription-plans.ts diff --git a/api/src/routes/teams.ts b/src/api/routes/teams.ts similarity index 100% rename from api/src/routes/teams.ts rename to src/api/routes/teams.ts diff --git a/api/src/routes/template.ts.disabled b/src/api/routes/template.ts.disabled similarity index 100% rename from api/src/routes/template.ts.disabled rename to src/api/routes/template.ts.disabled diff --git a/api/src/routes/track.ts b/src/api/routes/track.ts similarity index 100% rename from api/src/routes/track.ts rename to src/api/routes/track.ts diff --git a/api/src/routes/updates.ts b/src/api/routes/updates.ts similarity index 100% rename from api/src/routes/updates.ts rename to src/api/routes/updates.ts diff --git a/api/src/routes/users/#id/index.ts b/src/api/routes/users/#id/index.ts similarity index 100% rename from api/src/routes/users/#id/index.ts rename to src/api/routes/users/#id/index.ts diff --git a/api/src/routes/users/#id/profile.ts b/src/api/routes/users/#id/profile.ts similarity index 100% rename from api/src/routes/users/#id/profile.ts rename to src/api/routes/users/#id/profile.ts diff --git a/api/src/routes/users/#id/relationships.ts b/src/api/routes/users/#id/relationships.ts similarity index 100% rename from api/src/routes/users/#id/relationships.ts rename to src/api/routes/users/#id/relationships.ts diff --git a/api/src/routes/users/@me/activities/statistics/applications.ts b/src/api/routes/users/@me/activities/statistics/applications.ts similarity index 100% rename from api/src/routes/users/@me/activities/statistics/applications.ts rename to src/api/routes/users/@me/activities/statistics/applications.ts diff --git a/api/src/routes/users/@me/affinities/guilds.ts b/src/api/routes/users/@me/affinities/guilds.ts similarity index 100% rename from api/src/routes/users/@me/affinities/guilds.ts rename to src/api/routes/users/@me/affinities/guilds.ts diff --git a/api/src/routes/users/@me/affinities/users.ts b/src/api/routes/users/@me/affinities/users.ts similarity index 100% rename from api/src/routes/users/@me/affinities/users.ts rename to src/api/routes/users/@me/affinities/users.ts diff --git a/api/src/routes/users/@me/applications/#app_id/entitlements.ts b/src/api/routes/users/@me/applications/#app_id/entitlements.ts similarity index 100% rename from api/src/routes/users/@me/applications/#app_id/entitlements.ts rename to src/api/routes/users/@me/applications/#app_id/entitlements.ts diff --git a/api/src/routes/users/@me/billing/country-code.ts b/src/api/routes/users/@me/billing/country-code.ts similarity index 100% rename from api/src/routes/users/@me/billing/country-code.ts rename to src/api/routes/users/@me/billing/country-code.ts diff --git a/api/src/routes/users/@me/billing/payment-sources.ts b/src/api/routes/users/@me/billing/payment-sources.ts similarity index 100% rename from api/src/routes/users/@me/billing/payment-sources.ts rename to src/api/routes/users/@me/billing/payment-sources.ts diff --git a/api/src/routes/users/@me/billing/subscriptions.ts b/src/api/routes/users/@me/billing/subscriptions.ts similarity index 100% rename from api/src/routes/users/@me/billing/subscriptions.ts rename to src/api/routes/users/@me/billing/subscriptions.ts diff --git a/api/src/routes/users/@me/channels.ts b/src/api/routes/users/@me/channels.ts similarity index 100% rename from api/src/routes/users/@me/channels.ts rename to src/api/routes/users/@me/channels.ts diff --git a/api/src/routes/users/@me/connections.ts b/src/api/routes/users/@me/connections.ts similarity index 100% rename from api/src/routes/users/@me/connections.ts rename to src/api/routes/users/@me/connections.ts diff --git a/api/src/routes/users/@me/delete.ts b/src/api/routes/users/@me/delete.ts similarity index 100% rename from api/src/routes/users/@me/delete.ts rename to src/api/routes/users/@me/delete.ts diff --git a/api/src/routes/users/@me/devices.ts b/src/api/routes/users/@me/devices.ts similarity index 100% rename from api/src/routes/users/@me/devices.ts rename to src/api/routes/users/@me/devices.ts diff --git a/api/src/routes/users/@me/disable.ts b/src/api/routes/users/@me/disable.ts similarity index 100% rename from api/src/routes/users/@me/disable.ts rename to src/api/routes/users/@me/disable.ts diff --git a/api/src/routes/users/@me/email-settings.ts b/src/api/routes/users/@me/email-settings.ts similarity index 100% rename from api/src/routes/users/@me/email-settings.ts rename to src/api/routes/users/@me/email-settings.ts diff --git a/api/src/routes/users/@me/entitlements.ts b/src/api/routes/users/@me/entitlements.ts similarity index 100% rename from api/src/routes/users/@me/entitlements.ts rename to src/api/routes/users/@me/entitlements.ts diff --git a/api/src/routes/users/@me/guilds.ts b/src/api/routes/users/@me/guilds.ts similarity index 100% rename from api/src/routes/users/@me/guilds.ts rename to src/api/routes/users/@me/guilds.ts diff --git a/api/src/routes/users/@me/guilds/premium/subscription-slots.ts b/src/api/routes/users/@me/guilds/premium/subscription-slots.ts similarity index 100% rename from api/src/routes/users/@me/guilds/premium/subscription-slots.ts rename to src/api/routes/users/@me/guilds/premium/subscription-slots.ts diff --git a/api/src/routes/users/@me/index.ts b/src/api/routes/users/@me/index.ts similarity index 100% rename from api/src/routes/users/@me/index.ts rename to src/api/routes/users/@me/index.ts diff --git a/api/src/routes/users/@me/library.ts b/src/api/routes/users/@me/library.ts similarity index 100% rename from api/src/routes/users/@me/library.ts rename to src/api/routes/users/@me/library.ts diff --git a/api/src/routes/users/@me/mfa/codes.ts b/src/api/routes/users/@me/mfa/codes.ts similarity index 100% rename from api/src/routes/users/@me/mfa/codes.ts rename to src/api/routes/users/@me/mfa/codes.ts diff --git a/api/src/routes/users/@me/mfa/totp/disable.ts b/src/api/routes/users/@me/mfa/totp/disable.ts similarity index 100% rename from api/src/routes/users/@me/mfa/totp/disable.ts rename to src/api/routes/users/@me/mfa/totp/disable.ts diff --git a/api/src/routes/users/@me/mfa/totp/enable.ts b/src/api/routes/users/@me/mfa/totp/enable.ts similarity index 100% rename from api/src/routes/users/@me/mfa/totp/enable.ts rename to src/api/routes/users/@me/mfa/totp/enable.ts diff --git a/api/src/routes/users/@me/notes.ts b/src/api/routes/users/@me/notes.ts similarity index 100% rename from api/src/routes/users/@me/notes.ts rename to src/api/routes/users/@me/notes.ts diff --git a/api/src/routes/users/@me/relationships.ts b/src/api/routes/users/@me/relationships.ts similarity index 100% rename from api/src/routes/users/@me/relationships.ts rename to src/api/routes/users/@me/relationships.ts diff --git a/api/src/routes/users/@me/settings.ts b/src/api/routes/users/@me/settings.ts similarity index 100% rename from api/src/routes/users/@me/settings.ts rename to src/api/routes/users/@me/settings.ts diff --git a/api/src/routes/voice/regions.ts b/src/api/routes/voice/regions.ts similarity index 100% rename from api/src/routes/voice/regions.ts rename to src/api/routes/voice/regions.ts diff --git a/api/src/start.ts b/src/api/start.ts similarity index 92% rename from api/src/start.ts rename to src/api/start.ts index 98beb1fa8..9ba198e72 100644 --- a/api/src/start.ts +++ b/src/api/start.ts @@ -13,7 +13,7 @@ try { console.log("[API] Failed to get thread count! Using 1...") } -if (cluster.isPrimary && process.env.NODE_ENV == "production") { +if (cluster.isMaster && process.env.NODE_ENV == "production") { console.log(`Primary ${process.pid} is running`); // Fork workers. diff --git a/api/src/util/entities/AssetCacheItem.ts b/src/api/util/entities/AssetCacheItem.ts similarity index 100% rename from api/src/util/entities/AssetCacheItem.ts rename to src/api/util/entities/AssetCacheItem.ts diff --git a/api/src/util/entities/blockedEmailDomains.txt b/src/api/util/entities/blockedEmailDomains.txt similarity index 100% rename from api/src/util/entities/blockedEmailDomains.txt rename to src/api/util/entities/blockedEmailDomains.txt diff --git a/api/src/util/entities/trustedEmailDomains.txt b/src/api/util/entities/trustedEmailDomains.txt similarity index 100% rename from api/src/util/entities/trustedEmailDomains.txt rename to src/api/util/entities/trustedEmailDomains.txt diff --git a/api/src/util/handlers/Instance.ts b/src/api/util/handlers/Instance.ts similarity index 100% rename from api/src/util/handlers/Instance.ts rename to src/api/util/handlers/Instance.ts diff --git a/api/src/util/handlers/Message.ts b/src/api/util/handlers/Message.ts similarity index 100% rename from api/src/util/handlers/Message.ts rename to src/api/util/handlers/Message.ts diff --git a/api/src/util/handlers/Voice.ts b/src/api/util/handlers/Voice.ts similarity index 100% rename from api/src/util/handlers/Voice.ts rename to src/api/util/handlers/Voice.ts diff --git a/api/src/util/handlers/route.ts b/src/api/util/handlers/route.ts similarity index 97% rename from api/src/util/handlers/route.ts rename to src/api/util/handlers/route.ts index f8130f3cb..71e149555 100644 --- a/api/src/util/handlers/route.ts +++ b/src/api/util/handlers/route.ts @@ -19,7 +19,7 @@ import Ajv from "ajv"; import { AnyValidateFunction } from "ajv/dist/core"; import addFormats from "ajv-formats"; -const SchemaPath = path.join(__dirname, "..", "..", "..", "assets", "schemas.json"); +const SchemaPath = path.join(__dirname, "..", "..", "..","..", "assets", "schemas.json"); const schemas = JSON.parse(fs.readFileSync(SchemaPath, { encoding: "utf8" })); export const ajv = new Ajv({ diff --git a/api/src/util/index.ts b/src/api/util/index.ts similarity index 100% rename from api/src/util/index.ts rename to src/api/util/index.ts diff --git a/api/src/util/utility/Base64.ts b/src/api/util/utility/Base64.ts similarity index 100% rename from api/src/util/utility/Base64.ts rename to src/api/util/utility/Base64.ts diff --git a/api/src/util/utility/RandomInviteID.ts b/src/api/util/utility/RandomInviteID.ts similarity index 100% rename from api/src/util/utility/RandomInviteID.ts rename to src/api/util/utility/RandomInviteID.ts diff --git a/api/src/util/utility/String.ts b/src/api/util/utility/String.ts similarity index 100% rename from api/src/util/utility/String.ts rename to src/api/util/utility/String.ts diff --git a/api/src/util/utility/ipAddress.ts b/src/api/util/utility/ipAddress.ts similarity index 100% rename from api/src/util/utility/ipAddress.ts rename to src/api/util/utility/ipAddress.ts diff --git a/api/src/util/utility/passwordStrength.ts b/src/api/util/utility/passwordStrength.ts similarity index 100% rename from api/src/util/utility/passwordStrength.ts rename to src/api/util/utility/passwordStrength.ts diff --git a/cdn/src/Server.ts b/src/cdn/Server.ts similarity index 100% rename from cdn/src/Server.ts rename to src/cdn/Server.ts diff --git a/cdn/src/index.ts b/src/cdn/index.ts similarity index 100% rename from cdn/src/index.ts rename to src/cdn/index.ts diff --git a/cdn/src/routes/attachments.ts b/src/cdn/routes/attachments.ts similarity index 100% rename from cdn/src/routes/attachments.ts rename to src/cdn/routes/attachments.ts diff --git a/cdn/src/routes/avatars.ts b/src/cdn/routes/avatars.ts similarity index 100% rename from cdn/src/routes/avatars.ts rename to src/cdn/routes/avatars.ts diff --git a/cdn/src/routes/external.ts b/src/cdn/routes/external.ts similarity index 100% rename from cdn/src/routes/external.ts rename to src/cdn/routes/external.ts diff --git a/cdn/src/routes/ping.ts b/src/cdn/routes/ping.ts similarity index 100% rename from cdn/src/routes/ping.ts rename to src/cdn/routes/ping.ts diff --git a/cdn/src/routes/role-icons.ts b/src/cdn/routes/role-icons.ts similarity index 100% rename from cdn/src/routes/role-icons.ts rename to src/cdn/routes/role-icons.ts diff --git a/cdn/src/start.ts b/src/cdn/start.ts similarity index 100% rename from cdn/src/start.ts rename to src/cdn/start.ts diff --git a/cdn/src/util/FileStorage.ts b/src/cdn/util/FileStorage.ts similarity index 100% rename from cdn/src/util/FileStorage.ts rename to src/cdn/util/FileStorage.ts diff --git a/cdn/src/util/S3Storage.ts b/src/cdn/util/S3Storage.ts similarity index 100% rename from cdn/src/util/S3Storage.ts rename to src/cdn/util/S3Storage.ts diff --git a/cdn/src/util/Storage.ts b/src/cdn/util/Storage.ts similarity index 100% rename from cdn/src/util/Storage.ts rename to src/cdn/util/Storage.ts diff --git a/cdn/src/util/index.ts b/src/cdn/util/index.ts similarity index 100% rename from cdn/src/util/index.ts rename to src/cdn/util/index.ts diff --git a/cdn/src/util/multer.ts b/src/cdn/util/multer.ts similarity index 100% rename from cdn/src/util/multer.ts rename to src/cdn/util/multer.ts diff --git a/gateway/src/Server.ts b/src/gateway/Server.ts similarity index 100% rename from gateway/src/Server.ts rename to src/gateway/Server.ts diff --git a/gateway/src/events/Close.ts b/src/gateway/events/Close.ts similarity index 100% rename from gateway/src/events/Close.ts rename to src/gateway/events/Close.ts diff --git a/gateway/src/events/Connection.ts b/src/gateway/events/Connection.ts similarity index 100% rename from gateway/src/events/Connection.ts rename to src/gateway/events/Connection.ts diff --git a/gateway/src/events/Message.ts b/src/gateway/events/Message.ts similarity index 94% rename from gateway/src/events/Message.ts rename to src/gateway/events/Message.ts index 7ed1dd067..569f5fc70 100644 --- a/gateway/src/events/Message.ts +++ b/src/gateway/events/Message.ts @@ -6,7 +6,6 @@ try { } catch (error) {} import OPCodeHandlers from "../opcodes"; import { check } from "../opcodes/instanceOf"; -import WS from "ws"; const PayloadSchema = { op: Number, @@ -15,7 +14,7 @@ const PayloadSchema = { $t: String, }; -export async function Message(this: WebSocket, buffer: WS.RawData) { +export async function Message(this: WebSocket, buffer: Buffer) { // TODO: compression let data: Payload; diff --git a/gateway/src/index.ts b/src/gateway/index.ts similarity index 100% rename from gateway/src/index.ts rename to src/gateway/index.ts diff --git a/gateway/src/listener/listener.ts b/src/gateway/listener/listener.ts similarity index 100% rename from gateway/src/listener/listener.ts rename to src/gateway/listener/listener.ts diff --git a/gateway/src/opcodes/Heartbeat.ts b/src/gateway/opcodes/Heartbeat.ts similarity index 100% rename from gateway/src/opcodes/Heartbeat.ts rename to src/gateway/opcodes/Heartbeat.ts diff --git a/src/gateway/opcodes/Identify.ts b/src/gateway/opcodes/Identify.ts new file mode 100644 index 000000000..4f17ab706 --- /dev/null +++ b/src/gateway/opcodes/Identify.ts @@ -0,0 +1,298 @@ +import { WebSocket, Payload } from "@fosscord/gateway"; +import { + checkToken, + Intents, + Member, + ReadyEventData, + User, + Session, + EVENTEnum, + Config, + PublicMember, + PublicUser, + PrivateUserProjection, + ReadState, + Application, + emitEvent, + SessionsReplace, + PrivateSessionProjection, + MemberPrivateProjection, + PresenceUpdateEvent, + UserSettings, + IdentifySchema, +} from "@fosscord/util"; +import { Send } from "../util/Send"; +import { CLOSECODES, OPCODES } from "../util/Constants"; +import { genSessionId } from "../util/SessionUtils"; +import { setupListener } from "../listener/listener"; +// import experiments from "./experiments.json"; +const experiments: any = []; +import { check } from "./instanceOf"; +import { Recipient } from "@fosscord/util"; +import { OrmUtils } from "@fosscord/util"; + +// TODO: user sharding +// TODO: check privileged intents, if defined in the config +// TODO: check if already identified + +export async function onIdentify(this: WebSocket, data: Payload) { + clearTimeout(this.readyTimeout); + check.call(this, IdentifySchema, data.d); + + const identify: IdentifySchema = data.d; + + try { + const { jwtSecret } = Config.get().security; + var { decoded } = await checkToken(identify.token, jwtSecret); // will throw an error if invalid + } catch (error) { + console.error("invalid token", error); + return this.close(CLOSECODES.Authentication_failed); + } + this.user_id = decoded.id; + + const session_id = genSessionId(); + this.session_id = session_id; //Set the session of the WebSocket object + + const [user, read_states, members, recipients, session, application] = + await Promise.all([ + User.findOneOrFail({ + where: { id: this.user_id }, + relations: ["relationships", "relationships.to", "settings"], + select: [...PrivateUserProjection, "relationships"], + }), + ReadState.find({ where: { user_id: this.user_id } }), + Member.find({ + where: { id: this.user_id }, + select: MemberPrivateProjection, + relations: [ + "guild", + "guild.channels", + "guild.emojis", + "guild.emojis.user", + "guild.roles", + "guild.stickers", + "user", + "roles", + ], + }), + Recipient.find({ + where: { user_id: this.user_id, closed: false }, + relations: [ + "channel", + "channel.recipients", + "channel.recipients.user", + ], + // TODO: public user selection + }), + // save the session and delete it when the websocket is closed + await OrmUtils.mergeDeep(new Session(), { + user_id: this.user_id, + session_id: session_id, + // TODO: check if status is only one of: online, dnd, offline, idle + status: identify.presence?.status || "offline", //does the session always start as online? + client_info: { + //TODO read from identity + client: "desktop", + os: identify.properties?.os, + version: 0, + }, + activities: [], + }).save(), + Application.findOne({ where: { id: this.user_id } }), + ]); + + if (!user) return this.close(CLOSECODES.Authentication_failed); + if (!user.settings) { //settings may not exist after updating... + user.settings = new UserSettings(); + user.settings.id = user.id; + await user.settings.save(); + } + + if (!identify.intents) identify.intents = "0x6ffffffff" + this.intents = new Intents(identify.intents); + if (identify.shard) { + this.shard_id = identify.shard[0]; + this.shard_count = identify.shard[1]; + if ( + this.shard_count == null || + this.shard_id == null || + this.shard_id >= this.shard_count || + this.shard_id < 0 || + this.shard_count <= 0 + ) { + console.log(identify.shard); + return this.close(CLOSECODES.Invalid_shard); + } + } + let users: PublicUser[] = []; + + const merged_members = members.map((x: Member) => { + return [ + { + ...x, + roles: x.roles.map((x) => x.id), + settings: undefined, + guild: undefined, + }, + ]; + }) as PublicMember[][]; + let guilds = members.map((x) => ({ ...x.guild, joined_at: x.joined_at })); + + // @ts-ignore + guilds = guilds.map((guild) => { + if (user.bot) { + setTimeout(() => { + Send(this, { + op: OPCODES.Dispatch, + t: EVENTEnum.GuildCreate, + s: this.sequence++, + d: guild, + }); + }, 500); + return { id: guild.id, unavailable: true }; + } + + return guild; + }); + + const user_guild_settings_entries = members.map((x) => x.settings); + + const channels = recipients.map((x) => { + // @ts-ignore + x.channel.recipients = x.channel.recipients?.map((x) => x.user); + //TODO is this needed? check if users in group dm that are not friends are sent in the READY event + users = users.concat(x.channel.recipients as unknown as User[]); + if (x.channel.isDm()) { + x.channel.recipients = x.channel.recipients!.filter( + (x) => x.id !== this.user_id + ); + } + return x.channel; + }); + + for (let relation of user.relationships) { + const related_user = relation.to; + const public_related_user = { + username: related_user.username, + discriminator: related_user.discriminator, + id: related_user.id, + public_flags: related_user.public_flags, + avatar: related_user.avatar, + bot: related_user.bot, + bio: related_user.bio, + premium_since: user.premium_since + }; + users.push(public_related_user); + } + + setImmediate(async () => { + // run in seperate "promise context" because ready payload is not dependent on those events + emitEvent({ + event: "SESSIONS_REPLACE", + user_id: this.user_id, + data: await Session.find({ + where: { user_id: this.user_id }, + select: PrivateSessionProjection, + }), + } as SessionsReplace); + emitEvent({ + event: "PRESENCE_UPDATE", + user_id: this.user_id, + data: { + user: await User.getPublicUser(this.user_id), + activities: session.activities, + client_status: session?.client_info, + status: session.status, + }, + } as PresenceUpdateEvent); + }); + + read_states.forEach((s: any) => { + s.id = s.channel_id; + delete s.user_id; + delete s.channel_id; + }); + + const privateUser = { + avatar: user.avatar, + mobile: user.mobile, + desktop: user.desktop, + discriminator: user.discriminator, + email: user.email, + flags: user.flags, + id: user.id, + mfa_enabled: user.mfa_enabled, + nsfw_allowed: user.nsfw_allowed, + phone: user.phone, + premium: user.premium, + premium_type: user.premium_type, + public_flags: user.public_flags, + username: user.username, + verified: user.verified, + bot: user.bot, + accent_color: user.accent_color || 0, + banner: user.banner, + bio: user.bio, + premium_since: user.premium_since + }; + + const d: ReadyEventData = { + v: 8, + application: {id: application?.id??'', flags: application?.flags??''}, //TODO: check this code! + user: privateUser, + user_settings: user.settings, + // @ts-ignore + guilds: guilds.map((x) => { + // @ts-ignore + x.guild_hashes = {}; // @ts-ignore + x.guild_scheduled_events = []; // @ts-ignore + x.threads = []; + return x; + }), + guild_experiments: [], // TODO + geo_ordered_rtc_regions: [], // TODO + relationships: user.relationships.map((x) => x.toPublicRelationship()), + read_state: { + entries: read_states, + partial: false, + version: 304128, + }, + user_guild_settings: { + entries: user_guild_settings_entries, + partial: false, // TODO partial + version: 642, + }, + private_channels: channels, + session_id: session_id, + analytics_token: "", // TODO + connected_accounts: [], // TODO + consents: { + personalization: { + consented: false, // TODO + }, + }, + country_code: user.settings.locale, + friend_suggestion_count: 0, // TODO + // @ts-ignore + experiments: experiments, // TODO + guild_join_requests: [], // TODO what is this? + users: users.filter((x) => x).unique(), + merged_members: merged_members, + // shard // TODO: only for user sharding + }; + + // TODO: send real proper data structure + await Send(this, { + op: OPCODES.Dispatch, + t: EVENTEnum.Ready, + s: this.sequence++, + d, + }); + + //TODO send READY_SUPPLEMENTAL + //TODO send GUILD_MEMBER_LIST_UPDATE + //TODO send SESSIONS_REPLACE + //TODO send VOICE_STATE_UPDATE to let the client know if another device is already connected to a voice channel + + await setupListener.call(this); +} diff --git a/gateway/src/opcodes/LazyRequest.ts b/src/gateway/opcodes/LazyRequest.ts similarity index 98% rename from gateway/src/opcodes/LazyRequest.ts rename to src/gateway/opcodes/LazyRequest.ts index cd0586de2..74996f5b8 100644 --- a/gateway/src/opcodes/LazyRequest.ts +++ b/src/gateway/opcodes/LazyRequest.ts @@ -16,7 +16,7 @@ async function getMembers(guild_id: string, range: [number, number]) { // TODO: wait for typeorm to implement ordering for .find queries https://github.com/typeorm/typeorm/issues/2620 // TODO: rewrite this, released in 0.3.0 - let members = await (await getOrInitialiseDatabase()).getRepository(Member) + let members: Member[] = await (await getOrInitialiseDatabase()).getRepository(Member) .createQueryBuilder("member") .where("member.guild_id = :guild_id", { guild_id }) .leftJoinAndSelect("member.roles", "role") diff --git a/gateway/src/opcodes/PresenceUpdate.ts b/src/gateway/opcodes/PresenceUpdate.ts similarity index 100% rename from gateway/src/opcodes/PresenceUpdate.ts rename to src/gateway/opcodes/PresenceUpdate.ts diff --git a/gateway/src/opcodes/RequestGuildMembers.ts b/src/gateway/opcodes/RequestGuildMembers.ts similarity index 100% rename from gateway/src/opcodes/RequestGuildMembers.ts rename to src/gateway/opcodes/RequestGuildMembers.ts diff --git a/gateway/src/opcodes/Resume.ts b/src/gateway/opcodes/Resume.ts similarity index 100% rename from gateway/src/opcodes/Resume.ts rename to src/gateway/opcodes/Resume.ts diff --git a/gateway/src/opcodes/VoiceStateUpdate.ts b/src/gateway/opcodes/VoiceStateUpdate.ts similarity index 98% rename from gateway/src/opcodes/VoiceStateUpdate.ts rename to src/gateway/opcodes/VoiceStateUpdate.ts index 73f73565c..c4297a68f 100644 --- a/gateway/src/opcodes/VoiceStateUpdate.ts +++ b/src/gateway/opcodes/VoiceStateUpdate.ts @@ -12,7 +12,7 @@ import { VoiceStateUpdateSchema, } from "@fosscord/util"; import { OrmUtils } from "@fosscord/util"; -import { Region } from "@fosscord/util/src/config"; +import { Region } from "@fosscord/util"; // TODO: check if a voice server is setup // Notice: Bot users respect the voice channel's user limit, if set. When the voice channel is full, you will not receive the Voice State Update or Voice Server Update events in response to your own Voice State Update. Having MANAGE_CHANNELS permission bypasses this limit and allows you to join regardless of the channel being full or not. diff --git a/gateway/src/opcodes/experiments.json b/src/gateway/opcodes/experiments.json similarity index 100% rename from gateway/src/opcodes/experiments.json rename to src/gateway/opcodes/experiments.json diff --git a/gateway/src/opcodes/index.ts b/src/gateway/opcodes/index.ts similarity index 100% rename from gateway/src/opcodes/index.ts rename to src/gateway/opcodes/index.ts diff --git a/gateway/src/opcodes/instanceOf.ts b/src/gateway/opcodes/instanceOf.ts similarity index 100% rename from gateway/src/opcodes/instanceOf.ts rename to src/gateway/opcodes/instanceOf.ts diff --git a/gateway/src/start.ts b/src/gateway/start.ts similarity index 100% rename from gateway/src/start.ts rename to src/gateway/start.ts diff --git a/gateway/src/util/Constants.ts b/src/gateway/util/Constants.ts similarity index 100% rename from gateway/src/util/Constants.ts rename to src/gateway/util/Constants.ts diff --git a/gateway/src/util/Heartbeat.ts b/src/gateway/util/Heartbeat.ts similarity index 100% rename from gateway/src/util/Heartbeat.ts rename to src/gateway/util/Heartbeat.ts diff --git a/gateway/src/util/Send.ts b/src/gateway/util/Send.ts similarity index 100% rename from gateway/src/util/Send.ts rename to src/gateway/util/Send.ts diff --git a/gateway/src/util/SessionUtils.ts b/src/gateway/util/SessionUtils.ts similarity index 100% rename from gateway/src/util/SessionUtils.ts rename to src/gateway/util/SessionUtils.ts diff --git a/gateway/src/util/WebSocket.ts b/src/gateway/util/WebSocket.ts similarity index 92% rename from gateway/src/util/WebSocket.ts rename to src/gateway/util/WebSocket.ts index e3313f406..9496da856 100644 --- a/gateway/src/util/WebSocket.ts +++ b/src/gateway/util/WebSocket.ts @@ -8,8 +8,8 @@ export interface WebSocket extends WS { session_id: string; encoding: "etf" | "json"; compress?: "zlib-stream"; - shard_count?: bigint; - shard_id?: bigint; + shard_count?: number; + shard_id?: number; deflate?: Deflate; heartbeatTimeout: NodeJS.Timeout; readyTimeout: NodeJS.Timeout; diff --git a/gateway/src/util/index.ts b/src/gateway/util/index.ts similarity index 100% rename from gateway/src/util/index.ts rename to src/gateway/util/index.ts diff --git a/bundle/src/start.ts b/src/start.ts similarity index 100% rename from bundle/src/start.ts rename to src/start.ts diff --git a/src/stats.ts b/src/stats.ts new file mode 100644 index 000000000..654e0a4f1 --- /dev/null +++ b/src/stats.ts @@ -0,0 +1,24 @@ +import os from "os"; +import { red } from "picocolors"; + +export function initStats() { + + console.log(`[Path] running in ${__dirname}`); + try { + console.log(`[CPU] ${os.cpus()[0].model} Cores x${os.cpus().length}`); + } + catch { + console.log('[CPU] Failed to get cpu model!') + } + + console.log(`[System] ${os.platform()} ${os.arch()}`); + console.log(`[Process] running with PID: ${process.pid}`); + if (process.getuid && process.getuid() === 0) { + console.warn( + red( + `[Process] Warning fosscord is running as root, this highly discouraged and might expose your system vulnerable to attackers. Please run fosscord as a user without root privileges.` + ) + ); + } + +} diff --git a/util/src/config/Config.ts b/src/util/config/Config.ts similarity index 95% rename from util/src/config/Config.ts rename to src/util/config/Config.ts index b703040f7..7aee17753 100644 --- a/util/src/config/Config.ts +++ b/src/util/config/Config.ts @@ -1,4 +1,4 @@ -import { ApiConfiguration, ClientConfiguration, DefaultsConfiguration, EndpointConfiguration, GeneralConfiguration, GifConfiguration, GuildConfiguration, KafkaConfiguration, LimitsConfiguration, LoginConfiguration, MetricsConfiguration, RabbitMQConfiguration, RegionConfiguration, RegisterConfiguration, SecurityConfiguration, SentryConfiguration, TemplateConfiguration } from "../config"; +import { ApiConfiguration, ClientConfiguration, DefaultsConfiguration, EndpointConfiguration, GeneralConfiguration, GifConfiguration, GuildConfiguration, KafkaConfiguration, LimitsConfiguration, LoginConfiguration, MetricsConfiguration, RabbitMQConfiguration, RegionConfiguration, RegisterConfiguration, SecurityConfiguration, SentryConfiguration, TemplateConfiguration } from "."; export class ConfigValue { gateway: EndpointConfiguration = new EndpointConfiguration(); diff --git a/util/src/config/index.ts b/src/util/config/index.ts similarity index 100% rename from util/src/config/index.ts rename to src/util/config/index.ts diff --git a/util/src/config/types/ApiConfiguration.ts b/src/util/config/types/ApiConfiguration.ts similarity index 100% rename from util/src/config/types/ApiConfiguration.ts rename to src/util/config/types/ApiConfiguration.ts diff --git a/util/src/config/types/ClientConfiguration.ts b/src/util/config/types/ClientConfiguration.ts similarity index 100% rename from util/src/config/types/ClientConfiguration.ts rename to src/util/config/types/ClientConfiguration.ts diff --git a/util/src/config/types/DefaultsConfiguration.ts b/src/util/config/types/DefaultsConfiguration.ts similarity index 100% rename from util/src/config/types/DefaultsConfiguration.ts rename to src/util/config/types/DefaultsConfiguration.ts diff --git a/util/src/config/types/EndpointConfiguration.ts b/src/util/config/types/EndpointConfiguration.ts similarity index 100% rename from util/src/config/types/EndpointConfiguration.ts rename to src/util/config/types/EndpointConfiguration.ts diff --git a/util/src/config/types/GeneralConfiguration.ts b/src/util/config/types/GeneralConfiguration.ts similarity index 100% rename from util/src/config/types/GeneralConfiguration.ts rename to src/util/config/types/GeneralConfiguration.ts diff --git a/util/src/config/types/GifConfiguration.ts b/src/util/config/types/GifConfiguration.ts similarity index 100% rename from util/src/config/types/GifConfiguration.ts rename to src/util/config/types/GifConfiguration.ts diff --git a/util/src/config/types/GuildConfiguration.ts b/src/util/config/types/GuildConfiguration.ts similarity index 100% rename from util/src/config/types/GuildConfiguration.ts rename to src/util/config/types/GuildConfiguration.ts diff --git a/util/src/config/types/KafkaConfiguration.ts b/src/util/config/types/KafkaConfiguration.ts similarity index 100% rename from util/src/config/types/KafkaConfiguration.ts rename to src/util/config/types/KafkaConfiguration.ts diff --git a/util/src/config/types/LimitConfigurations.ts b/src/util/config/types/LimitConfigurations.ts similarity index 100% rename from util/src/config/types/LimitConfigurations.ts rename to src/util/config/types/LimitConfigurations.ts diff --git a/util/src/config/types/LoginConfiguration.ts b/src/util/config/types/LoginConfiguration.ts similarity index 100% rename from util/src/config/types/LoginConfiguration.ts rename to src/util/config/types/LoginConfiguration.ts diff --git a/util/src/config/types/MetricsConfiguration.ts b/src/util/config/types/MetricsConfiguration.ts similarity index 100% rename from util/src/config/types/MetricsConfiguration.ts rename to src/util/config/types/MetricsConfiguration.ts diff --git a/util/src/config/types/RabbitMQConfiguration.ts b/src/util/config/types/RabbitMQConfiguration.ts similarity index 100% rename from util/src/config/types/RabbitMQConfiguration.ts rename to src/util/config/types/RabbitMQConfiguration.ts diff --git a/util/src/config/types/RegionConfiguration.ts b/src/util/config/types/RegionConfiguration.ts similarity index 100% rename from util/src/config/types/RegionConfiguration.ts rename to src/util/config/types/RegionConfiguration.ts diff --git a/util/src/config/types/RegisterConfiguration.ts b/src/util/config/types/RegisterConfiguration.ts similarity index 100% rename from util/src/config/types/RegisterConfiguration.ts rename to src/util/config/types/RegisterConfiguration.ts diff --git a/util/src/config/types/SecurityConfiguration.ts b/src/util/config/types/SecurityConfiguration.ts similarity index 100% rename from util/src/config/types/SecurityConfiguration.ts rename to src/util/config/types/SecurityConfiguration.ts diff --git a/util/src/config/types/SentryConfiguration.ts b/src/util/config/types/SentryConfiguration.ts similarity index 100% rename from util/src/config/types/SentryConfiguration.ts rename to src/util/config/types/SentryConfiguration.ts diff --git a/util/src/config/types/TemplateConfiguration.ts b/src/util/config/types/TemplateConfiguration.ts similarity index 100% rename from util/src/config/types/TemplateConfiguration.ts rename to src/util/config/types/TemplateConfiguration.ts diff --git a/util/src/config/types/index.ts b/src/util/config/types/index.ts similarity index 100% rename from util/src/config/types/index.ts rename to src/util/config/types/index.ts diff --git a/util/src/config/types/subconfigurations/client/ClientReleaseConfiguration.ts b/src/util/config/types/subconfigurations/client/ClientReleaseConfiguration.ts similarity index 100% rename from util/src/config/types/subconfigurations/client/ClientReleaseConfiguration.ts rename to src/util/config/types/subconfigurations/client/ClientReleaseConfiguration.ts diff --git a/util/src/config/types/subconfigurations/client/index.ts b/src/util/config/types/subconfigurations/client/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/client/index.ts rename to src/util/config/types/subconfigurations/client/index.ts diff --git a/util/src/config/types/subconfigurations/defaults/GuildDefaults.ts b/src/util/config/types/subconfigurations/defaults/GuildDefaults.ts similarity index 100% rename from util/src/config/types/subconfigurations/defaults/GuildDefaults.ts rename to src/util/config/types/subconfigurations/defaults/GuildDefaults.ts diff --git a/util/src/config/types/subconfigurations/defaults/UserDefaults.ts b/src/util/config/types/subconfigurations/defaults/UserDefaults.ts similarity index 100% rename from util/src/config/types/subconfigurations/defaults/UserDefaults.ts rename to src/util/config/types/subconfigurations/defaults/UserDefaults.ts diff --git a/util/src/config/types/subconfigurations/defaults/index.ts b/src/util/config/types/subconfigurations/defaults/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/defaults/index.ts rename to src/util/config/types/subconfigurations/defaults/index.ts diff --git a/util/src/config/types/subconfigurations/guild/AutoJoin.ts b/src/util/config/types/subconfigurations/guild/AutoJoin.ts similarity index 100% rename from util/src/config/types/subconfigurations/guild/AutoJoin.ts rename to src/util/config/types/subconfigurations/guild/AutoJoin.ts diff --git a/util/src/config/types/subconfigurations/guild/Discovery.ts b/src/util/config/types/subconfigurations/guild/Discovery.ts similarity index 100% rename from util/src/config/types/subconfigurations/guild/Discovery.ts rename to src/util/config/types/subconfigurations/guild/Discovery.ts diff --git a/util/src/config/types/subconfigurations/guild/index.ts b/src/util/config/types/subconfigurations/guild/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/guild/index.ts rename to src/util/config/types/subconfigurations/guild/index.ts diff --git a/util/src/config/types/subconfigurations/index.ts b/src/util/config/types/subconfigurations/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/index.ts rename to src/util/config/types/subconfigurations/index.ts diff --git a/util/src/config/types/subconfigurations/kafka/KafkaBroker.ts b/src/util/config/types/subconfigurations/kafka/KafkaBroker.ts similarity index 100% rename from util/src/config/types/subconfigurations/kafka/KafkaBroker.ts rename to src/util/config/types/subconfigurations/kafka/KafkaBroker.ts diff --git a/util/src/config/types/subconfigurations/kafka/index.ts b/src/util/config/types/subconfigurations/kafka/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/kafka/index.ts rename to src/util/config/types/subconfigurations/kafka/index.ts diff --git a/util/src/config/types/subconfigurations/limits/ChannelLimits.ts b/src/util/config/types/subconfigurations/limits/ChannelLimits.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/ChannelLimits.ts rename to src/util/config/types/subconfigurations/limits/ChannelLimits.ts diff --git a/util/src/config/types/subconfigurations/limits/GuildLimits.ts b/src/util/config/types/subconfigurations/limits/GuildLimits.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/GuildLimits.ts rename to src/util/config/types/subconfigurations/limits/GuildLimits.ts diff --git a/util/src/config/types/subconfigurations/limits/MessageLimits.ts b/src/util/config/types/subconfigurations/limits/MessageLimits.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/MessageLimits.ts rename to src/util/config/types/subconfigurations/limits/MessageLimits.ts diff --git a/util/src/config/types/subconfigurations/limits/RateLimits.ts b/src/util/config/types/subconfigurations/limits/RateLimits.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/RateLimits.ts rename to src/util/config/types/subconfigurations/limits/RateLimits.ts diff --git a/util/src/config/types/subconfigurations/limits/UserLimits.ts b/src/util/config/types/subconfigurations/limits/UserLimits.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/UserLimits.ts rename to src/util/config/types/subconfigurations/limits/UserLimits.ts diff --git a/util/src/config/types/subconfigurations/limits/index.ts b/src/util/config/types/subconfigurations/limits/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/index.ts rename to src/util/config/types/subconfigurations/limits/index.ts diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/Auth.ts b/src/util/config/types/subconfigurations/limits/ratelimits/Auth.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/ratelimits/Auth.ts rename to src/util/config/types/subconfigurations/limits/ratelimits/Auth.ts diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts b/src/util/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts rename to src/util/config/types/subconfigurations/limits/ratelimits/RateLimitOptions.ts diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/Route.ts b/src/util/config/types/subconfigurations/limits/ratelimits/Route.ts similarity index 90% rename from util/src/config/types/subconfigurations/limits/ratelimits/Route.ts rename to src/util/config/types/subconfigurations/limits/ratelimits/Route.ts index 3012a8a8d..844b1b9a9 100644 --- a/util/src/config/types/subconfigurations/limits/ratelimits/Route.ts +++ b/src/util/config/types/subconfigurations/limits/ratelimits/Route.ts @@ -1,4 +1,4 @@ -import { AuthRateLimit } from "."; +import { AuthRateLimit } from "./Auth"; import { RateLimitOptions } from "./RateLimitOptions"; export class RouteRateLimit { diff --git a/util/src/config/types/subconfigurations/limits/ratelimits/index.ts b/src/util/config/types/subconfigurations/limits/ratelimits/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/limits/ratelimits/index.ts rename to src/util/config/types/subconfigurations/limits/ratelimits/index.ts diff --git a/util/src/config/types/subconfigurations/region/Region.ts b/src/util/config/types/subconfigurations/region/Region.ts similarity index 100% rename from util/src/config/types/subconfigurations/region/Region.ts rename to src/util/config/types/subconfigurations/region/Region.ts diff --git a/util/src/config/types/subconfigurations/region/index.ts b/src/util/config/types/subconfigurations/region/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/region/index.ts rename to src/util/config/types/subconfigurations/region/index.ts diff --git a/util/src/config/types/subconfigurations/register/DateOfBirth.ts b/src/util/config/types/subconfigurations/register/DateOfBirth.ts similarity index 100% rename from util/src/config/types/subconfigurations/register/DateOfBirth.ts rename to src/util/config/types/subconfigurations/register/DateOfBirth.ts diff --git a/util/src/config/types/subconfigurations/register/Email.ts b/src/util/config/types/subconfigurations/register/Email.ts similarity index 100% rename from util/src/config/types/subconfigurations/register/Email.ts rename to src/util/config/types/subconfigurations/register/Email.ts diff --git a/util/src/config/types/subconfigurations/register/Password.ts b/src/util/config/types/subconfigurations/register/Password.ts similarity index 100% rename from util/src/config/types/subconfigurations/register/Password.ts rename to src/util/config/types/subconfigurations/register/Password.ts diff --git a/util/src/config/types/subconfigurations/register/index.ts b/src/util/config/types/subconfigurations/register/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/register/index.ts rename to src/util/config/types/subconfigurations/register/index.ts diff --git a/util/src/config/types/subconfigurations/security/Captcha.ts b/src/util/config/types/subconfigurations/security/Captcha.ts similarity index 100% rename from util/src/config/types/subconfigurations/security/Captcha.ts rename to src/util/config/types/subconfigurations/security/Captcha.ts diff --git a/util/src/config/types/subconfigurations/security/TwoFactor.ts b/src/util/config/types/subconfigurations/security/TwoFactor.ts similarity index 100% rename from util/src/config/types/subconfigurations/security/TwoFactor.ts rename to src/util/config/types/subconfigurations/security/TwoFactor.ts diff --git a/util/src/config/types/subconfigurations/security/index.ts b/src/util/config/types/subconfigurations/security/index.ts similarity index 100% rename from util/src/config/types/subconfigurations/security/index.ts rename to src/util/config/types/subconfigurations/security/index.ts diff --git a/util/src/dtos/DmChannelDTO.ts b/src/util/dtos/DmChannelDTO.ts similarity index 100% rename from util/src/dtos/DmChannelDTO.ts rename to src/util/dtos/DmChannelDTO.ts diff --git a/util/src/dtos/UserDTO.ts b/src/util/dtos/UserDTO.ts similarity index 100% rename from util/src/dtos/UserDTO.ts rename to src/util/dtos/UserDTO.ts diff --git a/util/src/dtos/index.ts b/src/util/dtos/index.ts similarity index 100% rename from util/src/dtos/index.ts rename to src/util/dtos/index.ts diff --git a/util/src/entities/Application.ts b/src/util/entities/Application.ts similarity index 100% rename from util/src/entities/Application.ts rename to src/util/entities/Application.ts diff --git a/util/src/entities/Attachment.ts b/src/util/entities/Attachment.ts similarity index 100% rename from util/src/entities/Attachment.ts rename to src/util/entities/Attachment.ts diff --git a/util/src/entities/AuditLog.ts b/src/util/entities/AuditLog.ts similarity index 100% rename from util/src/entities/AuditLog.ts rename to src/util/entities/AuditLog.ts diff --git a/util/src/entities/BackupCodes.ts b/src/util/entities/BackupCodes.ts similarity index 100% rename from util/src/entities/BackupCodes.ts rename to src/util/entities/BackupCodes.ts diff --git a/util/src/entities/Ban.ts b/src/util/entities/Ban.ts similarity index 100% rename from util/src/entities/Ban.ts rename to src/util/entities/Ban.ts diff --git a/util/src/entities/BaseClass.ts b/src/util/entities/BaseClass.ts similarity index 100% rename from util/src/entities/BaseClass.ts rename to src/util/entities/BaseClass.ts diff --git a/util/src/entities/Categories.ts b/src/util/entities/Categories.ts similarity index 100% rename from util/src/entities/Categories.ts rename to src/util/entities/Categories.ts diff --git a/util/src/entities/Channel.ts b/src/util/entities/Channel.ts similarity index 100% rename from util/src/entities/Channel.ts rename to src/util/entities/Channel.ts diff --git a/util/src/entities/ClientRelease.ts b/src/util/entities/ClientRelease.ts similarity index 100% rename from util/src/entities/ClientRelease.ts rename to src/util/entities/ClientRelease.ts diff --git a/util/src/entities/Config.ts b/src/util/entities/Config.ts similarity index 100% rename from util/src/entities/Config.ts rename to src/util/entities/Config.ts diff --git a/util/src/entities/ConnectedAccount.ts b/src/util/entities/ConnectedAccount.ts similarity index 100% rename from util/src/entities/ConnectedAccount.ts rename to src/util/entities/ConnectedAccount.ts diff --git a/util/src/entities/Emoji.ts b/src/util/entities/Emoji.ts similarity index 100% rename from util/src/entities/Emoji.ts rename to src/util/entities/Emoji.ts diff --git a/util/src/entities/Encryption.ts b/src/util/entities/Encryption.ts similarity index 100% rename from util/src/entities/Encryption.ts rename to src/util/entities/Encryption.ts diff --git a/util/src/entities/Group.ts b/src/util/entities/Group.ts similarity index 100% rename from util/src/entities/Group.ts rename to src/util/entities/Group.ts diff --git a/util/src/entities/Guild.ts b/src/util/entities/Guild.ts similarity index 100% rename from util/src/entities/Guild.ts rename to src/util/entities/Guild.ts diff --git a/util/src/entities/Invite.ts b/src/util/entities/Invite.ts similarity index 100% rename from util/src/entities/Invite.ts rename to src/util/entities/Invite.ts diff --git a/util/src/entities/Member.ts b/src/util/entities/Member.ts similarity index 100% rename from util/src/entities/Member.ts rename to src/util/entities/Member.ts diff --git a/util/src/entities/Message.ts b/src/util/entities/Message.ts similarity index 100% rename from util/src/entities/Message.ts rename to src/util/entities/Message.ts diff --git a/util/src/entities/Migration.ts b/src/util/entities/Migration.ts similarity index 100% rename from util/src/entities/Migration.ts rename to src/util/entities/Migration.ts diff --git a/util/src/entities/Note.ts b/src/util/entities/Note.ts similarity index 100% rename from util/src/entities/Note.ts rename to src/util/entities/Note.ts diff --git a/util/src/entities/RateLimit.ts b/src/util/entities/RateLimit.ts similarity index 100% rename from util/src/entities/RateLimit.ts rename to src/util/entities/RateLimit.ts diff --git a/util/src/entities/ReadState.ts b/src/util/entities/ReadState.ts similarity index 100% rename from util/src/entities/ReadState.ts rename to src/util/entities/ReadState.ts diff --git a/util/src/entities/Recipient.ts b/src/util/entities/Recipient.ts similarity index 100% rename from util/src/entities/Recipient.ts rename to src/util/entities/Recipient.ts diff --git a/util/src/entities/Relationship.ts b/src/util/entities/Relationship.ts similarity index 100% rename from util/src/entities/Relationship.ts rename to src/util/entities/Relationship.ts diff --git a/util/src/entities/Role.ts b/src/util/entities/Role.ts similarity index 100% rename from util/src/entities/Role.ts rename to src/util/entities/Role.ts diff --git a/util/src/entities/Session.ts b/src/util/entities/Session.ts similarity index 100% rename from util/src/entities/Session.ts rename to src/util/entities/Session.ts diff --git a/util/src/entities/Sticker.ts b/src/util/entities/Sticker.ts similarity index 100% rename from util/src/entities/Sticker.ts rename to src/util/entities/Sticker.ts diff --git a/util/src/entities/StickerPack.ts b/src/util/entities/StickerPack.ts similarity index 100% rename from util/src/entities/StickerPack.ts rename to src/util/entities/StickerPack.ts diff --git a/util/src/entities/Team.ts b/src/util/entities/Team.ts similarity index 100% rename from util/src/entities/Team.ts rename to src/util/entities/Team.ts diff --git a/util/src/entities/TeamMember.ts b/src/util/entities/TeamMember.ts similarity index 100% rename from util/src/entities/TeamMember.ts rename to src/util/entities/TeamMember.ts diff --git a/util/src/entities/Template.ts b/src/util/entities/Template.ts similarity index 100% rename from util/src/entities/Template.ts rename to src/util/entities/Template.ts diff --git a/util/src/entities/User.ts b/src/util/entities/User.ts similarity index 100% rename from util/src/entities/User.ts rename to src/util/entities/User.ts diff --git a/util/src/entities/UserGroup.ts b/src/util/entities/UserGroup.ts similarity index 100% rename from util/src/entities/UserGroup.ts rename to src/util/entities/UserGroup.ts diff --git a/util/src/entities/UserSettings.ts b/src/util/entities/UserSettings.ts similarity index 100% rename from util/src/entities/UserSettings.ts rename to src/util/entities/UserSettings.ts diff --git a/util/src/entities/VoiceState.ts b/src/util/entities/VoiceState.ts similarity index 100% rename from util/src/entities/VoiceState.ts rename to src/util/entities/VoiceState.ts diff --git a/util/src/entities/Webhook.ts b/src/util/entities/Webhook.ts similarity index 100% rename from util/src/entities/Webhook.ts rename to src/util/entities/Webhook.ts diff --git a/util/src/entities/index.ts b/src/util/entities/index.ts similarity index 100% rename from util/src/entities/index.ts rename to src/util/entities/index.ts diff --git a/util/src/index.ts b/src/util/index.ts similarity index 76% rename from util/src/index.ts rename to src/util/index.ts index daeffd698..d944dc49f 100644 --- a/util/src/index.ts +++ b/src/util/index.ts @@ -1,6 +1,7 @@ import "reflect-metadata"; export * from "./util/index"; +export * from "./config/index"; export * from "./interfaces/index"; export * from "./entities/index"; export * from "./dtos/index"; diff --git a/util/src/interfaces/Activity.ts b/src/util/interfaces/Activity.ts similarity index 100% rename from util/src/interfaces/Activity.ts rename to src/util/interfaces/Activity.ts diff --git a/util/src/interfaces/Event.ts b/src/util/interfaces/Event.ts similarity index 100% rename from util/src/interfaces/Event.ts rename to src/util/interfaces/Event.ts diff --git a/util/src/interfaces/Interaction.ts b/src/util/interfaces/Interaction.ts similarity index 100% rename from util/src/interfaces/Interaction.ts rename to src/util/interfaces/Interaction.ts diff --git a/util/src/interfaces/Presence.ts b/src/util/interfaces/Presence.ts similarity index 100% rename from util/src/interfaces/Presence.ts rename to src/util/interfaces/Presence.ts diff --git a/util/src/interfaces/Status.ts b/src/util/interfaces/Status.ts similarity index 100% rename from util/src/interfaces/Status.ts rename to src/util/interfaces/Status.ts diff --git a/util/src/interfaces/index.ts b/src/util/interfaces/index.ts similarity index 100% rename from util/src/interfaces/index.ts rename to src/util/interfaces/index.ts diff --git a/util/src/migrations/mariadb/1659901151025-initial.ts b/src/util/migrations/mariadb/1659901151025-initial.ts similarity index 100% rename from util/src/migrations/mariadb/1659901151025-initial.ts rename to src/util/migrations/mariadb/1659901151025-initial.ts diff --git a/util/src/migrations/mariadb/1659921859145-premium_since_as_date.ts b/src/util/migrations/mariadb/1659921859145-premium_since_as_date.ts similarity index 100% rename from util/src/migrations/mariadb/1659921859145-premium_since_as_date.ts rename to src/util/migrations/mariadb/1659921859145-premium_since_as_date.ts diff --git a/util/src/migrations/mariadb/1660258393551-CodeCleanup3.ts b/src/util/migrations/mariadb/1660258393551-CodeCleanup3.ts similarity index 100% rename from util/src/migrations/mariadb/1660258393551-CodeCleanup3.ts rename to src/util/migrations/mariadb/1660258393551-CodeCleanup3.ts diff --git a/util/src/migrations/mariadb/1660260587556-CodeCleanup4.ts b/src/util/migrations/mariadb/1660260587556-CodeCleanup4.ts similarity index 100% rename from util/src/migrations/mariadb/1660260587556-CodeCleanup4.ts rename to src/util/migrations/mariadb/1660260587556-CodeCleanup4.ts diff --git a/util/src/migrations/mariadb/1660265930624-CodeCleanup5.ts b/src/util/migrations/mariadb/1660265930624-CodeCleanup5.ts similarity index 100% rename from util/src/migrations/mariadb/1660265930624-CodeCleanup5.ts rename to src/util/migrations/mariadb/1660265930624-CodeCleanup5.ts diff --git a/util/src/migrations/postgres/1659899687168-initial.ts b/src/util/migrations/postgres/1659899687168-initial.ts similarity index 100% rename from util/src/migrations/postgres/1659899687168-initial.ts rename to src/util/migrations/postgres/1659899687168-initial.ts diff --git a/util/src/migrations/postgres/1659921826567-premium_since_as_date.ts b/src/util/migrations/postgres/1659921826567-premium_since_as_date.ts similarity index 100% rename from util/src/migrations/postgres/1659921826567-premium_since_as_date.ts rename to src/util/migrations/postgres/1659921826567-premium_since_as_date.ts diff --git a/util/src/migrations/postgres/1660257815436-CodeCleanup2.ts b/src/util/migrations/postgres/1660257815436-CodeCleanup2.ts similarity index 100% rename from util/src/migrations/postgres/1660257815436-CodeCleanup2.ts rename to src/util/migrations/postgres/1660257815436-CodeCleanup2.ts diff --git a/util/src/migrations/postgres/1660258372154-CodeCleanup3.ts b/src/util/migrations/postgres/1660258372154-CodeCleanup3.ts similarity index 100% rename from util/src/migrations/postgres/1660258372154-CodeCleanup3.ts rename to src/util/migrations/postgres/1660258372154-CodeCleanup3.ts diff --git a/util/src/migrations/postgres/1660260565996-CodeCleanup4.ts b/src/util/migrations/postgres/1660260565996-CodeCleanup4.ts similarity index 100% rename from util/src/migrations/postgres/1660260565996-CodeCleanup4.ts rename to src/util/migrations/postgres/1660260565996-CodeCleanup4.ts diff --git a/util/src/migrations/postgres/1660265907544-CodeCleanup5.ts b/src/util/migrations/postgres/1660265907544-CodeCleanup5.ts similarity index 100% rename from util/src/migrations/postgres/1660265907544-CodeCleanup5.ts rename to src/util/migrations/postgres/1660265907544-CodeCleanup5.ts diff --git a/util/src/migrations/sqlite/1659899662635-initial.ts b/src/util/migrations/sqlite/1659899662635-initial.ts similarity index 100% rename from util/src/migrations/sqlite/1659899662635-initial.ts rename to src/util/migrations/sqlite/1659899662635-initial.ts diff --git a/util/src/migrations/sqlite/1659921722863-premium_since_as_date.ts b/src/util/migrations/sqlite/1659921722863-premium_since_as_date.ts similarity index 100% rename from util/src/migrations/sqlite/1659921722863-premium_since_as_date.ts rename to src/util/migrations/sqlite/1659921722863-premium_since_as_date.ts diff --git a/util/src/migrations/sqlite/1660257576211-CodeCleanup1.ts b/src/util/migrations/sqlite/1660257576211-CodeCleanup1.ts similarity index 100% rename from util/src/migrations/sqlite/1660257576211-CodeCleanup1.ts rename to src/util/migrations/sqlite/1660257576211-CodeCleanup1.ts diff --git a/util/src/migrations/sqlite/1660257795259-CodeCleanup2.ts b/src/util/migrations/sqlite/1660257795259-CodeCleanup2.ts similarity index 100% rename from util/src/migrations/sqlite/1660257795259-CodeCleanup2.ts rename to src/util/migrations/sqlite/1660257795259-CodeCleanup2.ts diff --git a/util/src/migrations/sqlite/1660258351379-CodeCleanup3.ts b/src/util/migrations/sqlite/1660258351379-CodeCleanup3.ts similarity index 100% rename from util/src/migrations/sqlite/1660258351379-CodeCleanup3.ts rename to src/util/migrations/sqlite/1660258351379-CodeCleanup3.ts diff --git a/util/src/migrations/sqlite/1660260672914-CodeCleanup4.ts b/src/util/migrations/sqlite/1660260672914-CodeCleanup4.ts similarity index 100% rename from util/src/migrations/sqlite/1660260672914-CodeCleanup4.ts rename to src/util/migrations/sqlite/1660260672914-CodeCleanup4.ts diff --git a/util/src/schemas/ActivitySchema.ts b/src/util/schemas/ActivitySchema.ts similarity index 100% rename from util/src/schemas/ActivitySchema.ts rename to src/util/schemas/ActivitySchema.ts diff --git a/util/src/schemas/BanCreateSchema.ts b/src/util/schemas/BanCreateSchema.ts similarity index 100% rename from util/src/schemas/BanCreateSchema.ts rename to src/util/schemas/BanCreateSchema.ts diff --git a/util/src/schemas/BanModeratorSchema.ts b/src/util/schemas/BanModeratorSchema.ts similarity index 100% rename from util/src/schemas/BanModeratorSchema.ts rename to src/util/schemas/BanModeratorSchema.ts diff --git a/util/src/schemas/BanRegistrySchema.ts b/src/util/schemas/BanRegistrySchema.ts similarity index 100% rename from util/src/schemas/BanRegistrySchema.ts rename to src/util/schemas/BanRegistrySchema.ts diff --git a/util/src/schemas/BulkDeleteSchema.ts b/src/util/schemas/BulkDeleteSchema.ts similarity index 100% rename from util/src/schemas/BulkDeleteSchema.ts rename to src/util/schemas/BulkDeleteSchema.ts diff --git a/util/src/schemas/ChannelModifySchema.ts b/src/util/schemas/ChannelModifySchema.ts similarity index 100% rename from util/src/schemas/ChannelModifySchema.ts rename to src/util/schemas/ChannelModifySchema.ts diff --git a/util/src/schemas/ChannelPermissionOverwriteSchema.ts b/src/util/schemas/ChannelPermissionOverwriteSchema.ts similarity index 100% rename from util/src/schemas/ChannelPermissionOverwriteSchema.ts rename to src/util/schemas/ChannelPermissionOverwriteSchema.ts diff --git a/util/src/schemas/ChannelReorderSchema.ts b/src/util/schemas/ChannelReorderSchema.ts similarity index 100% rename from util/src/schemas/ChannelReorderSchema.ts rename to src/util/schemas/ChannelReorderSchema.ts diff --git a/util/src/schemas/DmChannelCreateSchema.ts b/src/util/schemas/DmChannelCreateSchema.ts similarity index 100% rename from util/src/schemas/DmChannelCreateSchema.ts rename to src/util/schemas/DmChannelCreateSchema.ts diff --git a/util/src/schemas/EmojiCreateSchema.ts b/src/util/schemas/EmojiCreateSchema.ts similarity index 100% rename from util/src/schemas/EmojiCreateSchema.ts rename to src/util/schemas/EmojiCreateSchema.ts diff --git a/util/src/schemas/EmojiModifySchema.ts b/src/util/schemas/EmojiModifySchema.ts similarity index 100% rename from util/src/schemas/EmojiModifySchema.ts rename to src/util/schemas/EmojiModifySchema.ts diff --git a/util/src/schemas/GuildCreateSchema.ts b/src/util/schemas/GuildCreateSchema.ts similarity index 100% rename from util/src/schemas/GuildCreateSchema.ts rename to src/util/schemas/GuildCreateSchema.ts diff --git a/util/src/schemas/GuildTemplateCreateSchema.ts b/src/util/schemas/GuildTemplateCreateSchema.ts similarity index 100% rename from util/src/schemas/GuildTemplateCreateSchema.ts rename to src/util/schemas/GuildTemplateCreateSchema.ts diff --git a/util/src/schemas/GuildUpdateSchema.ts b/src/util/schemas/GuildUpdateSchema.ts similarity index 100% rename from util/src/schemas/GuildUpdateSchema.ts rename to src/util/schemas/GuildUpdateSchema.ts diff --git a/util/src/schemas/GuildUpdateWelcomeScreenSchema.ts b/src/util/schemas/GuildUpdateWelcomeScreenSchema.ts similarity index 100% rename from util/src/schemas/GuildUpdateWelcomeScreenSchema.ts rename to src/util/schemas/GuildUpdateWelcomeScreenSchema.ts diff --git a/util/src/schemas/IdentifySchema.ts b/src/util/schemas/IdentifySchema.ts similarity index 93% rename from util/src/schemas/IdentifySchema.ts rename to src/util/schemas/IdentifySchema.ts index 8f95c6a0c..f3d60fb35 100644 --- a/util/src/schemas/IdentifySchema.ts +++ b/src/util/schemas/IdentifySchema.ts @@ -2,7 +2,7 @@ import { ActivitySchema } from "./ActivitySchema"; export const IdentifySchema = { token: String, - $intents: BigInt, // discord uses a Integer for bitfields we use bigints tho. | instanceOf will automatically convert the Number to a BigInt + $intents: String, // discord uses a Integer for bitfields we use bigints tho. | instanceOf will automatically convert the Number to a BigInt $properties: Object, // { // // discord uses $ in the property key for bots, so we need to double prefix it, because instanceOf treats $ (prefix) as a optional key @@ -33,7 +33,7 @@ export const IdentifySchema = { $presence: ActivitySchema, $compress: Boolean, $large_threshold: Number, - $shard: [BigInt, BigInt], + $shard: [Number, Number], $guild_subscriptions: Boolean, $capabilities: Number, $client_state: { @@ -71,11 +71,11 @@ export interface IdentifySchema { client_version?: string; system_locale?: string; }; - intents?: bigint; // discord uses a Integer for bitfields we use bigints tho. | instanceOf will automatically convert the Number to a BigInt + intents?: string; // discord uses a Integer for bitfields we use bigints tho. | instanceOf will automatically convert the Number to a BigInt presence?: ActivitySchema; compress?: boolean; large_threshold?: number; - shard?: [bigint, bigint]; + shard?: [number, number]; guild_subscriptions?: boolean; capabilities?: number; client_state?: { diff --git a/util/src/schemas/InviteCreateSchema.ts b/src/util/schemas/InviteCreateSchema.ts similarity index 100% rename from util/src/schemas/InviteCreateSchema.ts rename to src/util/schemas/InviteCreateSchema.ts diff --git a/util/src/schemas/LazyRequestSchema.ts b/src/util/schemas/LazyRequestSchema.ts similarity index 100% rename from util/src/schemas/LazyRequestSchema.ts rename to src/util/schemas/LazyRequestSchema.ts diff --git a/util/src/schemas/LoginSchema.ts b/src/util/schemas/LoginSchema.ts similarity index 100% rename from util/src/schemas/LoginSchema.ts rename to src/util/schemas/LoginSchema.ts diff --git a/util/src/schemas/MemberChangeSchema.ts b/src/util/schemas/MemberChangeSchema.ts similarity index 100% rename from util/src/schemas/MemberChangeSchema.ts rename to src/util/schemas/MemberChangeSchema.ts diff --git a/util/src/schemas/MemberNickChangeSchema.ts b/src/util/schemas/MemberNickChangeSchema.ts similarity index 100% rename from util/src/schemas/MemberNickChangeSchema.ts rename to src/util/schemas/MemberNickChangeSchema.ts diff --git a/util/src/schemas/MessageAcknowledgeSchema.ts b/src/util/schemas/MessageAcknowledgeSchema.ts similarity index 100% rename from util/src/schemas/MessageAcknowledgeSchema.ts rename to src/util/schemas/MessageAcknowledgeSchema.ts diff --git a/util/src/schemas/MessageCreateSchema.ts b/src/util/schemas/MessageCreateSchema.ts similarity index 100% rename from util/src/schemas/MessageCreateSchema.ts rename to src/util/schemas/MessageCreateSchema.ts diff --git a/util/src/schemas/MfaCodesSchema.ts b/src/util/schemas/MfaCodesSchema.ts similarity index 100% rename from util/src/schemas/MfaCodesSchema.ts rename to src/util/schemas/MfaCodesSchema.ts diff --git a/util/src/schemas/ModifyGuildStickerSchema.ts b/src/util/schemas/ModifyGuildStickerSchema.ts similarity index 100% rename from util/src/schemas/ModifyGuildStickerSchema.ts rename to src/util/schemas/ModifyGuildStickerSchema.ts diff --git a/util/src/schemas/PruneSchema.ts b/src/util/schemas/PruneSchema.ts similarity index 100% rename from util/src/schemas/PruneSchema.ts rename to src/util/schemas/PruneSchema.ts diff --git a/util/src/schemas/PurgeSchema.ts b/src/util/schemas/PurgeSchema.ts similarity index 100% rename from util/src/schemas/PurgeSchema.ts rename to src/util/schemas/PurgeSchema.ts diff --git a/util/src/schemas/RegisterSchema.ts b/src/util/schemas/RegisterSchema.ts similarity index 100% rename from util/src/schemas/RegisterSchema.ts rename to src/util/schemas/RegisterSchema.ts diff --git a/util/src/schemas/RelationshipPostSchema.ts b/src/util/schemas/RelationshipPostSchema.ts similarity index 100% rename from util/src/schemas/RelationshipPostSchema.ts rename to src/util/schemas/RelationshipPostSchema.ts diff --git a/util/src/schemas/RelationshipPutSchema.ts b/src/util/schemas/RelationshipPutSchema.ts similarity index 100% rename from util/src/schemas/RelationshipPutSchema.ts rename to src/util/schemas/RelationshipPutSchema.ts diff --git a/util/src/schemas/RoleModifySchema.ts b/src/util/schemas/RoleModifySchema.ts similarity index 100% rename from util/src/schemas/RoleModifySchema.ts rename to src/util/schemas/RoleModifySchema.ts diff --git a/util/src/schemas/RolePositionUpdateSchema.ts b/src/util/schemas/RolePositionUpdateSchema.ts similarity index 100% rename from util/src/schemas/RolePositionUpdateSchema.ts rename to src/util/schemas/RolePositionUpdateSchema.ts diff --git a/util/src/schemas/TemplateCreateSchema.ts b/src/util/schemas/TemplateCreateSchema.ts similarity index 100% rename from util/src/schemas/TemplateCreateSchema.ts rename to src/util/schemas/TemplateCreateSchema.ts diff --git a/util/src/schemas/TemplateModifySchema.ts b/src/util/schemas/TemplateModifySchema.ts similarity index 100% rename from util/src/schemas/TemplateModifySchema.ts rename to src/util/schemas/TemplateModifySchema.ts diff --git a/util/src/schemas/TotpDisableSchema.ts b/src/util/schemas/TotpDisableSchema.ts similarity index 100% rename from util/src/schemas/TotpDisableSchema.ts rename to src/util/schemas/TotpDisableSchema.ts diff --git a/util/src/schemas/TotpEnableSchema.ts b/src/util/schemas/TotpEnableSchema.ts similarity index 100% rename from util/src/schemas/TotpEnableSchema.ts rename to src/util/schemas/TotpEnableSchema.ts diff --git a/util/src/schemas/TotpSchema.ts b/src/util/schemas/TotpSchema.ts similarity index 100% rename from util/src/schemas/TotpSchema.ts rename to src/util/schemas/TotpSchema.ts diff --git a/util/src/schemas/UserModifySchema.ts b/src/util/schemas/UserModifySchema.ts similarity index 100% rename from util/src/schemas/UserModifySchema.ts rename to src/util/schemas/UserModifySchema.ts diff --git a/util/src/schemas/UserSettingsSchema.ts b/src/util/schemas/UserSettingsSchema.ts similarity index 100% rename from util/src/schemas/UserSettingsSchema.ts rename to src/util/schemas/UserSettingsSchema.ts diff --git a/util/src/schemas/VanityUrlSchema.ts b/src/util/schemas/VanityUrlSchema.ts similarity index 100% rename from util/src/schemas/VanityUrlSchema.ts rename to src/util/schemas/VanityUrlSchema.ts diff --git a/util/src/schemas/VoiceStateUpdateSchema.ts b/src/util/schemas/VoiceStateUpdateSchema.ts similarity index 100% rename from util/src/schemas/VoiceStateUpdateSchema.ts rename to src/util/schemas/VoiceStateUpdateSchema.ts diff --git a/util/src/schemas/WebhookCreateSchema.ts b/src/util/schemas/WebhookCreateSchema.ts similarity index 100% rename from util/src/schemas/WebhookCreateSchema.ts rename to src/util/schemas/WebhookCreateSchema.ts diff --git a/util/src/schemas/WidgetModifySchema.ts b/src/util/schemas/WidgetModifySchema.ts similarity index 100% rename from util/src/schemas/WidgetModifySchema.ts rename to src/util/schemas/WidgetModifySchema.ts diff --git a/util/src/schemas/index.ts b/src/util/schemas/index.ts similarity index 100% rename from util/src/schemas/index.ts rename to src/util/schemas/index.ts diff --git a/util/src/util/ApiError.ts b/src/util/util/ApiError.ts similarity index 100% rename from util/src/util/ApiError.ts rename to src/util/util/ApiError.ts diff --git a/util/src/util/Array.ts b/src/util/util/Array.ts similarity index 100% rename from util/src/util/Array.ts rename to src/util/util/Array.ts diff --git a/util/src/util/AutoUpdate.ts b/src/util/util/AutoUpdate.ts similarity index 100% rename from util/src/util/AutoUpdate.ts rename to src/util/util/AutoUpdate.ts diff --git a/util/src/util/BitField.ts b/src/util/util/BitField.ts similarity index 100% rename from util/src/util/BitField.ts rename to src/util/util/BitField.ts diff --git a/util/src/util/Categories.ts b/src/util/util/Categories.ts similarity index 100% rename from util/src/util/Categories.ts rename to src/util/util/Categories.ts diff --git a/util/src/util/Config.ts b/src/util/util/Config.ts similarity index 100% rename from util/src/util/Config.ts rename to src/util/util/Config.ts diff --git a/util/src/util/Constants.ts b/src/util/util/Constants.ts similarity index 100% rename from util/src/util/Constants.ts rename to src/util/util/Constants.ts diff --git a/util/src/util/Database.ts b/src/util/util/Database.ts similarity index 100% rename from util/src/util/Database.ts rename to src/util/util/Database.ts diff --git a/util/src/util/Email.ts b/src/util/util/Email.ts similarity index 100% rename from util/src/util/Email.ts rename to src/util/util/Email.ts diff --git a/util/src/util/Event.ts b/src/util/util/Event.ts similarity index 100% rename from util/src/util/Event.ts rename to src/util/util/Event.ts diff --git a/util/src/util/FieldError.ts b/src/util/util/FieldError.ts similarity index 100% rename from util/src/util/FieldError.ts rename to src/util/util/FieldError.ts diff --git a/util/src/util/Intents.ts b/src/util/util/Intents.ts similarity index 100% rename from util/src/util/Intents.ts rename to src/util/util/Intents.ts diff --git a/util/src/util/InvisibleCharacters.ts b/src/util/util/InvisibleCharacters.ts similarity index 100% rename from util/src/util/InvisibleCharacters.ts rename to src/util/util/InvisibleCharacters.ts diff --git a/util/src/util/MFA.ts b/src/util/util/MFA.ts similarity index 100% rename from util/src/util/MFA.ts rename to src/util/util/MFA.ts diff --git a/util/src/util/MessageFlags.ts b/src/util/util/MessageFlags.ts similarity index 100% rename from util/src/util/MessageFlags.ts rename to src/util/util/MessageFlags.ts diff --git a/util/src/util/Permissions.ts b/src/util/util/Permissions.ts similarity index 100% rename from util/src/util/Permissions.ts rename to src/util/util/Permissions.ts diff --git a/util/src/util/RabbitMQ.ts b/src/util/util/RabbitMQ.ts similarity index 100% rename from util/src/util/RabbitMQ.ts rename to src/util/util/RabbitMQ.ts diff --git a/util/src/util/Regex.ts b/src/util/util/Regex.ts similarity index 100% rename from util/src/util/Regex.ts rename to src/util/util/Regex.ts diff --git a/util/src/util/Rights.ts b/src/util/util/Rights.ts similarity index 100% rename from util/src/util/Rights.ts rename to src/util/util/Rights.ts diff --git a/util/src/util/Snowflake.ts b/src/util/util/Snowflake.ts similarity index 100% rename from util/src/util/Snowflake.ts rename to src/util/util/Snowflake.ts diff --git a/util/src/util/String.ts b/src/util/util/String.ts similarity index 100% rename from util/src/util/String.ts rename to src/util/util/String.ts diff --git a/util/src/util/Token.ts b/src/util/util/Token.ts similarity index 100% rename from util/src/util/Token.ts rename to src/util/util/Token.ts diff --git a/util/src/util/TraverseDirectory.ts b/src/util/util/TraverseDirectory.ts similarity index 100% rename from util/src/util/TraverseDirectory.ts rename to src/util/util/TraverseDirectory.ts diff --git a/util/src/util/cdn.ts b/src/util/util/cdn.ts similarity index 100% rename from util/src/util/cdn.ts rename to src/util/util/cdn.ts diff --git a/util/src/util/imports/Checks.ts b/src/util/util/imports/Checks.ts similarity index 100% rename from util/src/util/imports/Checks.ts rename to src/util/util/imports/Checks.ts diff --git a/util/src/util/imports/HTTPError.ts b/src/util/util/imports/HTTPError.ts similarity index 100% rename from util/src/util/imports/HTTPError.ts rename to src/util/util/imports/HTTPError.ts diff --git a/util/src/util/imports/OrmUtils.ts b/src/util/util/imports/OrmUtils.ts similarity index 100% rename from util/src/util/imports/OrmUtils.ts rename to src/util/util/imports/OrmUtils.ts diff --git a/util/src/util/imports/index.ts b/src/util/util/imports/index.ts similarity index 100% rename from util/src/util/imports/index.ts rename to src/util/util/imports/index.ts diff --git a/util/src/util/index.ts b/src/util/util/index.ts similarity index 100% rename from util/src/util/index.ts rename to src/util/util/index.ts diff --git a/util/tests/User.test.js b/tests/User.test.js similarity index 100% rename from util/tests/User.test.js rename to tests/User.test.js diff --git a/cdn/tests/antman.jpg b/tests/antman.jpg similarity index 100% rename from cdn/tests/antman.jpg rename to tests/antman.jpg diff --git a/cdn/tests/cdn_endpoints.test.js b/tests/cdn_endpoints.test.js similarity index 100% rename from cdn/tests/cdn_endpoints.test.js rename to tests/cdn_endpoints.test.js diff --git a/cdn/tests/filestorage.test.js b/tests/filestorage.test.js similarity index 100% rename from cdn/tests/filestorage.test.js rename to tests/filestorage.test.js diff --git a/api/tests/routes.test.ts b/tests/routes.test.ts similarity index 100% rename from api/tests/routes.test.ts rename to tests/routes.test.ts diff --git a/api/tests/routes/auth/login.test.js b/tests/routes/auth/login.test.js similarity index 100% rename from api/tests/routes/auth/login.test.js rename to tests/routes/auth/login.test.js diff --git a/api/tests/routes/auth/register.test.js b/tests/routes/auth/register.test.js similarity index 100% rename from api/tests/routes/auth/register.test.js rename to tests/routes/auth/register.test.js diff --git a/api/tests/routes/ping.test.js b/tests/routes/ping.test.js similarity index 100% rename from api/tests/routes/ping.test.js rename to tests/routes/ping.test.js diff --git a/util/tests/setupJest.js b/tests/setupJest.js similarity index 100% rename from util/tests/setupJest.js rename to tests/setupJest.js diff --git a/bundle/tsconfig.json b/tsconfig.json similarity index 92% rename from bundle/tsconfig.json rename to tsconfig.json index 87f6578ac..b9e17f299 100644 --- a/bundle/tsconfig.json +++ b/tsconfig.json @@ -1,5 +1,5 @@ { - "include": ["dist/**/*.ts"], + "include": ["src/**/*.ts"], "exclude": [], "compilerOptions": { @@ -18,7 +18,7 @@ "sourceMap": true /* Generates corresponding '.map' file. */, // "outFile": "./", /* Concatenate and emit output to single file. */ "outDir": "./dist/" /* Redirect output structure to the directory. */, - "rootDir": "./dist/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, + "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, // "composite": true, /* Enable project compilation */ // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ // "removeComments": true, /* Do not emit comments to output. */ @@ -71,12 +71,12 @@ "emitDecoratorMetadata": true, "experimentalDecorators": true, "resolveJsonModule": true, - "baseUrl": "./dist/", + "baseUrl": "./src/", "paths": { - "@fosscord/api": ["api/src/index"], - "@fosscord/gateway": ["gateway/src/index"], - "@fosscord/cdn": ["cdn/src/index"], - "@fosscord/util": ["util/src/index"] + "@fosscord/api": ["./api/index"], + "@fosscord/gateway": ["./gateway/index"], + "@fosscord/cdn": ["./cdn/index"], + "@fosscord/util": ["./util/index"] }, "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }], "noEmitHelpers": true, diff --git a/util/.gitignore b/util/.gitignore deleted file mode 100644 index 768a04259..000000000 --- a/util/.gitignore +++ /dev/null @@ -1,110 +0,0 @@ -# Logs -logs -*.log -npm-debug.log* -yarn-debug.log* -yarn-error.log* -lerna-debug.log* - -# Diagnostic reports (https://nodejs.org/api/report.html) -report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json - -# Runtime data -pids -*.pid -*.seed -*.pid.lock - -yarn.lock - -# Directory for instrumented libs generated by jscoverage/JSCover -lib-cov - -# Coverage directory used by tools like istanbul -coverage -*.lcov - -# nyc test coverage -.nyc_output - -# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) -.grunt - -# Bower dependency directory (https://bower.io/) -bower_components - -# node-waf configuration -.lock-wscript - -# Compiled binary addons (https://nodejs.org/api/addons.html) -build/Release - -# Dependency directories -node_modules/ -jspm_packages/ - -# TypeScript v1 declaration files -typings/ - -# TypeScript cache -*.tsbuildinfo - -# Optional npm cache directory -.npm - -# Optional eslint cache -.eslintcache - -# Microbundle cache -.rpt2_cache/ -.rts2_cache_cjs/ -.rts2_cache_es/ -.rts2_cache_umd/ - -# Optional REPL history -.node_repl_history - -# Output of 'npm pack' -*.tgz - -# Yarn Integrity file -.yarn-integrity - -# dotenv environment variables file -.env -.env.test - -# parcel-bundler cache (https://parceljs.org/) -.cache - -# Next.js build output -.next - -# Nuxt.js build / generate output -.nuxt - -# Gatsby files -.cache/ -# Comment in the public line in if your project uses Gatsby and *not* Next.js -# https://nextjs.org/blog/next-9-1#public-directory-support -# public - -# vuepress build output -.vuepress/dist - -# Serverless directories -.serverless/ - -# FuseBox cache -.fusebox/ - -# DynamoDB Local files -.dynamodb/ - -# TernJS port file -.tern-port -.DS_Store - -# Compiled TypeScript code -dist/ -database.db \ No newline at end of file diff --git a/util/.npmignore b/util/.npmignore deleted file mode 100644 index 05a9d0cf2..000000000 --- a/util/.npmignore +++ /dev/null @@ -1 +0,0 @@ -!dist/ \ No newline at end of file diff --git a/util/.prettierrc b/util/.prettierrc deleted file mode 100644 index d569c548e..000000000 --- a/util/.prettierrc +++ /dev/null @@ -1,5 +0,0 @@ -{ - "tabWidth": 4, - "useTabs": true, - "printWidth": 120 -} diff --git a/util/.vscode/launch.json b/util/.vscode/launch.json deleted file mode 100644 index 524622d13..000000000 --- a/util/.vscode/launch.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - // 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": [ - { - "sourceMaps": true, - "type": "node", - "request": "launch", - "name": "Launch Util", - "program": "${workspaceFolder}/dist/index.js", - "preLaunchTask": "tsc: build - tsconfig.json", - "outFiles": ["${workspaceFolder}/dist/**/*.js"] - }, - { - "name": "Debug Jest Tests", - "type": "node", - "request": "launch", - "runtimeArgs": ["--inspect-brk", "${workspaceRoot}/node_modules/jest/bin/jest.js", "--runInBand"], - "preLaunchTask": "tsc: build - tsconfig.json", - "console": "integratedTerminal", - "internalConsoleOptions": "neverOpen", - "port": 9229 - } - ] -} diff --git a/util/README.md b/util/README.md deleted file mode 100644 index 1934df2a7..000000000 --- a/util/README.md +++ /dev/null @@ -1,29 +0,0 @@ -

- -

-

Fosscord server util

- -

- - - - - - - - -

- -## [About](https://fosscord.com) - -Fosscord is a free open source selfhostable chat, voice and video discord-compatible platform. - -Fosscord server util contains all necessary logic that is shared between the [api](https://github.com/fosscord/fosscord-server/tree/master/api), [gateway](https://github.com/fosscord/fosscord-server/tree/master/gateway) and [cdn](https://github.com/fosscord/fosscord-server/tree/master/cdn). - -It contains all mongoose database models and utility functions. - -## Installation - -```bash -npm install @fosscord/server-util -``` diff --git a/util/package-lock.json b/util/package-lock.json deleted file mode 100644 index 04b2857b792f34bf4fd4e060c1603cbc4aa21385..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 460763 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

H=+_-1@OInQ~GFPQT37|fN$8TJZFLi7tB;s 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 j7y4@4xr%c08u1_7S`^KbtbZh+9D diff --git a/util/package.json b/util/package.json deleted file mode 100644 index 01c3d9f20..000000000 --- a/util/package.json +++ /dev/null @@ -1,59 +0,0 @@ -{ - "name": "@fosscord/util", - "version": "1.0.0", - "description": "Utility functions for the all server repositories", - "main": "dist/index.js", - "types": "src/index.ts", - "scripts": { - "start": "npm run build && node dist/", - "test": "npm run build && npx jest", - "postinstall": "npm run build", - "build": "npx tsc -p .", - "typeorm": "node --require ts-node/register ./node_modules/typeorm/cli.js" - }, - "repository": { - "type": "git", - "url": "git+https://github.com/fosscord/fosscord-server.git" - }, - "keywords": [ - "discord", - "fosscord", - "fosscord-server", - "discord open source", - "discord-open-source" - ], - "author": "Fosscord", - "license": "AGPL-3.0-only", - "bugs": { - "url": "https://github.com/fosscord/fosscord-server/issues" - }, - "homepage": "https://docs.fosscord.com/", - "devDependencies": { - "@types/amqplib": "^0.8.1", - "@types/jsonwebtoken": "^8.5.8", - "@types/multer": "^1.4.7", - "@types/node": "^18.0.6", - "jest": "^28.1.3", - "ts-node": "^10.2.1" - }, - "dependencies": { - "@types/node-fetch": "^2.6.2", - "amqplib": "^0.10.0", - "form-data": "^4.0.0", - "jsonwebtoken": "^8.5.1", - "lambert-server": "^1.2.12", - "missing-native-js-functions": "^1.2.18", - "multer": "^1.4.5-lts.1", - "node-fetch": "^2.6.7", - "picocolors": "^1.0.0", - "proxy-agent": "^5.0.0", - "reflect-metadata": "^0.1.13", - "typeorm": "^0.3.7", - "typescript": "^4.7.4" - }, - "jest": { - "setupFilesAfterEnv": [ - "./tests/setupJest.js" - ] - } -} diff --git a/util/tsconfig.json b/util/tsconfig.json deleted file mode 100644 index a5d5ae05f..000000000 --- a/util/tsconfig.json +++ /dev/null @@ -1,73 +0,0 @@ -{ - "include": ["src/**/*.ts"], - "compilerOptions": { - /* Visit https://aka.ms/tsconfig.json to read more about this file */ - - /* Basic Options */ - "incremental": false /* Enable incremental compilation */, - "target": "ES6" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, - "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, - "lib": ["ES2021"] /* Specify library files to be included in the compilation. */, - "allowJs": true /* Allow javascript files to be compiled. */, - "checkJs": true /* Report errors in .js files. */, - // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ - "declaration": true /* Generates corresponding '.d.ts' file. */, - "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, - "sourceMap": true /* Generates corresponding '.map' file. */, - // "outFile": "./", /* Concatenate and emit output to single file. */ - "outDir": "./dist/" /* Redirect output structure to the directory. */, - "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, - // "composite": true, /* Enable project compilation */ - // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ - // "removeComments": true, /* Do not emit comments to output. */ - // "noEmit": true, /* Do not emit outputs. */ - // "importHelpers": true, /* Import emit helpers from 'tslib'. */ - // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ - // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ - - /* Strict Type-Checking Options */ - "strict": true /* Enable all strict type-checking options. */, - "noImplicitAny": true /* Raise error on expressions and declarations with an implied 'any' type. */, - "strictNullChecks": true /* Enable strict null checks. */, - // "strictFunctionTypes": true, /* Enable strict checking of function types. */ - // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ - "strictPropertyInitialization": false /* Enable strict checking of property initialization in classes. */, - // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ - "alwaysStrict": true /* Parse in strict mode and emit "use strict" for each source file. */, - - /* Additional Checks */ - // "noUnusedLocals": true, /* Report errors on unused locals. */ - // "noUnusedParameters": true, /* Report errors on unused parameters. */ - // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ - // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ - - /* Module Resolution Options */ - // "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ - // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ - // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ - // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ - // "typeRoots": [], /* List of folders to include type definitions from. */ - "types": ["node"] /* Type declaration files to be included in compilation. */, - // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ - "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, - // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ - // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ - - /* Source Map Options */ - // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ - // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ - // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ - // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ - - /* Experimental Options */ - // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ - // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ - - /* Advanced Options */ - "skipLibCheck": true /* Skip type checking of declaration files. */, - "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */, - "emitDecoratorMetadata": true, - "experimentalDecorators": true, - "resolveJsonModule": true - } -} diff --git a/webrtc/.DS_Store b/webrtc/.DS_Store deleted file mode 100644 index bfb0a4165ee92c5850a98ab16b2c02a383ec7a7e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6148 zcmeHKJ5Iwu5S<||EYYN-px6^2asv~Y6XXKOiGU)JBM`kiI1IPo2AqgDAHb1CN(y)* z%|7qUyj}Sf9*>CV@@caWnTtpbHeE23 zRDcRlfiDH@`%vJ9P2v#fpAIZO0s!qd-VM(_O8|=nfKB2MhzLxB3Jj{|h@nA8ykuRI zI0Ob=)NjT)d9&t(qJBH##mhyTK(17P3LGjhi|yR{|26!F`Tvl_9TlJge@X$Z+Eu&6 zD`jt;yqxvg0>6QO8fv{9i??E+w_ZG%D~L3VZ+r CMmVVi6$34h~<3Hb6of+CZ9_{_V~bk`N^oOZVL9 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 { - socket.on("message", (message) => { - socket.emit( - JSON.stringify({ - op: 2, - d: { - ssrc: 1, - ip: "127.0.0.1", - port: 3004, - modes: [ - "xsalsa20_poly1305", - "xsalsa20_poly1305_suffix", - "xsalsa20_poly1305_lite", - ], - heartbeat_interval: 1, - }, - }) - ); - }); - }); - } - - async listen(): Promise { - // @ts-ignore - await (db as Promise); - await Config.init(); - console.log("[DB] connected"); - console.log(`[WebRTC] online on 0.0.0.0:${port}`); - } -} diff --git a/webrtc/src/index.ts b/webrtc/src/index.ts deleted file mode 100644 index e69de29bb..000000000 diff --git a/webrtc/src/start.ts b/webrtc/src/start.ts deleted file mode 100644 index 68867a2cf..000000000 --- a/webrtc/src/start.ts +++ /dev/null @@ -1,3 +0,0 @@ -import { Server } from "./Server"; - -const server = new Server(); diff --git a/webrtc/src/test.ts b/webrtc/src/test.ts deleted file mode 100644 index df407b56a..000000000 --- a/webrtc/src/test.ts +++ /dev/null @@ -1,8 +0,0 @@ -import { getSupportedRtpCapabilities } from "mediasoup"; - -async function test() { - console.log(getSupportedRtpCapabilities()); -} -setTimeout(() => {}, 1000000); - -test(); diff --git a/webrtc/tsconfig.json b/webrtc/tsconfig.json deleted file mode 100644 index 77353db0d..000000000 --- a/webrtc/tsconfig.json +++ /dev/null @@ -1,72 +0,0 @@ -{ - "include": ["src/**/*.ts"], - "compilerOptions": { - /* Visit https://aka.ms/tsconfig.json to read more about this file */ - - /* Basic Options */ - // "incremental": true, /* Enable incremental compilation */ - "target": "ESNext" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, - "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, - "lib": [ - "ES2021" - ] /* Specify library files to be included in the compilation. */, - "allowJs": true /* Allow javascript files to be compiled. */, - "checkJs": true /* Report errors in .js files. */, - // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ - "declaration": true /* Generates corresponding '.d.ts' file. */, - "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, - "sourceMap": true /* Generates corresponding '.map' file. */, - // "outFile": "./", /* Concatenate and emit output to single file. */ - "outDir": "./dist/" /* Redirect output structure to the directory. */, - "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, - // "composite": true, /* Enable project compilation */ - // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ - // "removeComments": true, /* Do not emit comments to output. */ - // "noEmit": true, /* Do not emit outputs. */ - // "importHelpers": true, /* Import emit helpers from 'tslib'. */ - // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ - // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ - - /* Strict Type-Checking Options */ - "strict": true /* Enable all strict type-checking options. */, - "noImplicitAny": true /* Raise error on expressions and declarations with an implied 'any' type. */, - "strictNullChecks": true /* Enable strict null checks. */, - // "strictFunctionTypes": true, /* Enable strict checking of function types. */ - // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ - "strictPropertyInitialization": false /* Enable strict checking of property initialization in classes. */, - // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ - "alwaysStrict": true /* Parse in strict mode and emit "use strict" for each source file. */, - - /* Additional Checks */ - // "noUnusedLocals": true, /* Report errors on unused locals. */ - // "noUnusedParameters": true, /* Report errors on unused parameters. */ - // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ - // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ - - /* Module Resolution Options */ - // "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ - // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ - // "typeRoots": [], /* List of folders to include type definitions from. */ - "types": [ - "node" - ] /* Type declaration files to be included in compilation. */, - // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ - "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, - // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ - // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ - - /* Source Map Options */ - // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ - // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ - // "inlineSourceMap": true, /* Emit a single file with source maps instead of having a separate file. */ - // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ - - /* Experimental Options */ - // "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ - // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ - - /* Advanced Options */ - "skipLibCheck": true /* Skip type checking of declaration files. */, - "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */ - } -} diff --git a/yarn.lock b/yarn.lock new file mode 100644 index 000000000..3173ddfa8 --- /dev/null +++ b/yarn.lock @@ -0,0 +1,6802 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@ampproject/remapping@^2.1.0": + version "2.2.0" + resolved "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz" + integrity sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w== + dependencies: + "@jridgewell/gen-mapping" "^0.1.0" + "@jridgewell/trace-mapping" "^0.3.9" + +"@aws-crypto/crc32@2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/crc32/-/crc32-2.0.0.tgz" + integrity sha512-TvE1r2CUueyXOuHdEigYjIZVesInd9KN+K/TFFNfkkxRThiNxO6i4ZqqAVMoEjAamZZ1AA8WXJkjCz7YShHPQA== + dependencies: + "@aws-crypto/util" "^2.0.0" + "@aws-sdk/types" "^3.1.0" + tslib "^1.11.1" + +"@aws-crypto/crc32c@2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/crc32c/-/crc32c-2.0.0.tgz" + integrity sha512-vF0eMdMHx3O3MoOXUfBZry8Y4ZDtcuskjjKgJz8YfIDjLStxTZrYXk+kZqtl6A0uCmmiN/Eb/JbC/CndTV1MHg== + dependencies: + "@aws-crypto/util" "^2.0.0" + "@aws-sdk/types" "^3.1.0" + tslib "^1.11.1" + +"@aws-crypto/ie11-detection@^2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/ie11-detection/-/ie11-detection-2.0.0.tgz" + integrity sha512-pkVXf/dq6PITJ0jzYZ69VhL8VFOFoPZLZqtU/12SGnzYuJOOGNfF41q9GxdI1yqC8R13Rq3jOLKDFpUJFT5eTA== + dependencies: + tslib "^1.11.1" + +"@aws-crypto/sha1-browser@2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/sha1-browser/-/sha1-browser-2.0.0.tgz" + integrity sha512-3fIVRjPFY8EG5HWXR+ZJZMdWNRpwbxGzJ9IH9q93FpbgCH8u8GHRi46mZXp3cYD7gealmyqpm3ThZwLKJjWJhA== + dependencies: + "@aws-crypto/ie11-detection" "^2.0.0" + "@aws-crypto/supports-web-crypto" "^2.0.0" + "@aws-sdk/types" "^3.1.0" + "@aws-sdk/util-locate-window" "^3.0.0" + "@aws-sdk/util-utf8-browser" "^3.0.0" + tslib "^1.11.1" + +"@aws-crypto/sha256-browser@2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/sha256-browser/-/sha256-browser-2.0.0.tgz" + integrity sha512-rYXOQ8BFOaqMEHJrLHul/25ckWH6GTJtdLSajhlqGMx0PmSueAuvboCuZCTqEKlxR8CQOwRarxYMZZSYlhRA1A== + dependencies: + "@aws-crypto/ie11-detection" "^2.0.0" + "@aws-crypto/sha256-js" "^2.0.0" + "@aws-crypto/supports-web-crypto" "^2.0.0" + "@aws-crypto/util" "^2.0.0" + "@aws-sdk/types" "^3.1.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@2.0.0", "@aws-crypto/sha256-js@^2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/sha256-js/-/sha256-js-2.0.0.tgz" + integrity sha512-VZY+mCY4Nmrs5WGfitmNqXzaE873fcIZDu54cbaDaaamsaTOP1DBImV9F4pICc3EHjQXujyE8jig+PFCaew9ig== + dependencies: + "@aws-crypto/util" "^2.0.0" + "@aws-sdk/types" "^3.1.0" + tslib "^1.11.1" + +"@aws-crypto/supports-web-crypto@^2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/@aws-crypto/supports-web-crypto/-/supports-web-crypto-2.0.0.tgz" + integrity sha512-Ge7WQ3E0OC7FHYprsZV3h0QIcpdyJLvIeg+uTuHqRYm8D6qCFJoiC+edSzSyFiHtZf+NOQDJ1q46qxjtzIY2nA== + dependencies: + tslib "^1.11.1" + +"@aws-crypto/util@^2.0.0": + version "2.0.1" + resolved "https://registry.npmjs.org/@aws-crypto/util/-/util-2.0.1.tgz" + integrity sha512-JJmFFwvbm08lULw4Nm5QOLg8+lAQeC8aCXK5xrtxntYzYXCGfHwUJ4Is3770Q7HmICsXthGQ+ZsDL7C2uH3yBQ== + dependencies: + "@aws-sdk/types" "^3.1.0" + "@aws-sdk/util-utf8-browser" "^3.0.0" + tslib "^1.11.1" + +"@aws-sdk/abort-controller@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/abort-controller/-/abort-controller-3.127.0.tgz" + integrity sha512-G77FLYcl9egUoD3ZmR6TX94NMqBMeT53hBGrEE3uVUJV1CwfGKfaF007mPpRZnIB3avnJBQGEK6MrwlCfv2qAw== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/chunked-blob-reader-native@3.109.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/chunked-blob-reader-native/-/chunked-blob-reader-native-3.109.0.tgz" + integrity sha512-Ybn3vDZ3CqGyprL2qdF6QZqoqlx8lA3qOJepobjuKKDRw+KgGxjUY4NvWe0R2MdRoduyaDj6uvhIay0S1MOSJQ== + dependencies: + "@aws-sdk/util-base64-browser" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/chunked-blob-reader@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/chunked-blob-reader/-/chunked-blob-reader-3.55.0.tgz" + integrity sha512-o/xjMCq81opAjSBjt7YdHJwIJcGVG5XIV9+C2KXcY5QwVimkOKPybWTv0mXPvSwSilSx+EhpLNhkcJuXdzhw4w== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/client-s3@^3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/client-s3/-/client-s3-3.137.0.tgz" + integrity sha512-WFOBywwV7ECAOkSOLecpPOGbgmYV5NxHzXHTJEio6xR6s2KzoLegJa0/mq5ljh0Zl5t2h5bsKT1CxYRC0sfwWw== + dependencies: + "@aws-crypto/sha1-browser" "2.0.0" + "@aws-crypto/sha256-browser" "2.0.0" + "@aws-crypto/sha256-js" "2.0.0" + "@aws-sdk/client-sts" "3.137.0" + "@aws-sdk/config-resolver" "3.130.0" + "@aws-sdk/credential-provider-node" "3.137.0" + "@aws-sdk/eventstream-serde-browser" "3.127.0" + "@aws-sdk/eventstream-serde-config-resolver" "3.127.0" + "@aws-sdk/eventstream-serde-node" "3.127.0" + "@aws-sdk/fetch-http-handler" "3.131.0" + "@aws-sdk/hash-blob-browser" "3.127.0" + "@aws-sdk/hash-node" "3.127.0" + "@aws-sdk/hash-stream-node" "3.127.0" + "@aws-sdk/invalid-dependency" "3.127.0" + "@aws-sdk/md5-js" "3.127.0" + "@aws-sdk/middleware-bucket-endpoint" "3.127.0" + "@aws-sdk/middleware-content-length" "3.127.0" + "@aws-sdk/middleware-expect-continue" "3.127.0" + "@aws-sdk/middleware-flexible-checksums" "3.127.0" + "@aws-sdk/middleware-host-header" "3.127.0" + "@aws-sdk/middleware-location-constraint" "3.127.0" + "@aws-sdk/middleware-logger" "3.127.0" + "@aws-sdk/middleware-recursion-detection" "3.127.0" + "@aws-sdk/middleware-retry" "3.127.0" + "@aws-sdk/middleware-sdk-s3" "3.127.0" + "@aws-sdk/middleware-serde" "3.127.0" + "@aws-sdk/middleware-signing" "3.130.0" + "@aws-sdk/middleware-ssec" "3.127.0" + "@aws-sdk/middleware-stack" "3.127.0" + "@aws-sdk/middleware-user-agent" "3.127.0" + "@aws-sdk/node-config-provider" "3.127.0" + "@aws-sdk/node-http-handler" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/signature-v4-multi-region" "3.130.0" + "@aws-sdk/smithy-client" "3.137.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/url-parser" "3.127.0" + "@aws-sdk/util-base64-browser" "3.109.0" + "@aws-sdk/util-base64-node" "3.55.0" + "@aws-sdk/util-body-length-browser" "3.55.0" + "@aws-sdk/util-body-length-node" "3.55.0" + "@aws-sdk/util-defaults-mode-browser" "3.137.0" + "@aws-sdk/util-defaults-mode-node" "3.137.0" + "@aws-sdk/util-stream-browser" "3.131.0" + "@aws-sdk/util-stream-node" "3.129.0" + "@aws-sdk/util-user-agent-browser" "3.127.0" + "@aws-sdk/util-user-agent-node" "3.127.0" + "@aws-sdk/util-utf8-browser" "3.109.0" + "@aws-sdk/util-utf8-node" "3.109.0" + "@aws-sdk/util-waiter" "3.127.0" + "@aws-sdk/xml-builder" "3.109.0" + entities "2.2.0" + fast-xml-parser "3.19.0" + tslib "^2.3.1" + +"@aws-sdk/client-sso@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/client-sso/-/client-sso-3.137.0.tgz" + integrity sha512-l9y9usMuXGI+o1c/VO2qMccN0Bm0T5bFmmbRljB6kIzbJYXD/wVqR8GMZwSnFnz52cnURQ4pgqM1ETg54FlBYQ== + dependencies: + "@aws-crypto/sha256-browser" "2.0.0" + "@aws-crypto/sha256-js" "2.0.0" + "@aws-sdk/config-resolver" "3.130.0" + "@aws-sdk/fetch-http-handler" "3.131.0" + "@aws-sdk/hash-node" "3.127.0" + "@aws-sdk/invalid-dependency" "3.127.0" + "@aws-sdk/middleware-content-length" "3.127.0" + "@aws-sdk/middleware-host-header" "3.127.0" + "@aws-sdk/middleware-logger" "3.127.0" + "@aws-sdk/middleware-recursion-detection" "3.127.0" + "@aws-sdk/middleware-retry" "3.127.0" + "@aws-sdk/middleware-serde" "3.127.0" + "@aws-sdk/middleware-stack" "3.127.0" + "@aws-sdk/middleware-user-agent" "3.127.0" + "@aws-sdk/node-config-provider" "3.127.0" + "@aws-sdk/node-http-handler" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/smithy-client" "3.137.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/url-parser" "3.127.0" + "@aws-sdk/util-base64-browser" "3.109.0" + "@aws-sdk/util-base64-node" "3.55.0" + "@aws-sdk/util-body-length-browser" "3.55.0" + "@aws-sdk/util-body-length-node" "3.55.0" + "@aws-sdk/util-defaults-mode-browser" "3.137.0" + "@aws-sdk/util-defaults-mode-node" "3.137.0" + "@aws-sdk/util-user-agent-browser" "3.127.0" + "@aws-sdk/util-user-agent-node" "3.127.0" + "@aws-sdk/util-utf8-browser" "3.109.0" + "@aws-sdk/util-utf8-node" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/client-sts@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/client-sts/-/client-sts-3.137.0.tgz" + integrity sha512-yJqfkEq0DG9Ds+oif/sc02PX6vfSNcyRe3YcaW5P6ouMyhJRljSIVCnA6iPwJaTsmK9BE9PDgFD2v/GYM/XgOA== + dependencies: + "@aws-crypto/sha256-browser" "2.0.0" + "@aws-crypto/sha256-js" "2.0.0" + "@aws-sdk/config-resolver" "3.130.0" + "@aws-sdk/credential-provider-node" "3.137.0" + "@aws-sdk/fetch-http-handler" "3.131.0" + "@aws-sdk/hash-node" "3.127.0" + "@aws-sdk/invalid-dependency" "3.127.0" + "@aws-sdk/middleware-content-length" "3.127.0" + "@aws-sdk/middleware-host-header" "3.127.0" + "@aws-sdk/middleware-logger" "3.127.0" + "@aws-sdk/middleware-recursion-detection" "3.127.0" + "@aws-sdk/middleware-retry" "3.127.0" + "@aws-sdk/middleware-sdk-sts" "3.130.0" + "@aws-sdk/middleware-serde" "3.127.0" + "@aws-sdk/middleware-signing" "3.130.0" + "@aws-sdk/middleware-stack" "3.127.0" + "@aws-sdk/middleware-user-agent" "3.127.0" + "@aws-sdk/node-config-provider" "3.127.0" + "@aws-sdk/node-http-handler" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/smithy-client" "3.137.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/url-parser" "3.127.0" + "@aws-sdk/util-base64-browser" "3.109.0" + "@aws-sdk/util-base64-node" "3.55.0" + "@aws-sdk/util-body-length-browser" "3.55.0" + "@aws-sdk/util-body-length-node" "3.55.0" + "@aws-sdk/util-defaults-mode-browser" "3.137.0" + "@aws-sdk/util-defaults-mode-node" "3.137.0" + "@aws-sdk/util-user-agent-browser" "3.127.0" + "@aws-sdk/util-user-agent-node" "3.127.0" + "@aws-sdk/util-utf8-browser" "3.109.0" + "@aws-sdk/util-utf8-node" "3.109.0" + entities "2.2.0" + fast-xml-parser "3.19.0" + tslib "^2.3.1" + +"@aws-sdk/config-resolver@3.130.0": + version "3.130.0" + resolved "https://registry.npmjs.org/@aws-sdk/config-resolver/-/config-resolver-3.130.0.tgz" + integrity sha512-7dkCHHI9kRcHW6YNr9/2Ub6XkvU9Fu6H/BnlKbaKlDR8jq7QpaFhPhctOVi5D/NDpxJgALifexFne0dvo3piTw== + dependencies: + "@aws-sdk/signature-v4" "3.130.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-config-provider" "3.109.0" + "@aws-sdk/util-middleware" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-env@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-env/-/credential-provider-env-3.127.0.tgz" + integrity sha512-Ig7XhUikRBlnRTYT5JBGzWfYZp68X5vkFVIFCmsHHt/qVy0Nz9raZpmDHicdS1u67yxDkWgCPn/bNevWnM0GFg== + dependencies: + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-imds@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-imds/-/credential-provider-imds-3.127.0.tgz" + integrity sha512-I6KlIBBzmJn/U1KikiC50PK3SspT9G5lkVLBaW5a6YfOcijqVTXfAN3kYzqhfeS0j4IgfJEwKVsjsZfmprJO5A== + dependencies: + "@aws-sdk/node-config-provider" "3.127.0" + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/url-parser" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-ini@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.137.0.tgz" + integrity sha512-FNSYjHaW83b4sQac+EWh/C6p1taBdvPOXFAVml1mPH49Nlkv9/E4bbjaWwgxvlxjqjNCbkDMKzhb19DN3gVulA== + dependencies: + "@aws-sdk/credential-provider-env" "3.127.0" + "@aws-sdk/credential-provider-imds" "3.127.0" + "@aws-sdk/credential-provider-sso" "3.137.0" + "@aws-sdk/credential-provider-web-identity" "3.127.0" + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/shared-ini-file-loader" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-node@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-node/-/credential-provider-node-3.137.0.tgz" + integrity sha512-if4CzNSyPS3ZERLtDocNNC+l5ejK93d2hoOzNHP2qCmTppThEPWF2TH506ez0v0lbUzeI7qWgpYe9m4+BFLEwQ== + dependencies: + "@aws-sdk/credential-provider-env" "3.127.0" + "@aws-sdk/credential-provider-imds" "3.127.0" + "@aws-sdk/credential-provider-ini" "3.137.0" + "@aws-sdk/credential-provider-process" "3.127.0" + "@aws-sdk/credential-provider-sso" "3.137.0" + "@aws-sdk/credential-provider-web-identity" "3.127.0" + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/shared-ini-file-loader" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-process@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-process/-/credential-provider-process-3.127.0.tgz" + integrity sha512-6v0m2lqkO9J5fNlTl+HjriQNIdfg8mjVST544+5y9EnC/FVmTnIz64vfHveWdNkP/fehFx7wTimNENtoSqCn3A== + dependencies: + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/shared-ini-file-loader" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-sso@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.137.0.tgz" + integrity sha512-Up2Q3tWSo6Mv2icXMrHa8dGtnC9yQAeUnftrIlvLXi3P9RjxlOPZCSg1NF8FOS90RdEgORlj/7LPlIniHgGUmg== + dependencies: + "@aws-sdk/client-sso" "3.137.0" + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/shared-ini-file-loader" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/credential-provider-web-identity@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.127.0.tgz" + integrity sha512-85ahDZnLYB3dqkW+cQ0bWt+NVqOoxomTrJoq3IC2q6muebeFrJ0pyf0JEW/RNRzBiUvvsZujzGdWifzWyQKfVg== + dependencies: + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/eventstream-codec@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/eventstream-codec/-/eventstream-codec-3.127.0.tgz" + integrity sha512-+Tlujx3VkB4DK8tYzG0rwxIE0ee6hWItQgSEREEmi5CwHQFw7VpRLYAShYabEx9wIJmRFObWzhlKxWNRi+TfaA== + dependencies: + "@aws-crypto/crc32" "2.0.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-hex-encoding" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/eventstream-serde-browser@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-browser/-/eventstream-serde-browser-3.127.0.tgz" + integrity sha512-d1rTK4ljEp3Y/BQ78/AJ7eqgGyI6TE0bxNosCmXWcUBv00Tr5cerPqPe7Zvw8XwIMPX5y8cjtd1/cOtB2ePaBw== + dependencies: + "@aws-sdk/eventstream-serde-universal" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/eventstream-serde-config-resolver@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-config-resolver/-/eventstream-serde-config-resolver-3.127.0.tgz" + integrity sha512-dYvLfQYcKLOFtZVgwLwKDCykAxNkDyDLQRWytJK9DHCyjRig66IKi1codts9vOy4j0CeYwnXWs5WDavrUaE05g== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/eventstream-serde-node@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-node/-/eventstream-serde-node-3.127.0.tgz" + integrity sha512-Ie59jZYAIw3Kt6GePvEilp1k3JoYEQpY3WIyVZltm3dkVf0GmzhCZrPROH9vgF3qApzu1aGOWDV2wX91poXF8A== + dependencies: + "@aws-sdk/eventstream-serde-universal" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/eventstream-serde-universal@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-universal/-/eventstream-serde-universal-3.127.0.tgz" + integrity sha512-cJLSTtYDGTevknMTykzHpcDNRbD6yGve8FBUKSAczuNVjXZOedj0GbHJqkASuLj0ZnojbKBdCx4uu1XGyvubng== + dependencies: + "@aws-sdk/eventstream-codec" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/fetch-http-handler@3.131.0": + version "3.131.0" + resolved "https://registry.npmjs.org/@aws-sdk/fetch-http-handler/-/fetch-http-handler-3.131.0.tgz" + integrity sha512-eNxmPZQX2IUeBGWHNC7eNTekWn9VIPLYEMKJbKYUBJryxuTJ7TtLeyEK5oakUjMwP1AUvWT+CV7C+8L7uG1omQ== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/querystring-builder" "3.127.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-base64-browser" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/hash-blob-browser@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/hash-blob-browser/-/hash-blob-browser-3.127.0.tgz" + integrity sha512-XH9s2w6GXCtDI+3/y+sDAzMWJRTvhRXJJtI1fVDsCiyq96SYUTNKLLaUSuR01uawEBiRDBqGDDPMT8qJPDXc/w== + dependencies: + "@aws-sdk/chunked-blob-reader" "3.55.0" + "@aws-sdk/chunked-blob-reader-native" "3.109.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/hash-node@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/hash-node/-/hash-node-3.127.0.tgz" + integrity sha512-wx7DKlXdKebH4JcMsOevdsm2oDNMVm36kuMm0XWRIrFWQ/oq7OquDpEMJzWvGqWF/IfFUpb7FhAWZZpALwlcwA== + dependencies: + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-buffer-from" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/hash-stream-node@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/hash-stream-node/-/hash-stream-node-3.127.0.tgz" + integrity sha512-ZCNqi+FJViYFCo8JfSx+YK0Hd/SC555gHqBe24GVBMCDqJ8UFIled7tF+GOQ8wTcKjxuwp/0EXDTXoaAb0K89g== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/invalid-dependency@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/invalid-dependency/-/invalid-dependency-3.127.0.tgz" + integrity sha512-bxvmtmJ6gIRfOHvh1jAPZBH2mzppEblPjEOFo4mOzXz4U3qPIxeuukCjboMnGK9QEpV2wObWcYYld0vxoRrfiA== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/is-array-buffer@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/is-array-buffer/-/is-array-buffer-3.55.0.tgz" + integrity sha512-NbiPHVYuPxdqdFd6FxzzN3H1BQn/iWA3ri3Ry7AyLeP/tGs1yzEWMwf8BN8TSMALI0GXT6Sh0GDWy3Ok5xB6DA== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/md5-js@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/md5-js/-/md5-js-3.127.0.tgz" + integrity sha512-9FzD++p2bvfZ56hbDxvGcLlA9JIMt9uZB/m4NEvbuvrpx1qnUpFv6HqthhGaVuhctkK25hONT5ZpOYHSisATrA== + dependencies: + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-utf8-browser" "3.109.0" + "@aws-sdk/util-utf8-node" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-bucket-endpoint@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-bucket-endpoint/-/middleware-bucket-endpoint-3.127.0.tgz" + integrity sha512-wJpXxWceBDhWktoxrRb4s6tMx0dWsEGYIaV0KkQPGhTPk2KMUgwa4xApfCXXVfYcE3THk486OKwHhPrR5jpe+g== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-arn-parser" "3.55.0" + "@aws-sdk/util-config-provider" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-content-length@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-content-length/-/middleware-content-length-3.127.0.tgz" + integrity sha512-AFmMaIEW3Rzg0TaKB9l/RENLowd7ZEEOpm0trYw1CgUUORWW/ydCsDT7pekPlC25CPbhUmWXCSA4xPFSYOVnDw== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-expect-continue@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-expect-continue/-/middleware-expect-continue-3.127.0.tgz" + integrity sha512-+X7mdgFqt9UqUDeGuMt+afR8CBX9nMecTxEIilAKdVOLx+fuXzHnC2mpddKMtiE9IGKMU4BI1Ahf7t32Odhs1Q== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-flexible-checksums@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-flexible-checksums/-/middleware-flexible-checksums-3.127.0.tgz" + integrity sha512-sXkAwhE9dikO72sEJ7DrUCo5mawauAxICCqipCCSGp0geSkptvtZHhySgJNMVSbUJQmu5bcS+zsFpFVwuJvGxg== + dependencies: + "@aws-crypto/crc32" "2.0.0" + "@aws-crypto/crc32c" "2.0.0" + "@aws-sdk/is-array-buffer" "3.55.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-host-header@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-host-header/-/middleware-host-header-3.127.0.tgz" + integrity sha512-e2gTLJb5lYP9lRV7hN3rKY2l4jv8OygOoHElZJ3Z8KPZskjHelYPcQ8XbdfhSXXxC3vc/0QqN0ResFt3W3Pplg== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-location-constraint@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-location-constraint/-/middleware-location-constraint-3.127.0.tgz" + integrity sha512-UtPmbOKEVu+Ue7CwICFSOOOSePV8Piydco/v2IpdRkMO0e4bqQ3Tn0XprBlWWfSW4QCtAPzydrArLsUdk636GA== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-logger@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-logger/-/middleware-logger-3.127.0.tgz" + integrity sha512-jMNLcZB/ECA7OfkNBLNeAlrLRehyfnUeNQJHW3kcxs9h1+6VxaF6wY+WKozszLI7/3OBzQrFHBQCfRZV7ykSLg== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-recursion-detection@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.127.0.tgz" + integrity sha512-tB6WX+Z1kUKTnn5h38XFrTCzoqPKjUZLUjN4Wb27/cbeSiTSKGAZcCXHOJm36Ukorl5arlybQTqGe689EU00Hw== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-retry@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-retry/-/middleware-retry-3.127.0.tgz" + integrity sha512-ZSvg/AyGUacWnf3i8ZbyImtiCH+NyafF8uV7bITP7JkwPrG+VdNocJZOr88GRM0c1A0jfkOf7+oq+fInPwwiNA== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/service-error-classification" "3.127.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-middleware" "3.127.0" + tslib "^2.3.1" + uuid "^8.3.2" + +"@aws-sdk/middleware-sdk-s3@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-sdk-s3/-/middleware-sdk-s3-3.127.0.tgz" + integrity sha512-q1mkEN7kYYdQ3LOHIhaT56omYe8DCubyiCKOXuEo5ZiIkE5iq06K/BxWxj3f8bFZxSX80Ma1m8XA5jcOEMphSA== + dependencies: + "@aws-sdk/middleware-bucket-endpoint" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-arn-parser" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-sdk-sts@3.130.0": + version "3.130.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-sdk-sts/-/middleware-sdk-sts-3.130.0.tgz" + integrity sha512-FDfs7+ohbhEK3eH3Dshr6JDiL8P72bp3ffeNpPBXuURFqwt4pCmjHuX3SqQR0JIJ2cl3aIdxc17rKaZJfOjtPw== + dependencies: + "@aws-sdk/middleware-signing" "3.130.0" + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/signature-v4" "3.130.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-serde@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-serde/-/middleware-serde-3.127.0.tgz" + integrity sha512-xmWMYV/t9M+b9yHjqaD1noDNJJViI2QwOH7TQZ9VbbrvdVtDrFuS9Sf9He80TBCJqeHShwQN9783W1I3Pu/8kw== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-signing@3.130.0": + version "3.130.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-signing/-/middleware-signing-3.130.0.tgz" + integrity sha512-JePq5XLR9TfRN3RQ0d7Za/bEW5D3xgtD1FNAwHeenWALeozMuQgRPjM5RroCnL/5jY3wuvCZI7cSXeqhawWqmA== + dependencies: + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/signature-v4" "3.130.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-ssec@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-ssec/-/middleware-ssec-3.127.0.tgz" + integrity sha512-R5A13EvdYPdYD2Tq9eW5jqIdscyZlQykQXFEolBD2oi4pew7TZpc/5aazZC0zo9YKJ29qiUR1P4NvjcFJ7zFBg== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/middleware-stack@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-stack/-/middleware-stack-3.127.0.tgz" + integrity sha512-S1IoUE5o1vCmjsF5nIE8zlItNOM1UE+lhmZeigF7knXJ9+a6ewMB6POAj/s4eoi0wcn0eSnAGsqJCWMSUjOPLA== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/middleware-user-agent@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.127.0.tgz" + integrity sha512-CHxgswoOzdkOEoIq7Oyob3Sx/4FYUv6BhUesAX7MNshaDDsTQPbSWjw5bqZDiL/gO+X/34fvqCVVpVD2GvxW/g== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/node-config-provider@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/node-config-provider/-/node-config-provider-3.127.0.tgz" + integrity sha512-bAHkASMhLZHT1yv2TX6OJGFV9Lc3t1gKfTMEKdXM2O2YhGfSx9A/qLeJm79oDfnILWQtSS2NicxlRDI2lYGf4g== + dependencies: + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/shared-ini-file-loader" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/node-http-handler@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/node-http-handler/-/node-http-handler-3.127.0.tgz" + integrity sha512-pyMKvheK8eDwWLgYIRsWy8wiyhsbYYcqkZQs3Eh6upI4E8iCY7eMmhWvHYCibvsO+UjsOwa4cAMOfwnv/Z9s8A== + dependencies: + "@aws-sdk/abort-controller" "3.127.0" + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/querystring-builder" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/property-provider@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/property-provider/-/property-provider-3.127.0.tgz" + integrity sha512-JxenxlTEkWfLrtJqIjaXaJzAVQbbscoCb5bNjmdud07ESLVfWRKJx2nAJdecHKYp2M5NQyqBuFhQ1ELSFYQKCA== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/protocol-http@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/protocol-http/-/protocol-http-3.127.0.tgz" + integrity sha512-UG83PVuKX40wilG2uRU0Fvz4OY8Bt+bSPOG776DFjwIXYzK7BwpJm9H2XI2HLhS5WxrJHhwrLBRgW6UiykMnFw== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/querystring-builder@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/querystring-builder/-/querystring-builder-3.127.0.tgz" + integrity sha512-tsoyp4lLPsASPDYWsezGAHD8VJsZbjUNATNAzTCFdH6p+4SKBK83Q5kfXCzxt13M+l3oKbxxIWLvS0kVQFyltQ== + dependencies: + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-uri-escape" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/querystring-parser@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/querystring-parser/-/querystring-parser-3.127.0.tgz" + integrity sha512-Vn/Dv+PqUSepp/DzLqq0LJJD8HdPefJCnLbO5WcHCARHSGlyGlZUFEM45k/oEHpTvgMXj/ORaP3A+tLwLu0AmA== + dependencies: + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/service-error-classification@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/service-error-classification/-/service-error-classification-3.127.0.tgz" + integrity sha512-wjZY9rnlA8SPrICUumTYicEKtK4/yKB62iadUk66hxe8MrH8JhuHH2NqIad0Pt/bK/YtNVhd3yb4pRapOeY5qQ== + +"@aws-sdk/shared-ini-file-loader@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/shared-ini-file-loader/-/shared-ini-file-loader-3.127.0.tgz" + integrity sha512-S3Nn4KRTqoJsB/TbRZSWBBUrkckNMR0Juqz7bOB+wupVvddKP6IcpspSC/GX9zgJjVMV8iGisZ6AUsYsC5r+cA== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/signature-v4-multi-region@3.130.0": + version "3.130.0" + resolved "https://registry.npmjs.org/@aws-sdk/signature-v4-multi-region/-/signature-v4-multi-region-3.130.0.tgz" + integrity sha512-ZRRoPRoCVdkGDtjuog81pqHsSLfnXK6ELrWm4Dq8xdcHQGbEDNdYmeXARXG9yPAO42x9yIJXHNutMz5Y/P64cw== + dependencies: + "@aws-sdk/protocol-http" "3.127.0" + "@aws-sdk/signature-v4" "3.130.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-arn-parser" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/signature-v4@3.130.0": + version "3.130.0" + resolved "https://registry.npmjs.org/@aws-sdk/signature-v4/-/signature-v4-3.130.0.tgz" + integrity sha512-g5G1a1NHL2uOoFfC2zQdZcj+wbjgBQPkx6xGdtqNKf9v2kS0n6ap5JUGEaqWE02lUlmWHsoMsS73hXtzwXaBRQ== + dependencies: + "@aws-sdk/is-array-buffer" "3.55.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-hex-encoding" "3.109.0" + "@aws-sdk/util-middleware" "3.127.0" + "@aws-sdk/util-uri-escape" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/smithy-client@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/smithy-client/-/smithy-client-3.137.0.tgz" + integrity sha512-YAuWiSzHJGV9jQCjmcBWxbWRoq/3INEpdtfAdpR+X+sEZaRJESDGPt4or7WbQ9Tmbd/uZ0uQLYIed/NDSyJLLQ== + dependencies: + "@aws-sdk/middleware-stack" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/types@3.127.0", "@aws-sdk/types@^3.1.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/types/-/types-3.127.0.tgz" + integrity sha512-e0wtx2IkOl7rwfKfLH5pPTzQ+d45V7b1WrjeL0WDI8kOu6w+sXmhNxI6uM2kf0k4NiTLN84lW290AEWupey9Og== + +"@aws-sdk/url-parser@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/url-parser/-/url-parser-3.127.0.tgz" + integrity sha512-njZ7zn41JHRpNfr3BCesVXCLZE0zcWSfEdtRV0ICw0cU1FgYcKELSuY9+gLUB4ci6uc7gq7mPE8+w30FcM4QeA== + dependencies: + "@aws-sdk/querystring-parser" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/util-arn-parser@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-arn-parser/-/util-arn-parser-3.55.0.tgz" + integrity sha512-76KJxp4MRWufHYWys7DFl64znr5yeJ3AIQNAPCKKw1sP0hzO7p6Kx0PaJnw9x+CPSzOrT4NbuApL6/srYhKDGg== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-base64-browser@3.109.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-base64-browser/-/util-base64-browser-3.109.0.tgz" + integrity sha512-lAZ6fyDGiRLaIsKT9qh7P9FGuNyZ4gAbr1YOSQk/5mHtaTuUvxlPptZuInNM/0MPQm6lpcot00D8IWTucn4PbA== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-base64-node@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-base64-node/-/util-base64-node-3.55.0.tgz" + integrity sha512-UQ/ZuNoAc8CFMpSiRYmevaTsuRKzLwulZTnM8LNlIt9Wx1tpNvqp80cfvVj7yySKROtEi20wq29h31dZf1eYNQ== + dependencies: + "@aws-sdk/util-buffer-from" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/util-body-length-browser@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-body-length-browser/-/util-body-length-browser-3.55.0.tgz" + integrity sha512-Ei2OCzXQw5N6ZkTMZbamUzc1z+z1R1Ja5tMEagz5BxuX4vWdBObT+uGlSzL8yvTbjoPjnxWA2aXyEqaUP3JS8Q== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-body-length-node@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-body-length-node/-/util-body-length-node-3.55.0.tgz" + integrity sha512-lU1d4I+9wJwydduXs0SxSfd+mHKjxeyd39VwOv6i2KSwWkPbji9UQqpflKLKw+r45jL7+xU/zfeTUg5Tt/3Gew== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-buffer-from@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-buffer-from/-/util-buffer-from-3.55.0.tgz" + integrity sha512-uVzKG1UgvnV7XX2FPTylBujYMKBPBaq/qFBxfl0LVNfrty7YjpfieQxAe6yRLD+T0Kir/WDQwGvYC+tOYG3IGA== + dependencies: + "@aws-sdk/is-array-buffer" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/util-config-provider@3.109.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-config-provider/-/util-config-provider-3.109.0.tgz" + integrity sha512-GrAZl/aBv0A28LkyNyq8SPJ5fmViCwz80fWLMeWx/6q5AbivuILogjlWwEZSvZ9zrlHOcFC0+AnCa5pQrjaslw== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-defaults-mode-browser@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-defaults-mode-browser/-/util-defaults-mode-browser-3.137.0.tgz" + integrity sha512-9f5045wqPAcGLKIAXzZKHE2n42ilGo/g4rLSS09OXx9CoFT4lVdqZPqBqh/prDUMrqXge9FK3EH2VId7L5GpEQ== + dependencies: + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/types" "3.127.0" + bowser "^2.11.0" + tslib "^2.3.1" + +"@aws-sdk/util-defaults-mode-node@3.137.0": + version "3.137.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-defaults-mode-node/-/util-defaults-mode-node-3.137.0.tgz" + integrity sha512-CvMpemcsOkoMEz0iALamyQBt1rHx98NvF/cay019F8m+umD03I8CclDugy/13DqESWfsVxn91lZY/DOnO+si7A== + dependencies: + "@aws-sdk/config-resolver" "3.130.0" + "@aws-sdk/credential-provider-imds" "3.127.0" + "@aws-sdk/node-config-provider" "3.127.0" + "@aws-sdk/property-provider" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/util-hex-encoding@3.109.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-hex-encoding/-/util-hex-encoding-3.109.0.tgz" + integrity sha512-s8CgTNrn3cLkrdiohfxLuOYPCanzvHn/aH5RW6DaMoeQiG5Hl9QUiP/WtdQ9QQx3xvpQFpmvxIaSBwSgFNLQxA== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-locate-window@^3.0.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-locate-window/-/util-locate-window-3.55.0.tgz" + integrity sha512-0sPmK2JaJE2BbTcnvybzob/VrFKCXKfN4CUKcvn0yGg/me7Bz+vtzQRB3Xp+YSx+7OtWxzv63wsvHoAnXvgxgg== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-middleware@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-middleware/-/util-middleware-3.127.0.tgz" + integrity sha512-EwAPPed9TNqh+Wov2VStLn2NuJ/Wyt7IkZCbCsBuSNp3BFZ1V4gfwTjqtKCtB2LQgQ48MTgWgNCvrH0zjCSPGg== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-stream-browser@3.131.0": + version "3.131.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-stream-browser/-/util-stream-browser-3.131.0.tgz" + integrity sha512-1YFbBPDu+elIgp8z1woUfT7zM+2PAvgJiw6ljDBuAlJzsP5xMhwk0X9e+8aQ+Qe4XftA0e7y/PH0gqvjNgCx2A== + dependencies: + "@aws-sdk/fetch-http-handler" "3.131.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-base64-browser" "3.109.0" + "@aws-sdk/util-hex-encoding" "3.109.0" + "@aws-sdk/util-utf8-browser" "3.109.0" + tslib "^2.3.1" + +"@aws-sdk/util-stream-node@3.129.0": + version "3.129.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-stream-node/-/util-stream-node-3.129.0.tgz" + integrity sha512-1iWqsWvVXyP4JLPPPs8tBZKyzs7D5e7KctXuCtIjI+cnGOCeVLL+X4L/7KDZfV7sI2D6vONtIoTnUjMl5V/kEg== + dependencies: + "@aws-sdk/node-http-handler" "3.127.0" + "@aws-sdk/types" "3.127.0" + "@aws-sdk/util-buffer-from" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/util-uri-escape@3.55.0": + version "3.55.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-uri-escape/-/util-uri-escape-3.55.0.tgz" + integrity sha512-mmdDLUpFCN2nkfwlLdOM54lTD528GiGSPN1qb8XtGLgZsJUmg3uJSFIN2lPeSbEwJB3NFjVas/rnQC48i7mV8w== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-user-agent-browser@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.127.0.tgz" + integrity sha512-uO2oHmJswuYKJS+GiMdYI8izhpC9M7/jFFvnAmLlTEVwpEi1VX9KePAOF+u5AaBC2kzITo/7dg141XfRHZloIQ== + dependencies: + "@aws-sdk/types" "3.127.0" + bowser "^2.11.0" + tslib "^2.3.1" + +"@aws-sdk/util-user-agent-node@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.127.0.tgz" + integrity sha512-3P/M4ZDD2qMeeoCk7TE/Mw7cG5IjB87F6BP8nI8/oHuaz7j6fsI7D49SNpyjl8JApRynZ122Ad6hwQwRj3isYw== + dependencies: + "@aws-sdk/node-config-provider" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/util-utf8-browser@3.109.0", "@aws-sdk/util-utf8-browser@^3.0.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.109.0.tgz" + integrity sha512-FmcGSz0v7Bqpl1SE8G1Gc0CtDpug+rvqNCG/szn86JApD/f5x8oByjbEiAyTU2ZH2VevUntx6EW68ulHyH+x+w== + dependencies: + tslib "^2.3.1" + +"@aws-sdk/util-utf8-node@3.109.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-utf8-node/-/util-utf8-node-3.109.0.tgz" + integrity sha512-Ti/ZBdvz2eSTElsucjzNmzpyg2MwfD1rXmxD0hZuIF8bPON/0+sZYnWd5CbDw9kgmhy28dmKue086tbZ1G0iLQ== + dependencies: + "@aws-sdk/util-buffer-from" "3.55.0" + tslib "^2.3.1" + +"@aws-sdk/util-waiter@3.127.0": + version "3.127.0" + resolved "https://registry.npmjs.org/@aws-sdk/util-waiter/-/util-waiter-3.127.0.tgz" + integrity sha512-E5qrRpBJS8dmClqSDW1pWVMKzCG/mxabG6jVUtlW/WLHnl/znxGaOQc6tnnwKik0nEq/4DpT9fEfPUz9JiLrkw== + dependencies: + "@aws-sdk/abort-controller" "3.127.0" + "@aws-sdk/types" "3.127.0" + tslib "^2.3.1" + +"@aws-sdk/xml-builder@3.109.0": + version "3.109.0" + resolved "https://registry.npmjs.org/@aws-sdk/xml-builder/-/xml-builder-3.109.0.tgz" + integrity sha512-+aAXynnrqya1Eukz4Gxch4xIXCZolIMWGD4Ll/Q5yXT5uAjGh2HQWd9J0LWE+gYChpWetZbAVYZ3cEJ6F+SpZA== + dependencies: + tslib "^2.3.1" + +"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz" + integrity sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q== + dependencies: + "@babel/highlight" "^7.18.6" + +"@babel/compat-data@^7.13.11", "@babel/compat-data@^7.18.8": + version "7.18.8" + resolved "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.8.tgz" + integrity sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ== + +"@babel/core@^7.11.6", "@babel/core@^7.12.3", "@babel/core@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz" + integrity sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g== + dependencies: + "@ampproject/remapping" "^2.1.0" + "@babel/code-frame" "^7.18.6" + "@babel/generator" "^7.18.9" + "@babel/helper-compilation-targets" "^7.18.9" + "@babel/helper-module-transforms" "^7.18.9" + "@babel/helpers" "^7.18.9" + "@babel/parser" "^7.18.9" + "@babel/template" "^7.18.6" + "@babel/traverse" "^7.18.9" + "@babel/types" "^7.18.9" + convert-source-map "^1.7.0" + debug "^4.1.0" + gensync "^1.0.0-beta.2" + json5 "^2.2.1" + semver "^6.3.0" + +"@babel/generator@^7.18.9", "@babel/generator@^7.7.2": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/generator/-/generator-7.18.9.tgz" + integrity sha512-wt5Naw6lJrL1/SGkipMiFxJjtyczUWTP38deiP1PO60HsBjDeKk08CGC3S8iVuvf0FmTdgKwU1KIXzSKL1G0Ug== + dependencies: + "@babel/types" "^7.18.9" + "@jridgewell/gen-mapping" "^0.3.2" + jsesc "^2.5.1" + +"@babel/helper-annotate-as-pure@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz" + integrity sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-builder-binary-assignment-operator-visitor@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.6.tgz" + integrity sha512-KT10c1oWEpmrIRYnthbzHgoOf6B+Xd6a5yhdbNtdhtG7aO1or5HViuf1TQR36xY/QprXA5nvxO6nAjhJ4y38jw== + dependencies: + "@babel/helper-explode-assignable-expression" "^7.18.6" + "@babel/types" "^7.18.6" + +"@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.9.tgz" + integrity sha512-tzLCyVmqUiFlcFoAPLA/gL9TeYrF61VLNtb+hvkuVaB5SUjW7jcfrglBIX1vUIoT7CLP3bBlIMeyEsIl2eFQNg== + dependencies: + "@babel/compat-data" "^7.18.8" + "@babel/helper-validator-option" "^7.18.6" + browserslist "^4.20.2" + semver "^6.3.0" + +"@babel/helper-create-class-features-plugin@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.6.tgz" + integrity sha512-YfDzdnoxHGV8CzqHGyCbFvXg5QESPFkXlHtvdCkesLjjVMT2Adxe4FGUR5ChIb3DxSaXO12iIOCWoXdsUVwnqw== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-environment-visitor" "^7.18.6" + "@babel/helper-function-name" "^7.18.6" + "@babel/helper-member-expression-to-functions" "^7.18.6" + "@babel/helper-optimise-call-expression" "^7.18.6" + "@babel/helper-replace-supers" "^7.18.6" + "@babel/helper-split-export-declaration" "^7.18.6" + +"@babel/helper-create-regexp-features-plugin@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz" + integrity sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + regexpu-core "^5.1.0" + +"@babel/helper-define-polyfill-provider@^0.3.1": + version "0.3.1" + resolved "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.1.tgz" + integrity sha512-J9hGMpJQmtWmj46B3kBHmL38UhJGhYX7eqkcq+2gsstyYt341HmPeWspihX43yVRA0mS+8GGk2Gckc7bY/HCmA== + dependencies: + "@babel/helper-compilation-targets" "^7.13.0" + "@babel/helper-module-imports" "^7.12.13" + "@babel/helper-plugin-utils" "^7.13.0" + "@babel/traverse" "^7.13.0" + debug "^4.1.1" + lodash.debounce "^4.0.8" + resolve "^1.14.2" + semver "^6.1.2" + +"@babel/helper-environment-visitor@^7.18.6", "@babel/helper-environment-visitor@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz" + integrity sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg== + +"@babel/helper-explode-assignable-expression@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz" + integrity sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-function-name@^7.18.6", "@babel/helper-function-name@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.9.tgz" + integrity sha512-fJgWlZt7nxGksJS9a0XdSaI4XvpExnNIgRP+rVefWh5U7BL8pPuir6SJUmFKRfjWQ51OtWSzwOxhaH/EBWWc0A== + dependencies: + "@babel/template" "^7.18.6" + "@babel/types" "^7.18.9" + +"@babel/helper-hoist-variables@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz" + integrity sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-member-expression-to-functions@^7.18.6", "@babel/helper-member-expression-to-functions@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz" + integrity sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg== + dependencies: + "@babel/types" "^7.18.9" + +"@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz" + integrity sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-module-transforms@^7.18.6", "@babel/helper-module-transforms@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.9.tgz" + integrity sha512-KYNqY0ICwfv19b31XzvmI/mfcylOzbLtowkw+mfvGPAQ3kfCnMLYbED3YecL5tPd8nAYFQFAd6JHp2LxZk/J1g== + dependencies: + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-module-imports" "^7.18.6" + "@babel/helper-simple-access" "^7.18.6" + "@babel/helper-split-export-declaration" "^7.18.6" + "@babel/helper-validator-identifier" "^7.18.6" + "@babel/template" "^7.18.6" + "@babel/traverse" "^7.18.9" + "@babel/types" "^7.18.9" + +"@babel/helper-optimise-call-expression@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz" + integrity sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.13.0", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.18.9", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.9.tgz" + integrity sha512-aBXPT3bmtLryXaoJLyYPXPlSD4p1ld9aYeR+sJNOZjJJGiOpb+fKfh3NkcCu7J54nUJwCERPBExCCpyCOHnu/w== + +"@babel/helper-remap-async-to-generator@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.6.tgz" + integrity sha512-z5wbmV55TveUPZlCLZvxWHtrjuJd+8inFhk7DG0WW87/oJuGDcjDiu7HIvGcpf5464L6xKCg3vNkmlVVz9hwyQ== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-environment-visitor" "^7.18.6" + "@babel/helper-wrap-function" "^7.18.6" + "@babel/types" "^7.18.6" + +"@babel/helper-replace-supers@^7.18.6", "@babel/helper-replace-supers@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.9.tgz" + integrity sha512-dNsWibVI4lNT6HiuOIBr1oyxo40HvIVmbwPUm3XZ7wMh4k2WxrxTqZwSqw/eEmXDS9np0ey5M2bz9tBmO9c+YQ== + dependencies: + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-member-expression-to-functions" "^7.18.9" + "@babel/helper-optimise-call-expression" "^7.18.6" + "@babel/traverse" "^7.18.9" + "@babel/types" "^7.18.9" + +"@babel/helper-simple-access@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz" + integrity sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-skip-transparent-expression-wrappers@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.9.tgz" + integrity sha512-imytd2gHi3cJPsybLRbmFrF7u5BIEuI2cNheyKi3/iOBC63kNn3q8Crn2xVuESli0aM4KYsyEqKyS7lFL8YVtw== + dependencies: + "@babel/types" "^7.18.9" + +"@babel/helper-split-export-declaration@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz" + integrity sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-validator-identifier@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz" + integrity sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g== + +"@babel/helper-validator-option@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz" + integrity sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw== + +"@babel/helper-wrap-function@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.6.tgz" + integrity sha512-I5/LZfozwMNbwr/b1vhhuYD+J/mU+gfGAj5td7l5Rv9WYmH6i3Om69WGKNmlIpsVW/mF6O5bvTKbvDQZVgjqOw== + dependencies: + "@babel/helper-function-name" "^7.18.6" + "@babel/template" "^7.18.6" + "@babel/traverse" "^7.18.6" + "@babel/types" "^7.18.6" + +"@babel/helpers@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/helpers/-/helpers-7.18.9.tgz" + integrity sha512-Jf5a+rbrLoR4eNdUmnFu8cN5eNJT6qdTdOg5IHIzq87WwyRw9PwguLFOWYgktN/60IP4fgDUawJvs7PjQIzELQ== + dependencies: + "@babel/template" "^7.18.6" + "@babel/traverse" "^7.18.9" + "@babel/types" "^7.18.9" + +"@babel/highlight@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz" + integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g== + dependencies: + "@babel/helper-validator-identifier" "^7.18.6" + chalk "^2.0.0" + js-tokens "^4.0.0" + +"@babel/parser@^7.1.0", "@babel/parser@^7.14.7", "@babel/parser@^7.18.6", "@babel/parser@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/parser/-/parser-7.18.9.tgz" + integrity sha512-9uJveS9eY9DJ0t64YbIBZICtJy8a5QrDEVdiLCG97fVLpDTpGX7t8mMSb6OWw6Lrnjqj4O8zwjELX3dhoMgiBg== + +"@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz" + integrity sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz" + integrity sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" + "@babel/plugin-proposal-optional-chaining" "^7.18.9" + +"@babel/plugin-proposal-async-generator-functions@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz" + integrity sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w== + dependencies: + "@babel/helper-environment-visitor" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/helper-remap-async-to-generator" "^7.18.6" + "@babel/plugin-syntax-async-generators" "^7.8.4" + +"@babel/plugin-proposal-class-properties@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz" + integrity sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-proposal-class-static-block@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz" + integrity sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-class-static-block" "^7.14.5" + +"@babel/plugin-proposal-dynamic-import@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz" + integrity sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + +"@babel/plugin-proposal-export-namespace-from@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz" + integrity sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + +"@babel/plugin-proposal-json-strings@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz" + integrity sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-json-strings" "^7.8.3" + +"@babel/plugin-proposal-logical-assignment-operators@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz" + integrity sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + +"@babel/plugin-proposal-nullish-coalescing-operator@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz" + integrity sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + +"@babel/plugin-proposal-numeric-separator@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz" + integrity sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + +"@babel/plugin-proposal-object-rest-spread@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.9.tgz" + integrity sha512-kDDHQ5rflIeY5xl69CEqGEZ0KY369ehsCIEbTGb4siHG5BE9sga/T0r0OUwyZNLMmZE79E1kbsqAjwFCW4ds6Q== + dependencies: + "@babel/compat-data" "^7.18.8" + "@babel/helper-compilation-targets" "^7.18.9" + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-transform-parameters" "^7.18.8" + +"@babel/plugin-proposal-optional-catch-binding@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz" + integrity sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + +"@babel/plugin-proposal-optional-chaining@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz" + integrity sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + +"@babel/plugin-proposal-private-methods@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz" + integrity sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-proposal-private-property-in-object@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz" + integrity sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-private-property-in-object" "^7.14.5" + +"@babel/plugin-proposal-unicode-property-regex@^7.18.6", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz" + integrity sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-syntax-async-generators@^7.8.4": + version "7.8.4" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz" + integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-bigint@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz" + integrity sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-class-properties@^7.12.13", "@babel/plugin-syntax-class-properties@^7.8.3": + version "7.12.13" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz" + integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-class-static-block@^7.14.5": + version "7.14.5" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz" + integrity sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw== + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-dynamic-import@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz" + integrity sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-export-namespace-from@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz" + integrity sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q== + dependencies: + "@babel/helper-plugin-utils" "^7.8.3" + +"@babel/plugin-syntax-import-assertions@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz" + integrity sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-syntax-import-meta@^7.8.3": + version "7.10.4" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz" + integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-json-strings@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz" + integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-logical-assignment-operators@^7.10.4", "@babel/plugin-syntax-logical-assignment-operators@^7.8.3": + version "7.10.4" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz" + integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz" + integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-numeric-separator@^7.10.4", "@babel/plugin-syntax-numeric-separator@^7.8.3": + version "7.10.4" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz" + integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-object-rest-spread@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz" + integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-catch-binding@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz" + integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-chaining@^7.8.3": + version "7.8.3" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz" + integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-private-property-in-object@^7.14.5": + version "7.14.5" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz" + integrity sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg== + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-top-level-await@^7.14.5", "@babel/plugin-syntax-top-level-await@^7.8.3": + version "7.14.5" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz" + integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw== + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-typescript@^7.18.6", "@babel/plugin-syntax-typescript@^7.7.2": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.18.6.tgz" + integrity sha512-mAWAuq4rvOepWCBid55JuRNvpTNf2UGVgoz4JV0fXEKolsVZDzsa4NqCef758WZJj/GDu0gVGItjKFiClTAmZA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-arrow-functions@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz" + integrity sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-async-to-generator@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz" + integrity sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag== + dependencies: + "@babel/helper-module-imports" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/helper-remap-async-to-generator" "^7.18.6" + +"@babel/plugin-transform-block-scoped-functions@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz" + integrity sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-block-scoping@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.9.tgz" + integrity sha512-5sDIJRV1KtQVEbt/EIBwGy4T01uYIo4KRB3VUqzkhrAIOGx7AoctL9+Ux88btY0zXdDyPJ9mW+bg+v+XEkGmtw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-classes@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.9.tgz" + integrity sha512-EkRQxsxoytpTlKJmSPYrsOMjCILacAjtSVkd4gChEe2kXjFCun3yohhW5I7plXJhCemM0gKsaGMcO8tinvCA5g== + dependencies: + "@babel/helper-annotate-as-pure" "^7.18.6" + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-function-name" "^7.18.9" + "@babel/helper-optimise-call-expression" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/helper-replace-supers" "^7.18.9" + "@babel/helper-split-export-declaration" "^7.18.6" + globals "^11.1.0" + +"@babel/plugin-transform-computed-properties@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz" + integrity sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-destructuring@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.9.tgz" + integrity sha512-p5VCYNddPLkZTq4XymQIaIfZNJwT9YsjkPOhkVEqt6QIpQFZVM9IltqqYpOEkJoN1DPznmxUDyZ5CTZs/ZCuHA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-dotall-regex@^7.18.6", "@babel/plugin-transform-dotall-regex@^7.4.4": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz" + integrity sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-duplicate-keys@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz" + integrity sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-exponentiation-operator@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz" + integrity sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw== + dependencies: + "@babel/helper-builder-binary-assignment-operator-visitor" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-for-of@^7.18.8": + version "7.18.8" + resolved "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz" + integrity sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-function-name@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz" + integrity sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ== + dependencies: + "@babel/helper-compilation-targets" "^7.18.9" + "@babel/helper-function-name" "^7.18.9" + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-literals@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz" + integrity sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-member-expression-literals@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz" + integrity sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-modules-amd@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz" + integrity sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg== + dependencies: + "@babel/helper-module-transforms" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + babel-plugin-dynamic-import-node "^2.3.3" + +"@babel/plugin-transform-modules-commonjs@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz" + integrity sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q== + dependencies: + "@babel/helper-module-transforms" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/helper-simple-access" "^7.18.6" + babel-plugin-dynamic-import-node "^2.3.3" + +"@babel/plugin-transform-modules-systemjs@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.9.tgz" + integrity sha512-zY/VSIbbqtoRoJKo2cDTewL364jSlZGvn0LKOf9ntbfxOvjfmyrdtEEOAdswOswhZEb8UH3jDkCKHd1sPgsS0A== + dependencies: + "@babel/helper-hoist-variables" "^7.18.6" + "@babel/helper-module-transforms" "^7.18.9" + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/helper-validator-identifier" "^7.18.6" + babel-plugin-dynamic-import-node "^2.3.3" + +"@babel/plugin-transform-modules-umd@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz" + integrity sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ== + dependencies: + "@babel/helper-module-transforms" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-named-capturing-groups-regex@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz" + integrity sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-new-target@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz" + integrity sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-object-super@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz" + integrity sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/helper-replace-supers" "^7.18.6" + +"@babel/plugin-transform-parameters@^7.18.8": + version "7.18.8" + resolved "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.8.tgz" + integrity sha512-ivfbE3X2Ss+Fj8nnXvKJS6sjRG4gzwPMsP+taZC+ZzEGjAYlvENixmt1sZ5Ca6tWls+BlKSGKPJ6OOXvXCbkFg== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-property-literals@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz" + integrity sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-regenerator@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz" + integrity sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + regenerator-transform "^0.15.0" + +"@babel/plugin-transform-reserved-words@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz" + integrity sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-shorthand-properties@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz" + integrity sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-spread@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.9.tgz" + integrity sha512-39Q814wyoOPtIB/qGopNIL9xDChOE1pNU0ZY5dO0owhiVt/5kFm4li+/bBtwc7QotG0u5EPzqhZdjMtmqBqyQA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" + +"@babel/plugin-transform-sticky-regex@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz" + integrity sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-template-literals@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz" + integrity sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-typeof-symbol@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz" + integrity sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.9" + +"@babel/plugin-transform-typescript@^7.18.6": + version "7.18.8" + resolved "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.18.8.tgz" + integrity sha512-p2xM8HI83UObjsZGofMV/EdYjamsDm6MoN3hXPYIT0+gxIoopE+B7rPYKAxfrz9K9PK7JafTTjqYC6qipLExYA== + dependencies: + "@babel/helper-create-class-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/plugin-syntax-typescript" "^7.18.6" + +"@babel/plugin-transform-unicode-escapes@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz" + integrity sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/plugin-transform-unicode-regex@^7.18.6": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz" + integrity sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA== + dependencies: + "@babel/helper-create-regexp-features-plugin" "^7.18.6" + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/preset-env@^7.18.9": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.9.tgz" + integrity sha512-75pt/q95cMIHWssYtyfjVlvI+QEZQThQbKvR9xH+F/Agtw/s4Wfc2V9Bwd/P39VtixB7oWxGdH4GteTTwYJWMg== + dependencies: + "@babel/compat-data" "^7.18.8" + "@babel/helper-compilation-targets" "^7.18.9" + "@babel/helper-plugin-utils" "^7.18.9" + "@babel/helper-validator-option" "^7.18.6" + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression" "^7.18.6" + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining" "^7.18.9" + "@babel/plugin-proposal-async-generator-functions" "^7.18.6" + "@babel/plugin-proposal-class-properties" "^7.18.6" + "@babel/plugin-proposal-class-static-block" "^7.18.6" + "@babel/plugin-proposal-dynamic-import" "^7.18.6" + "@babel/plugin-proposal-export-namespace-from" "^7.18.9" + "@babel/plugin-proposal-json-strings" "^7.18.6" + "@babel/plugin-proposal-logical-assignment-operators" "^7.18.9" + "@babel/plugin-proposal-nullish-coalescing-operator" "^7.18.6" + "@babel/plugin-proposal-numeric-separator" "^7.18.6" + "@babel/plugin-proposal-object-rest-spread" "^7.18.9" + "@babel/plugin-proposal-optional-catch-binding" "^7.18.6" + "@babel/plugin-proposal-optional-chaining" "^7.18.9" + "@babel/plugin-proposal-private-methods" "^7.18.6" + "@babel/plugin-proposal-private-property-in-object" "^7.18.6" + "@babel/plugin-proposal-unicode-property-regex" "^7.18.6" + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-class-properties" "^7.12.13" + "@babel/plugin-syntax-class-static-block" "^7.14.5" + "@babel/plugin-syntax-dynamic-import" "^7.8.3" + "@babel/plugin-syntax-export-namespace-from" "^7.8.3" + "@babel/plugin-syntax-import-assertions" "^7.18.6" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.10.4" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-private-property-in-object" "^7.14.5" + "@babel/plugin-syntax-top-level-await" "^7.14.5" + "@babel/plugin-transform-arrow-functions" "^7.18.6" + "@babel/plugin-transform-async-to-generator" "^7.18.6" + "@babel/plugin-transform-block-scoped-functions" "^7.18.6" + "@babel/plugin-transform-block-scoping" "^7.18.9" + "@babel/plugin-transform-classes" "^7.18.9" + "@babel/plugin-transform-computed-properties" "^7.18.9" + "@babel/plugin-transform-destructuring" "^7.18.9" + "@babel/plugin-transform-dotall-regex" "^7.18.6" + "@babel/plugin-transform-duplicate-keys" "^7.18.9" + "@babel/plugin-transform-exponentiation-operator" "^7.18.6" + "@babel/plugin-transform-for-of" "^7.18.8" + "@babel/plugin-transform-function-name" "^7.18.9" + "@babel/plugin-transform-literals" "^7.18.9" + "@babel/plugin-transform-member-expression-literals" "^7.18.6" + "@babel/plugin-transform-modules-amd" "^7.18.6" + "@babel/plugin-transform-modules-commonjs" "^7.18.6" + "@babel/plugin-transform-modules-systemjs" "^7.18.9" + "@babel/plugin-transform-modules-umd" "^7.18.6" + "@babel/plugin-transform-named-capturing-groups-regex" "^7.18.6" + "@babel/plugin-transform-new-target" "^7.18.6" + "@babel/plugin-transform-object-super" "^7.18.6" + "@babel/plugin-transform-parameters" "^7.18.8" + "@babel/plugin-transform-property-literals" "^7.18.6" + "@babel/plugin-transform-regenerator" "^7.18.6" + "@babel/plugin-transform-reserved-words" "^7.18.6" + "@babel/plugin-transform-shorthand-properties" "^7.18.6" + "@babel/plugin-transform-spread" "^7.18.9" + "@babel/plugin-transform-sticky-regex" "^7.18.6" + "@babel/plugin-transform-template-literals" "^7.18.9" + "@babel/plugin-transform-typeof-symbol" "^7.18.9" + "@babel/plugin-transform-unicode-escapes" "^7.18.6" + "@babel/plugin-transform-unicode-regex" "^7.18.6" + "@babel/preset-modules" "^0.1.5" + "@babel/types" "^7.18.9" + babel-plugin-polyfill-corejs2 "^0.3.1" + babel-plugin-polyfill-corejs3 "^0.5.2" + babel-plugin-polyfill-regenerator "^0.3.1" + core-js-compat "^3.22.1" + semver "^6.3.0" + +"@babel/preset-modules@^0.1.5": + version "0.1.5" + resolved "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz" + integrity sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA== + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@babel/plugin-proposal-unicode-property-regex" "^7.4.4" + "@babel/plugin-transform-dotall-regex" "^7.4.4" + "@babel/types" "^7.4.4" + esutils "^2.0.2" + +"@babel/preset-typescript@^7.15.0": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.18.6.tgz" + integrity sha512-s9ik86kXBAnD760aybBucdpnLsAt0jK1xqJn2juOn9lkOvSHV60os5hxoVJsPzMQxvnUJFAlkont2DvvaYEBtQ== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + "@babel/helper-validator-option" "^7.18.6" + "@babel/plugin-transform-typescript" "^7.18.6" + +"@babel/runtime@^7.17.2", "@babel/runtime@^7.8.4": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.6.tgz" + integrity sha512-t9wi7/AW6XtKahAe20Yw0/mMljKq0B1r2fPdvaAdV/KPDZewFXdaaa6K7lxmZBZ8FBNpCiAT6iHPmd6QO9bKfQ== + dependencies: + regenerator-runtime "^0.13.4" + +"@babel/template@^7.18.6", "@babel/template@^7.3.3": + version "7.18.6" + resolved "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz" + integrity sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw== + dependencies: + "@babel/code-frame" "^7.18.6" + "@babel/parser" "^7.18.6" + "@babel/types" "^7.18.6" + +"@babel/traverse@^7.13.0", "@babel/traverse@^7.18.6", "@babel/traverse@^7.18.9", "@babel/traverse@^7.7.2": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.9.tgz" + integrity sha512-LcPAnujXGwBgv3/WHv01pHtb2tihcyW1XuL9wd7jqh1Z8AQkTd+QVjMrMijrln0T7ED3UXLIy36P9Ao7W75rYg== + dependencies: + "@babel/code-frame" "^7.18.6" + "@babel/generator" "^7.18.9" + "@babel/helper-environment-visitor" "^7.18.9" + "@babel/helper-function-name" "^7.18.9" + "@babel/helper-hoist-variables" "^7.18.6" + "@babel/helper-split-export-declaration" "^7.18.6" + "@babel/parser" "^7.18.9" + "@babel/types" "^7.18.9" + debug "^4.1.0" + globals "^11.1.0" + +"@babel/types@^7.0.0", "@babel/types@^7.18.6", "@babel/types@^7.18.9", "@babel/types@^7.3.0", "@babel/types@^7.3.3", "@babel/types@^7.4.4": + version "7.18.9" + resolved "https://registry.npmjs.org/@babel/types/-/types-7.18.9.tgz" + integrity sha512-WwMLAg2MvJmt/rKEVQBBhIVffMmnilX4oe0sRe7iPOHIGsqpruFHHdrfj4O1CMMtgMtCU4oPafZjDPCRgO57Wg== + dependencies: + "@babel/helper-validator-identifier" "^7.18.6" + to-fast-properties "^2.0.0" + +"@bcoe/v8-coverage@^0.2.3": + version "0.2.3" + resolved "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz" + integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== + +"@cspotcode/source-map-support@^0.8.0": + version "0.8.1" + resolved "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz" + integrity sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw== + dependencies: + "@jridgewell/trace-mapping" "0.3.9" + +"@gar/promisify@^1.0.1": + version "1.1.3" + resolved "https://registry.yarnpkg.com/@gar/promisify/-/promisify-1.1.3.tgz#555193ab2e3bb3b6adc3d551c9c030d9e860daf6" + integrity sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw== + +"@istanbuljs/load-nyc-config@^1.0.0": + version "1.1.0" + resolved "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz" + integrity sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ== + dependencies: + camelcase "^5.3.1" + find-up "^4.1.0" + get-package-type "^0.1.0" + js-yaml "^3.13.1" + resolve-from "^5.0.0" + +"@istanbuljs/schema@^0.1.2": + version "0.1.3" + resolved "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz" + integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA== + +"@jest/console@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/console/-/console-28.1.3.tgz" + integrity sha512-QPAkP5EwKdK/bxIr6C1I4Vs0rm2nHiANzj/Z5X2JQkrZo6IqvC4ldZ9K95tF0HdidhA8Bo6egxSzUFPYKcEXLw== + dependencies: + "@jest/types" "^28.1.3" + "@types/node" "*" + chalk "^4.0.0" + jest-message-util "^28.1.3" + jest-util "^28.1.3" + slash "^3.0.0" + +"@jest/core@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/core/-/core-28.1.3.tgz" + integrity sha512-CIKBrlaKOzA7YG19BEqCw3SLIsEwjZkeJzf5bdooVnW4bH5cktqe3JX+G2YV1aK5vP8N9na1IGWFzYaTp6k6NA== + dependencies: + "@jest/console" "^28.1.3" + "@jest/reporters" "^28.1.3" + "@jest/test-result" "^28.1.3" + "@jest/transform" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + ci-info "^3.2.0" + exit "^0.1.2" + graceful-fs "^4.2.9" + jest-changed-files "^28.1.3" + jest-config "^28.1.3" + jest-haste-map "^28.1.3" + jest-message-util "^28.1.3" + jest-regex-util "^28.0.2" + jest-resolve "^28.1.3" + jest-resolve-dependencies "^28.1.3" + jest-runner "^28.1.3" + jest-runtime "^28.1.3" + jest-snapshot "^28.1.3" + jest-util "^28.1.3" + jest-validate "^28.1.3" + jest-watcher "^28.1.3" + micromatch "^4.0.4" + pretty-format "^28.1.3" + rimraf "^3.0.0" + slash "^3.0.0" + strip-ansi "^6.0.0" + +"@jest/environment@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/environment/-/environment-28.1.3.tgz" + integrity sha512-1bf40cMFTEkKyEf585R9Iz1WayDjHoHqvts0XFYEqyKM3cFWDpeMoqKKTAF9LSYQModPUlh8FKptoM2YcMWAXA== + dependencies: + "@jest/fake-timers" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/node" "*" + jest-mock "^28.1.3" + +"@jest/expect-utils@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-28.1.3.tgz" + integrity sha512-wvbi9LUrHJLn3NlDW6wF2hvIMtd4JUl2QNVrjq+IBSHirgfrR3o9RnVtxzdEGO2n9JyIWwHnLfby5KzqBGg2YA== + dependencies: + jest-get-type "^28.0.2" + +"@jest/expect@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/expect/-/expect-28.1.3.tgz" + integrity sha512-lzc8CpUbSoE4dqT0U+g1qODQjBRHPpCPXissXD4mS9+sWQdmmpeJ9zSH1rS1HEkrsMN0fb7nKrJ9giAR1d3wBw== + dependencies: + expect "^28.1.3" + jest-snapshot "^28.1.3" + +"@jest/fake-timers@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-28.1.3.tgz" + integrity sha512-D/wOkL2POHv52h+ok5Oj/1gOG9HSywdoPtFsRCUmlCILXNn5eIWmcnd3DIiWlJnpGvQtmajqBP95Ei0EimxfLw== + dependencies: + "@jest/types" "^28.1.3" + "@sinonjs/fake-timers" "^9.1.2" + "@types/node" "*" + jest-message-util "^28.1.3" + jest-mock "^28.1.3" + jest-util "^28.1.3" + +"@jest/globals@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/globals/-/globals-28.1.3.tgz" + integrity sha512-XFU4P4phyryCXu1pbcqMO0GSQcYe1IsalYCDzRNyhetyeyxMcIxa11qPNDpVNLeretItNqEmYYQn1UYz/5x1NA== + dependencies: + "@jest/environment" "^28.1.3" + "@jest/expect" "^28.1.3" + "@jest/types" "^28.1.3" + +"@jest/reporters@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/reporters/-/reporters-28.1.3.tgz" + integrity sha512-JuAy7wkxQZVNU/V6g9xKzCGC5LVXx9FDcABKsSXp5MiKPEE2144a/vXTEDoyzjUpZKfVwp08Wqg5A4WfTMAzjg== + dependencies: + "@bcoe/v8-coverage" "^0.2.3" + "@jest/console" "^28.1.3" + "@jest/test-result" "^28.1.3" + "@jest/transform" "^28.1.3" + "@jest/types" "^28.1.3" + "@jridgewell/trace-mapping" "^0.3.13" + "@types/node" "*" + chalk "^4.0.0" + collect-v8-coverage "^1.0.0" + exit "^0.1.2" + glob "^7.1.3" + graceful-fs "^4.2.9" + istanbul-lib-coverage "^3.0.0" + istanbul-lib-instrument "^5.1.0" + istanbul-lib-report "^3.0.0" + istanbul-lib-source-maps "^4.0.0" + istanbul-reports "^3.1.3" + jest-message-util "^28.1.3" + jest-util "^28.1.3" + jest-worker "^28.1.3" + slash "^3.0.0" + string-length "^4.0.1" + strip-ansi "^6.0.0" + terminal-link "^2.0.0" + v8-to-istanbul "^9.0.1" + +"@jest/schemas@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/schemas/-/schemas-28.1.3.tgz" + integrity sha512-/l/VWsdt/aBXgjshLWOFyFt3IVdYypu5y2Wn2rOO1un6nkqIn8SLXzgIMYXFyYsRWDyF5EthmKJMIdJvk08grg== + dependencies: + "@sinclair/typebox" "^0.24.1" + +"@jest/source-map@^28.1.2": + version "28.1.2" + resolved "https://registry.npmjs.org/@jest/source-map/-/source-map-28.1.2.tgz" + integrity sha512-cV8Lx3BeStJb8ipPHnqVw/IM2VCMWO3crWZzYodSIkxXnRcXJipCdx1JCK0K5MsJJouZQTH73mzf4vgxRaH9ww== + dependencies: + "@jridgewell/trace-mapping" "^0.3.13" + callsites "^3.0.0" + graceful-fs "^4.2.9" + +"@jest/test-result@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/test-result/-/test-result-28.1.3.tgz" + integrity sha512-kZAkxnSE+FqE8YjW8gNuoVkkC9I7S1qmenl8sGcDOLropASP+BkcGKwhXoyqQuGOGeYY0y/ixjrd/iERpEXHNg== + dependencies: + "@jest/console" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/istanbul-lib-coverage" "^2.0.0" + collect-v8-coverage "^1.0.0" + +"@jest/test-sequencer@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-28.1.3.tgz" + integrity sha512-NIMPEqqa59MWnDi1kvXXpYbqsfQmSJsIbnd85mdVGkiDfQ9WQQTXOLsvISUfonmnBT+w85WEgneCigEEdHDFxw== + dependencies: + "@jest/test-result" "^28.1.3" + graceful-fs "^4.2.9" + jest-haste-map "^28.1.3" + slash "^3.0.0" + +"@jest/transform@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/transform/-/transform-28.1.3.tgz" + integrity sha512-u5dT5di+oFI6hfcLOHGTAfmUxFRrjK+vnaP0kkVow9Md/M7V/MxqQMOz/VV25UZO8pzeA9PjfTpOu6BDuwSPQA== + dependencies: + "@babel/core" "^7.11.6" + "@jest/types" "^28.1.3" + "@jridgewell/trace-mapping" "^0.3.13" + babel-plugin-istanbul "^6.1.1" + chalk "^4.0.0" + convert-source-map "^1.4.0" + fast-json-stable-stringify "^2.0.0" + graceful-fs "^4.2.9" + jest-haste-map "^28.1.3" + jest-regex-util "^28.0.2" + jest-util "^28.1.3" + micromatch "^4.0.4" + pirates "^4.0.4" + slash "^3.0.0" + write-file-atomic "^4.0.1" + +"@jest/types@^28.1.3": + version "28.1.3" + resolved "https://registry.npmjs.org/@jest/types/-/types-28.1.3.tgz" + integrity sha512-RyjiyMUZrKz/c+zlMFO1pm70DcIlST8AeWTkoUdZevew44wcNZQHsEVOiCVtgVnlFFD82FPaXycys58cf2muVQ== + dependencies: + "@jest/schemas" "^28.1.3" + "@types/istanbul-lib-coverage" "^2.0.0" + "@types/istanbul-reports" "^3.0.0" + "@types/node" "*" + "@types/yargs" "^17.0.8" + chalk "^4.0.0" + +"@jridgewell/gen-mapping@^0.1.0": + version "0.1.1" + resolved "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz" + integrity sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w== + dependencies: + "@jridgewell/set-array" "^1.0.0" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@jridgewell/gen-mapping@^0.3.2": + version "0.3.2" + resolved "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz" + integrity sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A== + dependencies: + "@jridgewell/set-array" "^1.0.1" + "@jridgewell/sourcemap-codec" "^1.4.10" + "@jridgewell/trace-mapping" "^0.3.9" + +"@jridgewell/resolve-uri@^3.0.3": + version "3.1.0" + resolved "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz" + integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w== + +"@jridgewell/set-array@^1.0.0", "@jridgewell/set-array@^1.0.1": + version "1.1.2" + resolved "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz" + integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw== + +"@jridgewell/sourcemap-codec@^1.4.10": + version "1.4.14" + resolved "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz" + integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw== + +"@jridgewell/trace-mapping@0.3.9": + version "0.3.9" + resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz" + integrity sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ== + dependencies: + "@jridgewell/resolve-uri" "^3.0.3" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@jridgewell/trace-mapping@^0.3.12", "@jridgewell/trace-mapping@^0.3.13", "@jridgewell/trace-mapping@^0.3.9": + version "0.3.14" + resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz" + integrity sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ== + dependencies: + "@jridgewell/resolve-uri" "^3.0.3" + "@jridgewell/sourcemap-codec" "^1.4.10" + +"@mapbox/node-pre-gyp@^1.0.0": + version "1.0.9" + resolved "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.9.tgz" + integrity sha512-aDF3S3rK9Q2gey/WAttUlISduDItz5BU3306M9Eyv6/oS40aMprnopshtlKTykxRNIBEZuRMaZAnbrQ4QtKGyw== + dependencies: + detect-libc "^2.0.0" + https-proxy-agent "^5.0.0" + make-dir "^3.1.0" + node-fetch "^2.6.7" + nopt "^5.0.0" + npmlog "^5.0.1" + rimraf "^3.0.2" + semver "^7.3.5" + tar "^6.1.11" + +"@npmcli/fs@^1.0.0": + version "1.1.1" + resolved "https://registry.yarnpkg.com/@npmcli/fs/-/fs-1.1.1.tgz#72f719fe935e687c56a4faecf3c03d06ba593257" + integrity sha512-8KG5RD0GVP4ydEzRn/I4BNDuxDtqVbOdm8675T49OIG/NGhaK0pjPX7ZcDlvKYbA+ulvVK3ztfcF4uBdOxuJbQ== + dependencies: + "@gar/promisify" "^1.0.1" + semver "^7.3.5" + +"@npmcli/move-file@^1.0.1": + version "1.1.2" + resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-1.1.2.tgz#1a82c3e372f7cae9253eb66d72543d6b8685c674" + integrity sha512-1SUf/Cg2GzGDyaf15aR9St9TWlb+XvbZXWpDx8YKs7MLzMH/BCeopv+y9vzrzgkfykCGuWOlSu3mZhj2+FQcrg== + dependencies: + mkdirp "^1.0.4" + rimraf "^3.0.2" + +"@ovos-media/ts-transform-paths@^1.7.18-1": + version "1.7.18-1" + resolved "https://registry.npmjs.org/@ovos-media/ts-transform-paths/-/ts-transform-paths-1.7.18-1.tgz" + integrity sha512-5uYtraYSWg1klaMYus3ouCOUUNzcI40pS0NCaw0PhoaPTimVfT3MV061ZLYR/4F14THqyofMjmCNcHgFrBX3AA== + dependencies: + "@zerollup/ts-helpers" "^1.7.18" + +"@sentry/core@7.10.0": + version "7.10.0" + resolved "https://registry.npmjs.org/@sentry/core/-/core-7.10.0.tgz" + integrity sha512-uq6oUXPH+6cjsEL5/j/xSW91mVrJo7knTqax7E5MDiA5j98BPK4budGiBiPO7GEB856QhA7N+pOO0lccii5QYQ== + dependencies: + "@sentry/hub" "7.10.0" + "@sentry/types" "7.10.0" + "@sentry/utils" "7.10.0" + tslib "^1.9.3" + +"@sentry/hub@7.10.0": + version "7.10.0" + resolved "https://registry.npmjs.org/@sentry/hub/-/hub-7.10.0.tgz" + integrity sha512-9Appy7J87EU7Xu2BDY1cLK79nsuE72geeYmG71lgdttTD3XOMcQBOxET4/2sAI+d/ansurXnURx+DAQ9FOKT+w== + dependencies: + "@sentry/types" "7.10.0" + "@sentry/utils" "7.10.0" + tslib "^1.9.3" + +"@sentry/node@^7.7.0": + version "7.10.0" + resolved "https://registry.npmjs.org/@sentry/node/-/node-7.10.0.tgz" + integrity sha512-L/DSEJ7Biy8ovvlCyfu5MpCYG108FIGVbJ1h0NBGr5+uLxTNg2WJWojJoiQNiRcWl4s0dcIXrRdi0HR2Sx+DUw== + dependencies: + "@sentry/core" "7.10.0" + "@sentry/hub" "7.10.0" + "@sentry/types" "7.10.0" + "@sentry/utils" "7.10.0" + cookie "^0.4.1" + https-proxy-agent "^5.0.0" + lru_map "^0.3.3" + tslib "^1.9.3" + +"@sentry/tracing@^7.7.0": + version "7.10.0" + resolved "https://registry.npmjs.org/@sentry/tracing/-/tracing-7.10.0.tgz" + integrity sha512-ojuBYS1bL/IGWKt/ItY4HmC8NElJrYtTUvm73VbhylhIO4zcn5ICHmgMFj1lqL9gQ1nCnAlifKiWIjL9qUatTA== + dependencies: + "@sentry/hub" "7.10.0" + "@sentry/types" "7.10.0" + "@sentry/utils" "7.10.0" + tslib "^1.9.3" + +"@sentry/types@7.10.0": + version "7.10.0" + resolved "https://registry.npmjs.org/@sentry/types/-/types-7.10.0.tgz" + integrity sha512-1UBwdbS0xXzANzp63g4eNQly/qKIXp0swP5OTKWoADvKBtL4anroLUA/l8ADMtuwFZYtVANc8WRGxM2+YmaXtg== + +"@sentry/utils@7.10.0": + version "7.10.0" + resolved "https://registry.npmjs.org/@sentry/utils/-/utils-7.10.0.tgz" + integrity sha512-/aD2DnfyOhV0Wdbb6VF78vu4fQIZJyuReDpBI7MV/EqcEB6FxUKq2YjinfKZF/exHEPig6Ag/Yt+CRFgvtVFuw== + dependencies: + "@sentry/types" "7.10.0" + tslib "^1.9.3" + +"@sinclair/typebox@^0.24.1": + version "0.24.20" + resolved "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.24.20.tgz" + integrity sha512-kVaO5aEFZb33nPMTZBxiPEkY+slxiPtqC7QX8f9B3eGOMBvEfuMfxp9DSTTCsRJPumPKjrge4yagyssO4q6qzQ== + +"@sinonjs/commons@^1.7.0": + version "1.8.3" + resolved "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz" + integrity sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ== + dependencies: + type-detect "4.0.8" + +"@sinonjs/fake-timers@^9.1.2": + version "9.1.2" + resolved "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-9.1.2.tgz" + integrity sha512-BPS4ynJW/o92PUR4wgriz2Ud5gpST5vz6GQfMixEDK0Z8ZCUv2M7SkBLykH56T++Xs+8ln9zTGbOvNGIe02/jw== + dependencies: + "@sinonjs/commons" "^1.7.0" + +"@sqltools/formatter@^1.2.2": + version "1.2.3" + resolved "https://registry.npmjs.org/@sqltools/formatter/-/formatter-1.2.3.tgz" + integrity sha512-O3uyB/JbkAEMZaP3YqyHH7TMnex7tWyCbCI4EfJdOCoN6HIhqdJBWTM6aCCiWQ/5f5wxjgU735QAIpJbjDvmzg== + +"@tokenizer/token@^0.3.0": + version "0.3.0" + resolved "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz" + integrity sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A== + +"@tootallnate/once@1": + version "1.1.2" + resolved "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz" + integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== + +"@tsconfig/node10@^1.0.7": + version "1.0.9" + resolved "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz" + integrity sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA== + +"@tsconfig/node12@^1.0.7": + version "1.0.11" + resolved "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz" + integrity sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag== + +"@tsconfig/node14@^1.0.0": + version "1.0.3" + resolved "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz" + integrity sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow== + +"@tsconfig/node16@^1.0.2": + version "1.0.3" + resolved "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.3.tgz" + integrity sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ== + +"@types/amqplib@^0.8.1": + version "0.8.2" + resolved "https://registry.npmjs.org/@types/amqplib/-/amqplib-0.8.2.tgz" + integrity sha512-p+TFLzo52f8UanB+Nq6gyUi65yecAcRY3nYowU6MPGFtaJvEDxcnFWrxssSTkF+ts1W3zyQDvgVICLQem5WxRA== + dependencies: + "@types/bluebird" "*" + "@types/node" "*" + +"@types/babel__core@^7.1.14": + version "7.1.19" + resolved "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.19.tgz" + integrity sha512-WEOTgRsbYkvA/KCsDwVEGkd7WAr1e3g31VHQ8zy5gul/V1qKullU/BU5I68X5v7V3GnB9eotmom4v5a5gjxorw== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + "@types/babel__generator" "*" + "@types/babel__template" "*" + "@types/babel__traverse" "*" + +"@types/babel__generator@*": + version "7.6.4" + resolved "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz" + integrity sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg== + dependencies: + "@babel/types" "^7.0.0" + +"@types/babel__template@*": + version "7.4.1" + resolved "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz" + integrity sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + +"@types/babel__traverse@*", "@types/babel__traverse@^7.0.6": + version "7.17.1" + resolved "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.17.1.tgz" + integrity sha512-kVzjari1s2YVi77D3w1yuvohV2idweYXMCDzqBiVNN63TcDWrIlTVOYpqVrvbbyOE/IyzBoTKF0fdnLPEORFxA== + dependencies: + "@babel/types" "^7.3.0" + +"@types/bcrypt@^5.0.0": + version "5.0.0" + resolved "https://registry.npmjs.org/@types/bcrypt/-/bcrypt-5.0.0.tgz" + integrity sha512-agtcFKaruL8TmcvqbndlqHPSJgsolhf/qPWchFlgnW1gECTN/nKbFcoFnvKAQRFfKbh+BO6A3SWdJu9t+xF3Lw== + dependencies: + "@types/node" "*" + +"@types/bluebird@*": + version "3.5.36" + resolved "https://registry.npmjs.org/@types/bluebird/-/bluebird-3.5.36.tgz" + integrity sha512-HBNx4lhkxN7bx6P0++W8E289foSu8kO8GCk2unhuVggO+cE7rh9DhZUyPhUxNRG9m+5B5BTKxZQ5ZP92x/mx9Q== + +"@types/body-parser@*", "@types/body-parser@^1.19.0": + version "1.19.2" + resolved "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz" + integrity sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g== + dependencies: + "@types/connect" "*" + "@types/node" "*" + +"@types/connect@*": + version "3.4.35" + resolved "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz" + integrity sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ== + dependencies: + "@types/node" "*" + +"@types/dotenv@^8.2.0": + version "8.2.0" + resolved "https://registry.npmjs.org/@types/dotenv/-/dotenv-8.2.0.tgz" + integrity sha512-ylSC9GhfRH7m1EUXBXofhgx4lUWmFeQDINW5oLuS+gxWdfUeW4zJdeVTYVkexEW+e2VUvlZR2kGnGGipAWR7kw== + dependencies: + dotenv "*" + +"@types/express-serve-static-core@^4.17.18": + version "4.17.29" + resolved "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.29.tgz" + integrity sha512-uMd++6dMKS32EOuw1Uli3e3BPgdLIXmezcfHv7N4c1s3gkhikBplORPpMq3fuWkxncZN1reb16d5n8yhQ80x7Q== + dependencies: + "@types/node" "*" + "@types/qs" "*" + "@types/range-parser" "*" + +"@types/express@*", "@types/express@^4.17.12": + version "4.17.13" + resolved "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz" + integrity sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA== + dependencies: + "@types/body-parser" "*" + "@types/express-serve-static-core" "^4.17.18" + "@types/qs" "*" + "@types/serve-static" "*" + +"@types/graceful-fs@^4.1.3": + version "4.1.5" + resolved "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz" + integrity sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw== + dependencies: + "@types/node" "*" + +"@types/i18next-node-fs-backend@^2.1.0": + version "2.1.1" + resolved "https://registry.npmjs.org/@types/i18next-node-fs-backend/-/i18next-node-fs-backend-2.1.1.tgz" + integrity sha512-ESvH90OICQkKU3yuuRzF6YfHt5KACE55FOiUM59mMGnC+h03lHGdEYo3z3THbwS5FdMskLyIs2O7f6Oaz8P9sw== + dependencies: + i18next ">=17.0.11" + +"@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0", "@types/istanbul-lib-coverage@^2.0.1": + version "2.0.4" + resolved "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz" + integrity sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g== + +"@types/istanbul-lib-report@*": + version "3.0.0" + resolved "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz" + integrity sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg== + dependencies: + "@types/istanbul-lib-coverage" "*" + +"@types/istanbul-reports@^3.0.0": + version "3.0.1" + resolved "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz" + integrity sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw== + dependencies: + "@types/istanbul-lib-report" "*" + +"@types/json-schema@^7.0.9": + version "7.0.11" + resolved "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz" + integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== + +"@types/jsonwebtoken@^8.5.8": + version "8.5.8" + resolved "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.8.tgz" + integrity sha512-zm6xBQpFDIDM6o9r6HSgDeIcLy82TKWctCXEPbJJcXb5AKmi5BNNdLXneixK4lplX3PqIVcwLBCGE/kAGnlD4A== + dependencies: + "@types/node" "*" + +"@types/mime@^1": + version "1.3.2" + resolved "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz" + integrity sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw== + +"@types/morgan@^1.9.3": + version "1.9.3" + resolved "https://registry.npmjs.org/@types/morgan/-/morgan-1.9.3.tgz" + integrity sha512-BiLcfVqGBZCyNCnCH3F4o2GmDLrpy0HeBVnNlyZG4fo88ZiE9SoiBe3C+2ezuwbjlEyT+PDZ17//TAlRxAn75Q== + dependencies: + "@types/node" "*" + +"@types/multer@^1.4.7": + version "1.4.7" + resolved "https://registry.npmjs.org/@types/multer/-/multer-1.4.7.tgz" + integrity sha512-/SNsDidUFCvqqcWDwxv2feww/yqhNeTRL5CVoL3jU4Goc4kKEL10T7Eye65ZqPNi4HRx8sAEX59pV1aEH7drNA== + dependencies: + "@types/express" "*" + +"@types/node-fetch@^2.6.2": + version "2.6.2" + resolved "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.2.tgz" + integrity sha512-DHqhlq5jeESLy19TYhLakJ07kNumXWjcDdxXsLUMJZ6ue8VZJj4kLPQVE/2mdHh3xZziNF1xppu5lwmS53HR+A== + dependencies: + "@types/node" "*" + form-data "^3.0.0" + +"@types/node-os-utils@^1.3.0": + version "1.3.0" + resolved "https://registry.npmjs.org/@types/node-os-utils/-/node-os-utils-1.3.0.tgz" + integrity sha512-XwVteWQx/XkfRPyaGkw8dEbrCAkoRZ73pI3XznUYIpzbCfpQB3UnDlR5TnmdhetlT889tUJGF8QWo9xrgTpsiA== + +"@types/node@*", "@types/node@^18.0.6": + version "18.6.3" + resolved "https://registry.npmjs.org/@types/node/-/node-18.6.3.tgz" + integrity sha512-6qKpDtoaYLM+5+AFChLhHermMQxc3TOEFIDzrZLPRGHPrLEwqFkkT5Kx3ju05g6X7uDPazz3jHbKPX0KzCjntg== + +"@types/node@^16.9.2": + version "16.11.45" + resolved "https://registry.npmjs.org/@types/node/-/node-16.11.45.tgz" + integrity sha512-3rKg/L5x0rofKuuUt5zlXzOnKyIHXmIu5R8A0TuNDMF2062/AOIDBciFIjToLEJ/9F9DzkHNot+BpNsMI1OLdQ== + +"@types/notp@^2.0.0": + version "2.0.2" + resolved "https://registry.npmjs.org/@types/notp/-/notp-2.0.2.tgz" + integrity sha512-JUcVYN9Tmw0AjoAfvjslS4hbv39fPBbZdftBK3b50g5z/DmhLsu6cd0UOEBiQuMwy2FirshF2Gk9gAvfWjshMw== + dependencies: + "@types/node" "*" + +"@types/prettier@^2.1.5": + version "2.6.3" + resolved "https://registry.npmjs.org/@types/prettier/-/prettier-2.6.3.tgz" + integrity sha512-ymZk3LEC/fsut+/Q5qejp6R9O1rMxz3XaRHDV6kX8MrGAhOSPqVARbDi+EZvInBpw+BnCX3TD240byVkOfQsHg== + +"@types/qs@*": + version "6.9.7" + resolved "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz" + integrity sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw== + +"@types/range-parser@*": + version "1.2.4" + resolved "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz" + integrity sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw== + +"@types/serve-static@*": + version "1.13.10" + resolved "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz" + integrity sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ== + dependencies: + "@types/mime" "^1" + "@types/node" "*" + +"@types/stack-utils@^2.0.0": + version "2.0.1" + resolved "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz" + integrity sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw== + +"@types/stream-buffers@^3.0.3": + version "3.0.4" + resolved "https://registry.npmjs.org/@types/stream-buffers/-/stream-buffers-3.0.4.tgz" + integrity sha512-qU/K1tb2yUdhXkLIATzsIPwbtX6BpZk0l3dPW6xqWyhfzzM1ECaQ/8faEnu3CNraLiQ9LHyQQPBGp7N9Fbs25w== + dependencies: + "@types/node" "*" + +"@types/strip-bom@^3.0.0": + version "3.0.0" + resolved "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz" + integrity sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ== + +"@types/strip-json-comments@0.0.30": + version "0.0.30" + resolved "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz" + integrity sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ== + +"@types/ws@^8.5.3": + version "8.5.3" + resolved "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz" + integrity sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w== + dependencies: + "@types/node" "*" + +"@types/yargs-parser@*": + version "21.0.0" + resolved "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz" + integrity sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA== + +"@types/yargs@^17.0.8": + version "17.0.10" + resolved "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.10.tgz" + integrity sha512-gmEaFwpj/7f/ROdtIlci1R1VYU1J4j95m8T+Tj3iBgiBFKg1foE/PSl93bBd5T9LDXNPo8UlNN6W0qwD8O5OaA== + dependencies: + "@types/yargs-parser" "*" + +"@yarnpkg/lockfile@^1.1.0": + version "1.1.0" + resolved "https://registry.npmjs.org/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz" + integrity sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ== + +"@zerollup/ts-helpers@^1.7.18": + version "1.7.18" + resolved "https://registry.npmjs.org/@zerollup/ts-helpers/-/ts-helpers-1.7.18.tgz" + integrity sha512-S9zN+y+i5yN/evfWquzSO3lubqPXIsPQf6p9OiPMpRxDx/0totPLF39XoRw48Dav5dSvbIE8D2eAPpXXJxvKwg== + dependencies: + resolve "^1.12.0" + +abbrev@1: + version "1.1.1" + resolved "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz" + integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== + +accepts@~1.3.8: + version "1.3.8" + resolved "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz" + integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== + dependencies: + mime-types "~2.1.34" + negotiator "0.6.3" + +acorn-walk@^8.1.1, acorn-walk@^8.2.0: + version "8.2.0" + resolved "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz" + integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== + +acorn@^8.4.1, acorn@^8.7.0: + version "8.7.1" + resolved "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz" + integrity sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A== + +agent-base@6, agent-base@^6.0.0, agent-base@^6.0.2: + version "6.0.2" + resolved "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz" + integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== + dependencies: + debug "4" + +agentkeepalive@^4.1.3: + version "4.2.1" + resolved "https://registry.yarnpkg.com/agentkeepalive/-/agentkeepalive-4.2.1.tgz#a7975cbb9f83b367f06c90cc51ff28fe7d499717" + integrity sha512-Zn4cw2NEqd+9fiSVWMscnjyQ1a8Yfoc5oBajLeo5w+YBHgDUcEBY2hS4YpTz6iN5f/2zQiktcuM6tS8x1p9dpA== + dependencies: + debug "^4.1.0" + depd "^1.1.2" + humanize-ms "^1.2.1" + +aggregate-error@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" + integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== + dependencies: + clean-stack "^2.0.0" + indent-string "^4.0.0" + +ajv-formats@^2.1.1: + version "2.1.1" + resolved "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz" + integrity sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA== + dependencies: + ajv "^8.0.0" + +ajv@^8.0.0, ajv@^8.11.0: + version "8.11.0" + resolved "https://registry.npmjs.org/ajv/-/ajv-8.11.0.tgz" + integrity sha512-wGgprdCvMalC0BztXvitD2hC04YffAvtsUn93JbGXYLAtCUO4xd17mCCZQxUOItiBwZvJScWo8NIvQMQ71rdpg== + dependencies: + fast-deep-equal "^3.1.1" + json-schema-traverse "^1.0.0" + require-from-string "^2.0.2" + uri-js "^4.2.2" + +amqplib@^0.10.1: + version "0.10.1" + resolved "https://registry.npmjs.org/amqplib/-/amqplib-0.10.1.tgz" + integrity sha512-Hs33MdtFmJ2WKQT9SBtrlet3aUNzMzZA/FF6p3NGGo7Fp/BVD4X3Po7bQxAA7uE0MmXPZ8EschLMbN+CjGx4dg== + dependencies: + bitsyntax "~0.1.0" + buffer-more-ints "~1.0.0" + readable-stream "1.x >=1.1.9" + url-parse "~1.5.10" + +ansi-escapes@^4.2.1: + version "4.3.2" + resolved "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz" + integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== + dependencies: + type-fest "^0.21.3" + +ansi-regex@^5.0.1: + version "5.0.1" + resolved "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== + +ansi-styles@^3.2.1: + version "3.2.1" + resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz" + integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== + dependencies: + color-convert "^1.9.0" + +ansi-styles@^4.0.0, ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + +ansi-styles@^5.0.0: + version "5.2.0" + resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz" + integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== + +any-promise@^1.0.0: + version "1.3.0" + resolved "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz" + integrity sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A== + +anymatch@^3.0.3, anymatch@~3.1.2: + version "3.1.2" + resolved "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz" + integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== + dependencies: + normalize-path "^3.0.0" + picomatch "^2.0.4" + +app-root-path@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/app-root-path/-/app-root-path-3.0.0.tgz" + integrity sha512-qMcx+Gy2UZynHjOHOIXPNvpf+9cjvk3cWrBBK7zg4gH9+clobJRb9NGzcT7mQTcV/6Gm/1WelUtqxVXnNlrwcw== + +append-field@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz" + integrity sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw== + +"aproba@^1.0.3 || ^2.0.0": + version "2.0.0" + resolved "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz" + integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== + +are-we-there-yet@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz" + integrity sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw== + dependencies: + delegates "^1.0.0" + readable-stream "^3.6.0" + +are-we-there-yet@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz#679df222b278c64f2cdba1175cdc00b0d96164bd" + integrity sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg== + dependencies: + delegates "^1.0.0" + readable-stream "^3.6.0" + +arg@^4.1.0: + version "4.1.3" + resolved "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz" + integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== + +argparse@^1.0.7: + version "1.0.10" + resolved "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz" + integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== + dependencies: + sprintf-js "~1.0.2" + +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + +array-flatten@1.1.1: + version "1.1.1" + resolved "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz" + integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== + +asap@^2.0.0: + version "2.0.6" + resolved "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz" + integrity sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA== + +ast-types@^0.13.2: + version "0.13.4" + resolved "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz" + integrity sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w== + dependencies: + tslib "^2.0.1" + +asynckit@^0.4.0: + version "0.4.0" + resolved "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz" + integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== + +babel-jest@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/babel-jest/-/babel-jest-28.1.3.tgz" + integrity sha512-epUaPOEWMk3cWX0M/sPvCHHCe9fMFAa/9hXEgKP8nFfNl/jlGkE9ucq9NqkZGXLDduCJYS0UvSlPUwC0S+rH6Q== + dependencies: + "@jest/transform" "^28.1.3" + "@types/babel__core" "^7.1.14" + babel-plugin-istanbul "^6.1.1" + babel-preset-jest "^28.1.3" + chalk "^4.0.0" + graceful-fs "^4.2.9" + slash "^3.0.0" + +babel-plugin-dynamic-import-node@^2.3.3: + version "2.3.3" + resolved "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz" + integrity sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ== + dependencies: + object.assign "^4.1.0" + +babel-plugin-istanbul@^6.1.1: + version "6.1.1" + resolved "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz" + integrity sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA== + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@istanbuljs/load-nyc-config" "^1.0.0" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-instrument "^5.0.4" + test-exclude "^6.0.0" + +babel-plugin-jest-hoist@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-28.1.3.tgz" + integrity sha512-Ys3tUKAmfnkRUpPdpa98eYrAR0nV+sSFUZZEGuQ2EbFd1y4SOLtD5QDNHAq+bb9a+bbXvYQC4b+ID/THIMcU6Q== + dependencies: + "@babel/template" "^7.3.3" + "@babel/types" "^7.3.3" + "@types/babel__core" "^7.1.14" + "@types/babel__traverse" "^7.0.6" + +babel-plugin-polyfill-corejs2@^0.3.1: + version "0.3.1" + resolved "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.1.tgz" + integrity sha512-v7/T6EQcNfVLfcN2X8Lulb7DjprieyLWJK/zOWH5DUYcAgex9sP3h25Q+DLsX9TloXe3y1O8l2q2Jv9q8UVB9w== + dependencies: + "@babel/compat-data" "^7.13.11" + "@babel/helper-define-polyfill-provider" "^0.3.1" + semver "^6.1.1" + +babel-plugin-polyfill-corejs3@^0.5.2: + version "0.5.2" + resolved "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.2.tgz" + integrity sha512-G3uJih0XWiID451fpeFaYGVuxHEjzKTHtc9uGFEjR6hHrvNzeS/PX+LLLcetJcytsB5m4j+K3o/EpXJNb/5IEQ== + dependencies: + "@babel/helper-define-polyfill-provider" "^0.3.1" + core-js-compat "^3.21.0" + +babel-plugin-polyfill-regenerator@^0.3.1: + version "0.3.1" + resolved "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz" + integrity sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A== + dependencies: + "@babel/helper-define-polyfill-provider" "^0.3.1" + +babel-preset-current-node-syntax@^1.0.0: + version "1.0.1" + resolved "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz" + integrity sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ== + dependencies: + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-bigint" "^7.8.3" + "@babel/plugin-syntax-class-properties" "^7.8.3" + "@babel/plugin-syntax-import-meta" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.8.3" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^7.8.3" + "@babel/plugin-syntax-object-rest-spread" "^7.8.3" + "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" + "@babel/plugin-syntax-optional-chaining" "^7.8.3" + "@babel/plugin-syntax-top-level-await" "^7.8.3" + +babel-preset-jest@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-28.1.3.tgz" + integrity sha512-L+fupJvlWAHbQfn74coNX3zf60LXMJsezNvvx8eIh7iOR1luJ1poxYgQk1F8PYtNq/6QODDHCqsSnTFSWC491A== + dependencies: + babel-plugin-jest-hoist "^28.1.3" + babel-preset-current-node-syntax "^1.0.0" + +balanced-match@^1.0.0: + version "1.0.2" + resolved "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== + +base64-js@^1.3.1: + version "1.5.1" + resolved "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz" + integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== + +basic-auth@~2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz" + integrity sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg== + dependencies: + safe-buffer "5.1.2" + +bcrypt@^5.0.1: + version "5.0.1" + resolved "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.1.tgz" + integrity sha512-9BTgmrhZM2t1bNuDtrtIMVSmmxZBrJ71n8Wg+YgdjHuIWYF7SjjmCPZFB+/5i/o/PIeRpwVJR3P+NrpIItUjqw== + dependencies: + "@mapbox/node-pre-gyp" "^1.0.0" + node-addon-api "^3.1.0" + +binary-extensions@^2.0.0: + version "2.2.0" + resolved "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz" + integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== + +bitsyntax@~0.1.0: + version "0.1.0" + resolved "https://registry.npmjs.org/bitsyntax/-/bitsyntax-0.1.0.tgz" + integrity sha512-ikAdCnrloKmFOugAfxWws89/fPc+nw0OOG1IzIE72uSOg/A3cYptKCjSUhDTuj7fhsJtzkzlv7l3b8PzRHLN0Q== + dependencies: + buffer-more-ints "~1.0.0" + debug "~2.6.9" + safe-buffer "~5.1.2" + +body-parser@1.20.0, body-parser@^1.19.0: + version "1.20.0" + resolved "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz" + integrity sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg== + dependencies: + bytes "3.1.2" + content-type "~1.0.4" + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + http-errors "2.0.0" + iconv-lite "0.4.24" + on-finished "2.4.1" + qs "6.10.3" + raw-body "2.5.1" + type-is "~1.6.18" + unpipe "1.0.0" + +boolbase@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz" + integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww== + +bowser@^2.11.0: + version "2.11.0" + resolved "https://registry.npmjs.org/bowser/-/bowser-2.11.0.tgz" + integrity sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA== + +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +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.npmjs.org/braces/-/braces-3.0.2.tgz" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + +browserslist@^4.20.2, browserslist@^4.21.1: + version "4.21.2" + resolved "https://registry.npmjs.org/browserslist/-/browserslist-4.21.2.tgz" + integrity sha512-MonuOgAtUB46uP5CezYbRaYKBNt2LxP0yX+Pmj4LkcDFGkn9Cbpi83d9sCjwQDErXsIJSzY5oKGDbgOlF/LPAA== + dependencies: + caniuse-lite "^1.0.30001366" + electron-to-chromium "^1.4.188" + node-releases "^2.0.6" + update-browserslist-db "^1.0.4" + +bser@2.1.1: + version "2.1.1" + resolved "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz" + integrity sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ== + dependencies: + node-int64 "^0.4.0" + +buffer-equal-constant-time@1.0.1: + version "1.0.1" + resolved "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz" + integrity sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA== + +buffer-from@^1.0.0: + version "1.1.2" + resolved "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz" + integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== + +buffer-more-ints@~1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/buffer-more-ints/-/buffer-more-ints-1.0.0.tgz" + integrity sha512-EMetuGFz5SLsT0QTnXzINh4Ksr+oo4i+UGTXEshiGCQWnsgSs7ZhJ8fzlwQ+OzEMs0MpDAMr1hxnblp5a4vcHg== + +buffer-writer@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/buffer-writer/-/buffer-writer-2.0.0.tgz#ce7eb81a38f7829db09c873f2fbb792c0c98ec04" + integrity sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw== + +buffer@^6.0.3: + version "6.0.3" + resolved "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz" + integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== + dependencies: + base64-js "^1.3.1" + ieee754 "^1.2.1" + +busboy@^1.0.0: + version "1.6.0" + resolved "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz" + integrity sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA== + dependencies: + streamsearch "^1.1.0" + +bytes@3.1.2: + version "3.1.2" + resolved "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz" + integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== + +cacache@^15.2.0: + version "15.3.0" + resolved "https://registry.yarnpkg.com/cacache/-/cacache-15.3.0.tgz#dc85380fb2f556fe3dda4c719bfa0ec875a7f1eb" + integrity sha512-VVdYzXEn+cnbXpFgWs5hTT7OScegHVmLhJIR8Ufqk3iFD6A6j5iSX1KuBTfNEv4tdJWE2PzA6IVFtcLC7fN9wQ== + dependencies: + "@npmcli/fs" "^1.0.0" + "@npmcli/move-file" "^1.0.1" + chownr "^2.0.0" + fs-minipass "^2.0.0" + glob "^7.1.4" + infer-owner "^1.0.4" + lru-cache "^6.0.0" + minipass "^3.1.1" + minipass-collect "^1.0.2" + minipass-flush "^1.0.5" + minipass-pipeline "^1.2.2" + mkdirp "^1.0.3" + p-map "^4.0.0" + promise-inflight "^1.0.1" + rimraf "^3.0.2" + ssri "^8.0.1" + tar "^6.0.2" + unique-filename "^1.1.1" + +call-bind@^1.0.0: + version "1.0.2" + resolved "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz" + integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== + dependencies: + function-bind "^1.1.1" + get-intrinsic "^1.0.2" + +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +camelcase@^5.3.1: + version "5.3.1" + resolved "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz" + integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== + +camelcase@^6.2.0: + version "6.3.0" + resolved "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz" + integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== + +caniuse-lite@^1.0.30001366: + version "1.0.30001367" + resolved "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001367.tgz" + integrity sha512-XDgbeOHfifWV3GEES2B8rtsrADx4Jf+juKX2SICJcaUhjYBO3bR96kvEIHa15VU6ohtOhBZuPGGYGbXMRn0NCw== + +canvas@^2.9.3: + version "2.9.3" + resolved "https://registry.npmjs.org/canvas/-/canvas-2.9.3.tgz" + integrity sha512-WOUM7ghii5TV2rbhaZkh1youv/vW1/Canev6Yx6BG2W+1S07w8jKZqKkPnbiPpQEDsnJdN8ouDd7OvQEGXDcUw== + dependencies: + "@mapbox/node-pre-gyp" "^1.0.0" + nan "^2.15.0" + simple-get "^3.0.3" + +chalk@^2.0.0, chalk@^2.4.2: + version "2.4.2" + resolved "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz" + integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== + dependencies: + ansi-styles "^3.2.1" + escape-string-regexp "^1.0.5" + supports-color "^5.3.0" + +chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.1, chalk@^4.1.2: + version "4.1.2" + resolved "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +char-regex@^1.0.2: + version "1.0.2" + resolved "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz" + integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== + +cheerio-select@^2.1.0: + version "2.1.0" + resolved "https://registry.npmjs.org/cheerio-select/-/cheerio-select-2.1.0.tgz" + integrity sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g== + dependencies: + boolbase "^1.0.0" + css-select "^5.1.0" + css-what "^6.1.0" + domelementtype "^2.3.0" + domhandler "^5.0.3" + domutils "^3.0.1" + +cheerio@^1.0.0-rc.10: + version "1.0.0-rc.12" + resolved "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.12.tgz" + integrity sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q== + dependencies: + cheerio-select "^2.1.0" + dom-serializer "^2.0.0" + domhandler "^5.0.3" + domutils "^3.0.1" + htmlparser2 "^8.0.1" + parse5 "^7.0.0" + parse5-htmlparser2-tree-adapter "^7.0.0" + +chokidar@^3.5.1: + version "3.5.3" + resolved "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz" + 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" + +chownr@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz" + integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== + +ci-info@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz" + integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== + +ci-info@^3.2.0: + version "3.3.2" + resolved "https://registry.npmjs.org/ci-info/-/ci-info-3.3.2.tgz" + integrity sha512-xmDt/QIAdeZ9+nfdPsaBCpMvHNLFiLdjj59qjqn+6iPe6YmHGQ35sBnQ8uslRBXFmXkiZQOJRjvQeoGppoTjjg== + +cjs-module-lexer@^1.0.0: + version "1.2.2" + resolved "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz" + integrity sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA== + +clean-stack@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" + integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== + +cli-highlight@^2.1.11: + version "2.1.11" + resolved "https://registry.npmjs.org/cli-highlight/-/cli-highlight-2.1.11.tgz" + integrity sha512-9KDcoEVwyUXrjcJNvHD0NFc/hiwe/WPVYIleQh2O1N2Zro5gWJZ/K+3DGn8w8P/F6FxOgzyC5bxDyHIgCSPhGg== + dependencies: + chalk "^4.0.0" + highlight.js "^10.7.1" + mz "^2.4.0" + parse5 "^5.1.1" + parse5-htmlparser2-tree-adapter "^6.0.0" + yargs "^16.0.0" + +cliui@^7.0.2: + version "7.0.4" + resolved "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz" + integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== + dependencies: + string-width "^4.2.0" + strip-ansi "^6.0.0" + wrap-ansi "^7.0.0" + +co@^4.6.0: + version "4.6.0" + resolved "https://registry.npmjs.org/co/-/co-4.6.0.tgz" + integrity sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ== + +collect-v8-coverage@^1.0.0: + version "1.0.1" + resolved "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz" + integrity sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg== + +color-convert@^1.9.0: + version "1.9.3" + resolved "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz" + integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== + dependencies: + color-name "1.1.3" + +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + +color-name@1.1.3: + version "1.1.3" + resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz" + integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== + +color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + +color-support@^1.1.2, color-support@^1.1.3: + version "1.1.3" + resolved "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz" + integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== + +combined-stream@^1.0.8: + version "1.0.8" + resolved "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz" + integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== + dependencies: + delayed-stream "~1.0.0" + +component-emitter@^1.3.0: + version "1.3.0" + resolved "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz" + integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + +concat-stream@^1.5.2: + version "1.6.2" + resolved "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz" + integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== + dependencies: + buffer-from "^1.0.0" + inherits "^2.0.3" + readable-stream "^2.2.2" + typedarray "^0.0.6" + +console-control-strings@^1.0.0, console-control-strings@^1.1.0: + version "1.1.0" + resolved "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz" + integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ== + +content-disposition@0.5.4: + version "0.5.4" + resolved "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz" + integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== + dependencies: + safe-buffer "5.2.1" + +content-type@~1.0.4: + version "1.0.4" + resolved "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz" + integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== + +convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: + version "1.8.0" + resolved "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz" + integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA== + dependencies: + safe-buffer "~5.1.1" + +cookie-signature@1.0.6: + version "1.0.6" + resolved "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" + integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== + +cookie@0.5.0: + version "0.5.0" + resolved "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz" + integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== + +cookie@^0.4.1: + version "0.4.2" + resolved "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz" + integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== + +cookiejar@^2.1.3: + version "2.1.3" + resolved "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.3.tgz" + integrity sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ== + +core-js-compat@^3.21.0, core-js-compat@^3.22.1: + version "3.23.4" + resolved "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.4.tgz" + integrity sha512-RkSRPe+JYEoflcsuxJWaiMPhnZoFS51FcIxm53k4KzhISCBTmaGlto9dTIrYuk0hnJc3G6pKufAKepHnBq6B6Q== + dependencies: + browserslist "^4.21.1" + semver "7.0.0" + +core-util-is@~1.0.0: + version "1.0.3" + resolved "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz" + integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== + +create-require@^1.1.0: + version "1.1.1" + resolved "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz" + integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== + +cross-spawn@^6.0.5: + version "6.0.5" + resolved "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz" + integrity sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ== + dependencies: + nice-try "^1.0.4" + path-key "^2.0.1" + semver "^5.5.0" + shebang-command "^1.2.0" + which "^1.2.9" + +cross-spawn@^7.0.3: + version "7.0.3" + resolved "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +css-select@^5.1.0: + version "5.1.0" + resolved "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz" + integrity sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg== + dependencies: + boolbase "^1.0.0" + css-what "^6.1.0" + domhandler "^5.0.2" + domutils "^3.0.1" + nth-check "^2.0.1" + +css-what@^6.1.0: + version "6.1.0" + resolved "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz" + integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw== + +data-uri-to-buffer@3: + version "3.0.1" + resolved "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz" + integrity sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og== + +date-fns@^2.28.0: + version "2.28.0" + resolved "https://registry.npmjs.org/date-fns/-/date-fns-2.28.0.tgz" + integrity sha512-8d35hViGYx/QH0icHYCeLmsLmMUheMmTyV9Fcm6gvNwdw31yXXH+O85sOBJ+OLnLQMKZowvpKb6FgMIQjcpvQw== + +debug@2.6.9, debug@~2.6.9: + version "2.6.9" + resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.3, debug@^4.3.4: + version "4.3.4" + resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + +decompress-response@^4.2.0: + version "4.2.1" + resolved "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz" + integrity sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw== + dependencies: + mimic-response "^2.0.0" + +dedent@^0.7.0: + version "0.7.0" + resolved "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz" + integrity sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA== + +deep-is@~0.1.3: + version "0.1.4" + resolved "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + +deepmerge@^4.2.2: + version "4.2.2" + resolved "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz" + integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== + +define-properties@^1.1.3: + version "1.1.4" + resolved "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz" + integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== + dependencies: + has-property-descriptors "^1.0.0" + object-keys "^1.1.1" + +degenerator@^3.0.2: + version "3.0.2" + resolved "https://registry.npmjs.org/degenerator/-/degenerator-3.0.2.tgz" + integrity sha512-c0mef3SNQo56t6urUU6tdQAs+ThoD0o9B9MJ8HEt7NQcGEILCRFqQb7ZbP9JAv+QF1Ky5plydhMR/IrqWDm+TQ== + dependencies: + ast-types "^0.13.2" + escodegen "^1.8.1" + esprima "^4.0.0" + vm2 "^3.9.8" + +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz" + integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== + +delegates@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz" + integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ== + +denque@^2.0.1: + version "2.1.0" + resolved "https://registry.yarnpkg.com/denque/-/denque-2.1.0.tgz#e93e1a6569fb5e66f16a3c2a2964617d349d6ab1" + integrity sha512-HVQE3AAb/pxF8fQAoiqpvg9i3evqug3hoiwakOyZAwJm+6vZehbkYXZ0l4JxS+I3QxM97v5aaRNhj8v5oBhekw== + +depd@2.0.0, depd@~2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz" + integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== + +depd@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" + integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== + +destroy@1.2.0: + version "1.2.0" + resolved "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz" + integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== + +detect-libc@^2.0.0: + version "2.0.1" + resolved "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz" + integrity sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w== + +detect-newline@^3.0.0: + version "3.1.0" + resolved "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz" + integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA== + +dezalgo@1.0.3: + version "1.0.3" + resolved "https://registry.npmjs.org/dezalgo/-/dezalgo-1.0.3.tgz" + integrity sha512-K7i4zNfT2kgQz3GylDw40ot9GAE47sFZ9EXHFSPP6zONLgH6kWXE0KWJchkbQJLBkRazq4APwZ4OwiFFlT95OQ== + dependencies: + asap "^2.0.0" + wrappy "1" + +diff-sequences@^28.1.1: + version "28.1.1" + resolved "https://registry.npmjs.org/diff-sequences/-/diff-sequences-28.1.1.tgz" + integrity sha512-FU0iFaH/E23a+a718l8Qa/19bF9p06kgE0KipMOMadwa3SjnaElKzPaUC0vnibs6/B/9ni97s61mcejk8W1fQw== + +diff@^4.0.1: + version "4.0.2" + resolved "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz" + integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== + +dom-serializer@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz" + integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg== + dependencies: + domelementtype "^2.3.0" + domhandler "^5.0.2" + entities "^4.2.0" + +domelementtype@^2.3.0: + version "2.3.0" + resolved "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz" + integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== + +domhandler@^5.0.1, domhandler@^5.0.2, domhandler@^5.0.3: + version "5.0.3" + resolved "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz" + integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w== + dependencies: + domelementtype "^2.3.0" + +domutils@^3.0.1: + version "3.0.1" + resolved "https://registry.npmjs.org/domutils/-/domutils-3.0.1.tgz" + integrity sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q== + dependencies: + dom-serializer "^2.0.0" + domelementtype "^2.3.0" + domhandler "^5.0.1" + +dotenv@*, dotenv@^16.0.0, dotenv@^16.0.1: + version "16.0.1" + resolved "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz" + integrity sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ== + +dynamic-dedupe@^0.3.0: + version "0.3.0" + resolved "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz" + integrity sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ== + dependencies: + xtend "^4.0.0" + +ecdsa-sig-formatter@1.0.11: + version "1.0.11" + resolved "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz" + integrity sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ== + dependencies: + safe-buffer "^5.0.1" + +ee-first@1.1.1: + version "1.1.1" + resolved "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" + integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== + +electron-to-chromium@^1.4.188: + version "1.4.192" + resolved "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.192.tgz" + integrity sha512-8nCXyIQY9An88NXAp+PuPy5h3/w5ZY7Iu2lag65Q0XREprcat5F8gKhoHsBUnQcFuCRnmevpR8yEBYRU3d2HDw== + +emittery@^0.10.2: + version "0.10.2" + resolved "https://registry.npmjs.org/emittery/-/emittery-0.10.2.tgz" + integrity sha512-aITqOwnLanpHLNXZJENbOgjUBeHocD+xsSJmNrjovKBW5HbSpW3d1pEls7GFQPUWXiwG9+0P4GtHfEqC/4M0Iw== + +emoji-regex@^8.0.0: + version "8.0.0" + resolved "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz" + integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== + +encodeurl@~1.0.2: + version "1.0.2" + resolved "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz" + integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== + +encoding@^0.1.12: + version "0.1.13" + resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" + integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== + dependencies: + iconv-lite "^0.6.2" + +entities@2.2.0: + version "2.2.0" + resolved "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz" + integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== + +entities@^4.2.0, entities@^4.3.0: + version "4.3.1" + resolved "https://registry.npmjs.org/entities/-/entities-4.3.1.tgz" + integrity sha512-o4q/dYJlmyjP2zfnaWDUC6A3BQFmVTX+tZPezK7k0GLSU9QYCauscf5Y+qcEPzKL+EixVouYDgLQK5H9GrLpkg== + +env-paths@^2.2.0: + version "2.2.1" + resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" + integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== + +err-code@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/err-code/-/err-code-2.0.3.tgz#23c2f3b756ffdfc608d30e27c9a941024807e7f9" + integrity sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA== + +error-ex@^1.3.1: + version "1.3.2" + resolved "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz" + integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== + dependencies: + is-arrayish "^0.2.1" + +escalade@^3.1.1: + version "3.1.1" + resolved "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz" + integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== + +escape-html@~1.0.3: + version "1.0.3" + resolved "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz" + integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== + +escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz" + integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== + +escape-string-regexp@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz" + integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== + +escodegen@^1.8.1: + version "1.14.3" + resolved "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz" + integrity sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw== + dependencies: + esprima "^4.0.1" + estraverse "^4.2.0" + esutils "^2.0.2" + optionator "^0.8.1" + optionalDependencies: + source-map "~0.6.1" + +esprima@^4.0.0, esprima@^4.0.1: + version "4.0.1" + resolved "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz" + integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== + +estraverse@^4.2.0: + version "4.3.0" + resolved "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz" + integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +etag@~1.8.1: + version "1.8.1" + resolved "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz" + integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== + +execa@^5.0.0: + version "5.1.1" + resolved "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz" + integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== + dependencies: + cross-spawn "^7.0.3" + get-stream "^6.0.0" + human-signals "^2.1.0" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.1" + onetime "^5.1.2" + signal-exit "^3.0.3" + strip-final-newline "^2.0.0" + +exif-be-gone@^1.3.0: + version "1.3.0" + resolved "https://registry.npmjs.org/exif-be-gone/-/exif-be-gone-1.3.0.tgz" + integrity sha512-6s/SnuWviwtP6TB3Gc2Nc2GIWYCIs3N9V4Md773EWIfC4uOR+O3thZXO4ElbJJOvjtDNR4FVoMVNKgZWRKiQNQ== + dependencies: + "@types/stream-buffers" "^3.0.3" + +exit@^0.1.2: + version "0.1.2" + resolved "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz" + integrity sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ== + +expect@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/expect/-/expect-28.1.3.tgz" + integrity sha512-eEh0xn8HlsuOBxFgIss+2mX85VAS4Qy3OSkjV7rlBWljtA4oWH37glVGyOZSZvErDT/yBywZdPGwCXuTvSG85g== + dependencies: + "@jest/expect-utils" "^28.1.3" + jest-get-type "^28.0.2" + jest-matcher-utils "^28.1.3" + jest-message-util "^28.1.3" + jest-util "^28.1.3" + +express-async-errors@^3.1.1: + version "3.1.1" + resolved "https://registry.npmjs.org/express-async-errors/-/express-async-errors-3.1.1.tgz" + integrity sha512-h6aK1da4tpqWSbyCa3FxB/V6Ehd4EEB15zyQq9qe75OZBp0krinNKuH4rAY+S/U/2I36vdLAUFSjQJ+TFmODng== + +express@^4.17.1: + version "4.18.1" + resolved "https://registry.npmjs.org/express/-/express-4.18.1.tgz" + integrity sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q== + dependencies: + accepts "~1.3.8" + array-flatten "1.1.1" + body-parser "1.20.0" + content-disposition "0.5.4" + content-type "~1.0.4" + cookie "0.5.0" + cookie-signature "1.0.6" + debug "2.6.9" + depd "2.0.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + finalhandler "1.2.0" + fresh "0.5.2" + http-errors "2.0.0" + merge-descriptors "1.0.1" + methods "~1.1.2" + on-finished "2.4.1" + parseurl "~1.3.3" + path-to-regexp "0.1.7" + proxy-addr "~2.0.7" + qs "6.10.3" + range-parser "~1.2.1" + safe-buffer "5.2.1" + send "0.18.0" + serve-static "1.15.0" + setprototypeof "1.2.0" + statuses "2.0.1" + type-is "~1.6.18" + utils-merge "1.0.1" + vary "~1.1.2" + +fast-deep-equal@^3.1.1: + version "3.1.3" + resolved "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-json-stable-stringify@^2.0.0: + version "2.1.0" + resolved "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-levenshtein@~2.0.6: + version "2.0.6" + resolved "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz" + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + +fast-safe-stringify@^2.1.1: + version "2.1.1" + resolved "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz" + integrity sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA== + +fast-xml-parser@3.19.0: + version "3.19.0" + resolved "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-3.19.0.tgz" + integrity sha512-4pXwmBplsCPv8FOY1WRakF970TjNGnGnfbOnLqjlYvMiF1SR3yOHyxMR/YCXpPTOspNF5gwudqktIP4VsWkvBg== + +fb-watchman@^2.0.0: + version "2.0.1" + resolved "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz" + integrity sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg== + dependencies: + bser "2.1.1" + +file-type@16.5: + version "16.5.4" + resolved "https://registry.npmjs.org/file-type/-/file-type-16.5.4.tgz" + integrity sha512-/yFHK0aGjFEgDJjEKP0pWCplsPFPhwyfwevf/pVxiN0tmE4L9LmwWxWukdJSHdoCli4VgQLehjJtwQBnqmsKcw== + dependencies: + readable-web-to-node-stream "^3.0.0" + strtok3 "^6.2.4" + token-types "^4.1.1" + +file-uri-to-path@2: + version "2.0.0" + resolved "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz" + integrity sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg== + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +finalhandler@1.2.0: + version "1.2.0" + resolved "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz" + integrity sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg== + dependencies: + debug "2.6.9" + encodeurl "~1.0.2" + escape-html "~1.0.3" + on-finished "2.4.1" + parseurl "~1.3.3" + statuses "2.0.1" + unpipe "~1.0.0" + +find-up@^4.0.0, find-up@^4.1.0: + version "4.1.0" + resolved "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz" + integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== + dependencies: + locate-path "^5.0.0" + path-exists "^4.0.0" + +find-yarn-workspace-root@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/find-yarn-workspace-root/-/find-yarn-workspace-root-2.0.0.tgz" + integrity sha512-1IMnbjt4KzsQfnhnzNd8wUEgXZ44IzZaZmnLYx7D5FZlaHt2gW20Cri8Q+E/t5tIj4+epTBub+2Zxu/vNILzqQ== + dependencies: + micromatch "^4.0.2" + +form-data@^3.0.0: + version "3.0.1" + resolved "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz" + integrity sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +form-data@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz" + integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +formidable@^2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/formidable/-/formidable-2.0.1.tgz" + integrity sha512-rjTMNbp2BpfQShhFbR3Ruk3qk2y9jKpvMW78nJgx8QKtxjDVrwbZG+wvDOmVbifHyOUOQJXxqEy6r0faRrPzTQ== + dependencies: + dezalgo "1.0.3" + hexoid "1.0.0" + once "1.4.0" + qs "6.9.3" + +forwarded@0.2.0: + version "0.2.0" + resolved "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz" + integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== + +fresh@0.5.2: + version "0.5.2" + resolved "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz" + integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== + +fs-extra@^7.0.1: + version "7.0.1" + resolved "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz" + integrity sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw== + dependencies: + graceful-fs "^4.1.2" + jsonfile "^4.0.0" + universalify "^0.1.0" + +fs-extra@^8.1.0: + version "8.1.0" + resolved "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz" + integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== + dependencies: + graceful-fs "^4.2.0" + jsonfile "^4.0.0" + universalify "^0.1.0" + +fs-minipass@^2.0.0: + version "2.1.0" + resolved "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz" + integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== + dependencies: + minipass "^3.0.0" + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz" + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== + +fsevents@^2.3.2, 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== + +ftp@^0.3.10: + version "0.3.10" + resolved "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz" + integrity sha512-faFVML1aBx2UoDStmLwv2Wptt4vw5x03xxX172nhA5Y5HBshW5JweqQ2W4xL4dezQTG8inJsuYcpPHHU3X5OTQ== + dependencies: + readable-stream "1.1.x" + xregexp "2.0.0" + +function-bind@^1.1.1: + version "1.1.1" + resolved "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz" + integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== + +gauge@^3.0.0: + version "3.0.2" + resolved "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz" + integrity sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q== + dependencies: + aproba "^1.0.3 || ^2.0.0" + color-support "^1.1.2" + console-control-strings "^1.0.0" + has-unicode "^2.0.1" + object-assign "^4.1.1" + signal-exit "^3.0.0" + string-width "^4.2.3" + strip-ansi "^6.0.1" + wide-align "^1.1.2" + +gauge@^4.0.3: + version "4.0.4" + resolved "https://registry.yarnpkg.com/gauge/-/gauge-4.0.4.tgz#52ff0652f2bbf607a989793d53b751bef2328dce" + integrity sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg== + dependencies: + aproba "^1.0.3 || ^2.0.0" + color-support "^1.1.3" + console-control-strings "^1.1.0" + has-unicode "^2.0.1" + signal-exit "^3.0.7" + string-width "^4.2.3" + strip-ansi "^6.0.1" + wide-align "^1.1.5" + +generate-function@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/generate-function/-/generate-function-2.3.1.tgz#f069617690c10c868e73b8465746764f97c3479f" + integrity sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ== + dependencies: + is-property "^1.0.2" + +gensync@^1.0.0-beta.2: + version "1.0.0-beta.2" + resolved "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz" + integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== + +get-caller-file@^2.0.5: + version "2.0.5" + resolved "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz" + integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== + +get-intrinsic@^1.0.2, get-intrinsic@^1.1.1: + version "1.1.2" + resolved "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz" + integrity sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA== + dependencies: + function-bind "^1.1.1" + has "^1.0.3" + has-symbols "^1.0.3" + +get-package-type@^0.1.0: + version "0.1.0" + resolved "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz" + integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== + +get-stream@^6.0.0: + version "6.0.1" + resolved "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz" + integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== + +get-uri@3: + version "3.0.2" + resolved "https://registry.npmjs.org/get-uri/-/get-uri-3.0.2.tgz" + integrity sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg== + dependencies: + "@tootallnate/once" "1" + data-uri-to-buffer "3" + debug "4" + file-uri-to-path "2" + fs-extra "^8.1.0" + ftp "^0.3.10" + +glob-parent@~5.1.2: + version "5.1.2" + resolved "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob@^7.0.0, glob@^7.1.3, glob@^7.1.4, glob@^7.1.7, glob@^7.2.0: + version "7.2.3" + resolved "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz" + 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" + +glob@^8.0.3: + version "8.0.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-8.0.3.tgz#415c6eb2deed9e502c68fa44a272e6da6eeca42e" + integrity sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^5.0.1" + once "^1.3.0" + +global-prefix@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz" + integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg== + dependencies: + ini "^1.3.5" + kind-of "^6.0.2" + which "^1.3.1" + +globals@^11.1.0: + version "11.12.0" + resolved "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz" + integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== + +graceful-fs@^4.1.11, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.6, graceful-fs@^4.2.9: + version "4.2.10" + resolved "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz" + integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== + +has-flag@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz" + integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +has-property-descriptors@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz" + integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== + dependencies: + get-intrinsic "^1.1.1" + +has-symbols@^1.0.1, has-symbols@^1.0.3: + version "1.0.3" + resolved "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz" + integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== + +has-unicode@^2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz" + integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ== + +has@^1.0.3: + version "1.0.3" + resolved "https://registry.npmjs.org/has/-/has-1.0.3.tgz" + integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== + dependencies: + function-bind "^1.1.1" + +helmet@^4.4.1: + version "4.6.0" + resolved "https://registry.npmjs.org/helmet/-/helmet-4.6.0.tgz" + integrity sha512-HVqALKZlR95ROkrnesdhbbZJFi/rIVSoNq6f3jA/9u6MIbTsPh3xZwihjeI5+DO/2sOV6HMHooXcEOuwskHpTg== + +hexoid@1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/hexoid/-/hexoid-1.0.0.tgz" + integrity sha512-QFLV0taWQOZtvIRIAdBChesmogZrtuXvVWsFHZTk2SU+anspqZ2vMnoLg7IE1+Uk16N19APic1BuF8bC8c2m5g== + +highlight.js@^10.7.1: + version "10.7.3" + resolved "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz" + integrity sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A== + +html-escaper@^2.0.0: + version "2.0.2" + resolved "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz" + integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== + +htmlparser2@^8.0.1: + version "8.0.1" + resolved "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.1.tgz" + integrity sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA== + dependencies: + domelementtype "^2.3.0" + domhandler "^5.0.2" + domutils "^3.0.1" + entities "^4.3.0" + +http-cache-semantics@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" + integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== + +http-errors@2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz" + integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== + dependencies: + depd "2.0.0" + inherits "2.0.4" + setprototypeof "1.2.0" + statuses "2.0.1" + toidentifier "1.0.1" + +http-proxy-agent@^4.0.0, http-proxy-agent@^4.0.1: + version "4.0.1" + resolved "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz" + integrity sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg== + dependencies: + "@tootallnate/once" "1" + agent-base "6" + debug "4" + +https-proxy-agent@5, https-proxy-agent@^5.0.0: + version "5.0.1" + resolved "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz" + integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== + dependencies: + agent-base "6" + debug "4" + +human-signals@^2.1.0: + version "2.1.0" + resolved "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz" + integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== + +humanize-ms@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/humanize-ms/-/humanize-ms-1.2.1.tgz#c46e3159a293f6b896da29316d8b6fe8bb79bbed" + integrity sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ== + dependencies: + ms "^2.0.0" + +i18next-http-middleware@^3.1.3: + version "3.2.1" + resolved "https://registry.npmjs.org/i18next-http-middleware/-/i18next-http-middleware-3.2.1.tgz" + integrity sha512-zBwXxDChT0YLoTXIR6jRuqnUUhXW0Iw7egoTnNXyaDRtTbfWNXwU0a53ThyuRPQ+k+tXu3ZMNKRzfLuononaRw== + +i18next-node-fs-backend@^2.1.3: + version "2.1.3" + resolved "https://registry.npmjs.org/i18next-node-fs-backend/-/i18next-node-fs-backend-2.1.3.tgz" + integrity sha512-CreMFiVl3ChlMc5ys/e0QfuLFOZyFcL40Jj6jaKD6DxZ/GCUMxPI9BpU43QMWUgC7r+PClpxg2cGXAl0CjG04g== + dependencies: + js-yaml "3.13.1" + json5 "2.0.0" + +i18next@>=17.0.11, i18next@^21.8.14: + version "21.8.14" + resolved "https://registry.npmjs.org/i18next/-/i18next-21.8.14.tgz" + integrity sha512-4Yi+DtexvMm/Yw3Q9fllzY12SgLk+Mcmar+rCAccsOPul/2UmnBzoHbTGn/L48IPkFcmrNaH7xTLboBWIbH6pw== + dependencies: + "@babel/runtime" "^7.17.2" + +iconv-lite@0.4.24: + version "0.4.24" + resolved "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz" + integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== + dependencies: + safer-buffer ">= 2.1.2 < 3" + +iconv-lite@^0.6.2, iconv-lite@^0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" + integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== + dependencies: + safer-buffer ">= 2.1.2 < 3.0.0" + +ieee754@^1.2.1: + version "1.2.1" + resolved "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz" + integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== + +image-size@^1.0.0: + version "1.0.2" + resolved "https://registry.npmjs.org/image-size/-/image-size-1.0.2.tgz" + integrity sha512-xfOoWjceHntRb3qFCrh5ZFORYH8XCdYpASltMhZ/Q0KZiOwjdE/Yl2QCiWdwD+lygV5bMCvauzgu5PxBX/Yerg== + dependencies: + queue "6.0.2" + +import-local@^3.0.2: + version "3.1.0" + resolved "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz" + integrity sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg== + dependencies: + pkg-dir "^4.2.0" + resolve-cwd "^3.0.0" + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz" + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== + +indent-string@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" + integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== + +infer-owner@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" + integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz" + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3: + version "2.0.4" + resolved "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +ini@^1.3.5: + version "1.3.8" + resolved "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz" + integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== + +interpret@^1.0.0: + version "1.4.0" + resolved "https://registry.npmjs.org/interpret/-/interpret-1.4.0.tgz" + integrity sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA== + +ip@^1.1.5: + version "1.1.8" + resolved "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz" + integrity sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg== + +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.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +is-arrayish@^0.2.1: + version "0.2.1" + resolved "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz" + integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== + +is-binary-path@~2.1.0: + version "2.1.0" + resolved "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz" + integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== + dependencies: + binary-extensions "^2.0.0" + +is-ci@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz" + integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== + dependencies: + ci-info "^2.0.0" + +is-core-module@^2.9.0: + version "2.9.0" + resolved "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz" + integrity sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A== + dependencies: + has "^1.0.3" + +is-docker@^2.0.0: + version "2.2.1" + resolved "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz" + integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== + +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + +is-fullwidth-code-point@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz" + integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== + +is-generator-fn@^2.0.0: + version "2.1.0" + resolved "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz" + integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== + +is-glob@^4.0.1, is-glob@~4.0.1: + version "4.0.3" + resolved "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + +is-lambda@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-lambda/-/is-lambda-1.0.1.tgz#3d9877899e6a53efc0160504cde15f82e6f061d5" + integrity sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ== + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-property@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-property/-/is-property-1.0.2.tgz#57fe1c4e48474edd65b09911f26b1cd4095dda84" + integrity sha512-Ks/IoX00TtClbGQr4TWXemAnktAQvYB7HzcCxDGqEZU6oCmb2INHuOoKxbtR+HFkmYWBKv/dOZtGRiAjDhj92g== + +is-stream@^2.0.0: + version "2.0.1" + resolved "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz" + integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== + +is-wsl@^2.1.1: + version "2.2.0" + resolved "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz" + integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== + dependencies: + is-docker "^2.0.0" + +isarray@0.0.1: + version "0.0.1" + resolved "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz" + integrity sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ== + +isarray@~1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz" + integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz" + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== + +istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: + version "3.2.0" + resolved "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz" + integrity sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw== + +istanbul-lib-instrument@^5.0.4, istanbul-lib-instrument@^5.1.0: + version "5.2.0" + resolved "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.0.tgz" + integrity sha512-6Lthe1hqXHBNsqvgDzGO6l03XNeu3CrG4RqQ1KM9+l5+jNGpEJfIELx1NS3SEHmJQA8np/u+E4EPRKRiu6m19A== + dependencies: + "@babel/core" "^7.12.3" + "@babel/parser" "^7.14.7" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-coverage "^3.2.0" + semver "^6.3.0" + +istanbul-lib-report@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz" + integrity sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw== + dependencies: + istanbul-lib-coverage "^3.0.0" + make-dir "^3.0.0" + supports-color "^7.1.0" + +istanbul-lib-source-maps@^4.0.0: + version "4.0.1" + resolved "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz" + integrity sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw== + dependencies: + debug "^4.1.1" + istanbul-lib-coverage "^3.0.0" + source-map "^0.6.1" + +istanbul-reports@^3.1.3: + version "3.1.5" + resolved "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz" + integrity sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w== + dependencies: + html-escaper "^2.0.0" + istanbul-lib-report "^3.0.0" + +jest-changed-files@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-28.1.3.tgz" + integrity sha512-esaOfUWJXk2nfZt9SPyC8gA1kNfdKLkQWyzsMlqq8msYSlNKfmZxfRgZn4Cd4MGVUF+7v6dBs0d5TOAKa7iIiA== + dependencies: + execa "^5.0.0" + p-limit "^3.1.0" + +jest-circus@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-circus/-/jest-circus-28.1.3.tgz" + integrity sha512-cZ+eS5zc79MBwt+IhQhiEp0OeBddpc1n8MBo1nMB8A7oPMKEO+Sre+wHaLJexQUj9Ya/8NOBY0RESUgYjB6fow== + dependencies: + "@jest/environment" "^28.1.3" + "@jest/expect" "^28.1.3" + "@jest/test-result" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + dedent "^0.7.0" + is-generator-fn "^2.0.0" + jest-each "^28.1.3" + jest-matcher-utils "^28.1.3" + jest-message-util "^28.1.3" + jest-runtime "^28.1.3" + jest-snapshot "^28.1.3" + jest-util "^28.1.3" + p-limit "^3.1.0" + pretty-format "^28.1.3" + slash "^3.0.0" + stack-utils "^2.0.3" + +jest-cli@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-cli/-/jest-cli-28.1.3.tgz" + integrity sha512-roY3kvrv57Azn1yPgdTebPAXvdR2xfezaKKYzVxZ6It/5NCxzJym6tUI5P1zkdWhfUYkxEI9uZWcQdaFLo8mJQ== + dependencies: + "@jest/core" "^28.1.3" + "@jest/test-result" "^28.1.3" + "@jest/types" "^28.1.3" + chalk "^4.0.0" + exit "^0.1.2" + graceful-fs "^4.2.9" + import-local "^3.0.2" + jest-config "^28.1.3" + jest-util "^28.1.3" + jest-validate "^28.1.3" + prompts "^2.0.1" + yargs "^17.3.1" + +jest-config@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-config/-/jest-config-28.1.3.tgz" + integrity sha512-MG3INjByJ0J4AsNBm7T3hsuxKQqFIiRo/AUqb1q9LRKI5UU6Aar9JHbr9Ivn1TVwfUD9KirRoM/T6u8XlcQPHQ== + dependencies: + "@babel/core" "^7.11.6" + "@jest/test-sequencer" "^28.1.3" + "@jest/types" "^28.1.3" + babel-jest "^28.1.3" + chalk "^4.0.0" + ci-info "^3.2.0" + deepmerge "^4.2.2" + glob "^7.1.3" + graceful-fs "^4.2.9" + jest-circus "^28.1.3" + jest-environment-node "^28.1.3" + jest-get-type "^28.0.2" + jest-regex-util "^28.0.2" + jest-resolve "^28.1.3" + jest-runner "^28.1.3" + jest-util "^28.1.3" + jest-validate "^28.1.3" + micromatch "^4.0.4" + parse-json "^5.2.0" + pretty-format "^28.1.3" + slash "^3.0.0" + strip-json-comments "^3.1.1" + +jest-diff@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-diff/-/jest-diff-28.1.3.tgz" + integrity sha512-8RqP1B/OXzjjTWkqMX67iqgwBVJRgCyKD3L9nq+6ZqJMdvjE8RgHktqZ6jNrkdMT+dJuYNI3rhQpxaz7drJHfw== + dependencies: + chalk "^4.0.0" + diff-sequences "^28.1.1" + jest-get-type "^28.0.2" + pretty-format "^28.1.3" + +jest-docblock@^28.1.1: + version "28.1.1" + resolved "https://registry.npmjs.org/jest-docblock/-/jest-docblock-28.1.1.tgz" + integrity sha512-3wayBVNiOYx0cwAbl9rwm5kKFP8yHH3d/fkEaL02NPTkDojPtheGB7HZSFY4wzX+DxyrvhXz0KSCVksmCknCuA== + dependencies: + detect-newline "^3.0.0" + +jest-each@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-each/-/jest-each-28.1.3.tgz" + integrity sha512-arT1z4sg2yABU5uogObVPvSlSMQlDA48owx07BDPAiasW0yYpYHYOo4HHLz9q0BVzDVU4hILFjzJw0So9aCL/g== + dependencies: + "@jest/types" "^28.1.3" + chalk "^4.0.0" + jest-get-type "^28.0.2" + jest-util "^28.1.3" + pretty-format "^28.1.3" + +jest-environment-node@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-28.1.3.tgz" + integrity sha512-ugP6XOhEpjAEhGYvp5Xj989ns5cB1K6ZdjBYuS30umT4CQEETaxSiPcZ/E1kFktX4GkrcM4qu07IIlDYX1gp+A== + dependencies: + "@jest/environment" "^28.1.3" + "@jest/fake-timers" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/node" "*" + jest-mock "^28.1.3" + jest-util "^28.1.3" + +jest-expect-message@^1.0.2: + version "1.0.2" + resolved "https://registry.npmjs.org/jest-expect-message/-/jest-expect-message-1.0.2.tgz" + integrity sha512-WFiXMgwS2lOqQZt1iJMI/hOXpUm32X+ApsuzYcQpW5m16Pv6/Gd9kgC+Q+Q1YVNU04kYcAOv9NXMnjg6kKUy6Q== + +jest-get-type@^28.0.2: + version "28.0.2" + resolved "https://registry.npmjs.org/jest-get-type/-/jest-get-type-28.0.2.tgz" + integrity sha512-ioj2w9/DxSYHfOm5lJKCdcAmPJzQXmbM/Url3rhlghrPvT3tt+7a/+oXc9azkKmLvoiXjtV83bEWqi+vs5nlPA== + +jest-haste-map@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-28.1.3.tgz" + integrity sha512-3S+RQWDXccXDKSWnkHa/dPwt+2qwA8CJzR61w3FoYCvoo3Pn8tvGcysmMF0Bj0EX5RYvAI2EIvC57OmotfdtKA== + dependencies: + "@jest/types" "^28.1.3" + "@types/graceful-fs" "^4.1.3" + "@types/node" "*" + anymatch "^3.0.3" + fb-watchman "^2.0.0" + graceful-fs "^4.2.9" + jest-regex-util "^28.0.2" + jest-util "^28.1.3" + jest-worker "^28.1.3" + micromatch "^4.0.4" + walker "^1.0.8" + optionalDependencies: + fsevents "^2.3.2" + +jest-leak-detector@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-28.1.3.tgz" + integrity sha512-WFVJhnQsiKtDEo5lG2mM0v40QWnBM+zMdHHyJs8AWZ7J0QZJS59MsyKeJHWhpBZBH32S48FOVvGyOFT1h0DlqA== + dependencies: + jest-get-type "^28.0.2" + pretty-format "^28.1.3" + +jest-matcher-utils@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-28.1.3.tgz" + integrity sha512-kQeJ7qHemKfbzKoGjHHrRKH6atgxMk8Enkk2iPQ3XwO6oE/KYD8lMYOziCkeSB9G4adPM4nR1DE8Tf5JeWH6Bw== + dependencies: + chalk "^4.0.0" + jest-diff "^28.1.3" + jest-get-type "^28.0.2" + pretty-format "^28.1.3" + +jest-message-util@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-message-util/-/jest-message-util-28.1.3.tgz" + integrity sha512-PFdn9Iewbt575zKPf1286Ht9EPoJmYT7P0kY+RibeYZ2XtOr53pDLEFoTWXbd1h4JiGiWpTBC84fc8xMXQMb7g== + dependencies: + "@babel/code-frame" "^7.12.13" + "@jest/types" "^28.1.3" + "@types/stack-utils" "^2.0.0" + chalk "^4.0.0" + graceful-fs "^4.2.9" + micromatch "^4.0.4" + pretty-format "^28.1.3" + slash "^3.0.0" + stack-utils "^2.0.3" + +jest-mock@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-mock/-/jest-mock-28.1.3.tgz" + integrity sha512-o3J2jr6dMMWYVH4Lh/NKmDXdosrsJgi4AviS8oXLujcjpCMBb1FMsblDnOXKZKfSiHLxYub1eS0IHuRXsio9eA== + dependencies: + "@jest/types" "^28.1.3" + "@types/node" "*" + +jest-pnp-resolver@^1.2.2: + version "1.2.2" + resolved "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz" + integrity sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w== + +jest-regex-util@^28.0.2: + version "28.0.2" + resolved "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-28.0.2.tgz" + integrity sha512-4s0IgyNIy0y9FK+cjoVYoxamT7Zeo7MhzqRGx7YDYmaQn1wucY9rotiGkBzzcMXTtjrCAP/f7f+E0F7+fxPNdw== + +jest-resolve-dependencies@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-28.1.3.tgz" + integrity sha512-qa0QO2Q0XzQoNPouMbCc7Bvtsem8eQgVPNkwn9LnS+R2n8DaVDPL/U1gngC0LTl1RYXJU0uJa2BMC2DbTfFrHA== + dependencies: + jest-regex-util "^28.0.2" + jest-snapshot "^28.1.3" + +jest-resolve@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-resolve/-/jest-resolve-28.1.3.tgz" + integrity sha512-Z1W3tTjE6QaNI90qo/BJpfnvpxtaFTFw5CDgwpyE/Kz8U/06N1Hjf4ia9quUhCh39qIGWF1ZuxFiBiJQwSEYKQ== + dependencies: + chalk "^4.0.0" + graceful-fs "^4.2.9" + jest-haste-map "^28.1.3" + jest-pnp-resolver "^1.2.2" + jest-util "^28.1.3" + jest-validate "^28.1.3" + resolve "^1.20.0" + resolve.exports "^1.1.0" + slash "^3.0.0" + +jest-runner@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-runner/-/jest-runner-28.1.3.tgz" + integrity sha512-GkMw4D/0USd62OVO0oEgjn23TM+YJa2U2Wu5zz9xsQB1MxWKDOlrnykPxnMsN0tnJllfLPinHTka61u0QhaxBA== + dependencies: + "@jest/console" "^28.1.3" + "@jest/environment" "^28.1.3" + "@jest/test-result" "^28.1.3" + "@jest/transform" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/node" "*" + chalk "^4.0.0" + emittery "^0.10.2" + graceful-fs "^4.2.9" + jest-docblock "^28.1.1" + jest-environment-node "^28.1.3" + jest-haste-map "^28.1.3" + jest-leak-detector "^28.1.3" + jest-message-util "^28.1.3" + jest-resolve "^28.1.3" + jest-runtime "^28.1.3" + jest-util "^28.1.3" + jest-watcher "^28.1.3" + jest-worker "^28.1.3" + p-limit "^3.1.0" + source-map-support "0.5.13" + +jest-runtime@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-runtime/-/jest-runtime-28.1.3.tgz" + integrity sha512-NU+881ScBQQLc1JHG5eJGU7Ui3kLKrmwCPPtYsJtBykixrM2OhVQlpMmFWJjMyDfdkGgBMNjXCGB/ebzsgNGQw== + dependencies: + "@jest/environment" "^28.1.3" + "@jest/fake-timers" "^28.1.3" + "@jest/globals" "^28.1.3" + "@jest/source-map" "^28.1.2" + "@jest/test-result" "^28.1.3" + "@jest/transform" "^28.1.3" + "@jest/types" "^28.1.3" + chalk "^4.0.0" + cjs-module-lexer "^1.0.0" + collect-v8-coverage "^1.0.0" + execa "^5.0.0" + glob "^7.1.3" + graceful-fs "^4.2.9" + jest-haste-map "^28.1.3" + jest-message-util "^28.1.3" + jest-mock "^28.1.3" + jest-regex-util "^28.0.2" + jest-resolve "^28.1.3" + jest-snapshot "^28.1.3" + jest-util "^28.1.3" + slash "^3.0.0" + strip-bom "^4.0.0" + +jest-snapshot@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-28.1.3.tgz" + integrity sha512-4lzMgtiNlc3DU/8lZfmqxN3AYD6GGLbl+72rdBpXvcV+whX7mDrREzkPdp2RnmfIiWBg1YbuFSkXduF2JcafJg== + dependencies: + "@babel/core" "^7.11.6" + "@babel/generator" "^7.7.2" + "@babel/plugin-syntax-typescript" "^7.7.2" + "@babel/traverse" "^7.7.2" + "@babel/types" "^7.3.3" + "@jest/expect-utils" "^28.1.3" + "@jest/transform" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/babel__traverse" "^7.0.6" + "@types/prettier" "^2.1.5" + babel-preset-current-node-syntax "^1.0.0" + chalk "^4.0.0" + expect "^28.1.3" + graceful-fs "^4.2.9" + jest-diff "^28.1.3" + jest-get-type "^28.0.2" + jest-haste-map "^28.1.3" + jest-matcher-utils "^28.1.3" + jest-message-util "^28.1.3" + jest-util "^28.1.3" + natural-compare "^1.4.0" + pretty-format "^28.1.3" + semver "^7.3.5" + +jest-util@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-util/-/jest-util-28.1.3.tgz" + integrity sha512-XdqfpHwpcSRko/C35uLYFM2emRAltIIKZiJ9eAmhjsj0CqZMa0p1ib0R5fWIqGhn1a103DebTbpqIaP1qCQ6tQ== + dependencies: + "@jest/types" "^28.1.3" + "@types/node" "*" + chalk "^4.0.0" + ci-info "^3.2.0" + graceful-fs "^4.2.9" + picomatch "^2.2.3" + +jest-validate@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-validate/-/jest-validate-28.1.3.tgz" + integrity sha512-SZbOGBWEsaTxBGCOpsRWlXlvNkvTkY0XxRfh7zYmvd8uL5Qzyg0CHAXiXKROflh801quA6+/DsT4ODDthOC/OA== + dependencies: + "@jest/types" "^28.1.3" + camelcase "^6.2.0" + chalk "^4.0.0" + jest-get-type "^28.0.2" + leven "^3.1.0" + pretty-format "^28.1.3" + +jest-watcher@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-watcher/-/jest-watcher-28.1.3.tgz" + integrity sha512-t4qcqj9hze+jviFPUN3YAtAEeFnr/azITXQEMARf5cMwKY2SMBRnCQTXLixTl20OR6mLh9KLMrgVJgJISym+1g== + dependencies: + "@jest/test-result" "^28.1.3" + "@jest/types" "^28.1.3" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + emittery "^0.10.2" + jest-util "^28.1.3" + string-length "^4.0.1" + +jest-worker@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest-worker/-/jest-worker-28.1.3.tgz" + integrity sha512-CqRA220YV/6jCo8VWvAt1KKx6eek1VIHMPeLEbpcfSfkEeWyBNppynM/o6q+Wmw+sOhos2ml34wZbSX3G13//g== + dependencies: + "@types/node" "*" + merge-stream "^2.0.0" + supports-color "^8.0.0" + +jest@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/jest/-/jest-28.1.3.tgz" + integrity sha512-N4GT5on8UkZgH0O5LUavMRV1EDEhNTL0KEfRmDIeZHSV7p2XgLoY9t9VDUgL6o+yfdgYHVxuz81G8oB9VG5uyA== + dependencies: + "@jest/core" "^28.1.3" + "@jest/types" "^28.1.3" + import-local "^3.0.2" + jest-cli "^28.1.3" + +js-tokens@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz" + integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== + +js-yaml@3.13.1, js-yaml@^3.13.1: + version "3.13.1" + resolved "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz" + integrity sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw== + dependencies: + argparse "^1.0.7" + esprima "^4.0.0" + +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + +jsesc@^2.5.1: + version "2.5.2" + resolved "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz" + integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== + +jsesc@~0.5.0: + version "0.5.0" + resolved "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz" + integrity sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA== + +json-parse-even-better-errors@^2.3.0: + version "2.3.1" + resolved "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz" + integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== + +json-schema-traverse@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz" + integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== + +json5@2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/json5/-/json5-2.0.0.tgz" + integrity sha512-0EdQvHuLm7yJ7lyG5dp7Q3X2ku++BG5ZHaJ5FTnaXpKqDrw4pMxel5Bt3oAYMthnrthFBdnZ1FcsXTPyrQlV0w== + dependencies: + minimist "^1.2.0" + +json5@^2.2.1: + version "2.2.1" + resolved "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz" + integrity sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA== + +jsonfile@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz" + integrity sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg== + optionalDependencies: + graceful-fs "^4.1.6" + +jsonwebtoken@^8.5.1: + version "8.5.1" + resolved "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz" + integrity sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w== + dependencies: + jws "^3.2.2" + lodash.includes "^4.3.0" + lodash.isboolean "^3.0.3" + lodash.isinteger "^4.0.4" + lodash.isnumber "^3.0.3" + lodash.isplainobject "^4.0.6" + lodash.isstring "^4.0.1" + lodash.once "^4.0.0" + ms "^2.1.1" + semver "^5.6.0" + +jwa@^1.4.1: + version "1.4.1" + resolved "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz" + integrity sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA== + dependencies: + buffer-equal-constant-time "1.0.1" + ecdsa-sig-formatter "1.0.11" + safe-buffer "^5.0.1" + +jws@^3.2.2: + version "3.2.2" + resolved "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz" + integrity sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA== + dependencies: + jwa "^1.4.1" + safe-buffer "^5.0.1" + +kind-of@^6.0.2: + version "6.0.3" + resolved "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz" + integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== + +klaw-sync@^6.0.0: + version "6.0.0" + resolved "https://registry.npmjs.org/klaw-sync/-/klaw-sync-6.0.0.tgz" + integrity sha512-nIeuVSzdCCs6TDPTqI8w1Yre34sSq7AkZ4B3sfOBbI2CgVSB4Du4aLQijFU2+lhAFCwt9+42Hel6lQNIv6AntQ== + dependencies: + graceful-fs "^4.1.11" + +kleur@^3.0.3: + version "3.0.3" + resolved "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" + integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== + +lambert-server@^1.2.12: + version "1.2.12" + resolved "https://registry.npmjs.org/lambert-server/-/lambert-server-1.2.12.tgz" + integrity sha512-TY6k60KLVfBpPrl9lcrN54RJdTBg9f8JqJPoHg5d/FMLnnwwQtT4budpoQjyLDwBLhS+zpXo0aBCwnnGgTVGaw== + dependencies: + body-parser "^1.19.0" + chalk "^4.1.1" + express "^4.17.1" + express-async-errors "^3.1.1" + helmet "^4.4.1" + missing-native-js-functions "^1.2.11" + +leven@^3.1.0: + version "3.1.0" + resolved "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz" + integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== + +levn@~0.3.0: + version "0.3.0" + resolved "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz" + integrity sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA== + dependencies: + prelude-ls "~1.1.2" + type-check "~0.3.2" + +lines-and-columns@^1.1.6: + version "1.2.4" + resolved "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz" + integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== + +locate-path@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz" + integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== + dependencies: + p-locate "^4.1.0" + +lodash.debounce@^4.0.8: + version "4.0.8" + resolved "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz" + integrity sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow== + +lodash.includes@^4.3.0: + version "4.3.0" + resolved "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz" + integrity sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w== + +lodash.isboolean@^3.0.3: + version "3.0.3" + resolved "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz" + integrity sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg== + +lodash.isinteger@^4.0.4: + version "4.0.4" + resolved "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz" + integrity sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA== + +lodash.isnumber@^3.0.3: + version "3.0.3" + resolved "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz" + integrity sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw== + +lodash.isplainobject@^4.0.6: + version "4.0.6" + resolved "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz" + integrity sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA== + +lodash.isstring@^4.0.1: + version "4.0.1" + resolved "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz" + integrity sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw== + +lodash.once@^4.0.0: + version "4.1.1" + resolved "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz" + integrity sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg== + +long@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28" + integrity sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA== + +lru-cache@^4.1.3: + version "4.1.5" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.5.tgz#8bbe50ea85bed59bc9e33dcab8235ee9bcf443cd" + integrity sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g== + dependencies: + pseudomap "^1.0.2" + yallist "^2.1.2" + +lru-cache@^5.1.1: + version "5.1.1" + resolved "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz" + integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== + dependencies: + yallist "^3.0.2" + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +lru_map@^0.3.3: + version "0.3.3" + resolved "https://registry.npmjs.org/lru_map/-/lru_map-0.3.3.tgz" + integrity sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ== + +make-dir@^3.0.0, make-dir@^3.1.0: + version "3.1.0" + resolved "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz" + integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== + dependencies: + semver "^6.0.0" + +make-error@^1.1.1: + version "1.3.6" + resolved "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz" + integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== + +make-fetch-happen@^9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/make-fetch-happen/-/make-fetch-happen-9.1.0.tgz#53085a09e7971433e6765f7971bf63f4e05cb968" + integrity sha512-+zopwDy7DNknmwPQplem5lAZX/eCOzSvSNNcSKm5eVwTkOBzoktEfXsa9L23J/GIRhxRsaxzkPEhrJEpE2F4Gg== + dependencies: + agentkeepalive "^4.1.3" + cacache "^15.2.0" + http-cache-semantics "^4.1.0" + http-proxy-agent "^4.0.1" + https-proxy-agent "^5.0.0" + is-lambda "^1.0.1" + lru-cache "^6.0.0" + minipass "^3.1.3" + minipass-collect "^1.0.2" + minipass-fetch "^1.3.2" + minipass-flush "^1.0.5" + minipass-pipeline "^1.2.4" + negotiator "^0.6.2" + promise-retry "^2.0.1" + socks-proxy-agent "^6.0.0" + ssri "^8.0.0" + +makeerror@1.0.12: + version "1.0.12" + resolved "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz" + integrity sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg== + dependencies: + tmpl "1.0.5" + +media-typer@0.3.0: + version "0.3.0" + resolved "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz" + integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== + +merge-descriptors@1.0.1: + version "1.0.1" + resolved "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz" + integrity sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w== + +merge-stream@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz" + integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== + +methods@^1.1.2, methods@~1.1.2: + version "1.1.2" + resolved "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" + integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== + +micromatch@^4.0.2, micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz" + 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.npmjs.org/mime-db/-/mime-db-1.52.0.tgz" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-types@^2.1.12, mime-types@~2.1.24, mime-types@~2.1.34: + version "2.1.35" + resolved "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + +mime@1.6.0: + version "1.6.0" + resolved "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz" + integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== + +mime@2.6.0: + version "2.6.0" + resolved "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz" + integrity sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg== + +mimic-fn@^2.1.0: + version "2.1.0" + resolved "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz" + integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== + +mimic-response@^2.0.0: + version "2.1.0" + resolved "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz" + integrity sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA== + +minimatch@^3.0.4, minimatch@^3.1.1: + version "3.1.2" + resolved "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +minimatch@^5.0.1: + version "5.1.0" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.0.tgz#1717b464f4971b144f6aabe8f2d0b8e4511e09c7" + integrity sha512-9TPBGGak4nHfGZsPBohm9AWg6NoT7QTCehS3BIJABslyZbzxfV78QM2Y6+i741OPZIafFAaiiEMh5OyIrJPgtg== + dependencies: + brace-expansion "^2.0.1" + +minimist@^1.2.0, minimist@^1.2.6: + version "1.2.6" + resolved "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz" + integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== + +minipass-collect@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" + integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== + dependencies: + minipass "^3.0.0" + +minipass-fetch@^1.3.2: + version "1.4.1" + resolved "https://registry.yarnpkg.com/minipass-fetch/-/minipass-fetch-1.4.1.tgz#d75e0091daac1b0ffd7e9d41629faff7d0c1f1b6" + integrity sha512-CGH1eblLq26Y15+Azk7ey4xh0J/XfJfrCox5LDJiKqI2Q2iwOLOKrlmIaODiSQS8d18jalF6y2K2ePUm0CmShw== + dependencies: + minipass "^3.1.0" + minipass-sized "^1.0.3" + minizlib "^2.0.0" + optionalDependencies: + encoding "^0.1.12" + +minipass-flush@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" + integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== + dependencies: + minipass "^3.0.0" + +minipass-pipeline@^1.2.2, minipass-pipeline@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" + integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== + dependencies: + minipass "^3.0.0" + +minipass-sized@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/minipass-sized/-/minipass-sized-1.0.3.tgz#70ee5a7c5052070afacfbc22977ea79def353b70" + integrity sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g== + dependencies: + minipass "^3.0.0" + +minipass@^3.0.0, minipass@^3.1.0, minipass@^3.1.1, minipass@^3.1.3: + version "3.3.4" + resolved "https://registry.npmjs.org/minipass/-/minipass-3.3.4.tgz" + integrity sha512-I9WPbWHCGu8W+6k1ZiGpPu0GkoKBeorkfKNuAFBNS1HNFJvke82sxvI5bzcCNpWPorkOO5QQ+zomzzwRxejXiw== + dependencies: + yallist "^4.0.0" + +minizlib@^2.0.0, minizlib@^2.1.1: + version "2.1.2" + resolved "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz" + integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== + dependencies: + minipass "^3.0.0" + yallist "^4.0.0" + +missing-native-js-functions@^1.2.11, missing-native-js-functions@^1.2.18: + version "1.2.18" + resolved "https://registry.npmjs.org/missing-native-js-functions/-/missing-native-js-functions-1.2.18.tgz" + integrity sha512-TZr1muzDE4kfu0LHDzg63O7m2qW3Gpyc875ki8+YlSRj+4ibZRv0ySQ0cSB06GoBL9ejeehLmkQnybLpp9jYcg== + +mkdirp@^0.5.4: + version "0.5.6" + resolved "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz" + integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== + dependencies: + minimist "^1.2.6" + +mkdirp@^1.0.3, mkdirp@^1.0.4: + version "1.0.4" + resolved "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz" + integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== + +morgan@^1.10.0: + version "1.10.0" + resolved "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz" + integrity sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ== + dependencies: + basic-auth "~2.0.1" + debug "2.6.9" + depd "~2.0.0" + on-finished "~2.3.0" + on-headers "~1.0.2" + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz" + integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== + +ms@2.1.2, ms@^2.1.1: + version "2.1.2" + resolved "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@2.1.3, ms@^2.0.0: + version "2.1.3" + resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +multer@^1.4.5-lts.1: + version "1.4.5-lts.1" + resolved "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.1.tgz" + integrity sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ== + dependencies: + append-field "^1.0.0" + busboy "^1.0.0" + concat-stream "^1.5.2" + mkdirp "^0.5.4" + object-assign "^4.1.1" + type-is "^1.6.4" + xtend "^4.0.0" + +mysql2@^2.3.3: + version "2.3.3" + resolved "https://registry.yarnpkg.com/mysql2/-/mysql2-2.3.3.tgz#944f3deca4b16629052ff8614fbf89d5552545a0" + integrity sha512-wxJUev6LgMSgACDkb/InIFxDprRa6T95+VEoR+xPvtngtccNH2dGjEB/fVZ8yg1gWv1510c9CvXuJHi5zUm0ZA== + dependencies: + denque "^2.0.1" + generate-function "^2.3.1" + iconv-lite "^0.6.3" + long "^4.0.0" + lru-cache "^6.0.0" + named-placeholders "^1.1.2" + seq-queue "^0.0.5" + sqlstring "^2.3.2" + +mz@^2.4.0: + version "2.7.0" + resolved "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz" + integrity sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q== + dependencies: + any-promise "^1.0.0" + object-assign "^4.0.1" + thenify-all "^1.0.0" + +named-placeholders@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/named-placeholders/-/named-placeholders-1.1.2.tgz#ceb1fbff50b6b33492b5cf214ccf5e39cef3d0e8" + integrity sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA== + dependencies: + lru-cache "^4.1.3" + +nan@^2.15.0: + version "2.16.0" + resolved "https://registry.npmjs.org/nan/-/nan-2.16.0.tgz" + integrity sha512-UdAqHyFngu7TfQKsCBgAA6pWDkT8MAO7d0jyOecVhN5354xbLqdn8mV9Tat9gepAupm0bt2DbeaSC8vS52MuFA== + +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz" + integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== + +negotiator@0.6.3, negotiator@^0.6.2: + version "0.6.3" + resolved "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz" + integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + +netmask@^2.0.2: + version "2.0.2" + resolved "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz" + integrity sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg== + +nice-try@^1.0.4: + version "1.0.5" + resolved "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz" + integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== + +node-2fa@^2.0.3: + version "2.0.3" + resolved "https://registry.npmjs.org/node-2fa/-/node-2fa-2.0.3.tgz" + integrity sha512-PQldrOhjuoZyoydMvMSctllPN1ZPZ1/NwkEcgYwY9faVqE/OymxR+3awPpbWZxm6acLKqvmNqQmdqTsqYyflFw== + dependencies: + "@types/notp" "^2.0.0" + notp "^2.0.3" + thirty-two "1.0.2" + tslib "^2.1.0" + +node-addon-api@^3.1.0: + version "3.2.1" + resolved "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz" + integrity sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A== + +node-addon-api@^4.2.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-4.3.0.tgz#52a1a0b475193e0928e98e0426a0d1254782b77f" + integrity sha512-73sE9+3UaLYYFmDsFZnqCInzPyh3MqIwZO9cw58yIqAZhONrrabrYyYe3TuIqtIiOuTXVhsGau8hcrhhwSsDIQ== + +node-fetch@^2.6.7: + version "2.6.7" + resolved "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz" + integrity sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ== + dependencies: + whatwg-url "^5.0.0" + +node-gyp@8.x: + version "8.4.1" + resolved "https://registry.yarnpkg.com/node-gyp/-/node-gyp-8.4.1.tgz#3d49308fc31f768180957d6b5746845fbd429937" + integrity sha512-olTJRgUtAb/hOXG0E93wZDs5YiJlgbXxTwQAFHyNlRsXQnYzUaF2aGgujZbw+hR8aF4ZG/rST57bWMWD16jr9w== + dependencies: + env-paths "^2.2.0" + glob "^7.1.4" + graceful-fs "^4.2.6" + make-fetch-happen "^9.1.0" + nopt "^5.0.0" + npmlog "^6.0.0" + rimraf "^3.0.2" + semver "^7.3.5" + tar "^6.1.2" + which "^2.0.2" + +node-int64@^0.4.0: + version "0.4.0" + resolved "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz" + integrity sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw== + +node-releases@^2.0.6: + version "2.0.6" + resolved "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz" + integrity sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg== + +nopt@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz" + integrity sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ== + dependencies: + abbrev "1" + +normalize-path@^3.0.0, normalize-path@~3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" + integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== + +notp@^2.0.3: + version "2.0.3" + resolved "https://registry.npmjs.org/notp/-/notp-2.0.3.tgz" + integrity sha512-oBig/2uqkjQ5AkBuw4QJYwkEWa/q+zHxI5/I5z6IeP2NT0alpJFsP/trrfCC+9xOAgQSZXssNi962kp5KBmypQ== + +npm-run-path@^4.0.1: + version "4.0.1" + resolved "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz" + integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== + dependencies: + path-key "^3.0.0" + +npmlog@^5.0.1: + version "5.0.1" + resolved "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz" + integrity sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw== + dependencies: + are-we-there-yet "^2.0.0" + console-control-strings "^1.1.0" + gauge "^3.0.0" + set-blocking "^2.0.0" + +npmlog@^6.0.0: + version "6.0.2" + resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-6.0.2.tgz#c8166017a42f2dea92d6453168dd865186a70830" + integrity sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg== + dependencies: + are-we-there-yet "^3.0.0" + console-control-strings "^1.1.0" + gauge "^4.0.3" + set-blocking "^2.0.0" + +nth-check@^2.0.1: + version "2.1.1" + resolved "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz" + integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w== + dependencies: + boolbase "^1.0.0" + +object-assign@^4.0.1, object-assign@^4.1.1: + version "4.1.1" + resolved "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz" + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== + +object-inspect@^1.9.0: + version "1.12.2" + resolved "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz" + integrity sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ== + +object-keys@^1.1.1: + version "1.1.1" + resolved "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz" + integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== + +object.assign@^4.1.0: + version "4.1.2" + resolved "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz" + integrity sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ== + dependencies: + call-bind "^1.0.0" + define-properties "^1.1.3" + has-symbols "^1.0.1" + object-keys "^1.1.1" + +on-finished@2.4.1: + version "2.4.1" + resolved "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz" + integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== + dependencies: + ee-first "1.1.1" + +on-finished@~2.3.0: + version "2.3.0" + resolved "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz" + integrity sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww== + dependencies: + ee-first "1.1.1" + +on-headers@~1.0.2: + version "1.0.2" + resolved "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz" + integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== + +once@1.4.0, once@^1.3.0, once@^1.3.1: + version "1.4.0" + resolved "https://registry.npmjs.org/once/-/once-1.4.0.tgz" + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== + dependencies: + wrappy "1" + +onetime@^5.1.2: + version "5.1.2" + resolved "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz" + integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== + dependencies: + mimic-fn "^2.1.0" + +open@^7.4.2: + version "7.4.2" + resolved "https://registry.npmjs.org/open/-/open-7.4.2.tgz" + integrity sha512-MVHddDVweXZF3awtlAS+6pgKLlm/JgxZ90+/NBurBoQctVOOB/zDdVjcyPzQ+0laDGbsWgrRkflI65sQeOgT9Q== + dependencies: + is-docker "^2.0.0" + is-wsl "^2.1.1" + +optionator@^0.8.1: + version "0.8.3" + resolved "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz" + integrity sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA== + dependencies: + deep-is "~0.1.3" + fast-levenshtein "~2.0.6" + levn "~0.3.0" + prelude-ls "~1.1.2" + type-check "~0.3.2" + word-wrap "~1.2.3" + +os-tmpdir@~1.0.2: + version "1.0.2" + resolved "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz" + integrity sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g== + +p-limit@^2.2.0: + version "2.3.0" + resolved "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz" + integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== + dependencies: + p-try "^2.0.0" + +p-limit@^3.1.0: + version "3.1.0" + resolved "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-locate@^4.1.0: + version "4.1.0" + resolved "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz" + integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== + dependencies: + p-limit "^2.2.0" + +p-map@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" + integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== + dependencies: + aggregate-error "^3.0.0" + +p-try@^2.0.0: + version "2.2.0" + resolved "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz" + integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== + +pac-proxy-agent@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz" + integrity sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ== + dependencies: + "@tootallnate/once" "1" + agent-base "6" + debug "4" + get-uri "3" + http-proxy-agent "^4.0.1" + https-proxy-agent "5" + pac-resolver "^5.0.0" + raw-body "^2.2.0" + socks-proxy-agent "5" + +pac-resolver@^5.0.0: + version "5.0.1" + resolved "https://registry.npmjs.org/pac-resolver/-/pac-resolver-5.0.1.tgz" + integrity sha512-cy7u00ko2KVgBAjuhevqpPeHIkCIqPe1v24cydhWjmeuzaBfmUWFCZJ1iAh5TuVzVZoUzXIW7K8sMYOZ84uZ9Q== + dependencies: + degenerator "^3.0.2" + ip "^1.1.5" + netmask "^2.0.2" + +packet-reader@1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/packet-reader/-/packet-reader-1.0.0.tgz#9238e5480dedabacfe1fe3f2771063f164157d74" + integrity sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ== + +parse-json@^5.2.0: + version "5.2.0" + resolved "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz" + integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== + dependencies: + "@babel/code-frame" "^7.0.0" + error-ex "^1.3.1" + json-parse-even-better-errors "^2.3.0" + lines-and-columns "^1.1.6" + +parse5-htmlparser2-tree-adapter@^6.0.0: + version "6.0.1" + resolved "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz" + integrity sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA== + dependencies: + parse5 "^6.0.1" + +parse5-htmlparser2-tree-adapter@^7.0.0: + version "7.0.0" + resolved "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz" + integrity sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g== + dependencies: + domhandler "^5.0.2" + parse5 "^7.0.0" + +parse5@^5.1.1: + version "5.1.1" + resolved "https://registry.npmjs.org/parse5/-/parse5-5.1.1.tgz" + integrity sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug== + +parse5@^6.0.1: + version "6.0.1" + resolved "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz" + integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== + +parse5@^7.0.0: + version "7.0.0" + resolved "https://registry.npmjs.org/parse5/-/parse5-7.0.0.tgz" + integrity sha512-y/t8IXSPWTuRZqXc0ajH/UwDj4mnqLEbSttNbThcFhGrZuOyoyvNBO85PBp2jQa55wY9d07PBNjsK8ZP3K5U6g== + dependencies: + entities "^4.3.0" + +parseurl@~1.3.3: + version "1.3.3" + resolved "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz" + integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== + +patch-package@^6.4.7: + version "6.4.7" + resolved "https://registry.npmjs.org/patch-package/-/patch-package-6.4.7.tgz" + integrity sha512-S0vh/ZEafZ17hbhgqdnpunKDfzHQibQizx9g8yEf5dcVk3KOflOfdufRXQX8CSEkyOQwuM/bNz1GwKvFj54kaQ== + dependencies: + "@yarnpkg/lockfile" "^1.1.0" + chalk "^2.4.2" + cross-spawn "^6.0.5" + find-yarn-workspace-root "^2.0.0" + fs-extra "^7.0.1" + is-ci "^2.0.0" + klaw-sync "^6.0.0" + minimist "^1.2.0" + open "^7.4.2" + rimraf "^2.6.3" + semver "^5.6.0" + slash "^2.0.0" + tmp "^0.0.33" + +path-equal@^1.1.2: + version "1.2.2" + resolved "https://registry.npmjs.org/path-equal/-/path-equal-1.2.2.tgz" + integrity sha512-AUJvbcle1Zgb1TgtftHYknlrgrSYyI1ytrYgSbKUHSybwqUDnbD2cw9PIWivuMvsN+GTXmr/DRN4VBXpHG6aGg== + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz" + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== + +path-key@^2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz" + integrity sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw== + +path-key@^3.0.0, path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== + +path-to-regexp@0.1.7: + version "0.1.7" + resolved "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" + integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== + +peek-readable@^4.1.0: + version "4.1.0" + resolved "https://registry.npmjs.org/peek-readable/-/peek-readable-4.1.0.tgz" + integrity sha512-ZI3LnwUv5nOGbQzD9c2iDG6toheuXSZP5esSHBjopsXH4dg19soufvpUGA3uohi5anFtGb2lhAVdHzH6R/Evvg== + +pg-connection-string@^2.5.0: + version "2.5.0" + resolved "https://registry.yarnpkg.com/pg-connection-string/-/pg-connection-string-2.5.0.tgz#538cadd0f7e603fc09a12590f3b8a452c2c0cf34" + integrity sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ== + +pg-int8@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/pg-int8/-/pg-int8-1.0.1.tgz#943bd463bf5b71b4170115f80f8efc9a0c0eb78c" + integrity sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw== + +pg-pool@^3.5.1: + version "3.5.1" + resolved "https://registry.yarnpkg.com/pg-pool/-/pg-pool-3.5.1.tgz#f499ce76f9bf5097488b3b83b19861f28e4ed905" + integrity sha512-6iCR0wVrro6OOHFsyavV+i6KYL4lVNyYAB9RD18w66xSzN+d8b66HiwuP30Gp1SH5O9T82fckkzsRjlrhD0ioQ== + +pg-protocol@^1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/pg-protocol/-/pg-protocol-1.5.0.tgz#b5dd452257314565e2d54ab3c132adc46565a6a0" + integrity sha512-muRttij7H8TqRNu/DxrAJQITO4Ac7RmX3Klyr/9mJEOBeIpgnF8f9jAfRz5d3XwQZl5qBjF9gLsUtMPJE0vezQ== + +pg-types@^2.1.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/pg-types/-/pg-types-2.2.0.tgz#2d0250d636454f7cfa3b6ae0382fdfa8063254a3" + integrity sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA== + dependencies: + pg-int8 "1.0.1" + postgres-array "~2.0.0" + postgres-bytea "~1.0.0" + postgres-date "~1.0.4" + postgres-interval "^1.1.0" + +pg@^8.7.3: + version "8.7.3" + resolved "https://registry.yarnpkg.com/pg/-/pg-8.7.3.tgz#8a5bdd664ca4fda4db7997ec634c6e5455b27c44" + integrity sha512-HPmH4GH4H3AOprDJOazoIcpI49XFsHCe8xlrjHkWiapdbHK+HLtbm/GQzXYAZwmPju/kzKhjaSfMACG+8cgJcw== + dependencies: + buffer-writer "2.0.0" + packet-reader "1.0.0" + pg-connection-string "^2.5.0" + pg-pool "^3.5.1" + pg-protocol "^1.5.0" + pg-types "^2.1.0" + pgpass "1.x" + +pgpass@1.x: + version "1.0.5" + resolved "https://registry.yarnpkg.com/pgpass/-/pgpass-1.0.5.tgz#9b873e4a564bb10fa7a7dbd55312728d422a223d" + integrity sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug== + dependencies: + split2 "^4.1.0" + +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.3, picomatch@^2.3.1: + version "2.3.1" + resolved "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + +pirates@^4.0.4: + version "4.0.5" + resolved "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz" + integrity sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ== + +pkg-dir@^4.2.0: + version "4.2.0" + resolved "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz" + integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== + dependencies: + find-up "^4.0.0" + +postgres-array@~2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/postgres-array/-/postgres-array-2.0.0.tgz#48f8fce054fbc69671999329b8834b772652d82e" + integrity sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA== + +postgres-bytea@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/postgres-bytea/-/postgres-bytea-1.0.0.tgz#027b533c0aa890e26d172d47cf9ccecc521acd35" + integrity sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w== + +postgres-date@~1.0.4: + version "1.0.7" + resolved "https://registry.yarnpkg.com/postgres-date/-/postgres-date-1.0.7.tgz#51bc086006005e5061c591cee727f2531bf641a8" + integrity sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q== + +postgres-interval@^1.1.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/postgres-interval/-/postgres-interval-1.2.0.tgz#b460c82cb1587507788819a06aa0fffdb3544695" + integrity sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ== + dependencies: + xtend "^4.0.0" + +prelude-ls@~1.1.2: + version "1.1.2" + resolved "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz" + integrity sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w== + +pretty-format@^28.1.3: + version "28.1.3" + resolved "https://registry.npmjs.org/pretty-format/-/pretty-format-28.1.3.tgz" + integrity sha512-8gFb/To0OmxHR9+ZTb14Df2vNxdGCX8g1xWGUTqUw5TiZvcQf5sHKObd5UcPyLLyowNwDAMTF3XWOG1B6mxl1Q== + dependencies: + "@jest/schemas" "^28.1.3" + ansi-regex "^5.0.1" + ansi-styles "^5.0.0" + react-is "^18.0.0" + +process-nextick-args@~2.0.0: + version "2.0.1" + resolved "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz" + integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== + +promise-inflight@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" + integrity sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g== + +promise-retry@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/promise-retry/-/promise-retry-2.0.1.tgz#ff747a13620ab57ba688f5fc67855410c370da22" + integrity sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g== + dependencies: + err-code "^2.0.2" + retry "^0.12.0" + +prompts@^2.0.1: + version "2.4.2" + resolved "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz" + integrity sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q== + dependencies: + kleur "^3.0.3" + sisteransi "^1.0.5" + +proxy-addr@~2.0.7: + version "2.0.7" + resolved "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz" + integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== + dependencies: + forwarded "0.2.0" + ipaddr.js "1.9.1" + +proxy-agent@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/proxy-agent/-/proxy-agent-5.0.0.tgz" + integrity sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g== + dependencies: + agent-base "^6.0.0" + debug "4" + http-proxy-agent "^4.0.0" + https-proxy-agent "^5.0.0" + lru-cache "^5.1.1" + pac-proxy-agent "^5.0.0" + proxy-from-env "^1.0.0" + socks-proxy-agent "^5.0.0" + +proxy-from-env@^1.0.0: + version "1.1.0" + resolved "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz" + integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== + +pseudomap@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3" + integrity sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ== + +punycode@^2.1.0: + version "2.1.1" + resolved "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz" + integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== + +qs@6.10.3, qs@^6.10.3: + version "6.10.3" + resolved "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz" + integrity sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ== + dependencies: + side-channel "^1.0.4" + +qs@6.9.3: + version "6.9.3" + resolved "https://registry.npmjs.org/qs/-/qs-6.9.3.tgz" + integrity sha512-EbZYNarm6138UKKq46tdx08Yo/q9ZhFoAXAI1meAFd2GtbRDhbZY2WQSICskT0c5q99aFzLG1D4nvTk9tqfXIw== + +querystringify@^2.1.1: + version "2.2.0" + resolved "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz" + integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== + +queue@6.0.2: + version "6.0.2" + resolved "https://registry.npmjs.org/queue/-/queue-6.0.2.tgz" + integrity sha512-iHZWu+q3IdFZFX36ro/lKBkSvfkztY5Y7HMiPlOUjhupPcG2JMfst2KKEpu5XndviX/3UhFbRngUPNKtgvtZiA== + dependencies: + inherits "~2.0.3" + +range-parser@~1.2.1: + version "1.2.1" + resolved "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz" + integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== + +raw-body@2.5.1, raw-body@^2.2.0: + version "2.5.1" + resolved "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz" + integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== + dependencies: + bytes "3.1.2" + http-errors "2.0.0" + iconv-lite "0.4.24" + unpipe "1.0.0" + +react-is@^18.0.0: + version "18.2.0" + resolved "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz" + integrity sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w== + +readable-stream@1.1.x, "readable-stream@1.x >=1.1.9": + version "1.1.14" + resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz" + integrity sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.1" + isarray "0.0.1" + string_decoder "~0.10.x" + +readable-stream@^2.2.2: + version "2.3.7" + resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz" + integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== + dependencies: + core-util-is "~1.0.0" + inherits "~2.0.3" + isarray "~1.0.0" + process-nextick-args "~2.0.0" + safe-buffer "~5.1.1" + string_decoder "~1.1.1" + util-deprecate "~1.0.1" + +readable-stream@^3.6.0: + version "3.6.0" + resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz" + integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== + dependencies: + inherits "^2.0.3" + string_decoder "^1.1.1" + util-deprecate "^1.0.1" + +readable-web-to-node-stream@^3.0.0: + version "3.0.2" + resolved "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz" + integrity sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw== + dependencies: + readable-stream "^3.6.0" + +readdirp@~3.6.0: + version "3.6.0" + resolved "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz" + integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== + dependencies: + picomatch "^2.2.1" + +rechoir@^0.6.2: + version "0.6.2" + resolved "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz" + integrity sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw== + dependencies: + resolve "^1.1.6" + +reflect-metadata@^0.1.13: + version "0.1.13" + resolved "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz" + integrity sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg== + +regenerate-unicode-properties@^10.0.1: + version "10.0.1" + resolved "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz" + integrity sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw== + dependencies: + regenerate "^1.4.2" + +regenerate@^1.4.2: + version "1.4.2" + resolved "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz" + integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== + +regenerator-runtime@^0.13.4: + version "0.13.9" + resolved "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz" + integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== + +regenerator-transform@^0.15.0: + version "0.15.0" + resolved "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz" + integrity sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg== + dependencies: + "@babel/runtime" "^7.8.4" + +regexpu-core@^5.1.0: + version "5.1.0" + resolved "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz" + integrity sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA== + dependencies: + regenerate "^1.4.2" + regenerate-unicode-properties "^10.0.1" + regjsgen "^0.6.0" + regjsparser "^0.8.2" + unicode-match-property-ecmascript "^2.0.0" + unicode-match-property-value-ecmascript "^2.0.0" + +regjsgen@^0.6.0: + version "0.6.0" + resolved "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz" + integrity sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA== + +regjsparser@^0.8.2: + version "0.8.4" + resolved "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz" + integrity sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA== + dependencies: + jsesc "~0.5.0" + +require-directory@^2.1.1: + version "2.1.1" + resolved "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz" + integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q== + +require-from-string@^2.0.2: + version "2.0.2" + resolved "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz" + integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== + +requires-port@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz" + integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== + +resolve-cwd@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz" + integrity sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg== + dependencies: + resolve-from "^5.0.0" + +resolve-from@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz" + integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw== + +resolve.exports@^1.1.0: + version "1.1.0" + resolved "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz" + integrity sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ== + +resolve@^1.0.0, resolve@^1.1.6, resolve@^1.12.0, resolve@^1.14.2, resolve@^1.20.0, resolve@^1.22.1: + version "1.22.1" + resolved "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz" + integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw== + dependencies: + is-core-module "^2.9.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +retry@^0.12.0: + version "0.12.0" + resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" + integrity sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow== + +rimraf@^2.6.1, rimraf@^2.6.3: + version "2.7.1" + resolved "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz" + integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== + dependencies: + glob "^7.1.3" + +rimraf@^3.0.0, rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1, safe-buffer@~5.1.2: + version "5.1.2" + resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" + integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== + +safe-buffer@5.2.1, safe-buffer@^5.0.1, safe-buffer@~5.2.0: + version "5.2.1" + resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" + integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== + +safe-stable-stringify@^2.2.0: + version "2.3.1" + resolved "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.3.1.tgz" + integrity sha512-kYBSfT+troD9cDA85VDnHZ1rpHC50O0g1e6WlGHVCz/g+JS+9WKLj+XwFYyR8UbrZN8ll9HUpDAAddY58MGisg== + +"safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0": + version "2.1.2" + resolved "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +sax@>=0.6.0: + version "1.2.4" + resolved "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz" + integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== + +semver@7.0.0: + version "7.0.0" + resolved "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz" + integrity sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A== + +semver@^5.5.0, semver@^5.6.0: + version "5.7.1" + resolved "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz" + integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== + +semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.3.0: + version "6.3.0" + resolved "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz" + integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== + +semver@^7.3.5, semver@^7.3.7: + version "7.3.7" + resolved "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz" + integrity sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g== + dependencies: + lru-cache "^6.0.0" + +send@0.18.0: + version "0.18.0" + resolved "https://registry.npmjs.org/send/-/send-0.18.0.tgz" + integrity sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg== + dependencies: + debug "2.6.9" + depd "2.0.0" + destroy "1.2.0" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + fresh "0.5.2" + http-errors "2.0.0" + mime "1.6.0" + ms "2.1.3" + on-finished "2.4.1" + range-parser "~1.2.1" + statuses "2.0.1" + +seq-queue@^0.0.5: + version "0.0.5" + resolved "https://registry.yarnpkg.com/seq-queue/-/seq-queue-0.0.5.tgz#d56812e1c017a6e4e7c3e3a37a1da6d78dd3c93e" + integrity sha512-hr3Wtp/GZIc/6DAGPDcV4/9WoZhjrkXsi5B/07QgX8tsdc6ilr7BFM6PM6rbdAX1kFSDYeZGLipIZZKyQP0O5Q== + +serve-static@1.15.0: + version "1.15.0" + resolved "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz" + integrity sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g== + dependencies: + encodeurl "~1.0.2" + escape-html "~1.0.3" + parseurl "~1.3.3" + send "0.18.0" + +set-blocking@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz" + integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== + +setprototypeof@1.2.0: + version "1.2.0" + resolved "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz" + integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== + +sha.js@^2.4.11: + version "2.4.11" + resolved "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz" + integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== + dependencies: + inherits "^2.0.1" + safe-buffer "^5.0.1" + +shebang-command@^1.2.0: + version "1.2.0" + resolved "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz" + integrity sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg== + dependencies: + shebang-regex "^1.0.0" + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz" + integrity sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ== + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +shelljs@^0.8.5: + version "0.8.5" + resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.5.tgz#de055408d8361bed66c669d2f000538ced8ee20c" + integrity sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow== + dependencies: + glob "^7.0.0" + interpret "^1.0.0" + rechoir "^0.6.2" + +side-channel@^1.0.4: + version "1.0.4" + resolved "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz" + integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== + dependencies: + call-bind "^1.0.0" + get-intrinsic "^1.0.2" + object-inspect "^1.9.0" + +signal-exit@^3.0.0, signal-exit@^3.0.3, signal-exit@^3.0.7: + version "3.0.7" + resolved "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz" + integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== + +simple-concat@^1.0.0: + version "1.0.1" + resolved "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz" + integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== + +simple-get@^3.0.3: + version "3.1.1" + resolved "https://registry.npmjs.org/simple-get/-/simple-get-3.1.1.tgz" + integrity sha512-CQ5LTKGfCpvE1K0n2us+kuMPbk/q0EKl82s4aheV9oXjFEz6W/Y7oQFVJuU6QG77hRT4Ghb5RURteF5vnWjupA== + dependencies: + decompress-response "^4.2.0" + once "^1.3.1" + simple-concat "^1.0.0" + +sisteransi@^1.0.5: + version "1.0.5" + resolved "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz" + integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg== + +slash@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz" + integrity sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A== + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +smart-buffer@^4.2.0: + version "4.2.0" + resolved "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz" + integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg== + +socks-proxy-agent@5, socks-proxy-agent@^5.0.0: + version "5.0.1" + resolved "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz" + integrity sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ== + dependencies: + agent-base "^6.0.2" + debug "4" + socks "^2.3.3" + +socks-proxy-agent@^6.0.0: + version "6.2.1" + resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-6.2.1.tgz#2687a31f9d7185e38d530bef1944fe1f1496d6ce" + integrity sha512-a6KW9G+6B3nWZ1yB8G7pJwL3ggLy1uTzKAgCb7ttblwqdz9fMGJUuTy3uFzEP48FAs9FLILlmzDlE2JJhVQaXQ== + dependencies: + agent-base "^6.0.2" + debug "^4.3.3" + socks "^2.6.2" + +socks@^2.3.3: + version "2.6.2" + resolved "https://registry.npmjs.org/socks/-/socks-2.6.2.tgz" + integrity sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA== + dependencies: + ip "^1.1.5" + smart-buffer "^4.2.0" + +socks@^2.6.2: + version "2.7.0" + resolved "https://registry.yarnpkg.com/socks/-/socks-2.7.0.tgz#f9225acdb841e874dca25f870e9130990f3913d0" + integrity sha512-scnOe9y4VuiNUULJN72GrM26BNOjVsfPXI+j+98PkyEfsIXroa5ofyjT+FzGvn/xHs73U2JtoBYAVx9Hl4quSA== + dependencies: + ip "^2.0.0" + smart-buffer "^4.2.0" + +source-map-support@0.5.13: + version "0.5.13" + resolved "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz" + integrity sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map-support@^0.5.12: + version "0.5.21" + resolved "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz" + integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: + version "0.6.1" + resolved "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" + integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== + +split2@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/split2/-/split2-4.1.0.tgz#101907a24370f85bb782f08adaabe4e281ecf809" + integrity sha512-VBiJxFkxiXRlUIeyMQi8s4hgvKCSjtknJv/LVYbrgALPwf5zSKmEwV9Lst25AkvMDnvxODugjdl6KZgwKM1WYQ== + +sprintf-js@~1.0.2: + version "1.0.3" + resolved "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz" + integrity sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g== + +sqlite3@^5.0.11: + version "5.0.11" + resolved "https://registry.yarnpkg.com/sqlite3/-/sqlite3-5.0.11.tgz#102c835d70be66da9d95a383fd6ea084a082ef7f" + integrity sha512-4akFOr7u9lJEeAWLJxmwiV43DJcGV7w3ab7SjQFAFaTVyknY3rZjvXTKIVtWqUoY4xwhjwoHKYs2HDW2SoHVsA== + dependencies: + "@mapbox/node-pre-gyp" "^1.0.0" + node-addon-api "^4.2.0" + tar "^6.1.11" + optionalDependencies: + node-gyp "8.x" + +sqlstring@^2.3.2: + version "2.3.3" + resolved "https://registry.yarnpkg.com/sqlstring/-/sqlstring-2.3.3.tgz#2ddc21f03bce2c387ed60680e739922c65751d0c" + integrity sha512-qC9iz2FlN7DQl3+wjwn3802RTyjCx7sDvfQEXchwa6CWOx07/WVfh91gBmQ9fahw8snwGEWU3xGzOt4tFyHLxg== + +ssri@^8.0.0, ssri@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/ssri/-/ssri-8.0.1.tgz#638e4e439e2ffbd2cd289776d5ca457c4f51a2af" + integrity sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ== + dependencies: + minipass "^3.1.1" + +stack-utils@^2.0.3: + version "2.0.5" + resolved "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz" + integrity sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA== + dependencies: + escape-string-regexp "^2.0.0" + +statuses@2.0.1: + version "2.0.1" + resolved "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz" + integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== + +streamsearch@^1.1.0: + version "1.1.0" + resolved "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz" + integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg== + +string-length@^4.0.1: + version "4.0.2" + resolved "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz" + integrity sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ== + dependencies: + char-regex "^1.0.2" + strip-ansi "^6.0.0" + +"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: + version "4.2.3" + resolved "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz" + integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== + dependencies: + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.1" + +string_decoder@^1.1.1: + version "1.3.0" + resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz" + integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== + dependencies: + safe-buffer "~5.2.0" + +string_decoder@~0.10.x: + version "0.10.31" + resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz" + integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== + +string_decoder@~1.1.1: + version "1.1.1" + resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz" + integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== + dependencies: + safe-buffer "~5.1.0" + +strip-ansi@^6.0.0, strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + +strip-bom@^3.0.0: + version "3.0.0" + resolved "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz" + integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== + +strip-bom@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz" + integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== + +strip-final-newline@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz" + integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== + +strip-json-comments@^2.0.0: + version "2.0.1" + resolved "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz" + integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== + +strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +strtok3@^6.2.4: + version "6.3.0" + resolved "https://registry.npmjs.org/strtok3/-/strtok3-6.3.0.tgz" + integrity sha512-fZtbhtvI9I48xDSywd/somNqgUHl2L2cstmXCCif0itOf96jeW18MBSyrLuNicYQVkvpOxkZtkzujiTJ9LW5Jw== + dependencies: + "@tokenizer/token" "^0.3.0" + peek-readable "^4.1.0" + +superagent@^8.0.0: + version "8.0.0" + resolved "https://registry.npmjs.org/superagent/-/superagent-8.0.0.tgz" + integrity sha512-iudipXEel+SzlP9y29UBWGDjB+Zzag+eeA1iLosaR2YHBRr1Q1kC29iBrF2zIVD9fqVbpZnXkN/VJmwFMVyNWg== + dependencies: + component-emitter "^1.3.0" + cookiejar "^2.1.3" + debug "^4.3.4" + fast-safe-stringify "^2.1.1" + form-data "^4.0.0" + formidable "^2.0.1" + methods "^1.1.2" + mime "2.6.0" + qs "^6.10.3" + readable-stream "^3.6.0" + semver "^7.3.7" + +supertest@^6.1.6: + version "6.2.4" + resolved "https://registry.npmjs.org/supertest/-/supertest-6.2.4.tgz" + integrity sha512-M8xVnCNv+q2T2WXVzxDECvL2695Uv2uUj2O0utxsld/HRyJvOU8W9f1gvsYxSNU4wmIe0/L/ItnpU4iKq0emDA== + dependencies: + methods "^1.1.2" + superagent "^8.0.0" + +supports-color@^5.3.0: + version "5.5.0" + resolved "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz" + integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== + dependencies: + has-flag "^3.0.0" + +supports-color@^7.0.0, supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-color@^8.0.0: + version "8.1.1" + resolved "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz" + integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== + dependencies: + has-flag "^4.0.0" + +supports-hyperlinks@^2.0.0: + version "2.2.0" + resolved "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz" + integrity sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ== + dependencies: + has-flag "^4.0.0" + supports-color "^7.0.0" + +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + +tar@^6.0.2, tar@^6.1.11, tar@^6.1.2: + version "6.1.11" + resolved "https://registry.npmjs.org/tar/-/tar-6.1.11.tgz" + integrity sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA== + dependencies: + chownr "^2.0.0" + fs-minipass "^2.0.0" + minipass "^3.0.0" + minizlib "^2.1.1" + mkdirp "^1.0.3" + yallist "^4.0.0" + +terminal-link@^2.0.0: + version "2.1.1" + resolved "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz" + integrity sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ== + dependencies: + ansi-escapes "^4.2.1" + supports-hyperlinks "^2.0.0" + +test-exclude@^6.0.0: + version "6.0.0" + resolved "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz" + integrity sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w== + dependencies: + "@istanbuljs/schema" "^0.1.2" + glob "^7.1.4" + minimatch "^3.0.4" + +thenify-all@^1.0.0: + version "1.6.0" + resolved "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz" + integrity sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA== + dependencies: + thenify ">= 3.1.0 < 4" + +"thenify@>= 3.1.0 < 4": + version "3.3.1" + resolved "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz" + integrity sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw== + dependencies: + any-promise "^1.0.0" + +thirty-two@1.0.2: + version "1.0.2" + resolved "https://registry.npmjs.org/thirty-two/-/thirty-two-1.0.2.tgz" + integrity sha512-OEI0IWCe+Dw46019YLl6V10Us5bi574EvlJEOcAkB29IzQ/mYD1A6RyNHLjZPiHCmuodxvgF6U+vZO1L15lxVA== + +tmp@^0.0.33: + version "0.0.33" + resolved "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz" + integrity sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw== + dependencies: + os-tmpdir "~1.0.2" + +tmpl@1.0.5: + version "1.0.5" + resolved "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz" + integrity sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw== + +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz" + integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +toidentifier@1.0.1: + version "1.0.1" + resolved "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz" + integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== + +token-types@^4.1.1: + version "4.2.1" + resolved "https://registry.npmjs.org/token-types/-/token-types-4.2.1.tgz" + integrity sha512-6udB24Q737UD/SDsKAHI9FCRP7Bqc9D/MQUV02ORQg5iskjtLJlZJNdN4kKtcdtwCeWIwIHDGaUsTsCCAa8sFQ== + dependencies: + "@tokenizer/token" "^0.3.0" + ieee754 "^1.2.1" + +tr46@~0.0.3: + version "0.0.3" + resolved "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz" + integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== + +tree-kill@^1.2.2: + version "1.2.2" + resolved "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz" + integrity sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A== + +ts-node-dev@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz" + 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.2.1, ts-node@^10.4.0: + version "10.9.1" + resolved "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz" + 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" + +ts-patch@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/ts-patch/-/ts-patch-2.0.2.tgz#be9dc294ced6f53d6a8912f1f6ac98af23a715cd" + integrity sha512-NbgdS/J/ylaARJVaF1w4cPw378yvw6C1026fU5NKC2GO4jCwRlkuE/G7gwknNMHwkAOhwamKjuzkuLw/u4KlBg== + dependencies: + chalk "^4.1.2" + glob "^8.0.3" + global-prefix "^3.0.0" + minimist "^1.2.6" + resolve "^1.22.1" + shelljs "^0.8.5" + strip-ansi "^6.0.1" + +tsconfig@^7.0.0: + version "7.0.0" + resolved "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz" + 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.9.3: + version "1.14.1" + resolved "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tslib@^2.0.1, tslib@^2.1.0, tslib@^2.3.1: + version "2.4.0" + resolved "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz" + integrity sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ== + +type-check@~0.3.2: + version "0.3.2" + resolved "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz" + integrity sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg== + dependencies: + prelude-ls "~1.1.2" + +type-detect@4.0.8: + version "4.0.8" + resolved "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz" + integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== + +type-fest@^0.21.3: + version "0.21.3" + resolved "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz" + integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== + +type-is@^1.6.4, type-is@~1.6.18: + version "1.6.18" + resolved "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz" + integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== + dependencies: + media-typer "0.3.0" + mime-types "~2.1.24" + +typedarray@^0.0.6: + version "0.0.6" + resolved "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz" + integrity sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA== + +typeorm@^0.3.7: + version "0.3.7" + resolved "https://registry.npmjs.org/typeorm/-/typeorm-0.3.7.tgz" + integrity sha512-MsPJeP6Zuwfe64c++l80+VRqpGEGxf0CkztIEnehQ+CMmQPSHjOnFbFxwBuZ2jiLqZTjLk2ZqQdVF0RmvxNF3Q== + dependencies: + "@sqltools/formatter" "^1.2.2" + app-root-path "^3.0.0" + buffer "^6.0.3" + chalk "^4.1.0" + cli-highlight "^2.1.11" + date-fns "^2.28.0" + debug "^4.3.3" + dotenv "^16.0.0" + glob "^7.2.0" + js-yaml "^4.1.0" + mkdirp "^1.0.4" + reflect-metadata "^0.1.13" + sha.js "^2.4.11" + tslib "^2.3.1" + uuid "^8.3.2" + xml2js "^0.4.23" + yargs "^17.3.1" + +typescript-json-schema@^0.54.0: + version "0.54.0" + resolved "https://registry.npmjs.org/typescript-json-schema/-/typescript-json-schema-0.54.0.tgz" + integrity sha512-/MNhm1pjdxXiVspjjyRCrQAA1B768cRzHU83aIqN5vQqQEW2NgyyKOfcguiRIMM64lseIZIelegnHOHEu7YDCg== + dependencies: + "@types/json-schema" "^7.0.9" + "@types/node" "^16.9.2" + glob "^7.1.7" + path-equal "^1.1.2" + safe-stable-stringify "^2.2.0" + ts-node "^10.2.1" + typescript "~4.6.0" + yargs "^17.1.1" + +typescript@^4.1.2: + version "4.7.4" + resolved "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz" + integrity sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ== + +typescript@~4.6.0: + version "4.6.4" + resolved "https://registry.npmjs.org/typescript/-/typescript-4.6.4.tgz" + integrity sha512-9ia/jWHIEbo49HfjrLGfKbZSuWo9iTMwXO+Ca3pRsSpbsMbc7/IU8NKdCZVRRBafVPGnoJeFL76ZOAA84I9fEg== + +unicode-canonical-property-names-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz" + integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== + +unicode-match-property-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz" + integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== + dependencies: + unicode-canonical-property-names-ecmascript "^2.0.0" + unicode-property-aliases-ecmascript "^2.0.0" + +unicode-match-property-value-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz" + integrity sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw== + +unicode-property-aliases-ecmascript@^2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz" + integrity sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ== + +unique-filename@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-1.1.1.tgz#1d69769369ada0583103a1e6ae87681b56573230" + integrity sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ== + dependencies: + unique-slug "^2.0.0" + +unique-slug@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-2.0.2.tgz#baabce91083fc64e945b0f3ad613e264f7cd4e6c" + integrity sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w== + dependencies: + imurmurhash "^0.1.4" + +universalify@^0.1.0: + version "0.1.2" + resolved "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz" + integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== + +unpipe@1.0.0, unpipe@~1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" + integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== + +update-browserslist-db@^1.0.4: + version "1.0.4" + resolved "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.4.tgz" + integrity sha512-jnmO2BEGUjsMOe/Fg9u0oczOe/ppIDZPebzccl1yDWGLFP16Pa1/RM5wEoKYPG2zstNcDuAStejyxsOuKINdGA== + dependencies: + escalade "^3.1.1" + picocolors "^1.0.0" + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +url-parse@~1.5.10: + version "1.5.10" + resolved "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz" + integrity sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ== + dependencies: + querystringify "^2.1.1" + requires-port "^1.0.0" + +util-deprecate@^1.0.1, util-deprecate@~1.0.1: + version "1.0.2" + resolved "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz" + integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== + +utils-merge@1.0.1: + version "1.0.1" + resolved "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz" + integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== + +uuid@^8.3.2: + version "8.3.2" + resolved "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz" + integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== + +v8-compile-cache-lib@^3.0.1: + version "3.0.1" + resolved "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz" + integrity sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg== + +v8-to-istanbul@^9.0.1: + version "9.0.1" + resolved "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.0.1.tgz" + integrity sha512-74Y4LqY74kLE6IFyIjPtkSTWzUZmj8tdHT9Ii/26dvQ6K9Dl2NbEfj0XgU2sHCtKgt5VupqhlO/5aWuqS+IY1w== + dependencies: + "@jridgewell/trace-mapping" "^0.3.12" + "@types/istanbul-lib-coverage" "^2.0.1" + convert-source-map "^1.6.0" + +vary@~1.1.2: + version "1.1.2" + resolved "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz" + integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== + +vm2@^3.9.8: + version "3.9.10" + resolved "https://registry.npmjs.org/vm2/-/vm2-3.9.10.tgz" + integrity sha512-AuECTSvwu2OHLAZYhG716YzwodKCIJxB6u1zG7PgSQwIgAlEaoXH52bxdcvT8GkGjnYK7r7yWDW0m0sOsPuBjQ== + dependencies: + acorn "^8.7.0" + acorn-walk "^8.2.0" + +walker@^1.0.8: + version "1.0.8" + resolved "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz" + integrity sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ== + dependencies: + makeerror "1.0.12" + +webidl-conversions@^3.0.0: + version "3.0.1" + resolved "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz" + integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== + +whatwg-url@^5.0.0: + version "5.0.0" + resolved "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz" + integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== + dependencies: + tr46 "~0.0.3" + webidl-conversions "^3.0.0" + +which@^1.2.9, which@^1.3.1: + version "1.3.1" + resolved "https://registry.npmjs.org/which/-/which-1.3.1.tgz" + integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== + dependencies: + isexe "^2.0.0" + +which@^2.0.1, which@^2.0.2: + version "2.0.2" + resolved "https://registry.npmjs.org/which/-/which-2.0.2.tgz" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +wide-align@^1.1.2, wide-align@^1.1.5: + version "1.1.5" + resolved "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz" + integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== + dependencies: + string-width "^1.0.2 || 2 || 3 || 4" + +word-wrap@~1.2.3: + version "1.2.3" + resolved "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz" + integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== + +wrap-ansi@^7.0.0: + version "7.0.0" + resolved "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz" + integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== + dependencies: + ansi-styles "^4.0.0" + string-width "^4.1.0" + strip-ansi "^6.0.0" + +wrappy@1: + version "1.0.2" + resolved "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz" + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== + +write-file-atomic@^4.0.1: + version "4.0.1" + resolved "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.1.tgz" + integrity sha512-nSKUxgAbyioruk6hU87QzVbY279oYT6uiwgDoujth2ju4mJ+TZau7SQBhtbTmUyuNYTuXnSyRn66FV0+eCgcrQ== + dependencies: + imurmurhash "^0.1.4" + signal-exit "^3.0.7" + +ws@^8.8.1: + version "8.8.1" + resolved "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz" + integrity sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA== + +xml2js@^0.4.23: + version "0.4.23" + resolved "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz" + integrity sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug== + dependencies: + sax ">=0.6.0" + xmlbuilder "~11.0.0" + +xmlbuilder@~11.0.0: + version "11.0.1" + resolved "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz" + integrity sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA== + +xregexp@2.0.0: + version "2.0.0" + resolved "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz" + integrity sha512-xl/50/Cf32VsGq/1R8jJE5ajH1yMCQkpmoS10QbFZWl2Oor4H0Me64Pu2yxvsRWK3m6soJbmGfzSR7BYmDcWAA== + +xtend@^4.0.0: + version "4.0.2" + resolved "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz" + integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== + +y18n@^5.0.5: + version "5.0.8" + resolved "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz" + integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== + +yallist@^2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52" + integrity sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A== + +yallist@^3.0.2: + version "3.1.1" + resolved "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz" + integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yargs-parser@^20.2.2: + version "20.2.9" + resolved "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz" + integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== + +yargs-parser@^21.0.0: + version "21.0.1" + resolved "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.0.1.tgz" + integrity sha512-9BK1jFpLzJROCI5TzwZL/TU4gqjK5xiHV/RfWLOahrjAko/e4DJkRDZQXfvqAsiZzzYhgAzbgz6lg48jcm4GLg== + +yargs@^16.0.0: + version "16.2.0" + resolved "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz" + integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== + dependencies: + cliui "^7.0.2" + escalade "^3.1.1" + get-caller-file "^2.0.5" + require-directory "^2.1.1" + string-width "^4.2.0" + y18n "^5.0.5" + yargs-parser "^20.2.2" + +yargs@^17.1.1, yargs@^17.3.1: + version "17.5.1" + resolved "https://registry.npmjs.org/yargs/-/yargs-17.5.1.tgz" + integrity sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA== + dependencies: + cliui "^7.0.2" + escalade "^3.1.1" + get-caller-file "^2.0.5" + require-directory "^2.1.1" + string-width "^4.2.3" + y18n "^5.0.5" + yargs-parser "^21.0.0" + +yn@3.1.1: + version "3.1.1" + resolved "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz" + integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== From 08d5aca13230308cb80199cf7a64e2d9752038f6 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 13 Aug 2022 04:21:48 +0200 Subject: [PATCH 217/238] Update scripts, update workspace, add launch.json --- .vscode/launch.json | 20 ++++++++ fosscord-server.code-workspace | 28 ++-------- package-lock.json | Bin 838348 -> 840738 bytes scripts/depcheck.js | 2 +- scripts/depclean.js | 91 ++++++++++++++++----------------- scripts/install.js | 23 --------- scripts/rights.js | 2 +- scripts/update_schemas.js | 2 +- scripts/utils.js | 2 - 9 files changed, 72 insertions(+), 98 deletions(-) create mode 100644 .vscode/launch.json delete mode 100644 scripts/install.js diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 000000000..1ddf16e7f --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,20 @@ +{ + // 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": [ + { + "type": "node", + "request": "launch", + "name": "Launch Program", + "skipFiles": [ + "/**" + ], + "program": "${file}", + "outFiles": [ + "${workspaceFolder}/**/*.js" + ] + } + ] +} \ No newline at end of file diff --git a/fosscord-server.code-workspace b/fosscord-server.code-workspace index 4a7440f67..1d6774adf 100644 --- a/fosscord-server.code-workspace +++ b/fosscord-server.code-workspace @@ -1,22 +1,16 @@ { "folders": [ { - "path": "bundle" + "path": "src/" }, { - "path": "api" + "path": "assets/" }, { - "path": "cdn" + "path": "scripts/" }, { - "path": "gateway" - }, - { - "path": "util" - }, - { - "path": "plugins" + "path": "." } ], "settings": { @@ -26,18 +20,6 @@ ".prettierrc": true, ".vscode": true, "*.ansi": true, - "benchmarks": true, - "database.db": true, - "files/": true, - "jest": true, - "locales/[!e]*": true, - "locales/e[!n]*": true, - "node_modules": true, - "package-lock.json": true, - "patches": true, - "README.md": true, - "tests/": true, - "tsconfig.tsbuildinfo": true } } -} +} \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index a97e75be2b2923dedbc5574e8587c3730b3735aa..2da3174eebafdffcfe1571914522f6a31b0cbb27 100644 GIT binary patch delta 1492 zcmchXTWBLy7=W2fW-^(~W?e5$+il%#y0${PNhX&`qOxp~O(ypyY0|VQ=uR$8(%jli z(@7#K>O%!Vy9Dw`~96R`~v5 zqu#E!!o)f1xOC-}8}bn`djVgPf%O~NB<%0W&9J|s)WZF@kW-0;n$y1#v**LQvYX+O zp%x=FVu#@ubBa0+Z#Ym5`1fVQ5Q;0+u>Aq9hNpY@L*h||>=Oh&zkm;kAMVM8K?qWa zi$=i55cqBz9Y*Z1`#5R>;|@wmF`Yvvlg&!SVzowmb3VUek@l{!9JlD@LTot_4hJ&a zM!4Z&y$h@%$~Fp2+r~H7Q@*6H(P0X0CgpMY7_JVhMM?IA?bG15OuT zX{R%t*7Cf~9t)cm8C}U{p=YCMKez04a;1_dT(r)%{f$7hunsYol=$~{>_Nb9A~UeM zggxBPXmhKFODH4=38e%nZuL~Mz5mDLU4)pq2qg7iiVSg5F$tG-s$bx&K*f({8eBGi zI^SC5YJ90)gSAUUaA5UE&k|F~!?5}sJRhM<>I_%mBsFrUtK53F2xo4nPKamkk?)|W zG_0_LDKw}wtg!a6av(1@7~R`P6cdLeFn668g6(U>*zXpP!B0Er7~D5aYG$Mlq*|(# z`ib^c{-@y5=HH4-f6FnE&|Ljdg(2|hG)cizDHR62BMNoj=NGOi>AugXRZqk1o5bWH cIeq?p()6##ow!Gy5MQ}OCJ?dr3}p`g29q`7X#fBK delta 493 zcmZ3q!uZTo;|c30hj5xre$c=%T|tGNW3n*6*k%pJKWvk$h2@%^INF^!7=f4xh?#+y z1&CR3{p#B&LU%u_%P*2AC(Mh8hND=T^ED8)^qvMMQ=r z28XzqMdX`DIcFyMdl?r;Whd!Z6bEMII|fFS<(cFMWMvyOn=DCXfVC@EEf->;q(m!tm2I3(+^bfSTLGSf8WI>Hr@Ul7mr|Z zMruw@RNA;o`s&tbjKhzjp+-z*#x#XPh^W=+P?o2<4MNp22 { - console.log(`Installing all packages for ${part}...`); - execIn("npm i", path.join(__dirname, "..", "..", part)); -}); +console.log(`Installing all packages...`); +execIn("npm i", path.join(__dirname, "..")); -parts.forEach((part) => { - let partDir = path.join(__dirname, "..", "..", part); - let distDir = path.join(partDir, "dist"); - let start = 0; - start = getLines( - execIn("npm ls --parseable --package-lock-only -a", partDir) - ); - if (fs.existsSync(distDir)) - fs.rmSync(distDir, { - recursive: true, - force: true, - }); - let x = { - dependencies: [], - devDependencies: [], - invalidDirs: [], - invalidFiles: [], - missing: [], - using: [], - }; - let dcproc = execIn("npx depcheck --json", partDir); - if(dcproc.stdout) x = JSON.parse(dcproc.stdout); - else x = JSON.parse(dcproc); +let partDir = path.join(__dirname, ".."); +let distDir = path.join(partDir, "dist"); +let start = 0; +start = getLines( + execIn("npm ls --parseable --package-lock-only -a", partDir) +); +if (fs.existsSync(distDir)) + fs.rmSync(distDir, { + recursive: true, + force: true, + }); +let x = { + dependencies: [], + devDependencies: [], + invalidDirs: [], + invalidFiles: [], + missing: [], + using: [], +}; +let dcproc = execIn("npx depcheck --json", partDir); +if(dcproc.stdout) x = JSON.parse(dcproc.stdout); +else x = JSON.parse(dcproc); - fs.writeFileSync( - path.join(__dirname, "..", `depclean.out.${part}.json`), - JSON.stringify(x, null, "\t"), - { encoding: "utf8" } - ); +fs.writeFileSync( + path.join(__dirname, "..", `depclean.out.json`), + JSON.stringify(x, null, "\t"), + { encoding: "utf8" } +); - let depsToRemove = x.dependencies.join(" "); - if (depsToRemove) execIn(`npm r --save ${depsToRemove}`, partDir); +let depsToRemove = x.dependencies.join(" "); +if (depsToRemove) execIn(`npm r --save ${depsToRemove}`, partDir); - depsToRemove = x.devDependencies.join(" "); - if (depsToRemove) execIn(`npm r --save --dev ${depsToRemove}`, partDir); +depsToRemove = x.devDependencies.join(" "); +if (depsToRemove) execIn(`npm r --save --dev ${depsToRemove}`, partDir); + +if (removeModules && fs.existsSync(path.join(partDir, "node_modules"))) + fs.rmSync(path.join(partDir, "node_modules"), { + recursive: true, + force: true, + }); +let end = getLines( + execIn("npm ls --parseable --package-lock-only -a", partDir) +); +console.log(`${part}: ${start} -> ${end} (diff: ${start - end})`); - if (removeModules && fs.existsSync(path.join(partDir, "node_modules"))) - fs.rmSync(path.join(partDir, "node_modules"), { - recursive: true, - force: true, - }); - let end = getLines( - execIn("npm ls --parseable --package-lock-only -a", partDir) - ); - console.log(`${part}: ${start} -> ${end} (diff: ${start - end})`); -}); console.log("Installing required packages for bundle..."); execIn(`npm i --save ${bundleRequired.join(" ")}`, path.join(__dirname, "..")); diff --git a/scripts/install.js b/scripts/install.js deleted file mode 100644 index db9dadbc6..000000000 --- a/scripts/install.js +++ /dev/null @@ -1,23 +0,0 @@ -const path = require("path"); -const fs = require("fs"); -const parts = ["api", "util", "cdn", "gateway"]; - -const bundle = require("../package.json"); - -for (const part of parts) { - const { devDependencies, dependencies } = require(path.join( - "..", - "..", - part, - "package.json" - )); - bundle.devDependencies = { ...bundle.devDependencies, ...devDependencies }; - bundle.dependencies = { ...bundle.dependencies, ...dependencies }; - delete bundle.dependencies["@fosscord/util"]; -} - -fs.writeFileSync( - path.join(__dirname, "..", "package.json"), - JSON.stringify(bundle, null, "\t"), - { encoding: "utf8" } -); diff --git a/scripts/rights.js b/scripts/rights.js index c363b0c50..20fd139c7 100644 --- a/scripts/rights.js +++ b/scripts/rights.js @@ -6,7 +6,7 @@ const { argv, stdout, exit } = require("process"); const { execIn, getLines, parts } = require("./utils"); -let lines = fs.readFileSync(path.join(__dirname, "..", "..", "util", "src","util","Rights.ts")).toString() +let lines = fs.readFileSync(path.join(__dirname, "..", "src", "util", "util","Rights.ts")).toString() let lines2 = lines.split("\n"); let lines3 = lines2.filter(y=>y.includes(": BitFlag(")); let lines4 = lines3.map(x=>x.split("//")[0].trim()) diff --git a/scripts/update_schemas.js b/scripts/update_schemas.js index a018120b9..361bedc13 100644 --- a/scripts/update_schemas.js +++ b/scripts/update_schemas.js @@ -6,4 +6,4 @@ const { argv, stdout, exit } = require("process"); const { execIn, getLines, parts } = require("./utils"); -execIn("node scripts/generate_schema.js", path.join("..", "api")); \ No newline at end of file +execIn("node scripts/generate_schema.js", path.join('.')); \ No newline at end of file diff --git a/scripts/utils.js b/scripts/utils.js index f4b1ad7f6..ca41bcf20 100644 --- a/scripts/utils.js +++ b/scripts/utils.js @@ -4,8 +4,6 @@ const { env } = require("process"); const { execSync } = require("child_process"); const { argv, stdout, exit } = require("process"); -const parts = ["api", "util", "cdn", "gateway", "bundle"]; - function copyRecursiveSync(src, dest) { //if (verbose) console.log(`cpsync: ${src} -> ${dest}`); let exists = fs.existsSync(src); From 9e00f759d788d54cd190a23a0b39a8a192eec1b2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Sat, 13 Aug 2022 10:21:42 +0300 Subject: [PATCH 218/238] Update .vscode/launch.json --- .vscode/launch.json | 3 --- 1 file changed, 3 deletions(-) diff --git a/.vscode/launch.json b/.vscode/launch.json index 1ddf16e7f..09ff71341 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -1,7 +1,4 @@ { - // 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": [ { From bed14559f83734c94ffb038a1407a2f5907e98df Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 13 Aug 2022 09:31:35 +0200 Subject: [PATCH 219/238] downgrade ajv so patches apply --- package-lock.json | Bin 840738 -> 840733 bytes package.json | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/package-lock.json b/package-lock.json index 2da3174eebafdffcfe1571914522f6a31b0cbb27..0d6f7bd0679d4557bf4e4ddabcfaf06f81c3c21c 100644 GIT binary patch delta 290 zcmZ3q!g%fq;|(7fCqL%YXqIAXmttbvF2%&OymLCE2D9OGEe%ed=|LLIN+FgO2IfII z;g0Dcre-GPA=)lksg@9w%CRa=Kc&Ih)Gpb}1jNih%mT!$K+Fcj n?As-KIquIwb4w^K++sQXpaQ#0JJ2ye%mu{U+fQlmM63n??=)Vz delta 324 zcmbQc!g$dN;|(7fSqu&J3?@J2RBe`IYL{eU+%Cz)w7iqiaPq}HhP;VcW%|1MKvLI2 z&u}`UIjeGrdwM}pigTH7Vve(cQ&mYsS!RigQHHaDNn~1@V_8XYXr869SCV@~q>p2X zbEv;bMT(($uCsGgU`43EXGx}0c~qHKaB_IQg`a0xpl_hLVNpuK^u#;N3e%5ja5haZ zPhb|GzWxNOWqVpL6A&{4F$)m00x=s9vu{u9<>;S9XZJmP&n?@2OoJ1Mxqz5^`!Nlk G@YMk7_Hax9 diff --git a/package.json b/package.json index 95dbb6597..59c66811d 100644 --- a/package.json +++ b/package.json @@ -61,7 +61,7 @@ "@sentry/node": "^7.7.0", "@sentry/tracing": "^7.7.0", "@types/node-fetch": "^2.6.2", - "ajv": "^8.11.0", + "ajv": "^8.6.2", "ajv-formats": "^2.1.1", "amqplib": "^0.10.1", "bcrypt": "^5.0.1", From 5e629decfc5aaa58fb5c584fa15e76fd5b44c23f Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 13 Aug 2022 20:43:35 +0200 Subject: [PATCH 220/238] Do the funny thing (make user->invite cascade delet) --- ... => 1660416072362-InvitersAreDeletable.ts} | 37 +-- .../1660416055566-InvitersAreDeletable.ts | 26 ++ .../1660416010862-InvitersAreDeletable.ts | 246 ++++++++++++++++++ 3 files changed, 292 insertions(+), 17 deletions(-) rename src/util/migrations/mariadb/{1660265930624-CodeCleanup5.ts => 1660416072362-InvitersAreDeletable.ts} (51%) create mode 100644 src/util/migrations/postgres/1660416055566-InvitersAreDeletable.ts create mode 100644 src/util/migrations/sqlite/1660416010862-InvitersAreDeletable.ts diff --git a/src/util/migrations/mariadb/1660265930624-CodeCleanup5.ts b/src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts similarity index 51% rename from src/util/migrations/mariadb/1660265930624-CodeCleanup5.ts rename to src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts index 04f8e6af4..8374eafbc 100644 --- a/src/util/migrations/mariadb/1660265930624-CodeCleanup5.ts +++ b/src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts @@ -1,16 +1,21 @@ import { MigrationInterface, QueryRunner } from "typeorm"; -export class CodeCleanup51660265930624 implements MigrationInterface { - name = 'CodeCleanup51660265930624' +export class InvitersAreDeletable1660416072362 implements MigrationInterface { + name = 'InvitersAreDeletable1660416072362' public async up(queryRunner: QueryRunner): Promise { await queryRunner.query(` - ALTER TABLE \`users\` - ADD \`settingsId\` varchar(255) NULL + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` `); await queryRunner.query(` - ALTER TABLE \`users\` - ADD UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` (\`settingsId\`) + DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` + `); + await queryRunner.query(` + CREATE TABLE \`plugin_config\` ( + \`key\` varchar(255) NOT NULL, + \`value\` text NULL, + PRIMARY KEY (\`key\`) + ) ENGINE = InnoDB `); await queryRunner.query(` ALTER TABLE \`channels\` @@ -21,20 +26,14 @@ export class CodeCleanup51660265930624 implements MigrationInterface { ADD \`default_thread_rate_limit_per_user\` int NULL `); await queryRunner.query(` - CREATE UNIQUE INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) - `); - await queryRunner.query(` - ALTER TABLE \`users\` - ADD CONSTRAINT \`FK_76ba283779c8441fd5ff819c8cf\` FOREIGN KEY (\`settingsId\`) REFERENCES \`user_settings\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION `); } public async down(queryRunner: QueryRunner): Promise { await queryRunner.query(` - ALTER TABLE \`users\` DROP FOREIGN KEY \`FK_76ba283779c8441fd5ff819c8cf\` - `); - await queryRunner.query(` - DROP INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` `); await queryRunner.query(` ALTER TABLE \`channels\` DROP COLUMN \`default_thread_rate_limit_per_user\` @@ -43,10 +42,14 @@ export class CodeCleanup51660265930624 implements MigrationInterface { ALTER TABLE \`channels\` DROP COLUMN \`flags\` `); await queryRunner.query(` - ALTER TABLE \`users\` DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` + DROP TABLE \`plugin_config\` `); await queryRunner.query(` - ALTER TABLE \`users\` DROP COLUMN \`settingsId\` + CREATE UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION `); } diff --git a/src/util/migrations/postgres/1660416055566-InvitersAreDeletable.ts b/src/util/migrations/postgres/1660416055566-InvitersAreDeletable.ts new file mode 100644 index 000000000..e61013189 --- /dev/null +++ b/src/util/migrations/postgres/1660416055566-InvitersAreDeletable.ts @@ -0,0 +1,26 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class InvitersAreDeletable1660416055566 implements MigrationInterface { + name = 'InvitersAreDeletable1660416055566' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" + `); + await queryRunner.query(` + ALTER TABLE "invites" + ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/src/util/migrations/sqlite/1660416010862-InvitersAreDeletable.ts b/src/util/migrations/sqlite/1660416010862-InvitersAreDeletable.ts new file mode 100644 index 000000000..9b29e119e --- /dev/null +++ b/src/util/migrations/sqlite/1660416010862-InvitersAreDeletable.ts @@ -0,0 +1,246 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class InvitersAreDeletable1660416010862 implements MigrationInterface { + name = 'InvitersAreDeletable1660416010862' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "invites" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + ALTER TABLE "temporary_invites" + RENAME TO "invites" + `); + await queryRunner.query(` + CREATE TABLE "temporary_invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "invites" + `); + await queryRunner.query(` + DROP TABLE "invites" + `); + await queryRunner.query(` + ALTER TABLE "temporary_invites" + RENAME TO "invites" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "invites" + RENAME TO "temporary_invites" + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "temporary_invites" + `); + await queryRunner.query(` + DROP TABLE "temporary_invites" + `); + await queryRunner.query(` + ALTER TABLE "invites" + RENAME TO "temporary_invites" + `); + await queryRunner.query(` + CREATE TABLE "invites" ( + "code" varchar PRIMARY KEY NOT NULL, + "temporary" boolean NOT NULL, + "uses" integer NOT NULL, + "max_uses" integer NOT NULL, + "max_age" integer NOT NULL, + "created_at" datetime NOT NULL, + "expires_at" datetime NOT NULL, + "guild_id" varchar, + "channel_id" varchar, + "inviter_id" varchar, + "target_user_id" varchar, + "target_user_type" integer, + "vanity_url" boolean, + CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, + CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "invites"( + "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + ) + SELECT "code", + "temporary", + "uses", + "max_uses", + "max_age", + "created_at", + "expires_at", + "guild_id", + "channel_id", + "inviter_id", + "target_user_id", + "target_user_type", + "vanity_url" + FROM "temporary_invites" + `); + await queryRunner.query(` + DROP TABLE "temporary_invites" + `); + } + +} From 6d3706c2c8efda6e170eac2081a60f41a09bb41f Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sat, 13 Aug 2022 22:14:22 +0200 Subject: [PATCH 221/238] Fix rebase conflicts --- gateway/src/opcodes/Identify.ts | 298 ------------------ .../api}/routes/applications/#id/bot/index.ts | 0 .../api}/routes/applications/#id/index.ts | 0 .../api}/routes/applications/#id/skus.ts | 0 src/gateway/opcodes/Identify.ts | 4 +- .../1660130586602-updated-applications.ts | 0 .../1660131942703-apps_nullable_team.ts | 0 .../mariadb/1660258393551-CodeCleanup3.ts | 232 -------------- .../1660130561959-updated-applications.ts | 0 .../1660130536131-updated-applications.ts | 0 .../1660416072362-InvitersAreDeletable.ts | 56 ---- .../1660416055566-InvitersAreDeletable.ts | 26 -- .../1660416010862-InvitersAreDeletable.ts | 246 --------------- 13 files changed, 2 insertions(+), 860 deletions(-) delete mode 100644 gateway/src/opcodes/Identify.ts rename {api/src => src/api}/routes/applications/#id/bot/index.ts (100%) rename {api/src => src/api}/routes/applications/#id/index.ts (100%) rename {api/src => src/api}/routes/applications/#id/skus.ts (100%) rename {util/src => src/util}/migrations/mariadb/1660130586602-updated-applications.ts (100%) rename {util/src => src/util}/migrations/mariadb/1660131942703-apps_nullable_team.ts (100%) delete mode 100644 src/util/migrations/mariadb/1660258393551-CodeCleanup3.ts rename {util/src => src/util}/migrations/postgres/1660130561959-updated-applications.ts (100%) rename {util/src => src/util}/migrations/sqlite/1660130536131-updated-applications.ts (100%) delete mode 100644 util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts delete mode 100644 util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts delete mode 100644 util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts diff --git a/gateway/src/opcodes/Identify.ts b/gateway/src/opcodes/Identify.ts deleted file mode 100644 index e62c15700..000000000 --- a/gateway/src/opcodes/Identify.ts +++ /dev/null @@ -1,298 +0,0 @@ -import { WebSocket, Payload } from "@fosscord/gateway"; -import { - checkToken, - Intents, - Member, - ReadyEventData, - User, - Session, - EVENTEnum, - Config, - PublicMember, - PublicUser, - PrivateUserProjection, - ReadState, - Application, - emitEvent, - SessionsReplace, - PrivateSessionProjection, - MemberPrivateProjection, - PresenceUpdateEvent, - UserSettings, - IdentifySchema, -} from "@fosscord/util"; -import { Send } from "../util/Send"; -import { CLOSECODES, OPCODES } from "../util/Constants"; -import { genSessionId } from "../util/SessionUtils"; -import { setupListener } from "../listener/listener"; -// import experiments from "./experiments.json"; -const experiments: any = []; -import { check } from "./instanceOf"; -import { Recipient } from "@fosscord/util"; -import { OrmUtils } from "@fosscord/util"; - -// TODO: user sharding -// TODO: check privileged intents, if defined in the config -// TODO: check if already identified - -export async function onIdentify(this: WebSocket, data: Payload) { - clearTimeout(this.readyTimeout); - check.call(this, IdentifySchema, data.d); - - const identify: IdentifySchema = data.d; - - try { - const { jwtSecret } = Config.get().security; - var { decoded } = await checkToken(identify.token, jwtSecret); // will throw an error if invalid - } catch (error) { - console.error("invalid token", error); - return this.close(CLOSECODES.Authentication_failed); - } - this.user_id = decoded.id; - - const session_id = genSessionId(); - this.session_id = session_id; //Set the session of the WebSocket object - - const [user, read_states, members, recipients, session, application] = - await Promise.all([ - User.findOneOrFail({ - where: { id: this.user_id }, - relations: ["relationships", "relationships.to", "settings"], - select: [...PrivateUserProjection, "relationships"], - }), - ReadState.find({ where: { user_id: this.user_id } }), - Member.find({ - where: { id: this.user_id }, - select: MemberPrivateProjection, - relations: [ - "guild", - "guild.channels", - "guild.emojis", - "guild.emojis.user", - "guild.roles", - "guild.stickers", - "user", - "roles", - ], - }), - Recipient.find({ - where: { user_id: this.user_id, closed: false }, - relations: [ - "channel", - "channel.recipients", - "channel.recipients.user", - ], - // TODO: public user selection - }), - // save the session and delete it when the websocket is closed - await OrmUtils.mergeDeep(new Session(), { - user_id: this.user_id, - session_id: session_id, - // TODO: check if status is only one of: online, dnd, offline, idle - status: identify.presence?.status || "offline", //does the session always start as online? - client_info: { - //TODO read from identity - client: "desktop", - os: identify.properties?.os, - version: 0, - }, - activities: [], - }).save(), - Application.findOne({ where: { id: this.user_id } }), - ]); - - if (!user) return this.close(CLOSECODES.Authentication_failed); - if (!user.settings) { //settings may not exist after updating... - user.settings = new UserSettings(); - user.settings.id = user.id; - await user.settings.save(); - } - - if (!identify.intents) identify.intents = BigInt("0x6ffffffff"); - this.intents = new Intents(identify.intents); - if (identify.shard) { - this.shard_id = identify.shard[0]; - this.shard_count = identify.shard[1]; - if ( - this.shard_count == null || - this.shard_id == null || - this.shard_id >= this.shard_count || - this.shard_id < 0 || - this.shard_count <= 0 - ) { - console.log(identify.shard); - return this.close(CLOSECODES.Invalid_shard); - } - } - let users: PublicUser[] = []; - - const merged_members = members.map((x: Member) => { - return [ - { - ...x, - roles: x.roles.map((x) => x.id), - settings: undefined, - guild: undefined, - }, - ]; - }) as PublicMember[][]; - let guilds = members.map((x) => ({ ...x.guild, joined_at: x.joined_at })); - - // @ts-ignore - guilds = guilds.map((guild) => { - if (user.bot) { - setTimeout(() => { - Send(this, { - op: OPCODES.Dispatch, - t: EVENTEnum.GuildCreate, - s: this.sequence++, - d: guild, - }); - }, 500); - return { id: guild.id, unavailable: true }; - } - - return guild; - }); - - const user_guild_settings_entries = members.map((x) => x.settings); - - const channels = recipients.map((x) => { - // @ts-ignore - x.channel.recipients = x.channel.recipients?.map((x) => x.user); - //TODO is this needed? check if users in group dm that are not friends are sent in the READY event - users = users.concat(x.channel.recipients as unknown as User[]); - if (x.channel.isDm()) { - x.channel.recipients = x.channel.recipients!.filter( - (x) => x.id !== this.user_id - ); - } - return x.channel; - }); - - for (let relation of user.relationships) { - const related_user = relation.to; - const public_related_user = { - username: related_user.username, - discriminator: related_user.discriminator, - id: related_user.id, - public_flags: related_user.public_flags, - avatar: related_user.avatar, - bot: related_user.bot, - bio: related_user.bio, - premium_since: user.premium_since - }; - users.push(public_related_user); - } - - setImmediate(async () => { - // run in seperate "promise context" because ready payload is not dependent on those events - emitEvent({ - event: "SESSIONS_REPLACE", - user_id: this.user_id, - data: await Session.find({ - where: { user_id: this.user_id }, - select: PrivateSessionProjection, - }), - } as SessionsReplace); - emitEvent({ - event: "PRESENCE_UPDATE", - user_id: this.user_id, - data: { - user: await User.getPublicUser(this.user_id), - activities: session.activities, - client_status: session?.client_info, - status: session.status, - }, - } as PresenceUpdateEvent); - }); - - read_states.forEach((s: any) => { - s.id = s.channel_id; - delete s.user_id; - delete s.channel_id; - }); - - const privateUser = { - avatar: user.avatar, - mobile: user.mobile, - desktop: user.desktop, - discriminator: user.discriminator, - email: user.email, - flags: user.flags, - id: user.id, - mfa_enabled: user.mfa_enabled, - nsfw_allowed: user.nsfw_allowed, - phone: user.phone, - premium: user.premium, - premium_type: user.premium_type, - public_flags: user.public_flags, - username: user.username, - verified: user.verified, - bot: user.bot, - accent_color: user.accent_color || 0, - banner: user.banner, - bio: user.bio, - premium_since: user.premium_since - }; - - const d: ReadyEventData = { - v: 8, - application: {id: application?.id??'', flags: application?.flags??0}, //TODO: check this code! - user: privateUser, - user_settings: user.settings, - // @ts-ignore - guilds: guilds.map((x) => { - // @ts-ignore - x.guild_hashes = {}; // @ts-ignore - x.guild_scheduled_events = []; // @ts-ignore - x.threads = []; - return x; - }), - guild_experiments: [], // TODO - geo_ordered_rtc_regions: [], // TODO - relationships: user.relationships.map((x) => x.toPublicRelationship()), - read_state: { - entries: read_states, - partial: false, - version: 304128, - }, - user_guild_settings: { - entries: user_guild_settings_entries, - partial: false, // TODO partial - version: 642, - }, - private_channels: channels, - session_id: session_id, - analytics_token: "", // TODO - connected_accounts: [], // TODO - consents: { - personalization: { - consented: false, // TODO - }, - }, - country_code: user.settings.locale, - friend_suggestion_count: 0, // TODO - // @ts-ignore - experiments: experiments, // TODO - guild_join_requests: [], // TODO what is this? - users: users.filter((x) => x).unique(), - merged_members: merged_members, - // shard // TODO: only for user sharding - }; - - // TODO: send real proper data structure - await Send(this, { - op: OPCODES.Dispatch, - t: EVENTEnum.Ready, - s: this.sequence++, - d, - }); - - //TODO send READY_SUPPLEMENTAL - //TODO send GUILD_MEMBER_LIST_UPDATE - //TODO send SESSIONS_REPLACE - //TODO send VOICE_STATE_UPDATE to let the client know if another device is already connected to a voice channel - - await setupListener.call(this); -} diff --git a/api/src/routes/applications/#id/bot/index.ts b/src/api/routes/applications/#id/bot/index.ts similarity index 100% rename from api/src/routes/applications/#id/bot/index.ts rename to src/api/routes/applications/#id/bot/index.ts diff --git a/api/src/routes/applications/#id/index.ts b/src/api/routes/applications/#id/index.ts similarity index 100% rename from api/src/routes/applications/#id/index.ts rename to src/api/routes/applications/#id/index.ts diff --git a/api/src/routes/applications/#id/skus.ts b/src/api/routes/applications/#id/skus.ts similarity index 100% rename from api/src/routes/applications/#id/skus.ts rename to src/api/routes/applications/#id/skus.ts diff --git a/src/gateway/opcodes/Identify.ts b/src/gateway/opcodes/Identify.ts index 4f17ab706..d5dae7b04 100644 --- a/src/gateway/opcodes/Identify.ts +++ b/src/gateway/opcodes/Identify.ts @@ -108,7 +108,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { await user.settings.save(); } - if (!identify.intents) identify.intents = "0x6ffffffff" + if (!identify.intents) identify.intents = "30064771071"; this.intents = new Intents(identify.intents); if (identify.shard) { this.shard_id = identify.shard[0]; @@ -238,7 +238,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { const d: ReadyEventData = { v: 8, - application: {id: application?.id??'', flags: application?.flags??''}, //TODO: check this code! + application: {id: application?.id??'', flags: application?.flags??0}, //TODO: check this code! user: privateUser, user_settings: user.settings, // @ts-ignore diff --git a/util/src/migrations/mariadb/1660130586602-updated-applications.ts b/src/util/migrations/mariadb/1660130586602-updated-applications.ts similarity index 100% rename from util/src/migrations/mariadb/1660130586602-updated-applications.ts rename to src/util/migrations/mariadb/1660130586602-updated-applications.ts diff --git a/util/src/migrations/mariadb/1660131942703-apps_nullable_team.ts b/src/util/migrations/mariadb/1660131942703-apps_nullable_team.ts similarity index 100% rename from util/src/migrations/mariadb/1660131942703-apps_nullable_team.ts rename to src/util/migrations/mariadb/1660131942703-apps_nullable_team.ts diff --git a/src/util/migrations/mariadb/1660258393551-CodeCleanup3.ts b/src/util/migrations/mariadb/1660258393551-CodeCleanup3.ts deleted file mode 100644 index 87d075e44..000000000 --- a/src/util/migrations/mariadb/1660258393551-CodeCleanup3.ts +++ /dev/null @@ -1,232 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class CodeCleanup31660258393551 implements MigrationInterface { - name = 'CodeCleanup31660258393551' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_2ce5a55796fe4c2f77ece57a647\` - `); - await queryRunner.query(` - DROP INDEX \`REL_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` - `); - await queryRunner.query(` - CREATE TABLE \`user_settings\` ( - \`id\` varchar(255) NOT NULL, - \`afk_timeout\` int NULL, - \`allow_accessibility_detection\` tinyint NULL, - \`animate_emoji\` tinyint NULL, - \`animate_stickers\` int NULL, - \`contact_sync_enabled\` tinyint NULL, - \`convert_emoticons\` tinyint NULL, - \`custom_status\` text NULL, - \`default_guilds_restricted\` tinyint NULL, - \`detect_platform_accounts\` tinyint NULL, - \`developer_mode\` tinyint NULL, - \`disable_games_tab\` tinyint NULL, - \`enable_tts_command\` tinyint NULL, - \`explicit_content_filter\` int NULL, - \`friend_source_flags\` text NULL, - \`gateway_connected\` tinyint NULL, - \`gif_auto_play\` tinyint NULL, - \`guild_folders\` text NULL, - \`guild_positions\` text NULL, - \`inline_attachment_media\` tinyint NULL, - \`inline_embed_media\` tinyint NULL, - \`locale\` varchar(255) NULL, - \`message_display_compact\` tinyint NULL, - \`native_phone_integration_enabled\` tinyint NULL, - \`render_embeds\` tinyint NULL, - \`render_reactions\` tinyint NULL, - \`restricted_guilds\` text NULL, - \`show_current_game\` tinyint NULL, - \`status\` varchar(255) NULL, - \`stream_notifications_enabled\` tinyint NULL, - \`theme\` varchar(255) NULL, - \`timezone_offset\` int NULL, - PRIMARY KEY (\`id\`) - ) ENGINE = InnoDB - `); - await queryRunner.query(` - ALTER TABLE \`users\` DROP COLUMN \`settings\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`type\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`hook\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`redirect_uris\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`rpc_application_state\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`store_application_state\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`verification_state\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`interactions_endpoint_url\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`integration_public\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`integration_require_code_grant\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`discoverability_state\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`discovery_eligibility_flags\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`tags\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`install_params\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`bot_user_id\` - `); - await queryRunner.query(` - ALTER TABLE \`guilds\` - ADD \`premium_progress_bar_enabled\` tinyint NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`rpc_origins\` text NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`primary_sku_id\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`slug\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`guild_id\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` CHANGE \`description\` \`description\` varchar(255) NOT NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`flags\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`flags\` varchar(255) NOT NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD CONSTRAINT \`FK_e5bf78cdbbe9ba91062d74c5aba\` FOREIGN KEY (\`guild_id\`) REFERENCES \`guilds\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`applications\` DROP FOREIGN KEY \`FK_e5bf78cdbbe9ba91062d74c5aba\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`flags\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`flags\` int NOT NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` CHANGE \`description\` \`description\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`guild_id\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`slug\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`primary_sku_id\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` DROP COLUMN \`rpc_origins\` - `); - await queryRunner.query(` - ALTER TABLE \`guilds\` DROP COLUMN \`premium_progress_bar_enabled\` - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`bot_user_id\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`install_params\` text NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`tags\` text NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`discovery_eligibility_flags\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`discoverability_state\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`integration_require_code_grant\` tinyint NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`integration_public\` tinyint NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`interactions_endpoint_url\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`verification_state\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`store_application_state\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`rpc_application_state\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`redirect_uris\` text NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`hook\` tinyint NOT NULL - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD \`type\` text NULL - `); - await queryRunner.query(` - ALTER TABLE \`users\` - ADD \`settings\` text NOT NULL - `); - await queryRunner.query(` - DROP TABLE \`user_settings\` - `); - await queryRunner.query(` - CREATE UNIQUE INDEX \`REL_2ce5a55796fe4c2f77ece57a64\` ON \`applications\` (\`bot_user_id\`) - `); - await queryRunner.query(` - ALTER TABLE \`applications\` - ADD CONSTRAINT \`FK_2ce5a55796fe4c2f77ece57a647\` FOREIGN KEY (\`bot_user_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION - `); - } - -} diff --git a/util/src/migrations/postgres/1660130561959-updated-applications.ts b/src/util/migrations/postgres/1660130561959-updated-applications.ts similarity index 100% rename from util/src/migrations/postgres/1660130561959-updated-applications.ts rename to src/util/migrations/postgres/1660130561959-updated-applications.ts diff --git a/util/src/migrations/sqlite/1660130536131-updated-applications.ts b/src/util/migrations/sqlite/1660130536131-updated-applications.ts similarity index 100% rename from util/src/migrations/sqlite/1660130536131-updated-applications.ts rename to src/util/migrations/sqlite/1660130536131-updated-applications.ts diff --git a/util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts b/util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts deleted file mode 100644 index 8374eafbc..000000000 --- a/util/src/migrations/mariadb/1660416072362-InvitersAreDeletable.ts +++ /dev/null @@ -1,56 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class InvitersAreDeletable1660416072362 implements MigrationInterface { - name = 'InvitersAreDeletable1660416072362' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` - `); - await queryRunner.query(` - DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` - `); - await queryRunner.query(` - CREATE TABLE \`plugin_config\` ( - \`key\` varchar(255) NOT NULL, - \`value\` text NULL, - PRIMARY KEY (\`key\`) - ) ENGINE = InnoDB - `); - await queryRunner.query(` - ALTER TABLE \`channels\` - ADD \`flags\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`channels\` - ADD \`default_thread_rate_limit_per_user\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`invites\` - ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` - `); - await queryRunner.query(` - ALTER TABLE \`channels\` DROP COLUMN \`default_thread_rate_limit_per_user\` - `); - await queryRunner.query(` - ALTER TABLE \`channels\` DROP COLUMN \`flags\` - `); - await queryRunner.query(` - DROP TABLE \`plugin_config\` - `); - await queryRunner.query(` - CREATE UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) - `); - await queryRunner.query(` - ALTER TABLE \`invites\` - ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION - `); - } - -} diff --git a/util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts b/util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts deleted file mode 100644 index e61013189..000000000 --- a/util/src/migrations/postgres/1660416055566-InvitersAreDeletable.ts +++ /dev/null @@ -1,26 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class InvitersAreDeletable1660416055566 implements MigrationInterface { - name = 'InvitersAreDeletable1660416055566' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" - `); - await queryRunner.query(` - ALTER TABLE "invites" - ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE CASCADE ON UPDATE NO ACTION - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "invites" DROP CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" - `); - await queryRunner.query(` - ALTER TABLE "invites" - ADD CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users"("id") ON DELETE NO ACTION ON UPDATE NO ACTION - `); - } - -} diff --git a/util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts b/util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts deleted file mode 100644 index 9b29e119e..000000000 --- a/util/src/migrations/sqlite/1660416010862-InvitersAreDeletable.ts +++ /dev/null @@ -1,246 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class InvitersAreDeletable1660416010862 implements MigrationInterface { - name = 'InvitersAreDeletable1660416010862' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - CREATE TABLE "temporary_invites" ( - "code" varchar PRIMARY KEY NOT NULL, - "temporary" boolean NOT NULL, - "uses" integer NOT NULL, - "max_uses" integer NOT NULL, - "max_age" integer NOT NULL, - "created_at" datetime NOT NULL, - "expires_at" datetime NOT NULL, - "guild_id" varchar, - "channel_id" varchar, - "inviter_id" varchar, - "target_user_id" varchar, - "target_user_type" integer, - "vanity_url" boolean, - CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_invites"( - "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - ) - SELECT "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - FROM "invites" - `); - await queryRunner.query(` - DROP TABLE "invites" - `); - await queryRunner.query(` - ALTER TABLE "temporary_invites" - RENAME TO "invites" - `); - await queryRunner.query(` - CREATE TABLE "temporary_invites" ( - "code" varchar PRIMARY KEY NOT NULL, - "temporary" boolean NOT NULL, - "uses" integer NOT NULL, - "max_uses" integer NOT NULL, - "max_age" integer NOT NULL, - "created_at" datetime NOT NULL, - "expires_at" datetime NOT NULL, - "guild_id" varchar, - "channel_id" varchar, - "inviter_id" varchar, - "target_user_id" varchar, - "target_user_type" integer, - "vanity_url" boolean, - CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "temporary_invites"( - "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - ) - SELECT "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - FROM "invites" - `); - await queryRunner.query(` - DROP TABLE "invites" - `); - await queryRunner.query(` - ALTER TABLE "temporary_invites" - RENAME TO "invites" - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE "invites" - RENAME TO "temporary_invites" - `); - await queryRunner.query(` - CREATE TABLE "invites" ( - "code" varchar PRIMARY KEY NOT NULL, - "temporary" boolean NOT NULL, - "uses" integer NOT NULL, - "max_uses" integer NOT NULL, - "max_age" integer NOT NULL, - "created_at" datetime NOT NULL, - "expires_at" datetime NOT NULL, - "guild_id" varchar, - "channel_id" varchar, - "inviter_id" varchar, - "target_user_id" varchar, - "target_user_type" integer, - "vanity_url" boolean, - CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "invites"( - "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - ) - SELECT "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - FROM "temporary_invites" - `); - await queryRunner.query(` - DROP TABLE "temporary_invites" - `); - await queryRunner.query(` - ALTER TABLE "invites" - RENAME TO "temporary_invites" - `); - await queryRunner.query(` - CREATE TABLE "invites" ( - "code" varchar PRIMARY KEY NOT NULL, - "temporary" boolean NOT NULL, - "uses" integer NOT NULL, - "max_uses" integer NOT NULL, - "max_age" integer NOT NULL, - "created_at" datetime NOT NULL, - "expires_at" datetime NOT NULL, - "guild_id" varchar, - "channel_id" varchar, - "inviter_id" varchar, - "target_user_id" varchar, - "target_user_type" integer, - "vanity_url" boolean, - CONSTRAINT "FK_11a0d394f8fc649c19ce5f16b59" FOREIGN KEY ("target_user_id") REFERENCES "users" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_15c35422032e0b22b4ada95f48f" FOREIGN KEY ("inviter_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, - CONSTRAINT "FK_6a15b051fe5050aa00a4b9ff0f6" FOREIGN KEY ("channel_id") REFERENCES "channels" ("id") ON DELETE CASCADE ON UPDATE NO ACTION, - CONSTRAINT "FK_3f4939aa1461e8af57fea3fb05d" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION - ) - `); - await queryRunner.query(` - INSERT INTO "invites"( - "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - ) - SELECT "code", - "temporary", - "uses", - "max_uses", - "max_age", - "created_at", - "expires_at", - "guild_id", - "channel_id", - "inviter_id", - "target_user_id", - "target_user_type", - "vanity_url" - FROM "temporary_invites" - `); - await queryRunner.query(` - DROP TABLE "temporary_invites" - `); - } - -} From 79d97a9252beff84104cdb8fabe477b310e81956 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 15 Aug 2022 06:14:02 +0200 Subject: [PATCH 222/238] Update db migration script --- scripts/db_migrations.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/scripts/db_migrations.sh b/scripts/db_migrations.sh index 83f15a2ba..242b01f00 100755 --- a/scripts/db_migrations.sh +++ b/scripts/db_migrations.sh @@ -15,10 +15,10 @@ fi make_migration() { echo "Creating migrations for $2" - mkdir "../util/src/migrations/$2" + mkdir "src/util/migrations/$2" # npm run build clean logerrors pretty-errors # THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle - THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "../util/src/migrations/$2/$FILENAME" -d ../util/src/util/Database.ts -p + THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "src/migrations/$2/$FILENAME" -d ../util/src/util/Database.ts -p npm run build clean logerrors pretty-errors THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle } From fcef1f4d273f8f792ec70ac75c1ea77fc9b03cd1 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 15 Aug 2022 06:22:22 +0200 Subject: [PATCH 223/238] Fix missing stuff --- fosscord-server.code-workspace | 4 - package.json | 1 - scripts/build.js | 79 +++++++++---------- scripts/utils.js | 1 - .../plugins}/example-plugin/build.sh | 0 .../plugins}/example-plugin/index.ts | 4 +- .../plugins}/example-plugin/plugin.json | 0 .../plugins}/example-plugin/tsconfig.json | 0 8 files changed, 38 insertions(+), 51 deletions(-) rename {plugins => src/plugins}/example-plugin/build.sh (100%) rename {plugins => src/plugins}/example-plugin/index.ts (76%) rename {plugins => src/plugins}/example-plugin/plugin.json (100%) rename {plugins => src/plugins}/example-plugin/tsconfig.json (100%) diff --git a/fosscord-server.code-workspace b/fosscord-server.code-workspace index 1d6774adf..f2df1e9ee 100644 --- a/fosscord-server.code-workspace +++ b/fosscord-server.code-workspace @@ -15,10 +15,6 @@ ], "settings": { "files.exclude": { - ".gitignore": true, - ".npmignore": true, - ".prettierrc": true, - ".vscode": true, "*.ansi": true, } } diff --git a/package.json b/package.json index 59c66811d..f1242d2bc 100644 --- a/package.json +++ b/package.json @@ -7,7 +7,6 @@ "setup": "npm install --omit optional && ts-patch install -s && patch-package && npm run build", "depclean": "node scripts/depclean.js", "depcheck": "node scripts/depcheck.js", - "syncdeps": "node scripts/install.js", "build": "node scripts/build.js", "postinstall": "patch-package", "genschemas": "node scripts/generate_schemas.js", diff --git a/scripts/build.js b/scripts/build.js index 49353c877..f5ec6bac0 100644 --- a/scripts/build.js +++ b/scripts/build.js @@ -8,7 +8,6 @@ if(argv.includes("help")) { console.log(`Fosscord build script help: Arguments: clean Cleans up previous builds - copyonly Only copy source files, don't build (useful for updating assets) verbose Enable verbose logging logerrors Log build errors to console pretty-errors Pretty-print build errors @@ -18,7 +17,6 @@ Arguments: let steps = 3, i = 0; if (argv.includes("clean")) steps++; -if (argv.includes("copyonly")) steps--; const verbose = argv.includes("verbose") || argv.includes("v"); const logerr = argv.includes("logerrors"); @@ -29,13 +27,11 @@ if(silent) console.error = console.log = function(){} if (argv.includes("clean")) { console.log(`[${++i}/${steps}] Cleaning...`); - parts.forEach((a) => { - let d = "../" + a + "/dist"; - if (fs.existsSync(d)) { - fs.rmSync(d, { recursive: true }); - if (verbose) console.log(`Deleted ${d}!`); - } - }); + let d = "dist"; + if (fs.existsSync(d)) { + fs.rmSync(d, { recursive: true }); + if (verbose) console.log(`Deleted ${d}!`); + } } console.log(`[${++i}/${steps}] Checking if dependencies were installed correctly...`); @@ -43,42 +39,39 @@ console.log(`[${++i}/${steps}] Checking if dependencies were installed correctly if(!fs.existsSync(path.join(__dirname, "..", "node_modules", "exif-be-gone", "index.js"))) execIn("npm run build", path.join(__dirname, "..", "node_modules", "exif-be-gone")); +console.log(`[${++i}/${steps}] Compiling src files ...`); -if (!argv.includes("copyonly")) { - console.log(`[${++i}/${steps}] Compiling src files ...`); +let buildFlags = '' +if(pretty) buildFlags += '--pretty ' - let buildFlags = '' - if(pretty) buildFlags += '--pretty ' - - try { - execSync( - 'node "' + - path.join(__dirname, "..", "node_modules", "typescript", "lib", "tsc.js") + - '" -p "' + - path.join(__dirname, "..") + - '" ' + buildFlags, - { - cwd: path.join(__dirname, ".."), - shell: true, - env: process.env, - encoding: "utf8" +try { + execSync( + 'node "' + + path.join(__dirname, "..", "node_modules", "typescript", "lib", "tsc.js") + + '" -p "' + + path.join(__dirname, "..") + + '" ' + buildFlags, + { + cwd: path.join(__dirname, ".."), + shell: true, + env: process.env, + encoding: "utf8" + } + ) +} catch (error) { + if(verbose || logerr) { + error.stdout.split(/\r?\n/).forEach((line) => { + let _line = line.replace('dist/','',1); + if(!pretty && _line.includes('.ts(')) { + //reformat file path for easy jumping + _line = _line.replace('(',':',1).replace(',',':',1).replace(')','',1) } - ) - } catch (error) { - if(verbose || logerr) { - error.stdout.split(/\r?\n/).forEach((line) => { - let _line = line.replace('dist/','',1); - if(!pretty && _line.includes('.ts(')) { - //reformat file path for easy jumping - _line = _line.replace('(',':',1).replace(',',':',1).replace(')','',1) - } - console.error(_line); - }) - } - console.error(`Build failed! Please check build.log for info!`); - if(!silent){ - if(pretty) fs.writeFileSync("build.log.ansi", error.stdout); - fs.writeFileSync("build.log", error.stdout.replaceAll(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '')); - } + console.error(_line); + }) + } + console.error(`Build failed! Please check build.log for info!`); + if(!silent){ + if(pretty) fs.writeFileSync("build.log.ansi", error.stdout); + fs.writeFileSync("build.log", error.stdout.replaceAll(/[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g, '')); } } \ No newline at end of file diff --git a/scripts/utils.js b/scripts/utils.js index ca41bcf20..84aaeed61 100644 --- a/scripts/utils.js +++ b/scripts/utils.js @@ -46,7 +46,6 @@ function getLines(output) { module.exports = { //consts - parts, //functions copyRecursiveSync, execIn, getLines }; diff --git a/plugins/example-plugin/build.sh b/src/plugins/example-plugin/build.sh similarity index 100% rename from plugins/example-plugin/build.sh rename to src/plugins/example-plugin/build.sh diff --git a/plugins/example-plugin/index.ts b/src/plugins/example-plugin/index.ts similarity index 76% rename from plugins/example-plugin/index.ts rename to src/plugins/example-plugin/index.ts index ec1ed7b50..d5db6563f 100644 --- a/plugins/example-plugin/index.ts +++ b/src/plugins/example-plugin/index.ts @@ -1,7 +1,7 @@ -import { Plugin } from "@fosscord/util" +/*import { Plugin } from "@fosscord/util" export default class TestPlugin extends Plugin { onPluginLoaded(): void { console.log("Hello from test plugin! IT WORKS!!!!!!!"); } -} \ No newline at end of file +}*/ \ No newline at end of file diff --git a/plugins/example-plugin/plugin.json b/src/plugins/example-plugin/plugin.json similarity index 100% rename from plugins/example-plugin/plugin.json rename to src/plugins/example-plugin/plugin.json diff --git a/plugins/example-plugin/tsconfig.json b/src/plugins/example-plugin/tsconfig.json similarity index 100% rename from plugins/example-plugin/tsconfig.json rename to src/plugins/example-plugin/tsconfig.json From 551fa530cf2d19b62707c40ca1202bcd6d92c0c0 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 15 Aug 2022 07:16:41 +0200 Subject: [PATCH 224/238] Update package, sync migrations --- package-lock.json | Bin 840733 -> 840752 bytes package.json | 6 +- scripts/build.js | 7 +- scripts/db_migrations.sh | 13 +- .../mariadb/1660540527213-sync_migrations.ts | 127 + .../sqlite/1660538628956-sync_migrations.ts | 172 + .../mariadb/1660260587556-CodeCleanup4.ts | 39 - .../1660416072362-InvitersAreDeletable.ts | 56 - yarn.lock | 9002 +++++++++-------- 9 files changed, 4895 insertions(+), 4527 deletions(-) create mode 100644 src/migrations/mariadb/1660540527213-sync_migrations.ts create mode 100644 src/migrations/sqlite/1660538628956-sync_migrations.ts delete mode 100644 src/util/migrations/mariadb/1660260587556-CodeCleanup4.ts delete mode 100644 src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts diff --git a/package-lock.json b/package-lock.json index 0d6f7bd0679d4557bf4e4ddabcfaf06f81c3c21c..0892cb884cfa2204a6ccaa744fc8f5cace7b0498 100644 GIT binary patch delta 825 zcmbQc!gvD^onxA=WWcRF`98noWG-ecW=lPT$$PoVCa+`OJ$W*R#O6$v^GuB9(*qS* zM4SEC+x^%XxBIa(eNUdQe3I30`hqkj_UZFZvhgxo=$TJ14C7P^@k+1qcP$Su^$l^V z@Tf|63er!@$Z+xxFDi4&D)ZN_3MfepO;1WH4a~GKD2nuq@+itS%=JqO3M~wXDh&1s zF!C@DDlai~b@TDjFY)tnF^s6tpWgU{S!()(c%Ws~xlCN`dO1wn^>Ucm#HRZmW7eO3 z@++spbma;*h0q+2GQYy4#E@bSgYc@1s1uhqvYh!ph}CRRM)UbH}BwFzqGP6gFLh1A|Fq;Oang`r|`0j$k3eWAM4o^reAPk zVc#y_%*+-yec}{m!)fkZ?9<~OGV@JuoX)Nk>ZEO^UzuWFXhi}SP<&! zTw(5R;h1TrT~ZjCQRJLa9BJa48(8R-;ci~&Ws(|V=96papBI#onHrXw<64qdkztbP z7?@p>;ujWG;xfIlgjr9(SJ>I6pJ!#`YwvgC0%Gp%{cb#c Fy#Uyt8#e#| delta 874 zcmdn6!g%fq;|=GSCST^anastkHTeQp)#SCzyC+}Z?%T}A>c}*G9y>et^qVgjxu-|- zaq=`5vbPtqGj1K*-7`GW*|XT#&oa!!H^toC z*frcU&Do^XKSZ#$<3P)_oSdpi zL!;nypKNX4cC9q!9N!eIFAG&wy;Vu>2XqQn$vS0G3&JZKVk-A79eH?Vm2UV-|qj2BSV8gOvKY7CQ8z6 zZI!q/dev/null + source .env.tmp 2>/dev/null ) +npm run build clean logerrors pretty-errors make_migration() { echo "Creating migrations for $2" - mkdir "src/util/migrations/$2" + mkdir "src/util/migrations/$2" 2>/dev/null # npm run build clean logerrors pretty-errors -# THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle - THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "src/migrations/$2/$FILENAME" -d ../util/src/util/Database.ts -p + THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle + THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "src/migrations/$2/$FILENAME" -d src/util/util/Database.ts -p npm run build clean logerrors pretty-errors THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle } @@ -36,5 +37,5 @@ make_migration "database.db" "sqlite" make_migration "$FC_DB_MARIADB" "mariadb" ) -[ -f ".env.tmp" ] && mv .env.tmp .env +[ -f ".env.tmp" ] && mv .env.tmp .env 2>/dev/null diff --git a/src/migrations/mariadb/1660540527213-sync_migrations.ts b/src/migrations/mariadb/1660540527213-sync_migrations.ts new file mode 100644 index 000000000..8cc1d2f17 --- /dev/null +++ b/src/migrations/mariadb/1660540527213-sync_migrations.ts @@ -0,0 +1,127 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class syncMigrations1660540527213 implements MigrationInterface { + name = 'syncMigrations1660540527213' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` CHANGE \`settings\` \`settingsId\` text NOT NULL + `); + await queryRunner.query(` + CREATE TABLE \`user_settings\` ( + \`id\` varchar(255) NOT NULL, + \`afk_timeout\` int NULL, + \`allow_accessibility_detection\` tinyint NULL, + \`animate_emoji\` tinyint NULL, + \`animate_stickers\` int NULL, + \`contact_sync_enabled\` tinyint NULL, + \`convert_emoticons\` tinyint NULL, + \`custom_status\` text NULL, + \`default_guilds_restricted\` tinyint NULL, + \`detect_platform_accounts\` tinyint NULL, + \`developer_mode\` tinyint NULL, + \`disable_games_tab\` tinyint NULL, + \`enable_tts_command\` tinyint NULL, + \`explicit_content_filter\` int NULL, + \`friend_source_flags\` text NULL, + \`gateway_connected\` tinyint NULL, + \`gif_auto_play\` tinyint NULL, + \`guild_folders\` text NULL, + \`guild_positions\` text NULL, + \`inline_attachment_media\` tinyint NULL, + \`inline_embed_media\` tinyint NULL, + \`locale\` varchar(255) NULL, + \`message_display_compact\` tinyint NULL, + \`native_phone_integration_enabled\` tinyint NULL, + \`render_embeds\` tinyint NULL, + \`render_reactions\` tinyint NULL, + \`restricted_guilds\` text NULL, + \`show_current_game\` tinyint NULL, + \`status\` varchar(255) NULL, + \`stream_notifications_enabled\` tinyint NULL, + \`theme\` varchar(255) NULL, + \`timezone_offset\` int NULL, + PRIMARY KEY (\`id\`) + ) ENGINE = InnoDB + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD \`flags\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`channels\` + ADD \`default_thread_rate_limit_per_user\` int NULL + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` + ADD \`premium_progress_bar_enabled\` tinyint NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP COLUMN \`settingsId\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD \`settingsId\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` (\`settingsId\`) + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD CONSTRAINT \`FK_76ba283779c8441fd5ff819c8cf\` FOREIGN KEY (\`settingsId\`) REFERENCES \`user_settings\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP FOREIGN KEY \`FK_76ba283779c8441fd5ff819c8cf\` + `); + await queryRunner.query(` + DROP INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` DROP COLUMN \`settingsId\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` + ADD \`settingsId\` text NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`guilds\` DROP COLUMN \`premium_progress_bar_enabled\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP COLUMN \`default_thread_rate_limit_per_user\` + `); + await queryRunner.query(` + ALTER TABLE \`channels\` DROP COLUMN \`flags\` + `); + await queryRunner.query(` + DROP TABLE \`user_settings\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` CHANGE \`settingsId\` \`settings\` text NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`invites\` + ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION + `); + } + +} diff --git a/src/migrations/sqlite/1660538628956-sync_migrations.ts b/src/migrations/sqlite/1660538628956-sync_migrations.ts new file mode 100644 index 000000000..9cdc064fb --- /dev/null +++ b/src/migrations/sqlite/1660538628956-sync_migrations.ts @@ -0,0 +1,172 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class syncMigrations1660538628956 implements MigrationInterface { + name = 'syncMigrations1660538628956' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_channels" ( + "id" varchar PRIMARY KEY NOT NULL, + "created_at" datetime NOT NULL, + "name" varchar, + "icon" text, + "type" integer NOT NULL, + "last_message_id" varchar, + "guild_id" varchar, + "parent_id" varchar, + "owner_id" varchar, + "last_pin_timestamp" integer, + "default_auto_archive_duration" integer, + "position" integer, + "permission_overwrites" text, + "video_quality_mode" integer, + "bitrate" integer, + "user_limit" integer, + "nsfw" boolean, + "rate_limit_per_user" integer, + "topic" varchar, + "retention_policy_id" varchar, + "flags" integer, + "default_thread_rate_limit_per_user" integer, + CONSTRAINT "FK_3873ed438575cce703ecff4fc7b" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_3274522d14af40540b1a883fc80" FOREIGN KEY ("parent_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_c253dafe5f3a03ec00cd8fb4581" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_channels"( + "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + ) + SELECT "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + FROM "channels" + `); + await queryRunner.query(` + DROP TABLE "channels" + `); + await queryRunner.query(` + ALTER TABLE "temporary_channels" + RENAME TO "channels" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "channels" + RENAME TO "temporary_channels" + `); + await queryRunner.query(` + CREATE TABLE "channels" ( + "id" varchar PRIMARY KEY NOT NULL, + "created_at" datetime NOT NULL, + "name" varchar, + "icon" text, + "type" integer NOT NULL, + "last_message_id" varchar, + "guild_id" varchar, + "parent_id" varchar, + "owner_id" varchar, + "last_pin_timestamp" integer, + "default_auto_archive_duration" integer, + "position" integer, + "permission_overwrites" text, + "video_quality_mode" integer, + "bitrate" integer, + "user_limit" integer, + "nsfw" boolean, + "rate_limit_per_user" integer, + "topic" varchar, + "retention_policy_id" varchar, + CONSTRAINT "FK_3873ed438575cce703ecff4fc7b" FOREIGN KEY ("owner_id") REFERENCES "users" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_3274522d14af40540b1a883fc80" FOREIGN KEY ("parent_id") REFERENCES "channels" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION, + CONSTRAINT "FK_c253dafe5f3a03ec00cd8fb4581" FOREIGN KEY ("guild_id") REFERENCES "guilds" ("id") ON DELETE CASCADE ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "channels"( + "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + ) + SELECT "id", + "created_at", + "name", + "icon", + "type", + "last_message_id", + "guild_id", + "parent_id", + "owner_id", + "last_pin_timestamp", + "default_auto_archive_duration", + "position", + "permission_overwrites", + "video_quality_mode", + "bitrate", + "user_limit", + "nsfw", + "rate_limit_per_user", + "topic", + "retention_policy_id" + FROM "temporary_channels" + `); + await queryRunner.query(` + DROP TABLE "temporary_channels" + `); + } + +} diff --git a/src/util/migrations/mariadb/1660260587556-CodeCleanup4.ts b/src/util/migrations/mariadb/1660260587556-CodeCleanup4.ts deleted file mode 100644 index 98da67dbf..000000000 --- a/src/util/migrations/mariadb/1660260587556-CodeCleanup4.ts +++ /dev/null @@ -1,39 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class CodeCleanup41660260587556 implements MigrationInterface { - name = 'CodeCleanup41660260587556' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`users\` - ADD \`settingsId\` varchar(255) NULL - `); - await queryRunner.query(` - ALTER TABLE \`users\` - ADD UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` (\`settingsId\`) - `); - await queryRunner.query(` - CREATE UNIQUE INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) - `); - await queryRunner.query(` - ALTER TABLE \`users\` - ADD CONSTRAINT \`FK_76ba283779c8441fd5ff819c8cf\` FOREIGN KEY (\`settingsId\`) REFERENCES \`user_settings\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`users\` DROP FOREIGN KEY \`FK_76ba283779c8441fd5ff819c8cf\` - `); - await queryRunner.query(` - DROP INDEX \`REL_76ba283779c8441fd5ff819c8c\` ON \`users\` - `); - await queryRunner.query(` - ALTER TABLE \`users\` DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` - `); - await queryRunner.query(` - ALTER TABLE \`users\` DROP COLUMN \`settingsId\` - `); - } - -} diff --git a/src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts b/src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts deleted file mode 100644 index 8374eafbc..000000000 --- a/src/util/migrations/mariadb/1660416072362-InvitersAreDeletable.ts +++ /dev/null @@ -1,56 +0,0 @@ -import { MigrationInterface, QueryRunner } from "typeorm"; - -export class InvitersAreDeletable1660416072362 implements MigrationInterface { - name = 'InvitersAreDeletable1660416072362' - - public async up(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` - `); - await queryRunner.query(` - DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` - `); - await queryRunner.query(` - CREATE TABLE \`plugin_config\` ( - \`key\` varchar(255) NOT NULL, - \`value\` text NULL, - PRIMARY KEY (\`key\`) - ) ENGINE = InnoDB - `); - await queryRunner.query(` - ALTER TABLE \`channels\` - ADD \`flags\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`channels\` - ADD \`default_thread_rate_limit_per_user\` int NULL - `); - await queryRunner.query(` - ALTER TABLE \`invites\` - ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE CASCADE ON UPDATE NO ACTION - `); - } - - public async down(queryRunner: QueryRunner): Promise { - await queryRunner.query(` - ALTER TABLE \`invites\` DROP FOREIGN KEY \`FK_15c35422032e0b22b4ada95f48f\` - `); - await queryRunner.query(` - ALTER TABLE \`channels\` DROP COLUMN \`default_thread_rate_limit_per_user\` - `); - await queryRunner.query(` - ALTER TABLE \`channels\` DROP COLUMN \`flags\` - `); - await queryRunner.query(` - DROP TABLE \`plugin_config\` - `); - await queryRunner.query(` - CREATE UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) - `); - await queryRunner.query(` - ALTER TABLE \`invites\` - ADD CONSTRAINT \`FK_15c35422032e0b22b4ada95f48f\` FOREIGN KEY (\`inviter_id\`) REFERENCES \`users\`(\`id\`) ON DELETE NO ACTION ON UPDATE NO ACTION - `); - } - -} diff --git a/yarn.lock b/yarn.lock index 3173ddfa8..c69f3ac0b 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3,54 +3,54 @@ "@ampproject/remapping@^2.1.0": - version "2.2.0" - resolved "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz" - integrity sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w== + "integrity" "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==" + "resolved" "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz" + "version" "2.2.0" dependencies: "@jridgewell/gen-mapping" "^0.1.0" "@jridgewell/trace-mapping" "^0.3.9" "@aws-crypto/crc32@2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/crc32/-/crc32-2.0.0.tgz" - integrity sha512-TvE1r2CUueyXOuHdEigYjIZVesInd9KN+K/TFFNfkkxRThiNxO6i4ZqqAVMoEjAamZZ1AA8WXJkjCz7YShHPQA== + "integrity" "sha512-TvE1r2CUueyXOuHdEigYjIZVesInd9KN+K/TFFNfkkxRThiNxO6i4ZqqAVMoEjAamZZ1AA8WXJkjCz7YShHPQA==" + "resolved" "https://registry.npmjs.org/@aws-crypto/crc32/-/crc32-2.0.0.tgz" + "version" "2.0.0" dependencies: "@aws-crypto/util" "^2.0.0" "@aws-sdk/types" "^3.1.0" - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-crypto/crc32c@2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/crc32c/-/crc32c-2.0.0.tgz" - integrity sha512-vF0eMdMHx3O3MoOXUfBZry8Y4ZDtcuskjjKgJz8YfIDjLStxTZrYXk+kZqtl6A0uCmmiN/Eb/JbC/CndTV1MHg== + "integrity" "sha512-vF0eMdMHx3O3MoOXUfBZry8Y4ZDtcuskjjKgJz8YfIDjLStxTZrYXk+kZqtl6A0uCmmiN/Eb/JbC/CndTV1MHg==" + "resolved" "https://registry.npmjs.org/@aws-crypto/crc32c/-/crc32c-2.0.0.tgz" + "version" "2.0.0" dependencies: "@aws-crypto/util" "^2.0.0" "@aws-sdk/types" "^3.1.0" - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-crypto/ie11-detection@^2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/ie11-detection/-/ie11-detection-2.0.0.tgz" - integrity sha512-pkVXf/dq6PITJ0jzYZ69VhL8VFOFoPZLZqtU/12SGnzYuJOOGNfF41q9GxdI1yqC8R13Rq3jOLKDFpUJFT5eTA== + "integrity" "sha512-pkVXf/dq6PITJ0jzYZ69VhL8VFOFoPZLZqtU/12SGnzYuJOOGNfF41q9GxdI1yqC8R13Rq3jOLKDFpUJFT5eTA==" + "resolved" "https://registry.npmjs.org/@aws-crypto/ie11-detection/-/ie11-detection-2.0.0.tgz" + "version" "2.0.0" dependencies: - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-crypto/sha1-browser@2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/sha1-browser/-/sha1-browser-2.0.0.tgz" - integrity sha512-3fIVRjPFY8EG5HWXR+ZJZMdWNRpwbxGzJ9IH9q93FpbgCH8u8GHRi46mZXp3cYD7gealmyqpm3ThZwLKJjWJhA== + "integrity" "sha512-3fIVRjPFY8EG5HWXR+ZJZMdWNRpwbxGzJ9IH9q93FpbgCH8u8GHRi46mZXp3cYD7gealmyqpm3ThZwLKJjWJhA==" + "resolved" "https://registry.npmjs.org/@aws-crypto/sha1-browser/-/sha1-browser-2.0.0.tgz" + "version" "2.0.0" dependencies: "@aws-crypto/ie11-detection" "^2.0.0" "@aws-crypto/supports-web-crypto" "^2.0.0" "@aws-sdk/types" "^3.1.0" "@aws-sdk/util-locate-window" "^3.0.0" "@aws-sdk/util-utf8-browser" "^3.0.0" - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-crypto/sha256-browser@2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/sha256-browser/-/sha256-browser-2.0.0.tgz" - integrity sha512-rYXOQ8BFOaqMEHJrLHul/25ckWH6GTJtdLSajhlqGMx0PmSueAuvboCuZCTqEKlxR8CQOwRarxYMZZSYlhRA1A== + "integrity" "sha512-rYXOQ8BFOaqMEHJrLHul/25ckWH6GTJtdLSajhlqGMx0PmSueAuvboCuZCTqEKlxR8CQOwRarxYMZZSYlhRA1A==" + "resolved" "https://registry.npmjs.org/@aws-crypto/sha256-browser/-/sha256-browser-2.0.0.tgz" + "version" "2.0.0" dependencies: "@aws-crypto/ie11-detection" "^2.0.0" "@aws-crypto/sha256-js" "^2.0.0" @@ -59,60 +59,60 @@ "@aws-sdk/types" "^3.1.0" "@aws-sdk/util-locate-window" "^3.0.0" "@aws-sdk/util-utf8-browser" "^3.0.0" - tslib "^1.11.1" + "tslib" "^1.11.1" -"@aws-crypto/sha256-js@2.0.0", "@aws-crypto/sha256-js@^2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/sha256-js/-/sha256-js-2.0.0.tgz" - integrity sha512-VZY+mCY4Nmrs5WGfitmNqXzaE873fcIZDu54cbaDaaamsaTOP1DBImV9F4pICc3EHjQXujyE8jig+PFCaew9ig== +"@aws-crypto/sha256-js@^2.0.0", "@aws-crypto/sha256-js@2.0.0": + "integrity" "sha512-VZY+mCY4Nmrs5WGfitmNqXzaE873fcIZDu54cbaDaaamsaTOP1DBImV9F4pICc3EHjQXujyE8jig+PFCaew9ig==" + "resolved" "https://registry.npmjs.org/@aws-crypto/sha256-js/-/sha256-js-2.0.0.tgz" + "version" "2.0.0" dependencies: "@aws-crypto/util" "^2.0.0" "@aws-sdk/types" "^3.1.0" - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-crypto/supports-web-crypto@^2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/@aws-crypto/supports-web-crypto/-/supports-web-crypto-2.0.0.tgz" - integrity sha512-Ge7WQ3E0OC7FHYprsZV3h0QIcpdyJLvIeg+uTuHqRYm8D6qCFJoiC+edSzSyFiHtZf+NOQDJ1q46qxjtzIY2nA== + "integrity" "sha512-Ge7WQ3E0OC7FHYprsZV3h0QIcpdyJLvIeg+uTuHqRYm8D6qCFJoiC+edSzSyFiHtZf+NOQDJ1q46qxjtzIY2nA==" + "resolved" "https://registry.npmjs.org/@aws-crypto/supports-web-crypto/-/supports-web-crypto-2.0.0.tgz" + "version" "2.0.0" dependencies: - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-crypto/util@^2.0.0": - version "2.0.1" - resolved "https://registry.npmjs.org/@aws-crypto/util/-/util-2.0.1.tgz" - integrity sha512-JJmFFwvbm08lULw4Nm5QOLg8+lAQeC8aCXK5xrtxntYzYXCGfHwUJ4Is3770Q7HmICsXthGQ+ZsDL7C2uH3yBQ== + "integrity" "sha512-JJmFFwvbm08lULw4Nm5QOLg8+lAQeC8aCXK5xrtxntYzYXCGfHwUJ4Is3770Q7HmICsXthGQ+ZsDL7C2uH3yBQ==" + "resolved" "https://registry.npmjs.org/@aws-crypto/util/-/util-2.0.1.tgz" + "version" "2.0.1" dependencies: "@aws-sdk/types" "^3.1.0" "@aws-sdk/util-utf8-browser" "^3.0.0" - tslib "^1.11.1" + "tslib" "^1.11.1" "@aws-sdk/abort-controller@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/abort-controller/-/abort-controller-3.127.0.tgz" - integrity sha512-G77FLYcl9egUoD3ZmR6TX94NMqBMeT53hBGrEE3uVUJV1CwfGKfaF007mPpRZnIB3avnJBQGEK6MrwlCfv2qAw== + "integrity" "sha512-G77FLYcl9egUoD3ZmR6TX94NMqBMeT53hBGrEE3uVUJV1CwfGKfaF007mPpRZnIB3avnJBQGEK6MrwlCfv2qAw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/abort-controller/-/abort-controller-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/chunked-blob-reader-native@3.109.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/chunked-blob-reader-native/-/chunked-blob-reader-native-3.109.0.tgz" - integrity sha512-Ybn3vDZ3CqGyprL2qdF6QZqoqlx8lA3qOJepobjuKKDRw+KgGxjUY4NvWe0R2MdRoduyaDj6uvhIay0S1MOSJQ== + "integrity" "sha512-Ybn3vDZ3CqGyprL2qdF6QZqoqlx8lA3qOJepobjuKKDRw+KgGxjUY4NvWe0R2MdRoduyaDj6uvhIay0S1MOSJQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/chunked-blob-reader-native/-/chunked-blob-reader-native-3.109.0.tgz" + "version" "3.109.0" dependencies: "@aws-sdk/util-base64-browser" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/chunked-blob-reader@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/chunked-blob-reader/-/chunked-blob-reader-3.55.0.tgz" - integrity sha512-o/xjMCq81opAjSBjt7YdHJwIJcGVG5XIV9+C2KXcY5QwVimkOKPybWTv0mXPvSwSilSx+EhpLNhkcJuXdzhw4w== + "integrity" "sha512-o/xjMCq81opAjSBjt7YdHJwIJcGVG5XIV9+C2KXcY5QwVimkOKPybWTv0mXPvSwSilSx+EhpLNhkcJuXdzhw4w==" + "resolved" "https://registry.npmjs.org/@aws-sdk/chunked-blob-reader/-/chunked-blob-reader-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/client-s3@^3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/client-s3/-/client-s3-3.137.0.tgz" - integrity sha512-WFOBywwV7ECAOkSOLecpPOGbgmYV5NxHzXHTJEio6xR6s2KzoLegJa0/mq5ljh0Zl5t2h5bsKT1CxYRC0sfwWw== + "integrity" "sha512-WFOBywwV7ECAOkSOLecpPOGbgmYV5NxHzXHTJEio6xR6s2KzoLegJa0/mq5ljh0Zl5t2h5bsKT1CxYRC0sfwWw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/client-s3/-/client-s3-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-crypto/sha1-browser" "2.0.0" "@aws-crypto/sha256-browser" "2.0.0" @@ -165,14 +165,14 @@ "@aws-sdk/util-utf8-node" "3.109.0" "@aws-sdk/util-waiter" "3.127.0" "@aws-sdk/xml-builder" "3.109.0" - entities "2.2.0" - fast-xml-parser "3.19.0" - tslib "^2.3.1" + "entities" "2.2.0" + "fast-xml-parser" "3.19.0" + "tslib" "^2.3.1" "@aws-sdk/client-sso@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/client-sso/-/client-sso-3.137.0.tgz" - integrity sha512-l9y9usMuXGI+o1c/VO2qMccN0Bm0T5bFmmbRljB6kIzbJYXD/wVqR8GMZwSnFnz52cnURQ4pgqM1ETg54FlBYQ== + "integrity" "sha512-l9y9usMuXGI+o1c/VO2qMccN0Bm0T5bFmmbRljB6kIzbJYXD/wVqR8GMZwSnFnz52cnURQ4pgqM1ETg54FlBYQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/client-sso/-/client-sso-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-crypto/sha256-browser" "2.0.0" "@aws-crypto/sha256-js" "2.0.0" @@ -204,12 +204,12 @@ "@aws-sdk/util-user-agent-node" "3.127.0" "@aws-sdk/util-utf8-browser" "3.109.0" "@aws-sdk/util-utf8-node" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/client-sts@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/client-sts/-/client-sts-3.137.0.tgz" - integrity sha512-yJqfkEq0DG9Ds+oif/sc02PX6vfSNcyRe3YcaW5P6ouMyhJRljSIVCnA6iPwJaTsmK9BE9PDgFD2v/GYM/XgOA== + "integrity" "sha512-yJqfkEq0DG9Ds+oif/sc02PX6vfSNcyRe3YcaW5P6ouMyhJRljSIVCnA6iPwJaTsmK9BE9PDgFD2v/GYM/XgOA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/client-sts/-/client-sts-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-crypto/sha256-browser" "2.0.0" "@aws-crypto/sha256-js" "2.0.0" @@ -244,45 +244,45 @@ "@aws-sdk/util-user-agent-node" "3.127.0" "@aws-sdk/util-utf8-browser" "3.109.0" "@aws-sdk/util-utf8-node" "3.109.0" - entities "2.2.0" - fast-xml-parser "3.19.0" - tslib "^2.3.1" + "entities" "2.2.0" + "fast-xml-parser" "3.19.0" + "tslib" "^2.3.1" "@aws-sdk/config-resolver@3.130.0": - version "3.130.0" - resolved "https://registry.npmjs.org/@aws-sdk/config-resolver/-/config-resolver-3.130.0.tgz" - integrity sha512-7dkCHHI9kRcHW6YNr9/2Ub6XkvU9Fu6H/BnlKbaKlDR8jq7QpaFhPhctOVi5D/NDpxJgALifexFne0dvo3piTw== + "integrity" "sha512-7dkCHHI9kRcHW6YNr9/2Ub6XkvU9Fu6H/BnlKbaKlDR8jq7QpaFhPhctOVi5D/NDpxJgALifexFne0dvo3piTw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/config-resolver/-/config-resolver-3.130.0.tgz" + "version" "3.130.0" dependencies: "@aws-sdk/signature-v4" "3.130.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-config-provider" "3.109.0" "@aws-sdk/util-middleware" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-env@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-env/-/credential-provider-env-3.127.0.tgz" - integrity sha512-Ig7XhUikRBlnRTYT5JBGzWfYZp68X5vkFVIFCmsHHt/qVy0Nz9raZpmDHicdS1u67yxDkWgCPn/bNevWnM0GFg== + "integrity" "sha512-Ig7XhUikRBlnRTYT5JBGzWfYZp68X5vkFVIFCmsHHt/qVy0Nz9raZpmDHicdS1u67yxDkWgCPn/bNevWnM0GFg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-env/-/credential-provider-env-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-imds@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-imds/-/credential-provider-imds-3.127.0.tgz" - integrity sha512-I6KlIBBzmJn/U1KikiC50PK3SspT9G5lkVLBaW5a6YfOcijqVTXfAN3kYzqhfeS0j4IgfJEwKVsjsZfmprJO5A== + "integrity" "sha512-I6KlIBBzmJn/U1KikiC50PK3SspT9G5lkVLBaW5a6YfOcijqVTXfAN3kYzqhfeS0j4IgfJEwKVsjsZfmprJO5A==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-imds/-/credential-provider-imds-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/node-config-provider" "3.127.0" "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/url-parser" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-ini@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.137.0.tgz" - integrity sha512-FNSYjHaW83b4sQac+EWh/C6p1taBdvPOXFAVml1mPH49Nlkv9/E4bbjaWwgxvlxjqjNCbkDMKzhb19DN3gVulA== + "integrity" "sha512-FNSYjHaW83b4sQac+EWh/C6p1taBdvPOXFAVml1mPH49Nlkv9/E4bbjaWwgxvlxjqjNCbkDMKzhb19DN3gVulA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-sdk/credential-provider-env" "3.127.0" "@aws-sdk/credential-provider-imds" "3.127.0" @@ -291,12 +291,12 @@ "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/shared-ini-file-loader" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-node@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-node/-/credential-provider-node-3.137.0.tgz" - integrity sha512-if4CzNSyPS3ZERLtDocNNC+l5ejK93d2hoOzNHP2qCmTppThEPWF2TH506ez0v0lbUzeI7qWgpYe9m4+BFLEwQ== + "integrity" "sha512-if4CzNSyPS3ZERLtDocNNC+l5ejK93d2hoOzNHP2qCmTppThEPWF2TH506ez0v0lbUzeI7qWgpYe9m4+BFLEwQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-node/-/credential-provider-node-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-sdk/credential-provider-env" "3.127.0" "@aws-sdk/credential-provider-imds" "3.127.0" @@ -307,599 +307,599 @@ "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/shared-ini-file-loader" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-process@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-process/-/credential-provider-process-3.127.0.tgz" - integrity sha512-6v0m2lqkO9J5fNlTl+HjriQNIdfg8mjVST544+5y9EnC/FVmTnIz64vfHveWdNkP/fehFx7wTimNENtoSqCn3A== + "integrity" "sha512-6v0m2lqkO9J5fNlTl+HjriQNIdfg8mjVST544+5y9EnC/FVmTnIz64vfHveWdNkP/fehFx7wTimNENtoSqCn3A==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-process/-/credential-provider-process-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/shared-ini-file-loader" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-sso@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.137.0.tgz" - integrity sha512-Up2Q3tWSo6Mv2icXMrHa8dGtnC9yQAeUnftrIlvLXi3P9RjxlOPZCSg1NF8FOS90RdEgORlj/7LPlIniHgGUmg== + "integrity" "sha512-Up2Q3tWSo6Mv2icXMrHa8dGtnC9yQAeUnftrIlvLXi3P9RjxlOPZCSg1NF8FOS90RdEgORlj/7LPlIniHgGUmg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-sdk/client-sso" "3.137.0" "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/shared-ini-file-loader" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/credential-provider-web-identity@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.127.0.tgz" - integrity sha512-85ahDZnLYB3dqkW+cQ0bWt+NVqOoxomTrJoq3IC2q6muebeFrJ0pyf0JEW/RNRzBiUvvsZujzGdWifzWyQKfVg== + "integrity" "sha512-85ahDZnLYB3dqkW+cQ0bWt+NVqOoxomTrJoq3IC2q6muebeFrJ0pyf0JEW/RNRzBiUvvsZujzGdWifzWyQKfVg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/eventstream-codec@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/eventstream-codec/-/eventstream-codec-3.127.0.tgz" - integrity sha512-+Tlujx3VkB4DK8tYzG0rwxIE0ee6hWItQgSEREEmi5CwHQFw7VpRLYAShYabEx9wIJmRFObWzhlKxWNRi+TfaA== + "integrity" "sha512-+Tlujx3VkB4DK8tYzG0rwxIE0ee6hWItQgSEREEmi5CwHQFw7VpRLYAShYabEx9wIJmRFObWzhlKxWNRi+TfaA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/eventstream-codec/-/eventstream-codec-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-crypto/crc32" "2.0.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-hex-encoding" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/eventstream-serde-browser@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-browser/-/eventstream-serde-browser-3.127.0.tgz" - integrity sha512-d1rTK4ljEp3Y/BQ78/AJ7eqgGyI6TE0bxNosCmXWcUBv00Tr5cerPqPe7Zvw8XwIMPX5y8cjtd1/cOtB2ePaBw== + "integrity" "sha512-d1rTK4ljEp3Y/BQ78/AJ7eqgGyI6TE0bxNosCmXWcUBv00Tr5cerPqPe7Zvw8XwIMPX5y8cjtd1/cOtB2ePaBw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/eventstream-serde-browser/-/eventstream-serde-browser-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/eventstream-serde-universal" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/eventstream-serde-config-resolver@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-config-resolver/-/eventstream-serde-config-resolver-3.127.0.tgz" - integrity sha512-dYvLfQYcKLOFtZVgwLwKDCykAxNkDyDLQRWytJK9DHCyjRig66IKi1codts9vOy4j0CeYwnXWs5WDavrUaE05g== + "integrity" "sha512-dYvLfQYcKLOFtZVgwLwKDCykAxNkDyDLQRWytJK9DHCyjRig66IKi1codts9vOy4j0CeYwnXWs5WDavrUaE05g==" + "resolved" "https://registry.npmjs.org/@aws-sdk/eventstream-serde-config-resolver/-/eventstream-serde-config-resolver-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/eventstream-serde-node@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-node/-/eventstream-serde-node-3.127.0.tgz" - integrity sha512-Ie59jZYAIw3Kt6GePvEilp1k3JoYEQpY3WIyVZltm3dkVf0GmzhCZrPROH9vgF3qApzu1aGOWDV2wX91poXF8A== + "integrity" "sha512-Ie59jZYAIw3Kt6GePvEilp1k3JoYEQpY3WIyVZltm3dkVf0GmzhCZrPROH9vgF3qApzu1aGOWDV2wX91poXF8A==" + "resolved" "https://registry.npmjs.org/@aws-sdk/eventstream-serde-node/-/eventstream-serde-node-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/eventstream-serde-universal" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/eventstream-serde-universal@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/eventstream-serde-universal/-/eventstream-serde-universal-3.127.0.tgz" - integrity sha512-cJLSTtYDGTevknMTykzHpcDNRbD6yGve8FBUKSAczuNVjXZOedj0GbHJqkASuLj0ZnojbKBdCx4uu1XGyvubng== + "integrity" "sha512-cJLSTtYDGTevknMTykzHpcDNRbD6yGve8FBUKSAczuNVjXZOedj0GbHJqkASuLj0ZnojbKBdCx4uu1XGyvubng==" + "resolved" "https://registry.npmjs.org/@aws-sdk/eventstream-serde-universal/-/eventstream-serde-universal-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/eventstream-codec" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/fetch-http-handler@3.131.0": - version "3.131.0" - resolved "https://registry.npmjs.org/@aws-sdk/fetch-http-handler/-/fetch-http-handler-3.131.0.tgz" - integrity sha512-eNxmPZQX2IUeBGWHNC7eNTekWn9VIPLYEMKJbKYUBJryxuTJ7TtLeyEK5oakUjMwP1AUvWT+CV7C+8L7uG1omQ== + "integrity" "sha512-eNxmPZQX2IUeBGWHNC7eNTekWn9VIPLYEMKJbKYUBJryxuTJ7TtLeyEK5oakUjMwP1AUvWT+CV7C+8L7uG1omQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/fetch-http-handler/-/fetch-http-handler-3.131.0.tgz" + "version" "3.131.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/querystring-builder" "3.127.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-base64-browser" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/hash-blob-browser@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/hash-blob-browser/-/hash-blob-browser-3.127.0.tgz" - integrity sha512-XH9s2w6GXCtDI+3/y+sDAzMWJRTvhRXJJtI1fVDsCiyq96SYUTNKLLaUSuR01uawEBiRDBqGDDPMT8qJPDXc/w== + "integrity" "sha512-XH9s2w6GXCtDI+3/y+sDAzMWJRTvhRXJJtI1fVDsCiyq96SYUTNKLLaUSuR01uawEBiRDBqGDDPMT8qJPDXc/w==" + "resolved" "https://registry.npmjs.org/@aws-sdk/hash-blob-browser/-/hash-blob-browser-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/chunked-blob-reader" "3.55.0" "@aws-sdk/chunked-blob-reader-native" "3.109.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/hash-node@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/hash-node/-/hash-node-3.127.0.tgz" - integrity sha512-wx7DKlXdKebH4JcMsOevdsm2oDNMVm36kuMm0XWRIrFWQ/oq7OquDpEMJzWvGqWF/IfFUpb7FhAWZZpALwlcwA== + "integrity" "sha512-wx7DKlXdKebH4JcMsOevdsm2oDNMVm36kuMm0XWRIrFWQ/oq7OquDpEMJzWvGqWF/IfFUpb7FhAWZZpALwlcwA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/hash-node/-/hash-node-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" "@aws-sdk/util-buffer-from" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/hash-stream-node@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/hash-stream-node/-/hash-stream-node-3.127.0.tgz" - integrity sha512-ZCNqi+FJViYFCo8JfSx+YK0Hd/SC555gHqBe24GVBMCDqJ8UFIled7tF+GOQ8wTcKjxuwp/0EXDTXoaAb0K89g== + "integrity" "sha512-ZCNqi+FJViYFCo8JfSx+YK0Hd/SC555gHqBe24GVBMCDqJ8UFIled7tF+GOQ8wTcKjxuwp/0EXDTXoaAb0K89g==" + "resolved" "https://registry.npmjs.org/@aws-sdk/hash-stream-node/-/hash-stream-node-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/invalid-dependency@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/invalid-dependency/-/invalid-dependency-3.127.0.tgz" - integrity sha512-bxvmtmJ6gIRfOHvh1jAPZBH2mzppEblPjEOFo4mOzXz4U3qPIxeuukCjboMnGK9QEpV2wObWcYYld0vxoRrfiA== + "integrity" "sha512-bxvmtmJ6gIRfOHvh1jAPZBH2mzppEblPjEOFo4mOzXz4U3qPIxeuukCjboMnGK9QEpV2wObWcYYld0vxoRrfiA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/invalid-dependency/-/invalid-dependency-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/is-array-buffer@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/is-array-buffer/-/is-array-buffer-3.55.0.tgz" - integrity sha512-NbiPHVYuPxdqdFd6FxzzN3H1BQn/iWA3ri3Ry7AyLeP/tGs1yzEWMwf8BN8TSMALI0GXT6Sh0GDWy3Ok5xB6DA== + "integrity" "sha512-NbiPHVYuPxdqdFd6FxzzN3H1BQn/iWA3ri3Ry7AyLeP/tGs1yzEWMwf8BN8TSMALI0GXT6Sh0GDWy3Ok5xB6DA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/is-array-buffer/-/is-array-buffer-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/md5-js@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/md5-js/-/md5-js-3.127.0.tgz" - integrity sha512-9FzD++p2bvfZ56hbDxvGcLlA9JIMt9uZB/m4NEvbuvrpx1qnUpFv6HqthhGaVuhctkK25hONT5ZpOYHSisATrA== + "integrity" "sha512-9FzD++p2bvfZ56hbDxvGcLlA9JIMt9uZB/m4NEvbuvrpx1qnUpFv6HqthhGaVuhctkK25hONT5ZpOYHSisATrA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/md5-js/-/md5-js-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" "@aws-sdk/util-utf8-browser" "3.109.0" "@aws-sdk/util-utf8-node" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-bucket-endpoint@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-bucket-endpoint/-/middleware-bucket-endpoint-3.127.0.tgz" - integrity sha512-wJpXxWceBDhWktoxrRb4s6tMx0dWsEGYIaV0KkQPGhTPk2KMUgwa4xApfCXXVfYcE3THk486OKwHhPrR5jpe+g== + "integrity" "sha512-wJpXxWceBDhWktoxrRb4s6tMx0dWsEGYIaV0KkQPGhTPk2KMUgwa4xApfCXXVfYcE3THk486OKwHhPrR5jpe+g==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-bucket-endpoint/-/middleware-bucket-endpoint-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-arn-parser" "3.55.0" "@aws-sdk/util-config-provider" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-content-length@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-content-length/-/middleware-content-length-3.127.0.tgz" - integrity sha512-AFmMaIEW3Rzg0TaKB9l/RENLowd7ZEEOpm0trYw1CgUUORWW/ydCsDT7pekPlC25CPbhUmWXCSA4xPFSYOVnDw== + "integrity" "sha512-AFmMaIEW3Rzg0TaKB9l/RENLowd7ZEEOpm0trYw1CgUUORWW/ydCsDT7pekPlC25CPbhUmWXCSA4xPFSYOVnDw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-content-length/-/middleware-content-length-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-expect-continue@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-expect-continue/-/middleware-expect-continue-3.127.0.tgz" - integrity sha512-+X7mdgFqt9UqUDeGuMt+afR8CBX9nMecTxEIilAKdVOLx+fuXzHnC2mpddKMtiE9IGKMU4BI1Ahf7t32Odhs1Q== + "integrity" "sha512-+X7mdgFqt9UqUDeGuMt+afR8CBX9nMecTxEIilAKdVOLx+fuXzHnC2mpddKMtiE9IGKMU4BI1Ahf7t32Odhs1Q==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-expect-continue/-/middleware-expect-continue-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-flexible-checksums@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-flexible-checksums/-/middleware-flexible-checksums-3.127.0.tgz" - integrity sha512-sXkAwhE9dikO72sEJ7DrUCo5mawauAxICCqipCCSGp0geSkptvtZHhySgJNMVSbUJQmu5bcS+zsFpFVwuJvGxg== + "integrity" "sha512-sXkAwhE9dikO72sEJ7DrUCo5mawauAxICCqipCCSGp0geSkptvtZHhySgJNMVSbUJQmu5bcS+zsFpFVwuJvGxg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-flexible-checksums/-/middleware-flexible-checksums-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-crypto/crc32" "2.0.0" "@aws-crypto/crc32c" "2.0.0" "@aws-sdk/is-array-buffer" "3.55.0" "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-host-header@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-host-header/-/middleware-host-header-3.127.0.tgz" - integrity sha512-e2gTLJb5lYP9lRV7hN3rKY2l4jv8OygOoHElZJ3Z8KPZskjHelYPcQ8XbdfhSXXxC3vc/0QqN0ResFt3W3Pplg== + "integrity" "sha512-e2gTLJb5lYP9lRV7hN3rKY2l4jv8OygOoHElZJ3Z8KPZskjHelYPcQ8XbdfhSXXxC3vc/0QqN0ResFt3W3Pplg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-host-header/-/middleware-host-header-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-location-constraint@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-location-constraint/-/middleware-location-constraint-3.127.0.tgz" - integrity sha512-UtPmbOKEVu+Ue7CwICFSOOOSePV8Piydco/v2IpdRkMO0e4bqQ3Tn0XprBlWWfSW4QCtAPzydrArLsUdk636GA== + "integrity" "sha512-UtPmbOKEVu+Ue7CwICFSOOOSePV8Piydco/v2IpdRkMO0e4bqQ3Tn0XprBlWWfSW4QCtAPzydrArLsUdk636GA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-location-constraint/-/middleware-location-constraint-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-logger@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-logger/-/middleware-logger-3.127.0.tgz" - integrity sha512-jMNLcZB/ECA7OfkNBLNeAlrLRehyfnUeNQJHW3kcxs9h1+6VxaF6wY+WKozszLI7/3OBzQrFHBQCfRZV7ykSLg== + "integrity" "sha512-jMNLcZB/ECA7OfkNBLNeAlrLRehyfnUeNQJHW3kcxs9h1+6VxaF6wY+WKozszLI7/3OBzQrFHBQCfRZV7ykSLg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-logger/-/middleware-logger-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-recursion-detection@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.127.0.tgz" - integrity sha512-tB6WX+Z1kUKTnn5h38XFrTCzoqPKjUZLUjN4Wb27/cbeSiTSKGAZcCXHOJm36Ukorl5arlybQTqGe689EU00Hw== + "integrity" "sha512-tB6WX+Z1kUKTnn5h38XFrTCzoqPKjUZLUjN4Wb27/cbeSiTSKGAZcCXHOJm36Ukorl5arlybQTqGe689EU00Hw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-retry@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-retry/-/middleware-retry-3.127.0.tgz" - integrity sha512-ZSvg/AyGUacWnf3i8ZbyImtiCH+NyafF8uV7bITP7JkwPrG+VdNocJZOr88GRM0c1A0jfkOf7+oq+fInPwwiNA== + "integrity" "sha512-ZSvg/AyGUacWnf3i8ZbyImtiCH+NyafF8uV7bITP7JkwPrG+VdNocJZOr88GRM0c1A0jfkOf7+oq+fInPwwiNA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-retry/-/middleware-retry-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/service-error-classification" "3.127.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-middleware" "3.127.0" - tslib "^2.3.1" - uuid "^8.3.2" + "tslib" "^2.3.1" + "uuid" "^8.3.2" "@aws-sdk/middleware-sdk-s3@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-sdk-s3/-/middleware-sdk-s3-3.127.0.tgz" - integrity sha512-q1mkEN7kYYdQ3LOHIhaT56omYe8DCubyiCKOXuEo5ZiIkE5iq06K/BxWxj3f8bFZxSX80Ma1m8XA5jcOEMphSA== + "integrity" "sha512-q1mkEN7kYYdQ3LOHIhaT56omYe8DCubyiCKOXuEo5ZiIkE5iq06K/BxWxj3f8bFZxSX80Ma1m8XA5jcOEMphSA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-sdk-s3/-/middleware-sdk-s3-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/middleware-bucket-endpoint" "3.127.0" "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-arn-parser" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-sdk-sts@3.130.0": - version "3.130.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-sdk-sts/-/middleware-sdk-sts-3.130.0.tgz" - integrity sha512-FDfs7+ohbhEK3eH3Dshr6JDiL8P72bp3ffeNpPBXuURFqwt4pCmjHuX3SqQR0JIJ2cl3aIdxc17rKaZJfOjtPw== + "integrity" "sha512-FDfs7+ohbhEK3eH3Dshr6JDiL8P72bp3ffeNpPBXuURFqwt4pCmjHuX3SqQR0JIJ2cl3aIdxc17rKaZJfOjtPw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-sdk-sts/-/middleware-sdk-sts-3.130.0.tgz" + "version" "3.130.0" dependencies: "@aws-sdk/middleware-signing" "3.130.0" "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/signature-v4" "3.130.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-serde@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-serde/-/middleware-serde-3.127.0.tgz" - integrity sha512-xmWMYV/t9M+b9yHjqaD1noDNJJViI2QwOH7TQZ9VbbrvdVtDrFuS9Sf9He80TBCJqeHShwQN9783W1I3Pu/8kw== + "integrity" "sha512-xmWMYV/t9M+b9yHjqaD1noDNJJViI2QwOH7TQZ9VbbrvdVtDrFuS9Sf9He80TBCJqeHShwQN9783W1I3Pu/8kw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-serde/-/middleware-serde-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-signing@3.130.0": - version "3.130.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-signing/-/middleware-signing-3.130.0.tgz" - integrity sha512-JePq5XLR9TfRN3RQ0d7Za/bEW5D3xgtD1FNAwHeenWALeozMuQgRPjM5RroCnL/5jY3wuvCZI7cSXeqhawWqmA== + "integrity" "sha512-JePq5XLR9TfRN3RQ0d7Za/bEW5D3xgtD1FNAwHeenWALeozMuQgRPjM5RroCnL/5jY3wuvCZI7cSXeqhawWqmA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-signing/-/middleware-signing-3.130.0.tgz" + "version" "3.130.0" dependencies: "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/signature-v4" "3.130.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-ssec@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-ssec/-/middleware-ssec-3.127.0.tgz" - integrity sha512-R5A13EvdYPdYD2Tq9eW5jqIdscyZlQykQXFEolBD2oi4pew7TZpc/5aazZC0zo9YKJ29qiUR1P4NvjcFJ7zFBg== + "integrity" "sha512-R5A13EvdYPdYD2Tq9eW5jqIdscyZlQykQXFEolBD2oi4pew7TZpc/5aazZC0zo9YKJ29qiUR1P4NvjcFJ7zFBg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-ssec/-/middleware-ssec-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-stack@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-stack/-/middleware-stack-3.127.0.tgz" - integrity sha512-S1IoUE5o1vCmjsF5nIE8zlItNOM1UE+lhmZeigF7knXJ9+a6ewMB6POAj/s4eoi0wcn0eSnAGsqJCWMSUjOPLA== + "integrity" "sha512-S1IoUE5o1vCmjsF5nIE8zlItNOM1UE+lhmZeigF7knXJ9+a6ewMB6POAj/s4eoi0wcn0eSnAGsqJCWMSUjOPLA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-stack/-/middleware-stack-3.127.0.tgz" + "version" "3.127.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/middleware-user-agent@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.127.0.tgz" - integrity sha512-CHxgswoOzdkOEoIq7Oyob3Sx/4FYUv6BhUesAX7MNshaDDsTQPbSWjw5bqZDiL/gO+X/34fvqCVVpVD2GvxW/g== + "integrity" "sha512-CHxgswoOzdkOEoIq7Oyob3Sx/4FYUv6BhUesAX7MNshaDDsTQPbSWjw5bqZDiL/gO+X/34fvqCVVpVD2GvxW/g==" + "resolved" "https://registry.npmjs.org/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/node-config-provider@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/node-config-provider/-/node-config-provider-3.127.0.tgz" - integrity sha512-bAHkASMhLZHT1yv2TX6OJGFV9Lc3t1gKfTMEKdXM2O2YhGfSx9A/qLeJm79oDfnILWQtSS2NicxlRDI2lYGf4g== + "integrity" "sha512-bAHkASMhLZHT1yv2TX6OJGFV9Lc3t1gKfTMEKdXM2O2YhGfSx9A/qLeJm79oDfnILWQtSS2NicxlRDI2lYGf4g==" + "resolved" "https://registry.npmjs.org/@aws-sdk/node-config-provider/-/node-config-provider-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/shared-ini-file-loader" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/node-http-handler@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/node-http-handler/-/node-http-handler-3.127.0.tgz" - integrity sha512-pyMKvheK8eDwWLgYIRsWy8wiyhsbYYcqkZQs3Eh6upI4E8iCY7eMmhWvHYCibvsO+UjsOwa4cAMOfwnv/Z9s8A== + "integrity" "sha512-pyMKvheK8eDwWLgYIRsWy8wiyhsbYYcqkZQs3Eh6upI4E8iCY7eMmhWvHYCibvsO+UjsOwa4cAMOfwnv/Z9s8A==" + "resolved" "https://registry.npmjs.org/@aws-sdk/node-http-handler/-/node-http-handler-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/abort-controller" "3.127.0" "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/querystring-builder" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/property-provider@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/property-provider/-/property-provider-3.127.0.tgz" - integrity sha512-JxenxlTEkWfLrtJqIjaXaJzAVQbbscoCb5bNjmdud07ESLVfWRKJx2nAJdecHKYp2M5NQyqBuFhQ1ELSFYQKCA== + "integrity" "sha512-JxenxlTEkWfLrtJqIjaXaJzAVQbbscoCb5bNjmdud07ESLVfWRKJx2nAJdecHKYp2M5NQyqBuFhQ1ELSFYQKCA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/property-provider/-/property-provider-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/protocol-http@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/protocol-http/-/protocol-http-3.127.0.tgz" - integrity sha512-UG83PVuKX40wilG2uRU0Fvz4OY8Bt+bSPOG776DFjwIXYzK7BwpJm9H2XI2HLhS5WxrJHhwrLBRgW6UiykMnFw== + "integrity" "sha512-UG83PVuKX40wilG2uRU0Fvz4OY8Bt+bSPOG776DFjwIXYzK7BwpJm9H2XI2HLhS5WxrJHhwrLBRgW6UiykMnFw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/protocol-http/-/protocol-http-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/querystring-builder@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/querystring-builder/-/querystring-builder-3.127.0.tgz" - integrity sha512-tsoyp4lLPsASPDYWsezGAHD8VJsZbjUNATNAzTCFdH6p+4SKBK83Q5kfXCzxt13M+l3oKbxxIWLvS0kVQFyltQ== + "integrity" "sha512-tsoyp4lLPsASPDYWsezGAHD8VJsZbjUNATNAzTCFdH6p+4SKBK83Q5kfXCzxt13M+l3oKbxxIWLvS0kVQFyltQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/querystring-builder/-/querystring-builder-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" "@aws-sdk/util-uri-escape" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/querystring-parser@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/querystring-parser/-/querystring-parser-3.127.0.tgz" - integrity sha512-Vn/Dv+PqUSepp/DzLqq0LJJD8HdPefJCnLbO5WcHCARHSGlyGlZUFEM45k/oEHpTvgMXj/ORaP3A+tLwLu0AmA== + "integrity" "sha512-Vn/Dv+PqUSepp/DzLqq0LJJD8HdPefJCnLbO5WcHCARHSGlyGlZUFEM45k/oEHpTvgMXj/ORaP3A+tLwLu0AmA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/querystring-parser/-/querystring-parser-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/service-error-classification@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/service-error-classification/-/service-error-classification-3.127.0.tgz" - integrity sha512-wjZY9rnlA8SPrICUumTYicEKtK4/yKB62iadUk66hxe8MrH8JhuHH2NqIad0Pt/bK/YtNVhd3yb4pRapOeY5qQ== + "integrity" "sha512-wjZY9rnlA8SPrICUumTYicEKtK4/yKB62iadUk66hxe8MrH8JhuHH2NqIad0Pt/bK/YtNVhd3yb4pRapOeY5qQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/service-error-classification/-/service-error-classification-3.127.0.tgz" + "version" "3.127.0" "@aws-sdk/shared-ini-file-loader@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/shared-ini-file-loader/-/shared-ini-file-loader-3.127.0.tgz" - integrity sha512-S3Nn4KRTqoJsB/TbRZSWBBUrkckNMR0Juqz7bOB+wupVvddKP6IcpspSC/GX9zgJjVMV8iGisZ6AUsYsC5r+cA== + "integrity" "sha512-S3Nn4KRTqoJsB/TbRZSWBBUrkckNMR0Juqz7bOB+wupVvddKP6IcpspSC/GX9zgJjVMV8iGisZ6AUsYsC5r+cA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/shared-ini-file-loader/-/shared-ini-file-loader-3.127.0.tgz" + "version" "3.127.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/signature-v4-multi-region@3.130.0": - version "3.130.0" - resolved "https://registry.npmjs.org/@aws-sdk/signature-v4-multi-region/-/signature-v4-multi-region-3.130.0.tgz" - integrity sha512-ZRRoPRoCVdkGDtjuog81pqHsSLfnXK6ELrWm4Dq8xdcHQGbEDNdYmeXARXG9yPAO42x9yIJXHNutMz5Y/P64cw== + "integrity" "sha512-ZRRoPRoCVdkGDtjuog81pqHsSLfnXK6ELrWm4Dq8xdcHQGbEDNdYmeXARXG9yPAO42x9yIJXHNutMz5Y/P64cw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/signature-v4-multi-region/-/signature-v4-multi-region-3.130.0.tgz" + "version" "3.130.0" dependencies: "@aws-sdk/protocol-http" "3.127.0" "@aws-sdk/signature-v4" "3.130.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-arn-parser" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/signature-v4@3.130.0": - version "3.130.0" - resolved "https://registry.npmjs.org/@aws-sdk/signature-v4/-/signature-v4-3.130.0.tgz" - integrity sha512-g5G1a1NHL2uOoFfC2zQdZcj+wbjgBQPkx6xGdtqNKf9v2kS0n6ap5JUGEaqWE02lUlmWHsoMsS73hXtzwXaBRQ== + "integrity" "sha512-g5G1a1NHL2uOoFfC2zQdZcj+wbjgBQPkx6xGdtqNKf9v2kS0n6ap5JUGEaqWE02lUlmWHsoMsS73hXtzwXaBRQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/signature-v4/-/signature-v4-3.130.0.tgz" + "version" "3.130.0" dependencies: "@aws-sdk/is-array-buffer" "3.55.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-hex-encoding" "3.109.0" "@aws-sdk/util-middleware" "3.127.0" "@aws-sdk/util-uri-escape" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/smithy-client@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/smithy-client/-/smithy-client-3.137.0.tgz" - integrity sha512-YAuWiSzHJGV9jQCjmcBWxbWRoq/3INEpdtfAdpR+X+sEZaRJESDGPt4or7WbQ9Tmbd/uZ0uQLYIed/NDSyJLLQ== + "integrity" "sha512-YAuWiSzHJGV9jQCjmcBWxbWRoq/3INEpdtfAdpR+X+sEZaRJESDGPt4or7WbQ9Tmbd/uZ0uQLYIed/NDSyJLLQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/smithy-client/-/smithy-client-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-sdk/middleware-stack" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" -"@aws-sdk/types@3.127.0", "@aws-sdk/types@^3.1.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/types/-/types-3.127.0.tgz" - integrity sha512-e0wtx2IkOl7rwfKfLH5pPTzQ+d45V7b1WrjeL0WDI8kOu6w+sXmhNxI6uM2kf0k4NiTLN84lW290AEWupey9Og== +"@aws-sdk/types@^3.1.0", "@aws-sdk/types@3.127.0": + "integrity" "sha512-e0wtx2IkOl7rwfKfLH5pPTzQ+d45V7b1WrjeL0WDI8kOu6w+sXmhNxI6uM2kf0k4NiTLN84lW290AEWupey9Og==" + "resolved" "https://registry.npmjs.org/@aws-sdk/types/-/types-3.127.0.tgz" + "version" "3.127.0" "@aws-sdk/url-parser@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/url-parser/-/url-parser-3.127.0.tgz" - integrity sha512-njZ7zn41JHRpNfr3BCesVXCLZE0zcWSfEdtRV0ICw0cU1FgYcKELSuY9+gLUB4ci6uc7gq7mPE8+w30FcM4QeA== + "integrity" "sha512-njZ7zn41JHRpNfr3BCesVXCLZE0zcWSfEdtRV0ICw0cU1FgYcKELSuY9+gLUB4ci6uc7gq7mPE8+w30FcM4QeA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/url-parser/-/url-parser-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/querystring-parser" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-arn-parser@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-arn-parser/-/util-arn-parser-3.55.0.tgz" - integrity sha512-76KJxp4MRWufHYWys7DFl64znr5yeJ3AIQNAPCKKw1sP0hzO7p6Kx0PaJnw9x+CPSzOrT4NbuApL6/srYhKDGg== + "integrity" "sha512-76KJxp4MRWufHYWys7DFl64znr5yeJ3AIQNAPCKKw1sP0hzO7p6Kx0PaJnw9x+CPSzOrT4NbuApL6/srYhKDGg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-arn-parser/-/util-arn-parser-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-base64-browser@3.109.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-base64-browser/-/util-base64-browser-3.109.0.tgz" - integrity sha512-lAZ6fyDGiRLaIsKT9qh7P9FGuNyZ4gAbr1YOSQk/5mHtaTuUvxlPptZuInNM/0MPQm6lpcot00D8IWTucn4PbA== + "integrity" "sha512-lAZ6fyDGiRLaIsKT9qh7P9FGuNyZ4gAbr1YOSQk/5mHtaTuUvxlPptZuInNM/0MPQm6lpcot00D8IWTucn4PbA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-base64-browser/-/util-base64-browser-3.109.0.tgz" + "version" "3.109.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-base64-node@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-base64-node/-/util-base64-node-3.55.0.tgz" - integrity sha512-UQ/ZuNoAc8CFMpSiRYmevaTsuRKzLwulZTnM8LNlIt9Wx1tpNvqp80cfvVj7yySKROtEi20wq29h31dZf1eYNQ== + "integrity" "sha512-UQ/ZuNoAc8CFMpSiRYmevaTsuRKzLwulZTnM8LNlIt9Wx1tpNvqp80cfvVj7yySKROtEi20wq29h31dZf1eYNQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-base64-node/-/util-base64-node-3.55.0.tgz" + "version" "3.55.0" dependencies: "@aws-sdk/util-buffer-from" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-body-length-browser@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-body-length-browser/-/util-body-length-browser-3.55.0.tgz" - integrity sha512-Ei2OCzXQw5N6ZkTMZbamUzc1z+z1R1Ja5tMEagz5BxuX4vWdBObT+uGlSzL8yvTbjoPjnxWA2aXyEqaUP3JS8Q== + "integrity" "sha512-Ei2OCzXQw5N6ZkTMZbamUzc1z+z1R1Ja5tMEagz5BxuX4vWdBObT+uGlSzL8yvTbjoPjnxWA2aXyEqaUP3JS8Q==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-body-length-browser/-/util-body-length-browser-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-body-length-node@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-body-length-node/-/util-body-length-node-3.55.0.tgz" - integrity sha512-lU1d4I+9wJwydduXs0SxSfd+mHKjxeyd39VwOv6i2KSwWkPbji9UQqpflKLKw+r45jL7+xU/zfeTUg5Tt/3Gew== + "integrity" "sha512-lU1d4I+9wJwydduXs0SxSfd+mHKjxeyd39VwOv6i2KSwWkPbji9UQqpflKLKw+r45jL7+xU/zfeTUg5Tt/3Gew==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-body-length-node/-/util-body-length-node-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-buffer-from@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-buffer-from/-/util-buffer-from-3.55.0.tgz" - integrity sha512-uVzKG1UgvnV7XX2FPTylBujYMKBPBaq/qFBxfl0LVNfrty7YjpfieQxAe6yRLD+T0Kir/WDQwGvYC+tOYG3IGA== + "integrity" "sha512-uVzKG1UgvnV7XX2FPTylBujYMKBPBaq/qFBxfl0LVNfrty7YjpfieQxAe6yRLD+T0Kir/WDQwGvYC+tOYG3IGA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-buffer-from/-/util-buffer-from-3.55.0.tgz" + "version" "3.55.0" dependencies: "@aws-sdk/is-array-buffer" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-config-provider@3.109.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-config-provider/-/util-config-provider-3.109.0.tgz" - integrity sha512-GrAZl/aBv0A28LkyNyq8SPJ5fmViCwz80fWLMeWx/6q5AbivuILogjlWwEZSvZ9zrlHOcFC0+AnCa5pQrjaslw== + "integrity" "sha512-GrAZl/aBv0A28LkyNyq8SPJ5fmViCwz80fWLMeWx/6q5AbivuILogjlWwEZSvZ9zrlHOcFC0+AnCa5pQrjaslw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-config-provider/-/util-config-provider-3.109.0.tgz" + "version" "3.109.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-defaults-mode-browser@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-defaults-mode-browser/-/util-defaults-mode-browser-3.137.0.tgz" - integrity sha512-9f5045wqPAcGLKIAXzZKHE2n42ilGo/g4rLSS09OXx9CoFT4lVdqZPqBqh/prDUMrqXge9FK3EH2VId7L5GpEQ== + "integrity" "sha512-9f5045wqPAcGLKIAXzZKHE2n42ilGo/g4rLSS09OXx9CoFT4lVdqZPqBqh/prDUMrqXge9FK3EH2VId7L5GpEQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-defaults-mode-browser/-/util-defaults-mode-browser-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/types" "3.127.0" - bowser "^2.11.0" - tslib "^2.3.1" + "bowser" "^2.11.0" + "tslib" "^2.3.1" "@aws-sdk/util-defaults-mode-node@3.137.0": - version "3.137.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-defaults-mode-node/-/util-defaults-mode-node-3.137.0.tgz" - integrity sha512-CvMpemcsOkoMEz0iALamyQBt1rHx98NvF/cay019F8m+umD03I8CclDugy/13DqESWfsVxn91lZY/DOnO+si7A== + "integrity" "sha512-CvMpemcsOkoMEz0iALamyQBt1rHx98NvF/cay019F8m+umD03I8CclDugy/13DqESWfsVxn91lZY/DOnO+si7A==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-defaults-mode-node/-/util-defaults-mode-node-3.137.0.tgz" + "version" "3.137.0" dependencies: "@aws-sdk/config-resolver" "3.130.0" "@aws-sdk/credential-provider-imds" "3.127.0" "@aws-sdk/node-config-provider" "3.127.0" "@aws-sdk/property-provider" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-hex-encoding@3.109.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-hex-encoding/-/util-hex-encoding-3.109.0.tgz" - integrity sha512-s8CgTNrn3cLkrdiohfxLuOYPCanzvHn/aH5RW6DaMoeQiG5Hl9QUiP/WtdQ9QQx3xvpQFpmvxIaSBwSgFNLQxA== + "integrity" "sha512-s8CgTNrn3cLkrdiohfxLuOYPCanzvHn/aH5RW6DaMoeQiG5Hl9QUiP/WtdQ9QQx3xvpQFpmvxIaSBwSgFNLQxA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-hex-encoding/-/util-hex-encoding-3.109.0.tgz" + "version" "3.109.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-locate-window@^3.0.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-locate-window/-/util-locate-window-3.55.0.tgz" - integrity sha512-0sPmK2JaJE2BbTcnvybzob/VrFKCXKfN4CUKcvn0yGg/me7Bz+vtzQRB3Xp+YSx+7OtWxzv63wsvHoAnXvgxgg== + "integrity" "sha512-0sPmK2JaJE2BbTcnvybzob/VrFKCXKfN4CUKcvn0yGg/me7Bz+vtzQRB3Xp+YSx+7OtWxzv63wsvHoAnXvgxgg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-locate-window/-/util-locate-window-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-middleware@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-middleware/-/util-middleware-3.127.0.tgz" - integrity sha512-EwAPPed9TNqh+Wov2VStLn2NuJ/Wyt7IkZCbCsBuSNp3BFZ1V4gfwTjqtKCtB2LQgQ48MTgWgNCvrH0zjCSPGg== + "integrity" "sha512-EwAPPed9TNqh+Wov2VStLn2NuJ/Wyt7IkZCbCsBuSNp3BFZ1V4gfwTjqtKCtB2LQgQ48MTgWgNCvrH0zjCSPGg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-middleware/-/util-middleware-3.127.0.tgz" + "version" "3.127.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-stream-browser@3.131.0": - version "3.131.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-stream-browser/-/util-stream-browser-3.131.0.tgz" - integrity sha512-1YFbBPDu+elIgp8z1woUfT7zM+2PAvgJiw6ljDBuAlJzsP5xMhwk0X9e+8aQ+Qe4XftA0e7y/PH0gqvjNgCx2A== + "integrity" "sha512-1YFbBPDu+elIgp8z1woUfT7zM+2PAvgJiw6ljDBuAlJzsP5xMhwk0X9e+8aQ+Qe4XftA0e7y/PH0gqvjNgCx2A==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-stream-browser/-/util-stream-browser-3.131.0.tgz" + "version" "3.131.0" dependencies: "@aws-sdk/fetch-http-handler" "3.131.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-base64-browser" "3.109.0" "@aws-sdk/util-hex-encoding" "3.109.0" "@aws-sdk/util-utf8-browser" "3.109.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-stream-node@3.129.0": - version "3.129.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-stream-node/-/util-stream-node-3.129.0.tgz" - integrity sha512-1iWqsWvVXyP4JLPPPs8tBZKyzs7D5e7KctXuCtIjI+cnGOCeVLL+X4L/7KDZfV7sI2D6vONtIoTnUjMl5V/kEg== + "integrity" "sha512-1iWqsWvVXyP4JLPPPs8tBZKyzs7D5e7KctXuCtIjI+cnGOCeVLL+X4L/7KDZfV7sI2D6vONtIoTnUjMl5V/kEg==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-stream-node/-/util-stream-node-3.129.0.tgz" + "version" "3.129.0" dependencies: "@aws-sdk/node-http-handler" "3.127.0" "@aws-sdk/types" "3.127.0" "@aws-sdk/util-buffer-from" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-uri-escape@3.55.0": - version "3.55.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-uri-escape/-/util-uri-escape-3.55.0.tgz" - integrity sha512-mmdDLUpFCN2nkfwlLdOM54lTD528GiGSPN1qb8XtGLgZsJUmg3uJSFIN2lPeSbEwJB3NFjVas/rnQC48i7mV8w== + "integrity" "sha512-mmdDLUpFCN2nkfwlLdOM54lTD528GiGSPN1qb8XtGLgZsJUmg3uJSFIN2lPeSbEwJB3NFjVas/rnQC48i7mV8w==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-uri-escape/-/util-uri-escape-3.55.0.tgz" + "version" "3.55.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-user-agent-browser@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.127.0.tgz" - integrity sha512-uO2oHmJswuYKJS+GiMdYI8izhpC9M7/jFFvnAmLlTEVwpEi1VX9KePAOF+u5AaBC2kzITo/7dg141XfRHZloIQ== + "integrity" "sha512-uO2oHmJswuYKJS+GiMdYI8izhpC9M7/jFFvnAmLlTEVwpEi1VX9KePAOF+u5AaBC2kzITo/7dg141XfRHZloIQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/types" "3.127.0" - bowser "^2.11.0" - tslib "^2.3.1" + "bowser" "^2.11.0" + "tslib" "^2.3.1" "@aws-sdk/util-user-agent-node@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.127.0.tgz" - integrity sha512-3P/M4ZDD2qMeeoCk7TE/Mw7cG5IjB87F6BP8nI8/oHuaz7j6fsI7D49SNpyjl8JApRynZ122Ad6hwQwRj3isYw== + "integrity" "sha512-3P/M4ZDD2qMeeoCk7TE/Mw7cG5IjB87F6BP8nI8/oHuaz7j6fsI7D49SNpyjl8JApRynZ122Ad6hwQwRj3isYw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/node-config-provider" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" -"@aws-sdk/util-utf8-browser@3.109.0", "@aws-sdk/util-utf8-browser@^3.0.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.109.0.tgz" - integrity sha512-FmcGSz0v7Bqpl1SE8G1Gc0CtDpug+rvqNCG/szn86JApD/f5x8oByjbEiAyTU2ZH2VevUntx6EW68ulHyH+x+w== +"@aws-sdk/util-utf8-browser@^3.0.0", "@aws-sdk/util-utf8-browser@3.109.0": + "integrity" "sha512-FmcGSz0v7Bqpl1SE8G1Gc0CtDpug+rvqNCG/szn86JApD/f5x8oByjbEiAyTU2ZH2VevUntx6EW68ulHyH+x+w==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.109.0.tgz" + "version" "3.109.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-utf8-node@3.109.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-utf8-node/-/util-utf8-node-3.109.0.tgz" - integrity sha512-Ti/ZBdvz2eSTElsucjzNmzpyg2MwfD1rXmxD0hZuIF8bPON/0+sZYnWd5CbDw9kgmhy28dmKue086tbZ1G0iLQ== + "integrity" "sha512-Ti/ZBdvz2eSTElsucjzNmzpyg2MwfD1rXmxD0hZuIF8bPON/0+sZYnWd5CbDw9kgmhy28dmKue086tbZ1G0iLQ==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-utf8-node/-/util-utf8-node-3.109.0.tgz" + "version" "3.109.0" dependencies: "@aws-sdk/util-buffer-from" "3.55.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/util-waiter@3.127.0": - version "3.127.0" - resolved "https://registry.npmjs.org/@aws-sdk/util-waiter/-/util-waiter-3.127.0.tgz" - integrity sha512-E5qrRpBJS8dmClqSDW1pWVMKzCG/mxabG6jVUtlW/WLHnl/znxGaOQc6tnnwKik0nEq/4DpT9fEfPUz9JiLrkw== + "integrity" "sha512-E5qrRpBJS8dmClqSDW1pWVMKzCG/mxabG6jVUtlW/WLHnl/znxGaOQc6tnnwKik0nEq/4DpT9fEfPUz9JiLrkw==" + "resolved" "https://registry.npmjs.org/@aws-sdk/util-waiter/-/util-waiter-3.127.0.tgz" + "version" "3.127.0" dependencies: "@aws-sdk/abort-controller" "3.127.0" "@aws-sdk/types" "3.127.0" - tslib "^2.3.1" + "tslib" "^2.3.1" "@aws-sdk/xml-builder@3.109.0": - version "3.109.0" - resolved "https://registry.npmjs.org/@aws-sdk/xml-builder/-/xml-builder-3.109.0.tgz" - integrity sha512-+aAXynnrqya1Eukz4Gxch4xIXCZolIMWGD4Ll/Q5yXT5uAjGh2HQWd9J0LWE+gYChpWetZbAVYZ3cEJ6F+SpZA== + "integrity" "sha512-+aAXynnrqya1Eukz4Gxch4xIXCZolIMWGD4Ll/Q5yXT5uAjGh2HQWd9J0LWE+gYChpWetZbAVYZ3cEJ6F+SpZA==" + "resolved" "https://registry.npmjs.org/@aws-sdk/xml-builder/-/xml-builder-3.109.0.tgz" + "version" "3.109.0" dependencies: - tslib "^2.3.1" + "tslib" "^2.3.1" "@babel/code-frame@^7.0.0", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz" - integrity sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q== + "integrity" "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==" + "resolved" "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/highlight" "^7.18.6" "@babel/compat-data@^7.13.11", "@babel/compat-data@^7.18.8": - version "7.18.8" - resolved "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.8.tgz" - integrity sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ== + "integrity" "sha512-HSmX4WZPPK3FUxYp7g2T6EyO8j96HlZJlxmKPSh6KAcqwyDrfx7hKjXpAW/0FhFfTJsR0Yt4lAjLI2coMptIHQ==" + "resolved" "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.18.8.tgz" + "version" "7.18.8" -"@babel/core@^7.11.6", "@babel/core@^7.12.3", "@babel/core@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz" - integrity sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g== +"@babel/core@^7.0.0", "@babel/core@^7.0.0-0", "@babel/core@^7.11.6", "@babel/core@^7.12.0", "@babel/core@^7.12.3", "@babel/core@^7.13.0", "@babel/core@^7.18.9", "@babel/core@^7.4.0-0", "@babel/core@^7.8.0": + "integrity" "sha512-1LIb1eL8APMy91/IMW+31ckrfBM4yCoLaVzoDhZUKSM4cu1L1nIidyxkCgzPAgrC5WEz36IPEr/eSeSF9pIn+g==" + "resolved" "https://registry.npmjs.org/@babel/core/-/core-7.18.9.tgz" + "version" "7.18.9" dependencies: "@ampproject/remapping" "^2.1.0" "@babel/code-frame" "^7.18.6" @@ -911,50 +911,50 @@ "@babel/template" "^7.18.6" "@babel/traverse" "^7.18.9" "@babel/types" "^7.18.9" - convert-source-map "^1.7.0" - debug "^4.1.0" - gensync "^1.0.0-beta.2" - json5 "^2.2.1" - semver "^6.3.0" + "convert-source-map" "^1.7.0" + "debug" "^4.1.0" + "gensync" "^1.0.0-beta.2" + "json5" "^2.2.1" + "semver" "^6.3.0" "@babel/generator@^7.18.9", "@babel/generator@^7.7.2": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/generator/-/generator-7.18.9.tgz" - integrity sha512-wt5Naw6lJrL1/SGkipMiFxJjtyczUWTP38deiP1PO60HsBjDeKk08CGC3S8iVuvf0FmTdgKwU1KIXzSKL1G0Ug== + "integrity" "sha512-wt5Naw6lJrL1/SGkipMiFxJjtyczUWTP38deiP1PO60HsBjDeKk08CGC3S8iVuvf0FmTdgKwU1KIXzSKL1G0Ug==" + "resolved" "https://registry.npmjs.org/@babel/generator/-/generator-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/types" "^7.18.9" "@jridgewell/gen-mapping" "^0.3.2" - jsesc "^2.5.1" + "jsesc" "^2.5.1" "@babel/helper-annotate-as-pure@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz" - integrity sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA== + "integrity" "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==" + "resolved" "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-builder-binary-assignment-operator-visitor@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.6.tgz" - integrity sha512-KT10c1oWEpmrIRYnthbzHgoOf6B+Xd6a5yhdbNtdhtG7aO1or5HViuf1TQR36xY/QprXA5nvxO6nAjhJ4y38jw== + "integrity" "sha512-KT10c1oWEpmrIRYnthbzHgoOf6B+Xd6a5yhdbNtdhtG7aO1or5HViuf1TQR36xY/QprXA5nvxO6nAjhJ4y38jw==" + "resolved" "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-explode-assignable-expression" "^7.18.6" "@babel/types" "^7.18.6" "@babel/helper-compilation-targets@^7.13.0", "@babel/helper-compilation-targets@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.9.tgz" - integrity sha512-tzLCyVmqUiFlcFoAPLA/gL9TeYrF61VLNtb+hvkuVaB5SUjW7jcfrglBIX1vUIoT7CLP3bBlIMeyEsIl2eFQNg== + "integrity" "sha512-tzLCyVmqUiFlcFoAPLA/gL9TeYrF61VLNtb+hvkuVaB5SUjW7jcfrglBIX1vUIoT7CLP3bBlIMeyEsIl2eFQNg==" + "resolved" "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/compat-data" "^7.18.8" "@babel/helper-validator-option" "^7.18.6" - browserslist "^4.20.2" - semver "^6.3.0" + "browserslist" "^4.20.2" + "semver" "^6.3.0" "@babel/helper-create-class-features-plugin@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.6.tgz" - integrity sha512-YfDzdnoxHGV8CzqHGyCbFvXg5QESPFkXlHtvdCkesLjjVMT2Adxe4FGUR5ChIb3DxSaXO12iIOCWoXdsUVwnqw== + "integrity" "sha512-YfDzdnoxHGV8CzqHGyCbFvXg5QESPFkXlHtvdCkesLjjVMT2Adxe4FGUR5ChIb3DxSaXO12iIOCWoXdsUVwnqw==" + "resolved" "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-annotate-as-pure" "^7.18.6" "@babel/helper-environment-visitor" "^7.18.6" @@ -965,72 +965,72 @@ "@babel/helper-split-export-declaration" "^7.18.6" "@babel/helper-create-regexp-features-plugin@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz" - integrity sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A== + "integrity" "sha512-7LcpH1wnQLGrI+4v+nPp+zUvIkF9x0ddv1Hkdue10tg3gmRnLy97DXh4STiOf1qeIInyD69Qv5kKSZzKD8B/7A==" + "resolved" "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-annotate-as-pure" "^7.18.6" - regexpu-core "^5.1.0" + "regexpu-core" "^5.1.0" "@babel/helper-define-polyfill-provider@^0.3.1": - version "0.3.1" - resolved "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.1.tgz" - integrity sha512-J9hGMpJQmtWmj46B3kBHmL38UhJGhYX7eqkcq+2gsstyYt341HmPeWspihX43yVRA0mS+8GGk2Gckc7bY/HCmA== + "integrity" "sha512-J9hGMpJQmtWmj46B3kBHmL38UhJGhYX7eqkcq+2gsstyYt341HmPeWspihX43yVRA0mS+8GGk2Gckc7bY/HCmA==" + "resolved" "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.1.tgz" + "version" "0.3.1" dependencies: "@babel/helper-compilation-targets" "^7.13.0" "@babel/helper-module-imports" "^7.12.13" "@babel/helper-plugin-utils" "^7.13.0" "@babel/traverse" "^7.13.0" - debug "^4.1.1" - lodash.debounce "^4.0.8" - resolve "^1.14.2" - semver "^6.1.2" + "debug" "^4.1.1" + "lodash.debounce" "^4.0.8" + "resolve" "^1.14.2" + "semver" "^6.1.2" "@babel/helper-environment-visitor@^7.18.6", "@babel/helper-environment-visitor@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz" - integrity sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg== + "integrity" "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==" + "resolved" "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz" + "version" "7.18.9" "@babel/helper-explode-assignable-expression@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz" - integrity sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg== + "integrity" "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==" + "resolved" "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-function-name@^7.18.6", "@babel/helper-function-name@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.9.tgz" - integrity sha512-fJgWlZt7nxGksJS9a0XdSaI4XvpExnNIgRP+rVefWh5U7BL8pPuir6SJUmFKRfjWQ51OtWSzwOxhaH/EBWWc0A== + "integrity" "sha512-fJgWlZt7nxGksJS9a0XdSaI4XvpExnNIgRP+rVefWh5U7BL8pPuir6SJUmFKRfjWQ51OtWSzwOxhaH/EBWWc0A==" + "resolved" "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/template" "^7.18.6" "@babel/types" "^7.18.9" "@babel/helper-hoist-variables@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz" - integrity sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q== + "integrity" "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==" + "resolved" "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-member-expression-to-functions@^7.18.6", "@babel/helper-member-expression-to-functions@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz" - integrity sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg== + "integrity" "sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg==" + "resolved" "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/types" "^7.18.9" "@babel/helper-module-imports@^7.12.13", "@babel/helper-module-imports@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz" - integrity sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA== + "integrity" "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==" + "resolved" "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-module-transforms@^7.18.6", "@babel/helper-module-transforms@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.9.tgz" - integrity sha512-KYNqY0ICwfv19b31XzvmI/mfcylOzbLtowkw+mfvGPAQ3kfCnMLYbED3YecL5tPd8nAYFQFAd6JHp2LxZk/J1g== + "integrity" "sha512-KYNqY0ICwfv19b31XzvmI/mfcylOzbLtowkw+mfvGPAQ3kfCnMLYbED3YecL5tPd8nAYFQFAd6JHp2LxZk/J1g==" + "resolved" "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-environment-visitor" "^7.18.9" "@babel/helper-module-imports" "^7.18.6" @@ -1042,21 +1042,21 @@ "@babel/types" "^7.18.9" "@babel/helper-optimise-call-expression@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz" - integrity sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA== + "integrity" "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==" + "resolved" "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.13.0", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.18.6", "@babel/helper-plugin-utils@^7.18.9", "@babel/helper-plugin-utils@^7.8.0", "@babel/helper-plugin-utils@^7.8.3": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.9.tgz" - integrity sha512-aBXPT3bmtLryXaoJLyYPXPlSD4p1ld9aYeR+sJNOZjJJGiOpb+fKfh3NkcCu7J54nUJwCERPBExCCpyCOHnu/w== + "integrity" "sha512-aBXPT3bmtLryXaoJLyYPXPlSD4p1ld9aYeR+sJNOZjJJGiOpb+fKfh3NkcCu7J54nUJwCERPBExCCpyCOHnu/w==" + "resolved" "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.18.9.tgz" + "version" "7.18.9" "@babel/helper-remap-async-to-generator@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.6.tgz" - integrity sha512-z5wbmV55TveUPZlCLZvxWHtrjuJd+8inFhk7DG0WW87/oJuGDcjDiu7HIvGcpf5464L6xKCg3vNkmlVVz9hwyQ== + "integrity" "sha512-z5wbmV55TveUPZlCLZvxWHtrjuJd+8inFhk7DG0WW87/oJuGDcjDiu7HIvGcpf5464L6xKCg3vNkmlVVz9hwyQ==" + "resolved" "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-annotate-as-pure" "^7.18.6" "@babel/helper-environment-visitor" "^7.18.6" @@ -1064,9 +1064,9 @@ "@babel/types" "^7.18.6" "@babel/helper-replace-supers@^7.18.6", "@babel/helper-replace-supers@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.9.tgz" - integrity sha512-dNsWibVI4lNT6HiuOIBr1oyxo40HvIVmbwPUm3XZ7wMh4k2WxrxTqZwSqw/eEmXDS9np0ey5M2bz9tBmO9c+YQ== + "integrity" "sha512-dNsWibVI4lNT6HiuOIBr1oyxo40HvIVmbwPUm3XZ7wMh4k2WxrxTqZwSqw/eEmXDS9np0ey5M2bz9tBmO9c+YQ==" + "resolved" "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-environment-visitor" "^7.18.9" "@babel/helper-member-expression-to-functions" "^7.18.9" @@ -1075,40 +1075,40 @@ "@babel/types" "^7.18.9" "@babel/helper-simple-access@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz" - integrity sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g== + "integrity" "sha512-iNpIgTgyAvDQpDj76POqg+YEt8fPxx3yaNBg3S30dxNKm2SWfYhD0TGrK/Eu9wHpUW63VQU894TsTg+GLbUa1g==" + "resolved" "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-skip-transparent-expression-wrappers@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.9.tgz" - integrity sha512-imytd2gHi3cJPsybLRbmFrF7u5BIEuI2cNheyKi3/iOBC63kNn3q8Crn2xVuESli0aM4KYsyEqKyS7lFL8YVtw== + "integrity" "sha512-imytd2gHi3cJPsybLRbmFrF7u5BIEuI2cNheyKi3/iOBC63kNn3q8Crn2xVuESli0aM4KYsyEqKyS7lFL8YVtw==" + "resolved" "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/types" "^7.18.9" "@babel/helper-split-export-declaration@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz" - integrity sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA== + "integrity" "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==" + "resolved" "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/types" "^7.18.6" "@babel/helper-validator-identifier@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz" - integrity sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g== + "integrity" "sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g==" + "resolved" "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz" + "version" "7.18.6" "@babel/helper-validator-option@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz" - integrity sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw== + "integrity" "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==" + "resolved" "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz" + "version" "7.18.6" "@babel/helper-wrap-function@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.6.tgz" - integrity sha512-I5/LZfozwMNbwr/b1vhhuYD+J/mU+gfGAj5td7l5Rv9WYmH6i3Om69WGKNmlIpsVW/mF6O5bvTKbvDQZVgjqOw== + "integrity" "sha512-I5/LZfozwMNbwr/b1vhhuYD+J/mU+gfGAj5td7l5Rv9WYmH6i3Om69WGKNmlIpsVW/mF6O5bvTKbvDQZVgjqOw==" + "resolved" "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-function-name" "^7.18.6" "@babel/template" "^7.18.6" @@ -1116,48 +1116,48 @@ "@babel/types" "^7.18.6" "@babel/helpers@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/helpers/-/helpers-7.18.9.tgz" - integrity sha512-Jf5a+rbrLoR4eNdUmnFu8cN5eNJT6qdTdOg5IHIzq87WwyRw9PwguLFOWYgktN/60IP4fgDUawJvs7PjQIzELQ== + "integrity" "sha512-Jf5a+rbrLoR4eNdUmnFu8cN5eNJT6qdTdOg5IHIzq87WwyRw9PwguLFOWYgktN/60IP4fgDUawJvs7PjQIzELQ==" + "resolved" "https://registry.npmjs.org/@babel/helpers/-/helpers-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/template" "^7.18.6" "@babel/traverse" "^7.18.9" "@babel/types" "^7.18.9" "@babel/highlight@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz" - integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g== + "integrity" "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==" + "resolved" "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-validator-identifier" "^7.18.6" - chalk "^2.0.0" - js-tokens "^4.0.0" + "chalk" "^2.0.0" + "js-tokens" "^4.0.0" "@babel/parser@^7.1.0", "@babel/parser@^7.14.7", "@babel/parser@^7.18.6", "@babel/parser@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/parser/-/parser-7.18.9.tgz" - integrity sha512-9uJveS9eY9DJ0t64YbIBZICtJy8a5QrDEVdiLCG97fVLpDTpGX7t8mMSb6OWw6Lrnjqj4O8zwjELX3dhoMgiBg== + "integrity" "sha512-9uJveS9eY9DJ0t64YbIBZICtJy8a5QrDEVdiLCG97fVLpDTpGX7t8mMSb6OWw6Lrnjqj4O8zwjELX3dhoMgiBg==" + "resolved" "https://registry.npmjs.org/@babel/parser/-/parser-7.18.9.tgz" + "version" "7.18.9" "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz" - integrity sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ== + "integrity" "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz" - integrity sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg== + "integrity" "sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" "@babel/plugin-proposal-optional-chaining" "^7.18.9" "@babel/plugin-proposal-async-generator-functions@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz" - integrity sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w== + "integrity" "sha512-WAz4R9bvozx4qwf74M+sfqPMKfSqwM0phxPTR6iJIi8robgzXwkEgmeJG1gEKhm6sDqT/U9aV3lfcqybIpev8w==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-environment-visitor" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" @@ -1165,74 +1165,74 @@ "@babel/plugin-syntax-async-generators" "^7.8.4" "@babel/plugin-proposal-class-properties@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz" - integrity sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ== + "integrity" "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-class-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-proposal-class-static-block@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz" - integrity sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw== + "integrity" "sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-class-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-class-static-block" "^7.14.5" "@babel/plugin-proposal-dynamic-import@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz" - integrity sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw== + "integrity" "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-dynamic-import" "^7.8.3" "@babel/plugin-proposal-export-namespace-from@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz" - integrity sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA== + "integrity" "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-syntax-export-namespace-from" "^7.8.3" "@babel/plugin-proposal-json-strings@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz" - integrity sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ== + "integrity" "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-json-strings" "^7.8.3" "@babel/plugin-proposal-logical-assignment-operators@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz" - integrity sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q== + "integrity" "sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-syntax-logical-assignment-operators" "^7.10.4" "@babel/plugin-proposal-nullish-coalescing-operator@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz" - integrity sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA== + "integrity" "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" "@babel/plugin-proposal-numeric-separator@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz" - integrity sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q== + "integrity" "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-numeric-separator" "^7.10.4" "@babel/plugin-proposal-object-rest-spread@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.9.tgz" - integrity sha512-kDDHQ5rflIeY5xl69CEqGEZ0KY369ehsCIEbTGb4siHG5BE9sga/T0r0OUwyZNLMmZE79E1kbsqAjwFCW4ds6Q== + "integrity" "sha512-kDDHQ5rflIeY5xl69CEqGEZ0KY369ehsCIEbTGb4siHG5BE9sga/T0r0OUwyZNLMmZE79E1kbsqAjwFCW4ds6Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/compat-data" "^7.18.8" "@babel/helper-compilation-targets" "^7.18.9" @@ -1241,34 +1241,34 @@ "@babel/plugin-transform-parameters" "^7.18.8" "@babel/plugin-proposal-optional-catch-binding@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz" - integrity sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw== + "integrity" "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-optional-catch-binding" "^7.8.3" "@babel/plugin-proposal-optional-chaining@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz" - integrity sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w== + "integrity" "sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" "@babel/plugin-syntax-optional-chaining" "^7.8.3" "@babel/plugin-proposal-private-methods@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz" - integrity sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA== + "integrity" "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-class-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-proposal-private-property-in-object@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz" - integrity sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw== + "integrity" "sha512-9Rysx7FOctvT5ouj5JODjAFAkgGoudQuLPamZb0v1TGLpapdNaftzifU8NTWQm0IRjqoYypdrSmyWgkocDQ8Dw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-annotate-as-pure" "^7.18.6" "@babel/helper-create-class-features-plugin" "^7.18.6" @@ -1276,173 +1276,173 @@ "@babel/plugin-syntax-private-property-in-object" "^7.14.5" "@babel/plugin-proposal-unicode-property-regex@^7.18.6", "@babel/plugin-proposal-unicode-property-regex@^7.4.4": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz" - integrity sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w== + "integrity" "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==" + "resolved" "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-regexp-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-async-generators@^7.8.4": - version "7.8.4" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz" - integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== + "integrity" "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz" + "version" "7.8.4" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-bigint@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz" - integrity sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg== + "integrity" "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-class-properties@^7.12.13", "@babel/plugin-syntax-class-properties@^7.8.3": - version "7.12.13" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz" - integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== + "integrity" "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz" + "version" "7.12.13" dependencies: "@babel/helper-plugin-utils" "^7.12.13" "@babel/plugin-syntax-class-static-block@^7.14.5": - version "7.14.5" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz" - integrity sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw== + "integrity" "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz" + "version" "7.14.5" dependencies: "@babel/helper-plugin-utils" "^7.14.5" "@babel/plugin-syntax-dynamic-import@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz" - integrity sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ== + "integrity" "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-export-namespace-from@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz" - integrity sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q== + "integrity" "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.3" "@babel/plugin-syntax-import-assertions@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz" - integrity sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ== + "integrity" "sha512-/DU3RXad9+bZwrgWJQKbr39gYbJpLJHezqEzRzi/BHRlJ9zsQb4CK2CA/5apllXNomwA1qHwzvHl+AdEmC5krQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-import-meta@^7.8.3": - version "7.10.4" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz" - integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== + "integrity" "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz" + "version" "7.10.4" dependencies: "@babel/helper-plugin-utils" "^7.10.4" "@babel/plugin-syntax-json-strings@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz" - integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== + "integrity" "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-logical-assignment-operators@^7.10.4", "@babel/plugin-syntax-logical-assignment-operators@^7.8.3": - version "7.10.4" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz" - integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== + "integrity" "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz" + "version" "7.10.4" dependencies: "@babel/helper-plugin-utils" "^7.10.4" "@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz" - integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== + "integrity" "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-numeric-separator@^7.10.4", "@babel/plugin-syntax-numeric-separator@^7.8.3": - version "7.10.4" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz" - integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== + "integrity" "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz" + "version" "7.10.4" dependencies: "@babel/helper-plugin-utils" "^7.10.4" "@babel/plugin-syntax-object-rest-spread@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz" - integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== + "integrity" "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-optional-catch-binding@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz" - integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== + "integrity" "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-optional-chaining@^7.8.3": - version "7.8.3" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz" - integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== + "integrity" "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz" + "version" "7.8.3" dependencies: "@babel/helper-plugin-utils" "^7.8.0" "@babel/plugin-syntax-private-property-in-object@^7.14.5": - version "7.14.5" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz" - integrity sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg== + "integrity" "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz" + "version" "7.14.5" dependencies: "@babel/helper-plugin-utils" "^7.14.5" "@babel/plugin-syntax-top-level-await@^7.14.5", "@babel/plugin-syntax-top-level-await@^7.8.3": - version "7.14.5" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz" - integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw== + "integrity" "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz" + "version" "7.14.5" dependencies: "@babel/helper-plugin-utils" "^7.14.5" "@babel/plugin-syntax-typescript@^7.18.6", "@babel/plugin-syntax-typescript@^7.7.2": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.18.6.tgz" - integrity sha512-mAWAuq4rvOepWCBid55JuRNvpTNf2UGVgoz4JV0fXEKolsVZDzsa4NqCef758WZJj/GDu0gVGItjKFiClTAmZA== + "integrity" "sha512-mAWAuq4rvOepWCBid55JuRNvpTNf2UGVgoz4JV0fXEKolsVZDzsa4NqCef758WZJj/GDu0gVGItjKFiClTAmZA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-arrow-functions@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz" - integrity sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ== + "integrity" "sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-async-to-generator@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz" - integrity sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag== + "integrity" "sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-module-imports" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/helper-remap-async-to-generator" "^7.18.6" "@babel/plugin-transform-block-scoped-functions@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz" - integrity sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ== + "integrity" "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-block-scoping@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.9.tgz" - integrity sha512-5sDIJRV1KtQVEbt/EIBwGy4T01uYIo4KRB3VUqzkhrAIOGx7AoctL9+Ux88btY0zXdDyPJ9mW+bg+v+XEkGmtw== + "integrity" "sha512-5sDIJRV1KtQVEbt/EIBwGy4T01uYIo4KRB3VUqzkhrAIOGx7AoctL9+Ux88btY0zXdDyPJ9mW+bg+v+XEkGmtw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-classes@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.9.tgz" - integrity sha512-EkRQxsxoytpTlKJmSPYrsOMjCILacAjtSVkd4gChEe2kXjFCun3yohhW5I7plXJhCemM0gKsaGMcO8tinvCA5g== + "integrity" "sha512-EkRQxsxoytpTlKJmSPYrsOMjCILacAjtSVkd4gChEe2kXjFCun3yohhW5I7plXJhCemM0gKsaGMcO8tinvCA5g==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-annotate-as-pure" "^7.18.6" "@babel/helper-environment-visitor" "^7.18.9" @@ -1451,229 +1451,229 @@ "@babel/helper-plugin-utils" "^7.18.9" "@babel/helper-replace-supers" "^7.18.9" "@babel/helper-split-export-declaration" "^7.18.6" - globals "^11.1.0" + "globals" "^11.1.0" "@babel/plugin-transform-computed-properties@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz" - integrity sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw== + "integrity" "sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-destructuring@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.9.tgz" - integrity sha512-p5VCYNddPLkZTq4XymQIaIfZNJwT9YsjkPOhkVEqt6QIpQFZVM9IltqqYpOEkJoN1DPznmxUDyZ5CTZs/ZCuHA== + "integrity" "sha512-p5VCYNddPLkZTq4XymQIaIfZNJwT9YsjkPOhkVEqt6QIpQFZVM9IltqqYpOEkJoN1DPznmxUDyZ5CTZs/ZCuHA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-dotall-regex@^7.18.6", "@babel/plugin-transform-dotall-regex@^7.4.4": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz" - integrity sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg== + "integrity" "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-regexp-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-duplicate-keys@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz" - integrity sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw== + "integrity" "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-exponentiation-operator@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz" - integrity sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw== + "integrity" "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-builder-binary-assignment-operator-visitor" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-for-of@^7.18.8": - version "7.18.8" - resolved "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz" - integrity sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ== + "integrity" "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz" + "version" "7.18.8" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-function-name@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz" - integrity sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ== + "integrity" "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-compilation-targets" "^7.18.9" "@babel/helper-function-name" "^7.18.9" "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-literals@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz" - integrity sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg== + "integrity" "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-member-expression-literals@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz" - integrity sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA== + "integrity" "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-modules-amd@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz" - integrity sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg== + "integrity" "sha512-Pra5aXsmTsOnjM3IajS8rTaLCy++nGM4v3YR4esk5PCsyg9z8NA5oQLwxzMUtDBd8F+UmVza3VxoAaWCbzH1rg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-module-transforms" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" - babel-plugin-dynamic-import-node "^2.3.3" + "babel-plugin-dynamic-import-node" "^2.3.3" "@babel/plugin-transform-modules-commonjs@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz" - integrity sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q== + "integrity" "sha512-Qfv2ZOWikpvmedXQJDSbxNqy7Xr/j2Y8/KfijM0iJyKkBTmWuvCA1yeH1yDM7NJhBW/2aXxeucLj6i80/LAJ/Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-module-transforms" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/helper-simple-access" "^7.18.6" - babel-plugin-dynamic-import-node "^2.3.3" + "babel-plugin-dynamic-import-node" "^2.3.3" "@babel/plugin-transform-modules-systemjs@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.9.tgz" - integrity sha512-zY/VSIbbqtoRoJKo2cDTewL364jSlZGvn0LKOf9ntbfxOvjfmyrdtEEOAdswOswhZEb8UH3jDkCKHd1sPgsS0A== + "integrity" "sha512-zY/VSIbbqtoRoJKo2cDTewL364jSlZGvn0LKOf9ntbfxOvjfmyrdtEEOAdswOswhZEb8UH3jDkCKHd1sPgsS0A==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-hoist-variables" "^7.18.6" "@babel/helper-module-transforms" "^7.18.9" "@babel/helper-plugin-utils" "^7.18.9" "@babel/helper-validator-identifier" "^7.18.6" - babel-plugin-dynamic-import-node "^2.3.3" + "babel-plugin-dynamic-import-node" "^2.3.3" "@babel/plugin-transform-modules-umd@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz" - integrity sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ== + "integrity" "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-module-transforms" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-named-capturing-groups-regex@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz" - integrity sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg== + "integrity" "sha512-UmEOGF8XgaIqD74bC8g7iV3RYj8lMf0Bw7NJzvnS9qQhM4mg+1WHKotUIdjxgD2RGrgFLZZPCFPFj3P/kVDYhg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-regexp-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-new-target@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz" - integrity sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw== + "integrity" "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-object-super@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz" - integrity sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA== + "integrity" "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/helper-replace-supers" "^7.18.6" "@babel/plugin-transform-parameters@^7.18.8": - version "7.18.8" - resolved "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.8.tgz" - integrity sha512-ivfbE3X2Ss+Fj8nnXvKJS6sjRG4gzwPMsP+taZC+ZzEGjAYlvENixmt1sZ5Ca6tWls+BlKSGKPJ6OOXvXCbkFg== + "integrity" "sha512-ivfbE3X2Ss+Fj8nnXvKJS6sjRG4gzwPMsP+taZC+ZzEGjAYlvENixmt1sZ5Ca6tWls+BlKSGKPJ6OOXvXCbkFg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.18.8.tgz" + "version" "7.18.8" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-property-literals@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz" - integrity sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg== + "integrity" "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-regenerator@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz" - integrity sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ== + "integrity" "sha512-poqRI2+qiSdeldcz4wTSTXBRryoq3Gc70ye7m7UD5Ww0nE29IXqMl6r7Nd15WBgRd74vloEMlShtH6CKxVzfmQ==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" - regenerator-transform "^0.15.0" + "regenerator-transform" "^0.15.0" "@babel/plugin-transform-reserved-words@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz" - integrity sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA== + "integrity" "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-shorthand-properties@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz" - integrity sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw== + "integrity" "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-spread@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.9.tgz" - integrity sha512-39Q814wyoOPtIB/qGopNIL9xDChOE1pNU0ZY5dO0owhiVt/5kFm4li+/bBtwc7QotG0u5EPzqhZdjMtmqBqyQA== + "integrity" "sha512-39Q814wyoOPtIB/qGopNIL9xDChOE1pNU0ZY5dO0owhiVt/5kFm4li+/bBtwc7QotG0u5EPzqhZdjMtmqBqyQA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/helper-skip-transparent-expression-wrappers" "^7.18.9" "@babel/plugin-transform-sticky-regex@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz" - integrity sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q== + "integrity" "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-template-literals@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz" - integrity sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA== + "integrity" "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-typeof-symbol@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz" - integrity sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw== + "integrity" "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-plugin-utils" "^7.18.9" "@babel/plugin-transform-typescript@^7.18.6": - version "7.18.8" - resolved "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.18.8.tgz" - integrity sha512-p2xM8HI83UObjsZGofMV/EdYjamsDm6MoN3hXPYIT0+gxIoopE+B7rPYKAxfrz9K9PK7JafTTjqYC6qipLExYA== + "integrity" "sha512-p2xM8HI83UObjsZGofMV/EdYjamsDm6MoN3hXPYIT0+gxIoopE+B7rPYKAxfrz9K9PK7JafTTjqYC6qipLExYA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.18.8.tgz" + "version" "7.18.8" dependencies: "@babel/helper-create-class-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-syntax-typescript" "^7.18.6" "@babel/plugin-transform-unicode-escapes@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz" - integrity sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw== + "integrity" "sha512-XNRwQUXYMP7VLuy54cr/KS/WeL3AZeORhrmeZ7iewgu+X2eBqmpaLI/hzqr9ZxCeUoq0ASK4GUzSM0BDhZkLFw==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/plugin-transform-unicode-regex@^7.18.6": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz" - integrity sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA== + "integrity" "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==" + "resolved" "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-create-regexp-features-plugin" "^7.18.6" "@babel/helper-plugin-utils" "^7.18.6" "@babel/preset-env@^7.18.9": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.9.tgz" - integrity sha512-75pt/q95cMIHWssYtyfjVlvI+QEZQThQbKvR9xH+F/Agtw/s4Wfc2V9Bwd/P39VtixB7oWxGdH4GteTTwYJWMg== + "integrity" "sha512-75pt/q95cMIHWssYtyfjVlvI+QEZQThQbKvR9xH+F/Agtw/s4Wfc2V9Bwd/P39VtixB7oWxGdH4GteTTwYJWMg==" + "resolved" "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/compat-data" "^7.18.8" "@babel/helper-compilation-targets" "^7.18.9" @@ -1745,52 +1745,52 @@ "@babel/plugin-transform-unicode-regex" "^7.18.6" "@babel/preset-modules" "^0.1.5" "@babel/types" "^7.18.9" - babel-plugin-polyfill-corejs2 "^0.3.1" - babel-plugin-polyfill-corejs3 "^0.5.2" - babel-plugin-polyfill-regenerator "^0.3.1" - core-js-compat "^3.22.1" - semver "^6.3.0" + "babel-plugin-polyfill-corejs2" "^0.3.1" + "babel-plugin-polyfill-corejs3" "^0.5.2" + "babel-plugin-polyfill-regenerator" "^0.3.1" + "core-js-compat" "^3.22.1" + "semver" "^6.3.0" "@babel/preset-modules@^0.1.5": - version "0.1.5" - resolved "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz" - integrity sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA== + "integrity" "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==" + "resolved" "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz" + "version" "0.1.5" dependencies: "@babel/helper-plugin-utils" "^7.0.0" "@babel/plugin-proposal-unicode-property-regex" "^7.4.4" "@babel/plugin-transform-dotall-regex" "^7.4.4" "@babel/types" "^7.4.4" - esutils "^2.0.2" + "esutils" "^2.0.2" "@babel/preset-typescript@^7.15.0": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.18.6.tgz" - integrity sha512-s9ik86kXBAnD760aybBucdpnLsAt0jK1xqJn2juOn9lkOvSHV60os5hxoVJsPzMQxvnUJFAlkont2DvvaYEBtQ== + "integrity" "sha512-s9ik86kXBAnD760aybBucdpnLsAt0jK1xqJn2juOn9lkOvSHV60os5hxoVJsPzMQxvnUJFAlkont2DvvaYEBtQ==" + "resolved" "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/helper-plugin-utils" "^7.18.6" "@babel/helper-validator-option" "^7.18.6" "@babel/plugin-transform-typescript" "^7.18.6" "@babel/runtime@^7.17.2", "@babel/runtime@^7.8.4": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.6.tgz" - integrity sha512-t9wi7/AW6XtKahAe20Yw0/mMljKq0B1r2fPdvaAdV/KPDZewFXdaaa6K7lxmZBZ8FBNpCiAT6iHPmd6QO9bKfQ== + "integrity" "sha512-t9wi7/AW6XtKahAe20Yw0/mMljKq0B1r2fPdvaAdV/KPDZewFXdaaa6K7lxmZBZ8FBNpCiAT6iHPmd6QO9bKfQ==" + "resolved" "https://registry.npmjs.org/@babel/runtime/-/runtime-7.18.6.tgz" + "version" "7.18.6" dependencies: - regenerator-runtime "^0.13.4" + "regenerator-runtime" "^0.13.4" "@babel/template@^7.18.6", "@babel/template@^7.3.3": - version "7.18.6" - resolved "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz" - integrity sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw== + "integrity" "sha512-JoDWzPe+wgBsTTgdnIma3iHNFC7YVJoPssVBDjiHfNlyt4YcunDtcDOUmfVDfCK5MfdsaIoX9PkijPhjH3nYUw==" + "resolved" "https://registry.npmjs.org/@babel/template/-/template-7.18.6.tgz" + "version" "7.18.6" dependencies: "@babel/code-frame" "^7.18.6" "@babel/parser" "^7.18.6" "@babel/types" "^7.18.6" "@babel/traverse@^7.13.0", "@babel/traverse@^7.18.6", "@babel/traverse@^7.18.9", "@babel/traverse@^7.7.2": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.9.tgz" - integrity sha512-LcPAnujXGwBgv3/WHv01pHtb2tihcyW1XuL9wd7jqh1Z8AQkTd+QVjMrMijrln0T7ED3UXLIy36P9Ao7W75rYg== + "integrity" "sha512-LcPAnujXGwBgv3/WHv01pHtb2tihcyW1XuL9wd7jqh1Z8AQkTd+QVjMrMijrln0T7ED3UXLIy36P9Ao7W75rYg==" + "resolved" "https://registry.npmjs.org/@babel/traverse/-/traverse-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/code-frame" "^7.18.6" "@babel/generator" "^7.18.9" @@ -1800,66 +1800,66 @@ "@babel/helper-split-export-declaration" "^7.18.6" "@babel/parser" "^7.18.9" "@babel/types" "^7.18.9" - debug "^4.1.0" - globals "^11.1.0" + "debug" "^4.1.0" + "globals" "^11.1.0" "@babel/types@^7.0.0", "@babel/types@^7.18.6", "@babel/types@^7.18.9", "@babel/types@^7.3.0", "@babel/types@^7.3.3", "@babel/types@^7.4.4": - version "7.18.9" - resolved "https://registry.npmjs.org/@babel/types/-/types-7.18.9.tgz" - integrity sha512-WwMLAg2MvJmt/rKEVQBBhIVffMmnilX4oe0sRe7iPOHIGsqpruFHHdrfj4O1CMMtgMtCU4oPafZjDPCRgO57Wg== + "integrity" "sha512-WwMLAg2MvJmt/rKEVQBBhIVffMmnilX4oe0sRe7iPOHIGsqpruFHHdrfj4O1CMMtgMtCU4oPafZjDPCRgO57Wg==" + "resolved" "https://registry.npmjs.org/@babel/types/-/types-7.18.9.tgz" + "version" "7.18.9" dependencies: "@babel/helper-validator-identifier" "^7.18.6" - to-fast-properties "^2.0.0" + "to-fast-properties" "^2.0.0" "@bcoe/v8-coverage@^0.2.3": - version "0.2.3" - resolved "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz" - integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== + "integrity" "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==" + "resolved" "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz" + "version" "0.2.3" "@cspotcode/source-map-support@^0.8.0": - version "0.8.1" - resolved "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz" - integrity sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw== + "integrity" "sha512-IchNf6dN4tHoMFIn/7OE8LWZ19Y6q/67Bmf6vnGREv8RSbBVb9LPJxEcnwrcwX6ixSvaiGoomAUvu4YSxXrVgw==" + "resolved" "https://registry.npmjs.org/@cspotcode/source-map-support/-/source-map-support-0.8.1.tgz" + "version" "0.8.1" dependencies: "@jridgewell/trace-mapping" "0.3.9" "@gar/promisify@^1.0.1": - version "1.1.3" - resolved "https://registry.yarnpkg.com/@gar/promisify/-/promisify-1.1.3.tgz#555193ab2e3bb3b6adc3d551c9c030d9e860daf6" - integrity sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw== + "integrity" "sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw==" + "resolved" "https://registry.npmjs.org/@gar/promisify/-/promisify-1.1.3.tgz" + "version" "1.1.3" "@istanbuljs/load-nyc-config@^1.0.0": - version "1.1.0" - resolved "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz" - integrity sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ== + "integrity" "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==" + "resolved" "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz" + "version" "1.1.0" dependencies: - camelcase "^5.3.1" - find-up "^4.1.0" - get-package-type "^0.1.0" - js-yaml "^3.13.1" - resolve-from "^5.0.0" + "camelcase" "^5.3.1" + "find-up" "^4.1.0" + "get-package-type" "^0.1.0" + "js-yaml" "^3.13.1" + "resolve-from" "^5.0.0" "@istanbuljs/schema@^0.1.2": - version "0.1.3" - resolved "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz" - integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA== + "integrity" "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==" + "resolved" "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz" + "version" "0.1.3" "@jest/console@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/console/-/console-28.1.3.tgz" - integrity sha512-QPAkP5EwKdK/bxIr6C1I4Vs0rm2nHiANzj/Z5X2JQkrZo6IqvC4ldZ9K95tF0HdidhA8Bo6egxSzUFPYKcEXLw== + "integrity" "sha512-QPAkP5EwKdK/bxIr6C1I4Vs0rm2nHiANzj/Z5X2JQkrZo6IqvC4ldZ9K95tF0HdidhA8Bo6egxSzUFPYKcEXLw==" + "resolved" "https://registry.npmjs.org/@jest/console/-/console-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" "@types/node" "*" - chalk "^4.0.0" - jest-message-util "^28.1.3" - jest-util "^28.1.3" - slash "^3.0.0" + "chalk" "^4.0.0" + "jest-message-util" "^28.1.3" + "jest-util" "^28.1.3" + "slash" "^3.0.0" "@jest/core@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/core/-/core-28.1.3.tgz" - integrity sha512-CIKBrlaKOzA7YG19BEqCw3SLIsEwjZkeJzf5bdooVnW4bH5cktqe3JX+G2YV1aK5vP8N9na1IGWFzYaTp6k6NA== + "integrity" "sha512-CIKBrlaKOzA7YG19BEqCw3SLIsEwjZkeJzf5bdooVnW4bH5cktqe3JX+G2YV1aK5vP8N9na1IGWFzYaTp6k6NA==" + "resolved" "https://registry.npmjs.org/@jest/core/-/core-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/console" "^28.1.3" "@jest/reporters" "^28.1.3" @@ -1867,80 +1867,80 @@ "@jest/transform" "^28.1.3" "@jest/types" "^28.1.3" "@types/node" "*" - ansi-escapes "^4.2.1" - chalk "^4.0.0" - ci-info "^3.2.0" - exit "^0.1.2" - graceful-fs "^4.2.9" - jest-changed-files "^28.1.3" - jest-config "^28.1.3" - jest-haste-map "^28.1.3" - jest-message-util "^28.1.3" - jest-regex-util "^28.0.2" - jest-resolve "^28.1.3" - jest-resolve-dependencies "^28.1.3" - jest-runner "^28.1.3" - jest-runtime "^28.1.3" - jest-snapshot "^28.1.3" - jest-util "^28.1.3" - jest-validate "^28.1.3" - jest-watcher "^28.1.3" - micromatch "^4.0.4" - pretty-format "^28.1.3" - rimraf "^3.0.0" - slash "^3.0.0" - strip-ansi "^6.0.0" + "ansi-escapes" "^4.2.1" + "chalk" "^4.0.0" + "ci-info" "^3.2.0" + "exit" "^0.1.2" + "graceful-fs" "^4.2.9" + "jest-changed-files" "^28.1.3" + "jest-config" "^28.1.3" + "jest-haste-map" "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-regex-util" "^28.0.2" + "jest-resolve" "^28.1.3" + "jest-resolve-dependencies" "^28.1.3" + "jest-runner" "^28.1.3" + "jest-runtime" "^28.1.3" + "jest-snapshot" "^28.1.3" + "jest-util" "^28.1.3" + "jest-validate" "^28.1.3" + "jest-watcher" "^28.1.3" + "micromatch" "^4.0.4" + "pretty-format" "^28.1.3" + "rimraf" "^3.0.0" + "slash" "^3.0.0" + "strip-ansi" "^6.0.0" "@jest/environment@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/environment/-/environment-28.1.3.tgz" - integrity sha512-1bf40cMFTEkKyEf585R9Iz1WayDjHoHqvts0XFYEqyKM3cFWDpeMoqKKTAF9LSYQModPUlh8FKptoM2YcMWAXA== + "integrity" "sha512-1bf40cMFTEkKyEf585R9Iz1WayDjHoHqvts0XFYEqyKM3cFWDpeMoqKKTAF9LSYQModPUlh8FKptoM2YcMWAXA==" + "resolved" "https://registry.npmjs.org/@jest/environment/-/environment-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/fake-timers" "^28.1.3" "@jest/types" "^28.1.3" "@types/node" "*" - jest-mock "^28.1.3" + "jest-mock" "^28.1.3" "@jest/expect-utils@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-28.1.3.tgz" - integrity sha512-wvbi9LUrHJLn3NlDW6wF2hvIMtd4JUl2QNVrjq+IBSHirgfrR3o9RnVtxzdEGO2n9JyIWwHnLfby5KzqBGg2YA== + "integrity" "sha512-wvbi9LUrHJLn3NlDW6wF2hvIMtd4JUl2QNVrjq+IBSHirgfrR3o9RnVtxzdEGO2n9JyIWwHnLfby5KzqBGg2YA==" + "resolved" "https://registry.npmjs.org/@jest/expect-utils/-/expect-utils-28.1.3.tgz" + "version" "28.1.3" dependencies: - jest-get-type "^28.0.2" + "jest-get-type" "^28.0.2" "@jest/expect@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/expect/-/expect-28.1.3.tgz" - integrity sha512-lzc8CpUbSoE4dqT0U+g1qODQjBRHPpCPXissXD4mS9+sWQdmmpeJ9zSH1rS1HEkrsMN0fb7nKrJ9giAR1d3wBw== + "integrity" "sha512-lzc8CpUbSoE4dqT0U+g1qODQjBRHPpCPXissXD4mS9+sWQdmmpeJ9zSH1rS1HEkrsMN0fb7nKrJ9giAR1d3wBw==" + "resolved" "https://registry.npmjs.org/@jest/expect/-/expect-28.1.3.tgz" + "version" "28.1.3" dependencies: - expect "^28.1.3" - jest-snapshot "^28.1.3" + "expect" "^28.1.3" + "jest-snapshot" "^28.1.3" "@jest/fake-timers@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-28.1.3.tgz" - integrity sha512-D/wOkL2POHv52h+ok5Oj/1gOG9HSywdoPtFsRCUmlCILXNn5eIWmcnd3DIiWlJnpGvQtmajqBP95Ei0EimxfLw== + "integrity" "sha512-D/wOkL2POHv52h+ok5Oj/1gOG9HSywdoPtFsRCUmlCILXNn5eIWmcnd3DIiWlJnpGvQtmajqBP95Ei0EimxfLw==" + "resolved" "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" "@sinonjs/fake-timers" "^9.1.2" "@types/node" "*" - jest-message-util "^28.1.3" - jest-mock "^28.1.3" - jest-util "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-mock" "^28.1.3" + "jest-util" "^28.1.3" "@jest/globals@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/globals/-/globals-28.1.3.tgz" - integrity sha512-XFU4P4phyryCXu1pbcqMO0GSQcYe1IsalYCDzRNyhetyeyxMcIxa11qPNDpVNLeretItNqEmYYQn1UYz/5x1NA== + "integrity" "sha512-XFU4P4phyryCXu1pbcqMO0GSQcYe1IsalYCDzRNyhetyeyxMcIxa11qPNDpVNLeretItNqEmYYQn1UYz/5x1NA==" + "resolved" "https://registry.npmjs.org/@jest/globals/-/globals-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/environment" "^28.1.3" "@jest/expect" "^28.1.3" "@jest/types" "^28.1.3" "@jest/reporters@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/reporters/-/reporters-28.1.3.tgz" - integrity sha512-JuAy7wkxQZVNU/V6g9xKzCGC5LVXx9FDcABKsSXp5MiKPEE2144a/vXTEDoyzjUpZKfVwp08Wqg5A4WfTMAzjg== + "integrity" "sha512-JuAy7wkxQZVNU/V6g9xKzCGC5LVXx9FDcABKsSXp5MiKPEE2144a/vXTEDoyzjUpZKfVwp08Wqg5A4WfTMAzjg==" + "resolved" "https://registry.npmjs.org/@jest/reporters/-/reporters-28.1.3.tgz" + "version" "28.1.3" dependencies: "@bcoe/v8-coverage" "^0.2.3" "@jest/console" "^28.1.3" @@ -1949,302 +1949,302 @@ "@jest/types" "^28.1.3" "@jridgewell/trace-mapping" "^0.3.13" "@types/node" "*" - chalk "^4.0.0" - collect-v8-coverage "^1.0.0" - exit "^0.1.2" - glob "^7.1.3" - graceful-fs "^4.2.9" - istanbul-lib-coverage "^3.0.0" - istanbul-lib-instrument "^5.1.0" - istanbul-lib-report "^3.0.0" - istanbul-lib-source-maps "^4.0.0" - istanbul-reports "^3.1.3" - jest-message-util "^28.1.3" - jest-util "^28.1.3" - jest-worker "^28.1.3" - slash "^3.0.0" - string-length "^4.0.1" - strip-ansi "^6.0.0" - terminal-link "^2.0.0" - v8-to-istanbul "^9.0.1" + "chalk" "^4.0.0" + "collect-v8-coverage" "^1.0.0" + "exit" "^0.1.2" + "glob" "^7.1.3" + "graceful-fs" "^4.2.9" + "istanbul-lib-coverage" "^3.0.0" + "istanbul-lib-instrument" "^5.1.0" + "istanbul-lib-report" "^3.0.0" + "istanbul-lib-source-maps" "^4.0.0" + "istanbul-reports" "^3.1.3" + "jest-message-util" "^28.1.3" + "jest-util" "^28.1.3" + "jest-worker" "^28.1.3" + "slash" "^3.0.0" + "string-length" "^4.0.1" + "strip-ansi" "^6.0.0" + "terminal-link" "^2.0.0" + "v8-to-istanbul" "^9.0.1" "@jest/schemas@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/schemas/-/schemas-28.1.3.tgz" - integrity sha512-/l/VWsdt/aBXgjshLWOFyFt3IVdYypu5y2Wn2rOO1un6nkqIn8SLXzgIMYXFyYsRWDyF5EthmKJMIdJvk08grg== + "integrity" "sha512-/l/VWsdt/aBXgjshLWOFyFt3IVdYypu5y2Wn2rOO1un6nkqIn8SLXzgIMYXFyYsRWDyF5EthmKJMIdJvk08grg==" + "resolved" "https://registry.npmjs.org/@jest/schemas/-/schemas-28.1.3.tgz" + "version" "28.1.3" dependencies: "@sinclair/typebox" "^0.24.1" "@jest/source-map@^28.1.2": - version "28.1.2" - resolved "https://registry.npmjs.org/@jest/source-map/-/source-map-28.1.2.tgz" - integrity sha512-cV8Lx3BeStJb8ipPHnqVw/IM2VCMWO3crWZzYodSIkxXnRcXJipCdx1JCK0K5MsJJouZQTH73mzf4vgxRaH9ww== + "integrity" "sha512-cV8Lx3BeStJb8ipPHnqVw/IM2VCMWO3crWZzYodSIkxXnRcXJipCdx1JCK0K5MsJJouZQTH73mzf4vgxRaH9ww==" + "resolved" "https://registry.npmjs.org/@jest/source-map/-/source-map-28.1.2.tgz" + "version" "28.1.2" dependencies: "@jridgewell/trace-mapping" "^0.3.13" - callsites "^3.0.0" - graceful-fs "^4.2.9" + "callsites" "^3.0.0" + "graceful-fs" "^4.2.9" "@jest/test-result@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/test-result/-/test-result-28.1.3.tgz" - integrity sha512-kZAkxnSE+FqE8YjW8gNuoVkkC9I7S1qmenl8sGcDOLropASP+BkcGKwhXoyqQuGOGeYY0y/ixjrd/iERpEXHNg== + "integrity" "sha512-kZAkxnSE+FqE8YjW8gNuoVkkC9I7S1qmenl8sGcDOLropASP+BkcGKwhXoyqQuGOGeYY0y/ixjrd/iERpEXHNg==" + "resolved" "https://registry.npmjs.org/@jest/test-result/-/test-result-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/console" "^28.1.3" "@jest/types" "^28.1.3" "@types/istanbul-lib-coverage" "^2.0.0" - collect-v8-coverage "^1.0.0" + "collect-v8-coverage" "^1.0.0" "@jest/test-sequencer@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-28.1.3.tgz" - integrity sha512-NIMPEqqa59MWnDi1kvXXpYbqsfQmSJsIbnd85mdVGkiDfQ9WQQTXOLsvISUfonmnBT+w85WEgneCigEEdHDFxw== + "integrity" "sha512-NIMPEqqa59MWnDi1kvXXpYbqsfQmSJsIbnd85mdVGkiDfQ9WQQTXOLsvISUfonmnBT+w85WEgneCigEEdHDFxw==" + "resolved" "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/test-result" "^28.1.3" - graceful-fs "^4.2.9" - jest-haste-map "^28.1.3" - slash "^3.0.0" + "graceful-fs" "^4.2.9" + "jest-haste-map" "^28.1.3" + "slash" "^3.0.0" "@jest/transform@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/transform/-/transform-28.1.3.tgz" - integrity sha512-u5dT5di+oFI6hfcLOHGTAfmUxFRrjK+vnaP0kkVow9Md/M7V/MxqQMOz/VV25UZO8pzeA9PjfTpOu6BDuwSPQA== + "integrity" "sha512-u5dT5di+oFI6hfcLOHGTAfmUxFRrjK+vnaP0kkVow9Md/M7V/MxqQMOz/VV25UZO8pzeA9PjfTpOu6BDuwSPQA==" + "resolved" "https://registry.npmjs.org/@jest/transform/-/transform-28.1.3.tgz" + "version" "28.1.3" dependencies: "@babel/core" "^7.11.6" "@jest/types" "^28.1.3" "@jridgewell/trace-mapping" "^0.3.13" - babel-plugin-istanbul "^6.1.1" - chalk "^4.0.0" - convert-source-map "^1.4.0" - fast-json-stable-stringify "^2.0.0" - graceful-fs "^4.2.9" - jest-haste-map "^28.1.3" - jest-regex-util "^28.0.2" - jest-util "^28.1.3" - micromatch "^4.0.4" - pirates "^4.0.4" - slash "^3.0.0" - write-file-atomic "^4.0.1" + "babel-plugin-istanbul" "^6.1.1" + "chalk" "^4.0.0" + "convert-source-map" "^1.4.0" + "fast-json-stable-stringify" "^2.0.0" + "graceful-fs" "^4.2.9" + "jest-haste-map" "^28.1.3" + "jest-regex-util" "^28.0.2" + "jest-util" "^28.1.3" + "micromatch" "^4.0.4" + "pirates" "^4.0.4" + "slash" "^3.0.0" + "write-file-atomic" "^4.0.1" "@jest/types@^28.1.3": - version "28.1.3" - resolved "https://registry.npmjs.org/@jest/types/-/types-28.1.3.tgz" - integrity sha512-RyjiyMUZrKz/c+zlMFO1pm70DcIlST8AeWTkoUdZevew44wcNZQHsEVOiCVtgVnlFFD82FPaXycys58cf2muVQ== + "integrity" "sha512-RyjiyMUZrKz/c+zlMFO1pm70DcIlST8AeWTkoUdZevew44wcNZQHsEVOiCVtgVnlFFD82FPaXycys58cf2muVQ==" + "resolved" "https://registry.npmjs.org/@jest/types/-/types-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/schemas" "^28.1.3" "@types/istanbul-lib-coverage" "^2.0.0" "@types/istanbul-reports" "^3.0.0" "@types/node" "*" "@types/yargs" "^17.0.8" - chalk "^4.0.0" + "chalk" "^4.0.0" "@jridgewell/gen-mapping@^0.1.0": - version "0.1.1" - resolved "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz" - integrity sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w== + "integrity" "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==" + "resolved" "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz" + "version" "0.1.1" dependencies: "@jridgewell/set-array" "^1.0.0" "@jridgewell/sourcemap-codec" "^1.4.10" "@jridgewell/gen-mapping@^0.3.2": - version "0.3.2" - resolved "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz" - integrity sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A== + "integrity" "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==" + "resolved" "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz" + "version" "0.3.2" dependencies: "@jridgewell/set-array" "^1.0.1" "@jridgewell/sourcemap-codec" "^1.4.10" "@jridgewell/trace-mapping" "^0.3.9" "@jridgewell/resolve-uri@^3.0.3": - version "3.1.0" - resolved "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz" - integrity sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w== + "integrity" "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==" + "resolved" "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz" + "version" "3.1.0" "@jridgewell/set-array@^1.0.0", "@jridgewell/set-array@^1.0.1": - version "1.1.2" - resolved "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz" - integrity sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw== + "integrity" "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==" + "resolved" "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz" + "version" "1.1.2" "@jridgewell/sourcemap-codec@^1.4.10": - version "1.4.14" - resolved "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz" - integrity sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw== + "integrity" "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" + "resolved" "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz" + "version" "1.4.14" -"@jridgewell/trace-mapping@0.3.9": - version "0.3.9" - resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz" - integrity sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ== +"@jridgewell/trace-mapping@^0.3.12", "@jridgewell/trace-mapping@^0.3.13", "@jridgewell/trace-mapping@^0.3.9": + "integrity" "sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ==" + "resolved" "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz" + "version" "0.3.14" dependencies: "@jridgewell/resolve-uri" "^3.0.3" "@jridgewell/sourcemap-codec" "^1.4.10" -"@jridgewell/trace-mapping@^0.3.12", "@jridgewell/trace-mapping@^0.3.13", "@jridgewell/trace-mapping@^0.3.9": - version "0.3.14" - resolved "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.14.tgz" - integrity sha512-bJWEfQ9lPTvm3SneWwRFVLzrh6nhjwqw7TUFFBEMzwvg7t7PCDenf2lDwqo4NQXzdpgBXyFgDWnQA+2vkruksQ== +"@jridgewell/trace-mapping@0.3.9": + "integrity" "sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==" + "resolved" "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.9.tgz" + "version" "0.3.9" dependencies: "@jridgewell/resolve-uri" "^3.0.3" "@jridgewell/sourcemap-codec" "^1.4.10" "@mapbox/node-pre-gyp@^1.0.0": - version "1.0.9" - resolved "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.9.tgz" - integrity sha512-aDF3S3rK9Q2gey/WAttUlISduDItz5BU3306M9Eyv6/oS40aMprnopshtlKTykxRNIBEZuRMaZAnbrQ4QtKGyw== + "integrity" "sha512-aDF3S3rK9Q2gey/WAttUlISduDItz5BU3306M9Eyv6/oS40aMprnopshtlKTykxRNIBEZuRMaZAnbrQ4QtKGyw==" + "resolved" "https://registry.npmjs.org/@mapbox/node-pre-gyp/-/node-pre-gyp-1.0.9.tgz" + "version" "1.0.9" dependencies: - detect-libc "^2.0.0" - https-proxy-agent "^5.0.0" - make-dir "^3.1.0" - node-fetch "^2.6.7" - nopt "^5.0.0" - npmlog "^5.0.1" - rimraf "^3.0.2" - semver "^7.3.5" - tar "^6.1.11" + "detect-libc" "^2.0.0" + "https-proxy-agent" "^5.0.0" + "make-dir" "^3.1.0" + "node-fetch" "^2.6.7" + "nopt" "^5.0.0" + "npmlog" "^5.0.1" + "rimraf" "^3.0.2" + "semver" "^7.3.5" + "tar" "^6.1.11" "@npmcli/fs@^1.0.0": - version "1.1.1" - resolved "https://registry.yarnpkg.com/@npmcli/fs/-/fs-1.1.1.tgz#72f719fe935e687c56a4faecf3c03d06ba593257" - integrity sha512-8KG5RD0GVP4ydEzRn/I4BNDuxDtqVbOdm8675T49OIG/NGhaK0pjPX7ZcDlvKYbA+ulvVK3ztfcF4uBdOxuJbQ== + "integrity" "sha512-8KG5RD0GVP4ydEzRn/I4BNDuxDtqVbOdm8675T49OIG/NGhaK0pjPX7ZcDlvKYbA+ulvVK3ztfcF4uBdOxuJbQ==" + "resolved" "https://registry.npmjs.org/@npmcli/fs/-/fs-1.1.1.tgz" + "version" "1.1.1" dependencies: "@gar/promisify" "^1.0.1" - semver "^7.3.5" + "semver" "^7.3.5" "@npmcli/move-file@^1.0.1": - version "1.1.2" - resolved "https://registry.yarnpkg.com/@npmcli/move-file/-/move-file-1.1.2.tgz#1a82c3e372f7cae9253eb66d72543d6b8685c674" - integrity sha512-1SUf/Cg2GzGDyaf15aR9St9TWlb+XvbZXWpDx8YKs7MLzMH/BCeopv+y9vzrzgkfykCGuWOlSu3mZhj2+FQcrg== + "integrity" "sha512-1SUf/Cg2GzGDyaf15aR9St9TWlb+XvbZXWpDx8YKs7MLzMH/BCeopv+y9vzrzgkfykCGuWOlSu3mZhj2+FQcrg==" + "resolved" "https://registry.npmjs.org/@npmcli/move-file/-/move-file-1.1.2.tgz" + "version" "1.1.2" dependencies: - mkdirp "^1.0.4" - rimraf "^3.0.2" + "mkdirp" "^1.0.4" + "rimraf" "^3.0.2" "@ovos-media/ts-transform-paths@^1.7.18-1": - version "1.7.18-1" - resolved "https://registry.npmjs.org/@ovos-media/ts-transform-paths/-/ts-transform-paths-1.7.18-1.tgz" - integrity sha512-5uYtraYSWg1klaMYus3ouCOUUNzcI40pS0NCaw0PhoaPTimVfT3MV061ZLYR/4F14THqyofMjmCNcHgFrBX3AA== + "integrity" "sha512-5uYtraYSWg1klaMYus3ouCOUUNzcI40pS0NCaw0PhoaPTimVfT3MV061ZLYR/4F14THqyofMjmCNcHgFrBX3AA==" + "resolved" "https://registry.npmjs.org/@ovos-media/ts-transform-paths/-/ts-transform-paths-1.7.18-1.tgz" + "version" "1.7.18-1" dependencies: "@zerollup/ts-helpers" "^1.7.18" "@sentry/core@7.10.0": - version "7.10.0" - resolved "https://registry.npmjs.org/@sentry/core/-/core-7.10.0.tgz" - integrity sha512-uq6oUXPH+6cjsEL5/j/xSW91mVrJo7knTqax7E5MDiA5j98BPK4budGiBiPO7GEB856QhA7N+pOO0lccii5QYQ== + "integrity" "sha512-uq6oUXPH+6cjsEL5/j/xSW91mVrJo7knTqax7E5MDiA5j98BPK4budGiBiPO7GEB856QhA7N+pOO0lccii5QYQ==" + "resolved" "https://registry.npmjs.org/@sentry/core/-/core-7.10.0.tgz" + "version" "7.10.0" dependencies: "@sentry/hub" "7.10.0" "@sentry/types" "7.10.0" "@sentry/utils" "7.10.0" - tslib "^1.9.3" + "tslib" "^1.9.3" "@sentry/hub@7.10.0": - version "7.10.0" - resolved "https://registry.npmjs.org/@sentry/hub/-/hub-7.10.0.tgz" - integrity sha512-9Appy7J87EU7Xu2BDY1cLK79nsuE72geeYmG71lgdttTD3XOMcQBOxET4/2sAI+d/ansurXnURx+DAQ9FOKT+w== + "integrity" "sha512-9Appy7J87EU7Xu2BDY1cLK79nsuE72geeYmG71lgdttTD3XOMcQBOxET4/2sAI+d/ansurXnURx+DAQ9FOKT+w==" + "resolved" "https://registry.npmjs.org/@sentry/hub/-/hub-7.10.0.tgz" + "version" "7.10.0" dependencies: "@sentry/types" "7.10.0" "@sentry/utils" "7.10.0" - tslib "^1.9.3" + "tslib" "^1.9.3" "@sentry/node@^7.7.0": - version "7.10.0" - resolved "https://registry.npmjs.org/@sentry/node/-/node-7.10.0.tgz" - integrity sha512-L/DSEJ7Biy8ovvlCyfu5MpCYG108FIGVbJ1h0NBGr5+uLxTNg2WJWojJoiQNiRcWl4s0dcIXrRdi0HR2Sx+DUw== + "integrity" "sha512-L/DSEJ7Biy8ovvlCyfu5MpCYG108FIGVbJ1h0NBGr5+uLxTNg2WJWojJoiQNiRcWl4s0dcIXrRdi0HR2Sx+DUw==" + "resolved" "https://registry.npmjs.org/@sentry/node/-/node-7.10.0.tgz" + "version" "7.10.0" dependencies: "@sentry/core" "7.10.0" "@sentry/hub" "7.10.0" "@sentry/types" "7.10.0" "@sentry/utils" "7.10.0" - cookie "^0.4.1" - https-proxy-agent "^5.0.0" - lru_map "^0.3.3" - tslib "^1.9.3" + "cookie" "^0.4.1" + "https-proxy-agent" "^5.0.0" + "lru_map" "^0.3.3" + "tslib" "^1.9.3" "@sentry/tracing@^7.7.0": - version "7.10.0" - resolved "https://registry.npmjs.org/@sentry/tracing/-/tracing-7.10.0.tgz" - integrity sha512-ojuBYS1bL/IGWKt/ItY4HmC8NElJrYtTUvm73VbhylhIO4zcn5ICHmgMFj1lqL9gQ1nCnAlifKiWIjL9qUatTA== + "integrity" "sha512-ojuBYS1bL/IGWKt/ItY4HmC8NElJrYtTUvm73VbhylhIO4zcn5ICHmgMFj1lqL9gQ1nCnAlifKiWIjL9qUatTA==" + "resolved" "https://registry.npmjs.org/@sentry/tracing/-/tracing-7.10.0.tgz" + "version" "7.10.0" dependencies: "@sentry/hub" "7.10.0" "@sentry/types" "7.10.0" "@sentry/utils" "7.10.0" - tslib "^1.9.3" + "tslib" "^1.9.3" "@sentry/types@7.10.0": - version "7.10.0" - resolved "https://registry.npmjs.org/@sentry/types/-/types-7.10.0.tgz" - integrity sha512-1UBwdbS0xXzANzp63g4eNQly/qKIXp0swP5OTKWoADvKBtL4anroLUA/l8ADMtuwFZYtVANc8WRGxM2+YmaXtg== + "integrity" "sha512-1UBwdbS0xXzANzp63g4eNQly/qKIXp0swP5OTKWoADvKBtL4anroLUA/l8ADMtuwFZYtVANc8WRGxM2+YmaXtg==" + "resolved" "https://registry.npmjs.org/@sentry/types/-/types-7.10.0.tgz" + "version" "7.10.0" "@sentry/utils@7.10.0": - version "7.10.0" - resolved "https://registry.npmjs.org/@sentry/utils/-/utils-7.10.0.tgz" - integrity sha512-/aD2DnfyOhV0Wdbb6VF78vu4fQIZJyuReDpBI7MV/EqcEB6FxUKq2YjinfKZF/exHEPig6Ag/Yt+CRFgvtVFuw== + "integrity" "sha512-/aD2DnfyOhV0Wdbb6VF78vu4fQIZJyuReDpBI7MV/EqcEB6FxUKq2YjinfKZF/exHEPig6Ag/Yt+CRFgvtVFuw==" + "resolved" "https://registry.npmjs.org/@sentry/utils/-/utils-7.10.0.tgz" + "version" "7.10.0" dependencies: "@sentry/types" "7.10.0" - tslib "^1.9.3" + "tslib" "^1.9.3" "@sinclair/typebox@^0.24.1": - version "0.24.20" - resolved "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.24.20.tgz" - integrity sha512-kVaO5aEFZb33nPMTZBxiPEkY+slxiPtqC7QX8f9B3eGOMBvEfuMfxp9DSTTCsRJPumPKjrge4yagyssO4q6qzQ== + "integrity" "sha512-kVaO5aEFZb33nPMTZBxiPEkY+slxiPtqC7QX8f9B3eGOMBvEfuMfxp9DSTTCsRJPumPKjrge4yagyssO4q6qzQ==" + "resolved" "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.24.20.tgz" + "version" "0.24.20" "@sinonjs/commons@^1.7.0": - version "1.8.3" - resolved "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz" - integrity sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ== + "integrity" "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==" + "resolved" "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz" + "version" "1.8.3" dependencies: - type-detect "4.0.8" + "type-detect" "4.0.8" "@sinonjs/fake-timers@^9.1.2": - version "9.1.2" - resolved "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-9.1.2.tgz" - integrity sha512-BPS4ynJW/o92PUR4wgriz2Ud5gpST5vz6GQfMixEDK0Z8ZCUv2M7SkBLykH56T++Xs+8ln9zTGbOvNGIe02/jw== + "integrity" "sha512-BPS4ynJW/o92PUR4wgriz2Ud5gpST5vz6GQfMixEDK0Z8ZCUv2M7SkBLykH56T++Xs+8ln9zTGbOvNGIe02/jw==" + "resolved" "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-9.1.2.tgz" + "version" "9.1.2" dependencies: "@sinonjs/commons" "^1.7.0" "@sqltools/formatter@^1.2.2": - version "1.2.3" - resolved "https://registry.npmjs.org/@sqltools/formatter/-/formatter-1.2.3.tgz" - integrity sha512-O3uyB/JbkAEMZaP3YqyHH7TMnex7tWyCbCI4EfJdOCoN6HIhqdJBWTM6aCCiWQ/5f5wxjgU735QAIpJbjDvmzg== + "integrity" "sha512-O3uyB/JbkAEMZaP3YqyHH7TMnex7tWyCbCI4EfJdOCoN6HIhqdJBWTM6aCCiWQ/5f5wxjgU735QAIpJbjDvmzg==" + "resolved" "https://registry.npmjs.org/@sqltools/formatter/-/formatter-1.2.3.tgz" + "version" "1.2.3" "@tokenizer/token@^0.3.0": - version "0.3.0" - resolved "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz" - integrity sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A== + "integrity" "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==" + "resolved" "https://registry.npmjs.org/@tokenizer/token/-/token-0.3.0.tgz" + "version" "0.3.0" "@tootallnate/once@1": - version "1.1.2" - resolved "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz" - integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw== + "integrity" "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==" + "resolved" "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz" + "version" "1.1.2" "@tsconfig/node10@^1.0.7": - version "1.0.9" - resolved "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz" - integrity sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA== + "integrity" "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==" + "resolved" "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz" + "version" "1.0.9" "@tsconfig/node12@^1.0.7": - version "1.0.11" - resolved "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz" - integrity sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag== + "integrity" "sha512-cqefuRsh12pWyGsIoBKJA9luFu3mRxCA+ORZvA4ktLSzIuCUtWVxGIuXigEwO5/ywWFMZ2QEGKWvkZG1zDMTag==" + "resolved" "https://registry.npmjs.org/@tsconfig/node12/-/node12-1.0.11.tgz" + "version" "1.0.11" "@tsconfig/node14@^1.0.0": - version "1.0.3" - resolved "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz" - integrity sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow== + "integrity" "sha512-ysT8mhdixWK6Hw3i1V2AeRqZ5WfXg1G43mqoYlM2nc6388Fq5jcXyr5mRsqViLx/GJYdoL0bfXD8nmF+Zn/Iow==" + "resolved" "https://registry.npmjs.org/@tsconfig/node14/-/node14-1.0.3.tgz" + "version" "1.0.3" "@tsconfig/node16@^1.0.2": - version "1.0.3" - resolved "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.3.tgz" - integrity sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ== + "integrity" "sha512-yOlFc+7UtL/89t2ZhjPvvB/DeAr3r+Dq58IgzsFkOAvVC6NMJXmCGjbptdXdR9qsX7pKcTL+s87FtYREi2dEEQ==" + "resolved" "https://registry.npmjs.org/@tsconfig/node16/-/node16-1.0.3.tgz" + "version" "1.0.3" "@types/amqplib@^0.8.1": - version "0.8.2" - resolved "https://registry.npmjs.org/@types/amqplib/-/amqplib-0.8.2.tgz" - integrity sha512-p+TFLzo52f8UanB+Nq6gyUi65yecAcRY3nYowU6MPGFtaJvEDxcnFWrxssSTkF+ts1W3zyQDvgVICLQem5WxRA== + "integrity" "sha512-p+TFLzo52f8UanB+Nq6gyUi65yecAcRY3nYowU6MPGFtaJvEDxcnFWrxssSTkF+ts1W3zyQDvgVICLQem5WxRA==" + "resolved" "https://registry.npmjs.org/@types/amqplib/-/amqplib-0.8.2.tgz" + "version" "0.8.2" dependencies: "@types/bluebird" "*" "@types/node" "*" "@types/babel__core@^7.1.14": - version "7.1.19" - resolved "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.19.tgz" - integrity sha512-WEOTgRsbYkvA/KCsDwVEGkd7WAr1e3g31VHQ8zy5gul/V1qKullU/BU5I68X5v7V3GnB9eotmom4v5a5gjxorw== + "integrity" "sha512-WEOTgRsbYkvA/KCsDwVEGkd7WAr1e3g31VHQ8zy5gul/V1qKullU/BU5I68X5v7V3GnB9eotmom4v5a5gjxorw==" + "resolved" "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.19.tgz" + "version" "7.1.19" dependencies: "@babel/parser" "^7.1.0" "@babel/types" "^7.0.0" @@ -2253,74 +2253,74 @@ "@types/babel__traverse" "*" "@types/babel__generator@*": - version "7.6.4" - resolved "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz" - integrity sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg== + "integrity" "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==" + "resolved" "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz" + "version" "7.6.4" dependencies: "@babel/types" "^7.0.0" "@types/babel__template@*": - version "7.4.1" - resolved "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz" - integrity sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g== + "integrity" "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==" + "resolved" "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz" + "version" "7.4.1" dependencies: "@babel/parser" "^7.1.0" "@babel/types" "^7.0.0" "@types/babel__traverse@*", "@types/babel__traverse@^7.0.6": - version "7.17.1" - resolved "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.17.1.tgz" - integrity sha512-kVzjari1s2YVi77D3w1yuvohV2idweYXMCDzqBiVNN63TcDWrIlTVOYpqVrvbbyOE/IyzBoTKF0fdnLPEORFxA== + "integrity" "sha512-kVzjari1s2YVi77D3w1yuvohV2idweYXMCDzqBiVNN63TcDWrIlTVOYpqVrvbbyOE/IyzBoTKF0fdnLPEORFxA==" + "resolved" "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.17.1.tgz" + "version" "7.17.1" dependencies: "@babel/types" "^7.3.0" "@types/bcrypt@^5.0.0": - version "5.0.0" - resolved "https://registry.npmjs.org/@types/bcrypt/-/bcrypt-5.0.0.tgz" - integrity sha512-agtcFKaruL8TmcvqbndlqHPSJgsolhf/qPWchFlgnW1gECTN/nKbFcoFnvKAQRFfKbh+BO6A3SWdJu9t+xF3Lw== + "integrity" "sha512-agtcFKaruL8TmcvqbndlqHPSJgsolhf/qPWchFlgnW1gECTN/nKbFcoFnvKAQRFfKbh+BO6A3SWdJu9t+xF3Lw==" + "resolved" "https://registry.npmjs.org/@types/bcrypt/-/bcrypt-5.0.0.tgz" + "version" "5.0.0" dependencies: "@types/node" "*" "@types/bluebird@*": - version "3.5.36" - resolved "https://registry.npmjs.org/@types/bluebird/-/bluebird-3.5.36.tgz" - integrity sha512-HBNx4lhkxN7bx6P0++W8E289foSu8kO8GCk2unhuVggO+cE7rh9DhZUyPhUxNRG9m+5B5BTKxZQ5ZP92x/mx9Q== + "integrity" "sha512-HBNx4lhkxN7bx6P0++W8E289foSu8kO8GCk2unhuVggO+cE7rh9DhZUyPhUxNRG9m+5B5BTKxZQ5ZP92x/mx9Q==" + "resolved" "https://registry.npmjs.org/@types/bluebird/-/bluebird-3.5.36.tgz" + "version" "3.5.36" "@types/body-parser@*", "@types/body-parser@^1.19.0": - version "1.19.2" - resolved "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz" - integrity sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g== + "integrity" "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==" + "resolved" "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz" + "version" "1.19.2" dependencies: "@types/connect" "*" "@types/node" "*" "@types/connect@*": - version "3.4.35" - resolved "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz" - integrity sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ== + "integrity" "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==" + "resolved" "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz" + "version" "3.4.35" dependencies: "@types/node" "*" "@types/dotenv@^8.2.0": - version "8.2.0" - resolved "https://registry.npmjs.org/@types/dotenv/-/dotenv-8.2.0.tgz" - integrity sha512-ylSC9GhfRH7m1EUXBXofhgx4lUWmFeQDINW5oLuS+gxWdfUeW4zJdeVTYVkexEW+e2VUvlZR2kGnGGipAWR7kw== + "integrity" "sha512-ylSC9GhfRH7m1EUXBXofhgx4lUWmFeQDINW5oLuS+gxWdfUeW4zJdeVTYVkexEW+e2VUvlZR2kGnGGipAWR7kw==" + "resolved" "https://registry.npmjs.org/@types/dotenv/-/dotenv-8.2.0.tgz" + "version" "8.2.0" dependencies: - dotenv "*" + "dotenv" "*" "@types/express-serve-static-core@^4.17.18": - version "4.17.29" - resolved "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.29.tgz" - integrity sha512-uMd++6dMKS32EOuw1Uli3e3BPgdLIXmezcfHv7N4c1s3gkhikBplORPpMq3fuWkxncZN1reb16d5n8yhQ80x7Q== + "integrity" "sha512-uMd++6dMKS32EOuw1Uli3e3BPgdLIXmezcfHv7N4c1s3gkhikBplORPpMq3fuWkxncZN1reb16d5n8yhQ80x7Q==" + "resolved" "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.29.tgz" + "version" "4.17.29" dependencies: "@types/node" "*" "@types/qs" "*" "@types/range-parser" "*" -"@types/express@*", "@types/express@^4.17.12": - version "4.17.13" - resolved "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz" - integrity sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA== +"@types/express@*", "@types/express@^4.17.12", "@types/express@^4.17.9": + "integrity" "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==" + "resolved" "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz" + "version" "4.17.13" dependencies: "@types/body-parser" "*" "@types/express-serve-static-core" "^4.17.18" @@ -2328,432 +2328,439 @@ "@types/serve-static" "*" "@types/graceful-fs@^4.1.3": - version "4.1.5" - resolved "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz" - integrity sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw== + "integrity" "sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==" + "resolved" "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz" + "version" "4.1.5" dependencies: "@types/node" "*" "@types/i18next-node-fs-backend@^2.1.0": - version "2.1.1" - resolved "https://registry.npmjs.org/@types/i18next-node-fs-backend/-/i18next-node-fs-backend-2.1.1.tgz" - integrity sha512-ESvH90OICQkKU3yuuRzF6YfHt5KACE55FOiUM59mMGnC+h03lHGdEYo3z3THbwS5FdMskLyIs2O7f6Oaz8P9sw== + "integrity" "sha512-ESvH90OICQkKU3yuuRzF6YfHt5KACE55FOiUM59mMGnC+h03lHGdEYo3z3THbwS5FdMskLyIs2O7f6Oaz8P9sw==" + "resolved" "https://registry.npmjs.org/@types/i18next-node-fs-backend/-/i18next-node-fs-backend-2.1.1.tgz" + "version" "2.1.1" dependencies: - i18next ">=17.0.11" + "i18next" ">=17.0.11" "@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0", "@types/istanbul-lib-coverage@^2.0.1": - version "2.0.4" - resolved "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz" - integrity sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g== + "integrity" "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==" + "resolved" "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz" + "version" "2.0.4" "@types/istanbul-lib-report@*": - version "3.0.0" - resolved "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz" - integrity sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg== + "integrity" "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==" + "resolved" "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz" + "version" "3.0.0" dependencies: "@types/istanbul-lib-coverage" "*" "@types/istanbul-reports@^3.0.0": - version "3.0.1" - resolved "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz" - integrity sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw== + "integrity" "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==" + "resolved" "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz" + "version" "3.0.1" dependencies: "@types/istanbul-lib-report" "*" "@types/json-schema@^7.0.9": - version "7.0.11" - resolved "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz" - integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== + "integrity" "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==" + "resolved" "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz" + "version" "7.0.11" "@types/jsonwebtoken@^8.5.8": - version "8.5.8" - resolved "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.8.tgz" - integrity sha512-zm6xBQpFDIDM6o9r6HSgDeIcLy82TKWctCXEPbJJcXb5AKmi5BNNdLXneixK4lplX3PqIVcwLBCGE/kAGnlD4A== + "integrity" "sha512-zm6xBQpFDIDM6o9r6HSgDeIcLy82TKWctCXEPbJJcXb5AKmi5BNNdLXneixK4lplX3PqIVcwLBCGE/kAGnlD4A==" + "resolved" "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.8.tgz" + "version" "8.5.8" dependencies: "@types/node" "*" "@types/mime@^1": - version "1.3.2" - resolved "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz" - integrity sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw== + "integrity" "sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==" + "resolved" "https://registry.npmjs.org/@types/mime/-/mime-1.3.2.tgz" + "version" "1.3.2" "@types/morgan@^1.9.3": - version "1.9.3" - resolved "https://registry.npmjs.org/@types/morgan/-/morgan-1.9.3.tgz" - integrity sha512-BiLcfVqGBZCyNCnCH3F4o2GmDLrpy0HeBVnNlyZG4fo88ZiE9SoiBe3C+2ezuwbjlEyT+PDZ17//TAlRxAn75Q== + "integrity" "sha512-BiLcfVqGBZCyNCnCH3F4o2GmDLrpy0HeBVnNlyZG4fo88ZiE9SoiBe3C+2ezuwbjlEyT+PDZ17//TAlRxAn75Q==" + "resolved" "https://registry.npmjs.org/@types/morgan/-/morgan-1.9.3.tgz" + "version" "1.9.3" dependencies: "@types/node" "*" -"@types/multer@^1.4.7": - version "1.4.7" - resolved "https://registry.npmjs.org/@types/multer/-/multer-1.4.7.tgz" - integrity sha512-/SNsDidUFCvqqcWDwxv2feww/yqhNeTRL5CVoL3jU4Goc4kKEL10T7Eye65ZqPNi4HRx8sAEX59pV1aEH7drNA== +"@types/multer@^1.4.5", "@types/multer@^1.4.7": + "integrity" "sha512-/SNsDidUFCvqqcWDwxv2feww/yqhNeTRL5CVoL3jU4Goc4kKEL10T7Eye65ZqPNi4HRx8sAEX59pV1aEH7drNA==" + "resolved" "https://registry.npmjs.org/@types/multer/-/multer-1.4.7.tgz" + "version" "1.4.7" dependencies: "@types/express" "*" "@types/node-fetch@^2.6.2": - version "2.6.2" - resolved "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.2.tgz" - integrity sha512-DHqhlq5jeESLy19TYhLakJ07kNumXWjcDdxXsLUMJZ6ue8VZJj4kLPQVE/2mdHh3xZziNF1xppu5lwmS53HR+A== + "integrity" "sha512-DHqhlq5jeESLy19TYhLakJ07kNumXWjcDdxXsLUMJZ6ue8VZJj4kLPQVE/2mdHh3xZziNF1xppu5lwmS53HR+A==" + "resolved" "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.2.tgz" + "version" "2.6.2" dependencies: "@types/node" "*" - form-data "^3.0.0" + "form-data" "^3.0.0" "@types/node-os-utils@^1.3.0": - version "1.3.0" - resolved "https://registry.npmjs.org/@types/node-os-utils/-/node-os-utils-1.3.0.tgz" - integrity sha512-XwVteWQx/XkfRPyaGkw8dEbrCAkoRZ73pI3XznUYIpzbCfpQB3UnDlR5TnmdhetlT889tUJGF8QWo9xrgTpsiA== + "integrity" "sha512-XwVteWQx/XkfRPyaGkw8dEbrCAkoRZ73pI3XznUYIpzbCfpQB3UnDlR5TnmdhetlT889tUJGF8QWo9xrgTpsiA==" + "resolved" "https://registry.npmjs.org/@types/node-os-utils/-/node-os-utils-1.3.0.tgz" + "version" "1.3.0" -"@types/node@*", "@types/node@^18.0.6": - version "18.6.3" - resolved "https://registry.npmjs.org/@types/node/-/node-18.6.3.tgz" - integrity sha512-6qKpDtoaYLM+5+AFChLhHermMQxc3TOEFIDzrZLPRGHPrLEwqFkkT5Kx3ju05g6X7uDPazz3jHbKPX0KzCjntg== +"@types/node@*", "@types/node@^18.0.6", "@types/node@^18.6.3", "@types/node@^18.7.3": + "integrity" "sha512-LJgzOEwWuMTBxHzgBR/fhhBOWrvBjvO+zPteUgbbuQi80rYIZHrk1mNbRUqPZqSLP2H7Rwt1EFLL/tNLD1Xx/w==" + "resolved" "https://registry.npmjs.org/@types/node/-/node-18.7.3.tgz" + "version" "18.7.3" "@types/node@^16.9.2": - version "16.11.45" - resolved "https://registry.npmjs.org/@types/node/-/node-16.11.45.tgz" - integrity sha512-3rKg/L5x0rofKuuUt5zlXzOnKyIHXmIu5R8A0TuNDMF2062/AOIDBciFIjToLEJ/9F9DzkHNot+BpNsMI1OLdQ== + "integrity" "sha512-3rKg/L5x0rofKuuUt5zlXzOnKyIHXmIu5R8A0TuNDMF2062/AOIDBciFIjToLEJ/9F9DzkHNot+BpNsMI1OLdQ==" + "resolved" "https://registry.npmjs.org/@types/node/-/node-16.11.45.tgz" + "version" "16.11.45" "@types/notp@^2.0.0": - version "2.0.2" - resolved "https://registry.npmjs.org/@types/notp/-/notp-2.0.2.tgz" - integrity sha512-JUcVYN9Tmw0AjoAfvjslS4hbv39fPBbZdftBK3b50g5z/DmhLsu6cd0UOEBiQuMwy2FirshF2Gk9gAvfWjshMw== + "integrity" "sha512-JUcVYN9Tmw0AjoAfvjslS4hbv39fPBbZdftBK3b50g5z/DmhLsu6cd0UOEBiQuMwy2FirshF2Gk9gAvfWjshMw==" + "resolved" "https://registry.npmjs.org/@types/notp/-/notp-2.0.2.tgz" + "version" "2.0.2" dependencies: "@types/node" "*" "@types/prettier@^2.1.5": - version "2.6.3" - resolved "https://registry.npmjs.org/@types/prettier/-/prettier-2.6.3.tgz" - integrity sha512-ymZk3LEC/fsut+/Q5qejp6R9O1rMxz3XaRHDV6kX8MrGAhOSPqVARbDi+EZvInBpw+BnCX3TD240byVkOfQsHg== + "integrity" "sha512-ymZk3LEC/fsut+/Q5qejp6R9O1rMxz3XaRHDV6kX8MrGAhOSPqVARbDi+EZvInBpw+BnCX3TD240byVkOfQsHg==" + "resolved" "https://registry.npmjs.org/@types/prettier/-/prettier-2.6.3.tgz" + "version" "2.6.3" "@types/qs@*": - version "6.9.7" - resolved "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz" - integrity sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw== + "integrity" "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" + "resolved" "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz" + "version" "6.9.7" "@types/range-parser@*": - version "1.2.4" - resolved "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz" - integrity sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw== + "integrity" "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==" + "resolved" "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz" + "version" "1.2.4" "@types/serve-static@*": - version "1.13.10" - resolved "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz" - integrity sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ== + "integrity" "sha512-nCkHGI4w7ZgAdNkrEu0bv+4xNV/XDqW+DydknebMOQwkpDGx8G+HTlj7R7ABI8i8nKxVw0wtKPi1D+lPOkh4YQ==" + "resolved" "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.10.tgz" + "version" "1.13.10" dependencies: "@types/mime" "^1" "@types/node" "*" "@types/stack-utils@^2.0.0": - version "2.0.1" - resolved "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz" - integrity sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw== + "integrity" "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==" + "resolved" "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz" + "version" "2.0.1" "@types/stream-buffers@^3.0.3": - version "3.0.4" - resolved "https://registry.npmjs.org/@types/stream-buffers/-/stream-buffers-3.0.4.tgz" - integrity sha512-qU/K1tb2yUdhXkLIATzsIPwbtX6BpZk0l3dPW6xqWyhfzzM1ECaQ/8faEnu3CNraLiQ9LHyQQPBGp7N9Fbs25w== + "integrity" "sha512-qU/K1tb2yUdhXkLIATzsIPwbtX6BpZk0l3dPW6xqWyhfzzM1ECaQ/8faEnu3CNraLiQ9LHyQQPBGp7N9Fbs25w==" + "resolved" "https://registry.npmjs.org/@types/stream-buffers/-/stream-buffers-3.0.4.tgz" + "version" "3.0.4" dependencies: "@types/node" "*" "@types/strip-bom@^3.0.0": - version "3.0.0" - resolved "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz" - integrity sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ== + "integrity" "sha512-xevGOReSYGM7g/kUBZzPqCrR/KYAo+F0yiPc85WFTJa0MSLtyFTVTU6cJu/aV4mid7IffDIWqo69THF2o4JiEQ==" + "resolved" "https://registry.npmjs.org/@types/strip-bom/-/strip-bom-3.0.0.tgz" + "version" "3.0.0" "@types/strip-json-comments@0.0.30": - version "0.0.30" - resolved "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz" - integrity sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ== + "integrity" "sha512-7NQmHra/JILCd1QqpSzl8+mJRc8ZHz3uDm8YV1Ks9IhK0epEiTw8aIErbvH9PI+6XbqhyIQy3462nEsn7UVzjQ==" + "resolved" "https://registry.npmjs.org/@types/strip-json-comments/-/strip-json-comments-0.0.30.tgz" + "version" "0.0.30" "@types/ws@^8.5.3": - version "8.5.3" - resolved "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz" - integrity sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w== + "integrity" "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==" + "resolved" "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz" + "version" "8.5.3" dependencies: "@types/node" "*" "@types/yargs-parser@*": - version "21.0.0" - resolved "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz" - integrity sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA== + "integrity" "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==" + "resolved" "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz" + "version" "21.0.0" "@types/yargs@^17.0.8": - version "17.0.10" - resolved "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.10.tgz" - integrity sha512-gmEaFwpj/7f/ROdtIlci1R1VYU1J4j95m8T+Tj3iBgiBFKg1foE/PSl93bBd5T9LDXNPo8UlNN6W0qwD8O5OaA== + "integrity" "sha512-gmEaFwpj/7f/ROdtIlci1R1VYU1J4j95m8T+Tj3iBgiBFKg1foE/PSl93bBd5T9LDXNPo8UlNN6W0qwD8O5OaA==" + "resolved" "https://registry.npmjs.org/@types/yargs/-/yargs-17.0.10.tgz" + "version" "17.0.10" dependencies: "@types/yargs-parser" "*" "@yarnpkg/lockfile@^1.1.0": - version "1.1.0" - resolved "https://registry.npmjs.org/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz" - integrity sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ== + "integrity" "sha512-GpSwvyXOcOOlV70vbnzjj4fW5xW/FdUF6nQEt1ENy7m4ZCczi1+/buVUPAqmGfqznsORNFzUMjctTIp8a9tuCQ==" + "resolved" "https://registry.npmjs.org/@yarnpkg/lockfile/-/lockfile-1.1.0.tgz" + "version" "1.1.0" "@zerollup/ts-helpers@^1.7.18": - version "1.7.18" - resolved "https://registry.npmjs.org/@zerollup/ts-helpers/-/ts-helpers-1.7.18.tgz" - integrity sha512-S9zN+y+i5yN/evfWquzSO3lubqPXIsPQf6p9OiPMpRxDx/0totPLF39XoRw48Dav5dSvbIE8D2eAPpXXJxvKwg== + "integrity" "sha512-S9zN+y+i5yN/evfWquzSO3lubqPXIsPQf6p9OiPMpRxDx/0totPLF39XoRw48Dav5dSvbIE8D2eAPpXXJxvKwg==" + "resolved" "https://registry.npmjs.org/@zerollup/ts-helpers/-/ts-helpers-1.7.18.tgz" + "version" "1.7.18" dependencies: - resolve "^1.12.0" + "resolve" "^1.12.0" -abbrev@1: - version "1.1.1" - resolved "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz" - integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== +"abbrev@1": + "integrity" "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" + "resolved" "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz" + "version" "1.1.1" -accepts@~1.3.8: - version "1.3.8" - resolved "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz" - integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== +"accepts@~1.3.8": + "integrity" "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==" + "resolved" "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz" + "version" "1.3.8" dependencies: - mime-types "~2.1.34" - negotiator "0.6.3" + "mime-types" "~2.1.34" + "negotiator" "0.6.3" -acorn-walk@^8.1.1, acorn-walk@^8.2.0: - version "8.2.0" - resolved "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz" - integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA== +"acorn-walk@^8.1.1", "acorn-walk@^8.2.0": + "integrity" "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==" + "resolved" "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz" + "version" "8.2.0" -acorn@^8.4.1, acorn@^8.7.0: - version "8.7.1" - resolved "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz" - integrity sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A== +"acorn@^8.4.1", "acorn@^8.7.0": + "integrity" "sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A==" + "resolved" "https://registry.npmjs.org/acorn/-/acorn-8.7.1.tgz" + "version" "8.7.1" -agent-base@6, agent-base@^6.0.0, agent-base@^6.0.2: - version "6.0.2" - resolved "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz" - integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ== +"agent-base@^6.0.0", "agent-base@^6.0.2", "agent-base@6": + "integrity" "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==" + "resolved" "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz" + "version" "6.0.2" dependencies: - debug "4" + "debug" "4" -agentkeepalive@^4.1.3: - version "4.2.1" - resolved "https://registry.yarnpkg.com/agentkeepalive/-/agentkeepalive-4.2.1.tgz#a7975cbb9f83b367f06c90cc51ff28fe7d499717" - integrity sha512-Zn4cw2NEqd+9fiSVWMscnjyQ1a8Yfoc5oBajLeo5w+YBHgDUcEBY2hS4YpTz6iN5f/2zQiktcuM6tS8x1p9dpA== +"agentkeepalive@^4.1.3": + "integrity" "sha512-Zn4cw2NEqd+9fiSVWMscnjyQ1a8Yfoc5oBajLeo5w+YBHgDUcEBY2hS4YpTz6iN5f/2zQiktcuM6tS8x1p9dpA==" + "resolved" "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-4.2.1.tgz" + "version" "4.2.1" dependencies: - debug "^4.1.0" - depd "^1.1.2" - humanize-ms "^1.2.1" + "debug" "^4.1.0" + "depd" "^1.1.2" + "humanize-ms" "^1.2.1" -aggregate-error@^3.0.0: - version "3.1.0" - resolved "https://registry.yarnpkg.com/aggregate-error/-/aggregate-error-3.1.0.tgz#92670ff50f5359bdb7a3e0d40d0ec30c5737687a" - integrity sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA== +"aggregate-error@^3.0.0": + "integrity" "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==" + "resolved" "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz" + "version" "3.1.0" dependencies: - clean-stack "^2.0.0" - indent-string "^4.0.0" + "clean-stack" "^2.0.0" + "indent-string" "^4.0.0" -ajv-formats@^2.1.1: - version "2.1.1" - resolved "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz" - integrity sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA== +"ajv-formats@^2.1.1": + "integrity" "sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==" + "resolved" "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz" + "version" "2.1.1" dependencies: - ajv "^8.0.0" + "ajv" "^8.0.0" -ajv@^8.0.0, ajv@^8.11.0: - version "8.11.0" - resolved "https://registry.npmjs.org/ajv/-/ajv-8.11.0.tgz" - integrity sha512-wGgprdCvMalC0BztXvitD2hC04YffAvtsUn93JbGXYLAtCUO4xd17mCCZQxUOItiBwZvJScWo8NIvQMQ71rdpg== +"ajv@^8.0.0", "ajv@^8.6.2", "ajv@8.6.2": + "integrity" "sha512-9807RlWAgT564wT+DjeyU5OFMPjmzxVobvDFmNAhY+5zD6A2ly3jDp6sgnfyDtlIQ+7H97oc/DGCzzfu9rjw9w==" + "resolved" "https://registry.npmjs.org/ajv/-/ajv-8.6.2.tgz" + "version" "8.6.2" dependencies: - fast-deep-equal "^3.1.1" - json-schema-traverse "^1.0.0" - require-from-string "^2.0.2" - uri-js "^4.2.2" + "fast-deep-equal" "^3.1.1" + "json-schema-traverse" "^1.0.0" + "require-from-string" "^2.0.2" + "uri-js" "^4.2.2" -amqplib@^0.10.1: - version "0.10.1" - resolved "https://registry.npmjs.org/amqplib/-/amqplib-0.10.1.tgz" - integrity sha512-Hs33MdtFmJ2WKQT9SBtrlet3aUNzMzZA/FF6p3NGGo7Fp/BVD4X3Po7bQxAA7uE0MmXPZ8EschLMbN+CjGx4dg== +"amqplib@^0.10.0", "amqplib@^0.10.1": + "integrity" "sha512-Hs33MdtFmJ2WKQT9SBtrlet3aUNzMzZA/FF6p3NGGo7Fp/BVD4X3Po7bQxAA7uE0MmXPZ8EschLMbN+CjGx4dg==" + "resolved" "https://registry.npmjs.org/amqplib/-/amqplib-0.10.1.tgz" + "version" "0.10.1" dependencies: - bitsyntax "~0.1.0" - buffer-more-ints "~1.0.0" - readable-stream "1.x >=1.1.9" - url-parse "~1.5.10" + "bitsyntax" "~0.1.0" + "buffer-more-ints" "~1.0.0" + "readable-stream" "1.x >=1.1.9" + "url-parse" "~1.5.10" -ansi-escapes@^4.2.1: - version "4.3.2" - resolved "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz" - integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== +"ansi-escapes@^4.2.1": + "integrity" "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==" + "resolved" "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz" + "version" "4.3.2" dependencies: - type-fest "^0.21.3" + "type-fest" "^0.21.3" -ansi-regex@^5.0.1: - version "5.0.1" - resolved "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz" - integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== +"ansi-regex@^5.0.1": + "integrity" "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" + "resolved" "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz" + "version" "5.0.1" -ansi-styles@^3.2.1: - version "3.2.1" - resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz" - integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== +"ansi-styles@^3.2.1": + "integrity" "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==" + "resolved" "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz" + "version" "3.2.1" dependencies: - color-convert "^1.9.0" + "color-convert" "^1.9.0" -ansi-styles@^4.0.0, ansi-styles@^4.1.0: - version "4.3.0" - resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz" - integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== +"ansi-styles@^4.0.0": + "integrity" "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==" + "resolved" "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz" + "version" "4.3.0" dependencies: - color-convert "^2.0.1" + "color-convert" "^2.0.1" -ansi-styles@^5.0.0: - version "5.2.0" - resolved "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz" - integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== - -any-promise@^1.0.0: - version "1.3.0" - resolved "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz" - integrity sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A== - -anymatch@^3.0.3, anymatch@~3.1.2: - version "3.1.2" - resolved "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz" - integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== +"ansi-styles@^4.1.0": + "integrity" "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==" + "resolved" "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz" + "version" "4.3.0" dependencies: - normalize-path "^3.0.0" - picomatch "^2.0.4" + "color-convert" "^2.0.1" -app-root-path@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/app-root-path/-/app-root-path-3.0.0.tgz" - integrity sha512-qMcx+Gy2UZynHjOHOIXPNvpf+9cjvk3cWrBBK7zg4gH9+clobJRb9NGzcT7mQTcV/6Gm/1WelUtqxVXnNlrwcw== +"ansi-styles@^5.0.0": + "integrity" "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==" + "resolved" "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz" + "version" "5.2.0" -append-field@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz" - integrity sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw== +"any-promise@^1.0.0": + "integrity" "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==" + "resolved" "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz" + "version" "1.3.0" + +"anymatch@^3.0.3", "anymatch@~3.1.2": + "integrity" "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==" + "resolved" "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz" + "version" "3.1.2" + dependencies: + "normalize-path" "^3.0.0" + "picomatch" "^2.0.4" + +"app-root-path@^3.0.0": + "integrity" "sha512-qMcx+Gy2UZynHjOHOIXPNvpf+9cjvk3cWrBBK7zg4gH9+clobJRb9NGzcT7mQTcV/6Gm/1WelUtqxVXnNlrwcw==" + "resolved" "https://registry.npmjs.org/app-root-path/-/app-root-path-3.0.0.tgz" + "version" "3.0.0" + +"append-field@^1.0.0": + "integrity" "sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==" + "resolved" "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz" + "version" "1.0.0" "aproba@^1.0.3 || ^2.0.0": - version "2.0.0" - resolved "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz" - integrity sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ== + "integrity" "sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==" + "resolved" "https://registry.npmjs.org/aproba/-/aproba-2.0.0.tgz" + "version" "2.0.0" -are-we-there-yet@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz" - integrity sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw== +"are-we-there-yet@^2.0.0": + "integrity" "sha512-Ci/qENmwHnsYo9xKIcUJN5LeDKdJ6R1Z1j9V/J5wyq8nh/mYPEpIKJbBZXtZjG04HiK7zV/p6Vs9952MrMeUIw==" + "resolved" "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-2.0.0.tgz" + "version" "2.0.0" dependencies: - delegates "^1.0.0" - readable-stream "^3.6.0" + "delegates" "^1.0.0" + "readable-stream" "^3.6.0" -are-we-there-yet@^3.0.0: - version "3.0.1" - resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz#679df222b278c64f2cdba1175cdc00b0d96164bd" - integrity sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg== +"are-we-there-yet@^3.0.0": + "integrity" "sha512-QZW4EDmGwlYur0Yyf/b2uGucHQMa8aFUP7eu9ddR73vvhFyt4V0Vl3QHPcTNJ8l6qYOBdxgXdnBXQrHilfRQBg==" + "resolved" "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-3.0.1.tgz" + "version" "3.0.1" dependencies: - delegates "^1.0.0" - readable-stream "^3.6.0" + "delegates" "^1.0.0" + "readable-stream" "^3.6.0" -arg@^4.1.0: - version "4.1.3" - resolved "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz" - integrity sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA== +"arg@^4.1.0": + "integrity" "sha512-58S9QDqG0Xx27YwPSt9fJxivjYl432YCwfDMfZ+71RAqUrZef7LrKQZ3LHLOwCS4FLNBplP533Zx895SeOCHvA==" + "resolved" "https://registry.npmjs.org/arg/-/arg-4.1.3.tgz" + "version" "4.1.3" -argparse@^1.0.7: - version "1.0.10" - resolved "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz" - integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== +"argparse@^1.0.7": + "integrity" "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==" + "resolved" "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz" + "version" "1.0.10" dependencies: - sprintf-js "~1.0.2" + "sprintf-js" "~1.0.2" -argparse@^2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz" - integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== +"argparse@^2.0.1": + "integrity" "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" + "resolved" "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz" + "version" "2.0.1" -array-flatten@1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz" - integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== +"array-flatten@1.1.1": + "integrity" "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" + "resolved" "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz" + "version" "1.1.1" -asap@^2.0.0: - version "2.0.6" - resolved "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz" - integrity sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA== +"asap@^2.0.0": + "integrity" "sha512-BSHWgDSAiKs50o2Re8ppvp3seVHXSRM44cdSsT9FfNEUUZLOGWVCsiWaRPWM1Znn+mqZ1OfVZ3z3DWEzSp7hRA==" + "resolved" "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz" + "version" "2.0.6" -ast-types@^0.13.2: - version "0.13.4" - resolved "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz" - integrity sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w== +"ast-types@^0.13.2": + "integrity" "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==" + "resolved" "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz" + "version" "0.13.4" dependencies: - tslib "^2.0.1" + "tslib" "^2.0.1" -asynckit@^0.4.0: - version "0.4.0" - resolved "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz" - integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== +"asynckit@^0.4.0": + "integrity" "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" + "resolved" "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz" + "version" "0.4.0" -babel-jest@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/babel-jest/-/babel-jest-28.1.3.tgz" - integrity sha512-epUaPOEWMk3cWX0M/sPvCHHCe9fMFAa/9hXEgKP8nFfNl/jlGkE9ucq9NqkZGXLDduCJYS0UvSlPUwC0S+rH6Q== +"babel-jest@^28.1.3": + "integrity" "sha512-epUaPOEWMk3cWX0M/sPvCHHCe9fMFAa/9hXEgKP8nFfNl/jlGkE9ucq9NqkZGXLDduCJYS0UvSlPUwC0S+rH6Q==" + "resolved" "https://registry.npmjs.org/babel-jest/-/babel-jest-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/transform" "^28.1.3" "@types/babel__core" "^7.1.14" - babel-plugin-istanbul "^6.1.1" - babel-preset-jest "^28.1.3" - chalk "^4.0.0" - graceful-fs "^4.2.9" - slash "^3.0.0" + "babel-plugin-istanbul" "^6.1.1" + "babel-preset-jest" "^28.1.3" + "chalk" "^4.0.0" + "graceful-fs" "^4.2.9" + "slash" "^3.0.0" -babel-plugin-dynamic-import-node@^2.3.3: - version "2.3.3" - resolved "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz" - integrity sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ== +"babel-plugin-dynamic-import-node@^2.3.3": + "integrity" "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==" + "resolved" "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz" + "version" "2.3.3" dependencies: - object.assign "^4.1.0" + "object.assign" "^4.1.0" -babel-plugin-istanbul@^6.1.1: - version "6.1.1" - resolved "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz" - integrity sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA== +"babel-plugin-istanbul@^6.1.1": + "integrity" "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==" + "resolved" "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz" + "version" "6.1.1" dependencies: "@babel/helper-plugin-utils" "^7.0.0" "@istanbuljs/load-nyc-config" "^1.0.0" "@istanbuljs/schema" "^0.1.2" - istanbul-lib-instrument "^5.0.4" - test-exclude "^6.0.0" + "istanbul-lib-instrument" "^5.0.4" + "test-exclude" "^6.0.0" -babel-plugin-jest-hoist@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-28.1.3.tgz" - integrity sha512-Ys3tUKAmfnkRUpPdpa98eYrAR0nV+sSFUZZEGuQ2EbFd1y4SOLtD5QDNHAq+bb9a+bbXvYQC4b+ID/THIMcU6Q== +"babel-plugin-jest-hoist@^28.1.3": + "integrity" "sha512-Ys3tUKAmfnkRUpPdpa98eYrAR0nV+sSFUZZEGuQ2EbFd1y4SOLtD5QDNHAq+bb9a+bbXvYQC4b+ID/THIMcU6Q==" + "resolved" "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-28.1.3.tgz" + "version" "28.1.3" dependencies: "@babel/template" "^7.3.3" "@babel/types" "^7.3.3" "@types/babel__core" "^7.1.14" "@types/babel__traverse" "^7.0.6" -babel-plugin-polyfill-corejs2@^0.3.1: - version "0.3.1" - resolved "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.1.tgz" - integrity sha512-v7/T6EQcNfVLfcN2X8Lulb7DjprieyLWJK/zOWH5DUYcAgex9sP3h25Q+DLsX9TloXe3y1O8l2q2Jv9q8UVB9w== +"babel-plugin-polyfill-corejs2@^0.3.1": + "integrity" "sha512-v7/T6EQcNfVLfcN2X8Lulb7DjprieyLWJK/zOWH5DUYcAgex9sP3h25Q+DLsX9TloXe3y1O8l2q2Jv9q8UVB9w==" + "resolved" "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.1.tgz" + "version" "0.3.1" dependencies: "@babel/compat-data" "^7.13.11" "@babel/helper-define-polyfill-provider" "^0.3.1" - semver "^6.1.1" + "semver" "^6.1.1" -babel-plugin-polyfill-corejs3@^0.5.2: - version "0.5.2" - resolved "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.2.tgz" - integrity sha512-G3uJih0XWiID451fpeFaYGVuxHEjzKTHtc9uGFEjR6hHrvNzeS/PX+LLLcetJcytsB5m4j+K3o/EpXJNb/5IEQ== +"babel-plugin-polyfill-corejs3@^0.5.2": + "integrity" "sha512-G3uJih0XWiID451fpeFaYGVuxHEjzKTHtc9uGFEjR6hHrvNzeS/PX+LLLcetJcytsB5m4j+K3o/EpXJNb/5IEQ==" + "resolved" "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.5.2.tgz" + "version" "0.5.2" dependencies: "@babel/helper-define-polyfill-provider" "^0.3.1" - core-js-compat "^3.21.0" + "core-js-compat" "^3.21.0" -babel-plugin-polyfill-regenerator@^0.3.1: - version "0.3.1" - resolved "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz" - integrity sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A== +"babel-plugin-polyfill-regenerator@^0.3.1": + "integrity" "sha512-Y2B06tvgHYt1x0yz17jGkGeeMr5FeKUu+ASJ+N6nB5lQ8Dapfg42i0OVrf8PNGJ3zKL4A23snMi1IRwrqqND7A==" + "resolved" "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.3.1.tgz" + "version" "0.3.1" dependencies: "@babel/helper-define-polyfill-provider" "^0.3.1" -babel-preset-current-node-syntax@^1.0.0: - version "1.0.1" - resolved "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz" - integrity sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ== +"babel-preset-current-node-syntax@^1.0.0": + "integrity" "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==" + "resolved" "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz" + "version" "1.0.1" dependencies: "@babel/plugin-syntax-async-generators" "^7.8.4" "@babel/plugin-syntax-bigint" "^7.8.3" @@ -2768,1727 +2775,1778 @@ babel-preset-current-node-syntax@^1.0.0: "@babel/plugin-syntax-optional-chaining" "^7.8.3" "@babel/plugin-syntax-top-level-await" "^7.8.3" -babel-preset-jest@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-28.1.3.tgz" - integrity sha512-L+fupJvlWAHbQfn74coNX3zf60LXMJsezNvvx8eIh7iOR1luJ1poxYgQk1F8PYtNq/6QODDHCqsSnTFSWC491A== +"babel-preset-jest@^28.1.3": + "integrity" "sha512-L+fupJvlWAHbQfn74coNX3zf60LXMJsezNvvx8eIh7iOR1luJ1poxYgQk1F8PYtNq/6QODDHCqsSnTFSWC491A==" + "resolved" "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-28.1.3.tgz" + "version" "28.1.3" dependencies: - babel-plugin-jest-hoist "^28.1.3" - babel-preset-current-node-syntax "^1.0.0" + "babel-plugin-jest-hoist" "^28.1.3" + "babel-preset-current-node-syntax" "^1.0.0" -balanced-match@^1.0.0: - version "1.0.2" - resolved "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz" - integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== +"balanced-match@^1.0.0": + "integrity" "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" + "resolved" "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz" + "version" "1.0.2" -base64-js@^1.3.1: - version "1.5.1" - resolved "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz" - integrity sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA== +"base64-js@^1.3.1": + "integrity" "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==" + "resolved" "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz" + "version" "1.5.1" -basic-auth@~2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz" - integrity sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg== +"basic-auth@~2.0.1": + "integrity" "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==" + "resolved" "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz" + "version" "2.0.1" dependencies: - safe-buffer "5.1.2" + "safe-buffer" "5.1.2" -bcrypt@^5.0.1: - version "5.0.1" - resolved "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.1.tgz" - integrity sha512-9BTgmrhZM2t1bNuDtrtIMVSmmxZBrJ71n8Wg+YgdjHuIWYF7SjjmCPZFB+/5i/o/PIeRpwVJR3P+NrpIItUjqw== +"bcrypt@^5.0.1": + "integrity" "sha512-9BTgmrhZM2t1bNuDtrtIMVSmmxZBrJ71n8Wg+YgdjHuIWYF7SjjmCPZFB+/5i/o/PIeRpwVJR3P+NrpIItUjqw==" + "resolved" "https://registry.npmjs.org/bcrypt/-/bcrypt-5.0.1.tgz" + "version" "5.0.1" dependencies: "@mapbox/node-pre-gyp" "^1.0.0" - node-addon-api "^3.1.0" + "node-addon-api" "^3.1.0" -binary-extensions@^2.0.0: - version "2.2.0" - resolved "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz" - integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== +"binary-extensions@^2.0.0": + "integrity" "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==" + "resolved" "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz" + "version" "2.2.0" -bitsyntax@~0.1.0: - version "0.1.0" - resolved "https://registry.npmjs.org/bitsyntax/-/bitsyntax-0.1.0.tgz" - integrity sha512-ikAdCnrloKmFOugAfxWws89/fPc+nw0OOG1IzIE72uSOg/A3cYptKCjSUhDTuj7fhsJtzkzlv7l3b8PzRHLN0Q== +"bitsyntax@~0.1.0": + "integrity" "sha512-ikAdCnrloKmFOugAfxWws89/fPc+nw0OOG1IzIE72uSOg/A3cYptKCjSUhDTuj7fhsJtzkzlv7l3b8PzRHLN0Q==" + "resolved" "https://registry.npmjs.org/bitsyntax/-/bitsyntax-0.1.0.tgz" + "version" "0.1.0" dependencies: - buffer-more-ints "~1.0.0" - debug "~2.6.9" - safe-buffer "~5.1.2" + "buffer-more-ints" "~1.0.0" + "debug" "~2.6.9" + "safe-buffer" "~5.1.2" -body-parser@1.20.0, body-parser@^1.19.0: - version "1.20.0" - resolved "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz" - integrity sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg== +"bl@^2.2.1": + "integrity" "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==" + "resolved" "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz" + "version" "2.2.1" dependencies: - bytes "3.1.2" - content-type "~1.0.4" - debug "2.6.9" - depd "2.0.0" - destroy "1.2.0" - http-errors "2.0.0" - iconv-lite "0.4.24" - on-finished "2.4.1" - qs "6.10.3" - raw-body "2.5.1" - type-is "~1.6.18" - unpipe "1.0.0" + "readable-stream" "^2.3.5" + "safe-buffer" "^5.1.1" -boolbase@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz" - integrity sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww== - -bowser@^2.11.0: - version "2.11.0" - resolved "https://registry.npmjs.org/bowser/-/bowser-2.11.0.tgz" - integrity sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA== - -brace-expansion@^1.1.7: - version "1.1.11" - resolved "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz" - integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== +"body-parser@^1.19.0", "body-parser@1.20.0": + "integrity" "sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg==" + "resolved" "https://registry.npmjs.org/body-parser/-/body-parser-1.20.0.tgz" + "version" "1.20.0" dependencies: - balanced-match "^1.0.0" - concat-map "0.0.1" + "bytes" "3.1.2" + "content-type" "~1.0.4" + "debug" "2.6.9" + "depd" "2.0.0" + "destroy" "1.2.0" + "http-errors" "2.0.0" + "iconv-lite" "0.4.24" + "on-finished" "2.4.1" + "qs" "6.10.3" + "raw-body" "2.5.1" + "type-is" "~1.6.18" + "unpipe" "1.0.0" -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== +"boolbase@^1.0.0": + "integrity" "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==" + "resolved" "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz" + "version" "1.0.0" + +"bowser@^2.11.0": + "integrity" "sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA==" + "resolved" "https://registry.npmjs.org/bowser/-/bowser-2.11.0.tgz" + "version" "2.11.0" + +"brace-expansion@^1.1.7": + "integrity" "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==" + "resolved" "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz" + "version" "1.1.11" dependencies: - balanced-match "^1.0.0" + "balanced-match" "^1.0.0" + "concat-map" "0.0.1" -braces@^3.0.2, braces@~3.0.2: - version "3.0.2" - resolved "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz" - integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== +"brace-expansion@^2.0.1": + "integrity" "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==" + "resolved" "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz" + "version" "2.0.1" dependencies: - fill-range "^7.0.1" + "balanced-match" "^1.0.0" -browserslist@^4.20.2, browserslist@^4.21.1: - version "4.21.2" - resolved "https://registry.npmjs.org/browserslist/-/browserslist-4.21.2.tgz" - integrity sha512-MonuOgAtUB46uP5CezYbRaYKBNt2LxP0yX+Pmj4LkcDFGkn9Cbpi83d9sCjwQDErXsIJSzY5oKGDbgOlF/LPAA== +"braces@^3.0.2", "braces@~3.0.2": + "integrity" "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==" + "resolved" "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz" + "version" "3.0.2" dependencies: - caniuse-lite "^1.0.30001366" - electron-to-chromium "^1.4.188" - node-releases "^2.0.6" - update-browserslist-db "^1.0.4" + "fill-range" "^7.0.1" -bser@2.1.1: - version "2.1.1" - resolved "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz" - integrity sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ== +"browserslist@^4.20.2", "browserslist@^4.21.1", "browserslist@>= 4.21.0": + "integrity" "sha512-MonuOgAtUB46uP5CezYbRaYKBNt2LxP0yX+Pmj4LkcDFGkn9Cbpi83d9sCjwQDErXsIJSzY5oKGDbgOlF/LPAA==" + "resolved" "https://registry.npmjs.org/browserslist/-/browserslist-4.21.2.tgz" + "version" "4.21.2" dependencies: - node-int64 "^0.4.0" + "caniuse-lite" "^1.0.30001366" + "electron-to-chromium" "^1.4.188" + "node-releases" "^2.0.6" + "update-browserslist-db" "^1.0.4" -buffer-equal-constant-time@1.0.1: - version "1.0.1" - resolved "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz" - integrity sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA== - -buffer-from@^1.0.0: - version "1.1.2" - resolved "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz" - integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== - -buffer-more-ints@~1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/buffer-more-ints/-/buffer-more-ints-1.0.0.tgz" - integrity sha512-EMetuGFz5SLsT0QTnXzINh4Ksr+oo4i+UGTXEshiGCQWnsgSs7ZhJ8fzlwQ+OzEMs0MpDAMr1hxnblp5a4vcHg== - -buffer-writer@2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/buffer-writer/-/buffer-writer-2.0.0.tgz#ce7eb81a38f7829db09c873f2fbb792c0c98ec04" - integrity sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw== - -buffer@^6.0.3: - version "6.0.3" - resolved "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz" - integrity sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA== +"bser@2.1.1": + "integrity" "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==" + "resolved" "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz" + "version" "2.1.1" dependencies: - base64-js "^1.3.1" - ieee754 "^1.2.1" + "node-int64" "^0.4.0" -busboy@^1.0.0: - version "1.6.0" - resolved "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz" - integrity sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA== +"bson@^1.1.4": + "integrity" "sha512-EvVNVeGo4tHxwi8L6bPj3y3itEvStdwvvlojVxxbyYfoaxJ6keLgrTuKdyfEAszFK+H3olzBuafE0yoh0D1gdg==" + "resolved" "https://registry.npmjs.org/bson/-/bson-1.1.6.tgz" + "version" "1.1.6" + +"buffer-equal-constant-time@1.0.1": + "integrity" "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" + "resolved" "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz" + "version" "1.0.1" + +"buffer-from@^1.0.0": + "integrity" "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" + "resolved" "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz" + "version" "1.1.2" + +"buffer-more-ints@~1.0.0": + "integrity" "sha512-EMetuGFz5SLsT0QTnXzINh4Ksr+oo4i+UGTXEshiGCQWnsgSs7ZhJ8fzlwQ+OzEMs0MpDAMr1hxnblp5a4vcHg==" + "resolved" "https://registry.npmjs.org/buffer-more-ints/-/buffer-more-ints-1.0.0.tgz" + "version" "1.0.0" + +"buffer-writer@2.0.0": + "integrity" "sha512-a7ZpuTZU1TRtnwyCNW3I5dc0wWNC3VR9S++Ewyk2HHZdrO3CQJqSpd+95Us590V6AL7JqUAH2IwZ/398PmNFgw==" + "resolved" "https://registry.npmjs.org/buffer-writer/-/buffer-writer-2.0.0.tgz" + "version" "2.0.0" + +"buffer@^6.0.3": + "integrity" "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==" + "resolved" "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz" + "version" "6.0.3" dependencies: - streamsearch "^1.1.0" + "base64-js" "^1.3.1" + "ieee754" "^1.2.1" -bytes@3.1.2: - version "3.1.2" - resolved "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz" - integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== +"busboy@^1.0.0": + "integrity" "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==" + "resolved" "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz" + "version" "1.6.0" + dependencies: + "streamsearch" "^1.1.0" -cacache@^15.2.0: - version "15.3.0" - resolved "https://registry.yarnpkg.com/cacache/-/cacache-15.3.0.tgz#dc85380fb2f556fe3dda4c719bfa0ec875a7f1eb" - integrity sha512-VVdYzXEn+cnbXpFgWs5hTT7OScegHVmLhJIR8Ufqk3iFD6A6j5iSX1KuBTfNEv4tdJWE2PzA6IVFtcLC7fN9wQ== +"bytes@3.1.2": + "integrity" "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==" + "resolved" "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz" + "version" "3.1.2" + +"cacache@^15.2.0": + "integrity" "sha512-VVdYzXEn+cnbXpFgWs5hTT7OScegHVmLhJIR8Ufqk3iFD6A6j5iSX1KuBTfNEv4tdJWE2PzA6IVFtcLC7fN9wQ==" + "resolved" "https://registry.npmjs.org/cacache/-/cacache-15.3.0.tgz" + "version" "15.3.0" dependencies: "@npmcli/fs" "^1.0.0" "@npmcli/move-file" "^1.0.1" - chownr "^2.0.0" - fs-minipass "^2.0.0" - glob "^7.1.4" - infer-owner "^1.0.4" - lru-cache "^6.0.0" - minipass "^3.1.1" - minipass-collect "^1.0.2" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.2" - mkdirp "^1.0.3" - p-map "^4.0.0" - promise-inflight "^1.0.1" - rimraf "^3.0.2" - ssri "^8.0.1" - tar "^6.0.2" - unique-filename "^1.1.1" + "chownr" "^2.0.0" + "fs-minipass" "^2.0.0" + "glob" "^7.1.4" + "infer-owner" "^1.0.4" + "lru-cache" "^6.0.0" + "minipass" "^3.1.1" + "minipass-collect" "^1.0.2" + "minipass-flush" "^1.0.5" + "minipass-pipeline" "^1.2.2" + "mkdirp" "^1.0.3" + "p-map" "^4.0.0" + "promise-inflight" "^1.0.1" + "rimraf" "^3.0.2" + "ssri" "^8.0.1" + "tar" "^6.0.2" + "unique-filename" "^1.1.1" -call-bind@^1.0.0: - version "1.0.2" - resolved "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz" - integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== +"call-bind@^1.0.0": + "integrity" "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==" + "resolved" "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz" + "version" "1.0.2" dependencies: - function-bind "^1.1.1" - get-intrinsic "^1.0.2" + "function-bind" "^1.1.1" + "get-intrinsic" "^1.0.2" -callsites@^3.0.0: - version "3.1.0" - resolved "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz" - integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== +"callsites@^3.0.0": + "integrity" "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" + "resolved" "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz" + "version" "3.1.0" -camelcase@^5.3.1: - version "5.3.1" - resolved "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz" - integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== +"camelcase@^5.3.1": + "integrity" "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" + "resolved" "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz" + "version" "5.3.1" -camelcase@^6.2.0: - version "6.3.0" - resolved "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz" - integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== +"camelcase@^6.2.0": + "integrity" "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==" + "resolved" "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz" + "version" "6.3.0" -caniuse-lite@^1.0.30001366: - version "1.0.30001367" - resolved "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001367.tgz" - integrity sha512-XDgbeOHfifWV3GEES2B8rtsrADx4Jf+juKX2SICJcaUhjYBO3bR96kvEIHa15VU6ohtOhBZuPGGYGbXMRn0NCw== +"caniuse-lite@^1.0.30001366": + "integrity" "sha512-XDgbeOHfifWV3GEES2B8rtsrADx4Jf+juKX2SICJcaUhjYBO3bR96kvEIHa15VU6ohtOhBZuPGGYGbXMRn0NCw==" + "resolved" "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001367.tgz" + "version" "1.0.30001367" -canvas@^2.9.3: - version "2.9.3" - resolved "https://registry.npmjs.org/canvas/-/canvas-2.9.3.tgz" - integrity sha512-WOUM7ghii5TV2rbhaZkh1youv/vW1/Canev6Yx6BG2W+1S07w8jKZqKkPnbiPpQEDsnJdN8ouDd7OvQEGXDcUw== +"canvas@^2.9.3": + "integrity" "sha512-WOUM7ghii5TV2rbhaZkh1youv/vW1/Canev6Yx6BG2W+1S07w8jKZqKkPnbiPpQEDsnJdN8ouDd7OvQEGXDcUw==" + "resolved" "https://registry.npmjs.org/canvas/-/canvas-2.9.3.tgz" + "version" "2.9.3" dependencies: "@mapbox/node-pre-gyp" "^1.0.0" - nan "^2.15.0" - simple-get "^3.0.3" + "nan" "^2.15.0" + "simple-get" "^3.0.3" -chalk@^2.0.0, chalk@^2.4.2: - version "2.4.2" - resolved "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz" - integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== +"chalk@^2.0.0", "chalk@^2.4.2": + "integrity" "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==" + "resolved" "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz" + "version" "2.4.2" dependencies: - ansi-styles "^3.2.1" - escape-string-regexp "^1.0.5" - supports-color "^5.3.0" + "ansi-styles" "^3.2.1" + "escape-string-regexp" "^1.0.5" + "supports-color" "^5.3.0" -chalk@^4.0.0, chalk@^4.1.0, chalk@^4.1.1, chalk@^4.1.2: - version "4.1.2" - resolved "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" - integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== +"chalk@^4.0.0": + "integrity" "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==" + "resolved" "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" + "version" "4.1.2" dependencies: - ansi-styles "^4.1.0" - supports-color "^7.1.0" + "ansi-styles" "^4.1.0" + "supports-color" "^7.1.0" -char-regex@^1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz" - integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== - -cheerio-select@^2.1.0: - version "2.1.0" - resolved "https://registry.npmjs.org/cheerio-select/-/cheerio-select-2.1.0.tgz" - integrity sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g== +"chalk@^4.1.0": + "integrity" "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==" + "resolved" "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" + "version" "4.1.2" dependencies: - boolbase "^1.0.0" - css-select "^5.1.0" - css-what "^6.1.0" - domelementtype "^2.3.0" - domhandler "^5.0.3" - domutils "^3.0.1" + "ansi-styles" "^4.1.0" + "supports-color" "^7.1.0" -cheerio@^1.0.0-rc.10: - version "1.0.0-rc.12" - resolved "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.12.tgz" - integrity sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q== +"chalk@^4.1.1": + "integrity" "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==" + "resolved" "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" + "version" "4.1.2" dependencies: - cheerio-select "^2.1.0" - dom-serializer "^2.0.0" - domhandler "^5.0.3" - domutils "^3.0.1" - htmlparser2 "^8.0.1" - parse5 "^7.0.0" - parse5-htmlparser2-tree-adapter "^7.0.0" + "ansi-styles" "^4.1.0" + "supports-color" "^7.1.0" -chokidar@^3.5.1: - version "3.5.3" - resolved "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz" - integrity sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw== +"chalk@^4.1.2": + "integrity" "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==" + "resolved" "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz" + "version" "4.1.2" 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" + "ansi-styles" "^4.1.0" + "supports-color" "^7.1.0" + +"char-regex@^1.0.2": + "integrity" "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==" + "resolved" "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz" + "version" "1.0.2" + +"cheerio-select@^2.1.0": + "integrity" "sha512-9v9kG0LvzrlcungtnJtpGNxY+fzECQKhK4EGJX2vByejiMX84MFNQw4UxPJl3bFbTMw+Dfs37XaIkCwTZfLh4g==" + "resolved" "https://registry.npmjs.org/cheerio-select/-/cheerio-select-2.1.0.tgz" + "version" "2.1.0" + dependencies: + "boolbase" "^1.0.0" + "css-select" "^5.1.0" + "css-what" "^6.1.0" + "domelementtype" "^2.3.0" + "domhandler" "^5.0.3" + "domutils" "^3.0.1" + +"cheerio@^1.0.0-rc.10": + "integrity" "sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q==" + "resolved" "https://registry.npmjs.org/cheerio/-/cheerio-1.0.0-rc.12.tgz" + "version" "1.0.0-rc.12" + dependencies: + "cheerio-select" "^2.1.0" + "dom-serializer" "^2.0.0" + "domhandler" "^5.0.3" + "domutils" "^3.0.1" + "htmlparser2" "^8.0.1" + "parse5" "^7.0.0" + "parse5-htmlparser2-tree-adapter" "^7.0.0" + +"chokidar@^3.5.1": + "integrity" "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==" + "resolved" "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz" + "version" "3.5.3" + 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" + "fsevents" "~2.3.2" -chownr@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz" - integrity sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ== +"chownr@^2.0.0": + "integrity" "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==" + "resolved" "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz" + "version" "2.0.0" -ci-info@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz" - integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== +"ci-info@^2.0.0": + "integrity" "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" + "resolved" "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz" + "version" "2.0.0" -ci-info@^3.2.0: - version "3.3.2" - resolved "https://registry.npmjs.org/ci-info/-/ci-info-3.3.2.tgz" - integrity sha512-xmDt/QIAdeZ9+nfdPsaBCpMvHNLFiLdjj59qjqn+6iPe6YmHGQ35sBnQ8uslRBXFmXkiZQOJRjvQeoGppoTjjg== +"ci-info@^3.2.0": + "integrity" "sha512-xmDt/QIAdeZ9+nfdPsaBCpMvHNLFiLdjj59qjqn+6iPe6YmHGQ35sBnQ8uslRBXFmXkiZQOJRjvQeoGppoTjjg==" + "resolved" "https://registry.npmjs.org/ci-info/-/ci-info-3.3.2.tgz" + "version" "3.3.2" -cjs-module-lexer@^1.0.0: - version "1.2.2" - resolved "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz" - integrity sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA== +"cjs-module-lexer@^1.0.0": + "integrity" "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==" + "resolved" "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz" + "version" "1.2.2" -clean-stack@^2.0.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/clean-stack/-/clean-stack-2.2.0.tgz#ee8472dbb129e727b31e8a10a427dee9dfe4008b" - integrity sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A== +"clean-stack@^2.0.0": + "integrity" "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==" + "resolved" "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz" + "version" "2.2.0" -cli-highlight@^2.1.11: - version "2.1.11" - resolved "https://registry.npmjs.org/cli-highlight/-/cli-highlight-2.1.11.tgz" - integrity sha512-9KDcoEVwyUXrjcJNvHD0NFc/hiwe/WPVYIleQh2O1N2Zro5gWJZ/K+3DGn8w8P/F6FxOgzyC5bxDyHIgCSPhGg== +"cli-highlight@^2.1.11": + "integrity" "sha512-9KDcoEVwyUXrjcJNvHD0NFc/hiwe/WPVYIleQh2O1N2Zro5gWJZ/K+3DGn8w8P/F6FxOgzyC5bxDyHIgCSPhGg==" + "resolved" "https://registry.npmjs.org/cli-highlight/-/cli-highlight-2.1.11.tgz" + "version" "2.1.11" dependencies: - chalk "^4.0.0" - highlight.js "^10.7.1" - mz "^2.4.0" - parse5 "^5.1.1" - parse5-htmlparser2-tree-adapter "^6.0.0" - yargs "^16.0.0" + "chalk" "^4.0.0" + "highlight.js" "^10.7.1" + "mz" "^2.4.0" + "parse5" "^5.1.1" + "parse5-htmlparser2-tree-adapter" "^6.0.0" + "yargs" "^16.0.0" -cliui@^7.0.2: - version "7.0.4" - resolved "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz" - integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== +"cliui@^7.0.2": + "integrity" "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==" + "resolved" "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz" + "version" "7.0.4" dependencies: - string-width "^4.2.0" - strip-ansi "^6.0.0" - wrap-ansi "^7.0.0" + "string-width" "^4.2.0" + "strip-ansi" "^6.0.0" + "wrap-ansi" "^7.0.0" -co@^4.6.0: - version "4.6.0" - resolved "https://registry.npmjs.org/co/-/co-4.6.0.tgz" - integrity sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ== +"co@^4.6.0": + "integrity" "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==" + "resolved" "https://registry.npmjs.org/co/-/co-4.6.0.tgz" + "version" "4.6.0" -collect-v8-coverage@^1.0.0: - version "1.0.1" - resolved "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz" - integrity sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg== +"collect-v8-coverage@^1.0.0": + "integrity" "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==" + "resolved" "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz" + "version" "1.0.1" -color-convert@^1.9.0: - version "1.9.3" - resolved "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz" - integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== +"color-convert@^1.9.0": + "integrity" "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==" + "resolved" "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz" + "version" "1.9.3" dependencies: - color-name "1.1.3" + "color-name" "1.1.3" -color-convert@^2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz" - integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== +"color-convert@^2.0.1": + "integrity" "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==" + "resolved" "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz" + "version" "2.0.1" dependencies: - color-name "~1.1.4" + "color-name" "~1.1.4" -color-name@1.1.3: - version "1.1.3" - resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz" - integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== +"color-name@~1.1.4": + "integrity" "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" + "resolved" "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" + "version" "1.1.4" -color-name@~1.1.4: - version "1.1.4" - resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" - integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== +"color-name@1.1.3": + "integrity" "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" + "resolved" "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz" + "version" "1.1.3" -color-support@^1.1.2, color-support@^1.1.3: - version "1.1.3" - resolved "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz" - integrity sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg== +"color-support@^1.1.2", "color-support@^1.1.3": + "integrity" "sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==" + "resolved" "https://registry.npmjs.org/color-support/-/color-support-1.1.3.tgz" + "version" "1.1.3" -combined-stream@^1.0.8: - version "1.0.8" - resolved "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz" - integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== +"combined-stream@^1.0.8": + "integrity" "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==" + "resolved" "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz" + "version" "1.0.8" dependencies: - delayed-stream "~1.0.0" + "delayed-stream" "~1.0.0" -component-emitter@^1.3.0: - version "1.3.0" - resolved "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz" - integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== +"component-emitter@^1.3.0": + "integrity" "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" + "resolved" "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz" + "version" "1.3.0" -concat-map@0.0.1: - version "0.0.1" - resolved "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz" - integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== +"concat-map@0.0.1": + "integrity" "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" + "resolved" "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz" + "version" "0.0.1" -concat-stream@^1.5.2: - version "1.6.2" - resolved "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz" - integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== +"concat-stream@^1.5.2": + "integrity" "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==" + "resolved" "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz" + "version" "1.6.2" dependencies: - buffer-from "^1.0.0" - inherits "^2.0.3" - readable-stream "^2.2.2" - typedarray "^0.0.6" + "buffer-from" "^1.0.0" + "inherits" "^2.0.3" + "readable-stream" "^2.2.2" + "typedarray" "^0.0.6" -console-control-strings@^1.0.0, console-control-strings@^1.1.0: - version "1.1.0" - resolved "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz" - integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ== +"console-control-strings@^1.0.0", "console-control-strings@^1.1.0": + "integrity" "sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==" + "resolved" "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz" + "version" "1.1.0" -content-disposition@0.5.4: - version "0.5.4" - resolved "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz" - integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== +"content-disposition@0.5.4": + "integrity" "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==" + "resolved" "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz" + "version" "0.5.4" dependencies: - safe-buffer "5.2.1" + "safe-buffer" "5.2.1" -content-type@~1.0.4: - version "1.0.4" - resolved "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz" - integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== +"content-type@~1.0.4": + "integrity" "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" + "resolved" "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz" + "version" "1.0.4" -convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: - version "1.8.0" - resolved "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz" - integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA== +"convert-source-map@^1.4.0", "convert-source-map@^1.6.0", "convert-source-map@^1.7.0": + "integrity" "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==" + "resolved" "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz" + "version" "1.8.0" dependencies: - safe-buffer "~5.1.1" + "safe-buffer" "~5.1.1" -cookie-signature@1.0.6: - version "1.0.6" - resolved "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" - integrity sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ== +"cookie-signature@1.0.6": + "integrity" "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" + "resolved" "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz" + "version" "1.0.6" -cookie@0.5.0: - version "0.5.0" - resolved "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz" - integrity sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw== +"cookie@^0.4.1": + "integrity" "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==" + "resolved" "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz" + "version" "0.4.2" -cookie@^0.4.1: - version "0.4.2" - resolved "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz" - integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== +"cookie@0.5.0": + "integrity" "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==" + "resolved" "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz" + "version" "0.5.0" -cookiejar@^2.1.3: - version "2.1.3" - resolved "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.3.tgz" - integrity sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ== +"cookiejar@^2.1.3": + "integrity" "sha512-JxbCBUdrfr6AQjOXrxoTvAMJO4HBTUIlBzslcJPAz+/KT8yk53fXun51u+RenNYvad/+Vc2DIz5o9UxlCDymFQ==" + "resolved" "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.3.tgz" + "version" "2.1.3" -core-js-compat@^3.21.0, core-js-compat@^3.22.1: - version "3.23.4" - resolved "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.4.tgz" - integrity sha512-RkSRPe+JYEoflcsuxJWaiMPhnZoFS51FcIxm53k4KzhISCBTmaGlto9dTIrYuk0hnJc3G6pKufAKepHnBq6B6Q== +"core-js-compat@^3.21.0", "core-js-compat@^3.22.1": + "integrity" "sha512-RkSRPe+JYEoflcsuxJWaiMPhnZoFS51FcIxm53k4KzhISCBTmaGlto9dTIrYuk0hnJc3G6pKufAKepHnBq6B6Q==" + "resolved" "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.23.4.tgz" + "version" "3.23.4" dependencies: - browserslist "^4.21.1" - semver "7.0.0" + "browserslist" "^4.21.1" + "semver" "7.0.0" -core-util-is@~1.0.0: - version "1.0.3" - resolved "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz" - integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ== +"core-util-is@~1.0.0": + "integrity" "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" + "resolved" "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz" + "version" "1.0.3" -create-require@^1.1.0: - version "1.1.1" - resolved "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz" - integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== +"create-require@^1.1.0": + "integrity" "sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ==" + "resolved" "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz" + "version" "1.1.1" -cross-spawn@^6.0.5: - version "6.0.5" - resolved "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz" - integrity sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ== +"cross-spawn@^6.0.5": + "integrity" "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==" + "resolved" "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz" + "version" "6.0.5" dependencies: - nice-try "^1.0.4" - path-key "^2.0.1" - semver "^5.5.0" - shebang-command "^1.2.0" - which "^1.2.9" + "nice-try" "^1.0.4" + "path-key" "^2.0.1" + "semver" "^5.5.0" + "shebang-command" "^1.2.0" + "which" "^1.2.9" -cross-spawn@^7.0.3: - version "7.0.3" - resolved "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz" - integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== +"cross-spawn@^7.0.3": + "integrity" "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==" + "resolved" "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz" + "version" "7.0.3" dependencies: - path-key "^3.1.0" - shebang-command "^2.0.0" - which "^2.0.1" + "path-key" "^3.1.0" + "shebang-command" "^2.0.0" + "which" "^2.0.1" -css-select@^5.1.0: - version "5.1.0" - resolved "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz" - integrity sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg== +"css-select@^5.1.0": + "integrity" "sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==" + "resolved" "https://registry.npmjs.org/css-select/-/css-select-5.1.0.tgz" + "version" "5.1.0" dependencies: - boolbase "^1.0.0" - css-what "^6.1.0" - domhandler "^5.0.2" - domutils "^3.0.1" - nth-check "^2.0.1" + "boolbase" "^1.0.0" + "css-what" "^6.1.0" + "domhandler" "^5.0.2" + "domutils" "^3.0.1" + "nth-check" "^2.0.1" -css-what@^6.1.0: - version "6.1.0" - resolved "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz" - integrity sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw== +"css-what@^6.1.0": + "integrity" "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==" + "resolved" "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz" + "version" "6.1.0" -data-uri-to-buffer@3: - version "3.0.1" - resolved "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz" - integrity sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og== +"data-uri-to-buffer@3": + "integrity" "sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og==" + "resolved" "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz" + "version" "3.0.1" -date-fns@^2.28.0: - version "2.28.0" - resolved "https://registry.npmjs.org/date-fns/-/date-fns-2.28.0.tgz" - integrity sha512-8d35hViGYx/QH0icHYCeLmsLmMUheMmTyV9Fcm6gvNwdw31yXXH+O85sOBJ+OLnLQMKZowvpKb6FgMIQjcpvQw== +"date-fns@^2.28.0": + "integrity" "sha512-8d35hViGYx/QH0icHYCeLmsLmMUheMmTyV9Fcm6gvNwdw31yXXH+O85sOBJ+OLnLQMKZowvpKb6FgMIQjcpvQw==" + "resolved" "https://registry.npmjs.org/date-fns/-/date-fns-2.28.0.tgz" + "version" "2.28.0" -debug@2.6.9, debug@~2.6.9: - version "2.6.9" - resolved "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" - integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== +"debug@^4.1.0", "debug@^4.1.1", "debug@^4.3.3", "debug@^4.3.4", "debug@4": + "integrity" "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==" + "resolved" "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" + "version" "4.3.4" dependencies: - ms "2.0.0" + "ms" "2.1.2" -debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.3, debug@^4.3.4: - version "4.3.4" - resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" - integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== +"debug@~2.6.9": + "integrity" "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==" + "resolved" "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" + "version" "2.6.9" dependencies: - ms "2.1.2" + "ms" "2.0.0" -decompress-response@^4.2.0: - version "4.2.1" - resolved "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz" - integrity sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw== +"debug@2.6.9": + "integrity" "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==" + "resolved" "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz" + "version" "2.6.9" dependencies: - mimic-response "^2.0.0" + "ms" "2.0.0" -dedent@^0.7.0: - version "0.7.0" - resolved "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz" - integrity sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA== - -deep-is@~0.1.3: - version "0.1.4" - resolved "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz" - integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== - -deepmerge@^4.2.2: - version "4.2.2" - resolved "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz" - integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== - -define-properties@^1.1.3: - version "1.1.4" - resolved "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz" - integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== +"decompress-response@^4.2.0": + "integrity" "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==" + "resolved" "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz" + "version" "4.2.1" dependencies: - has-property-descriptors "^1.0.0" - object-keys "^1.1.1" + "mimic-response" "^2.0.0" -degenerator@^3.0.2: - version "3.0.2" - resolved "https://registry.npmjs.org/degenerator/-/degenerator-3.0.2.tgz" - integrity sha512-c0mef3SNQo56t6urUU6tdQAs+ThoD0o9B9MJ8HEt7NQcGEILCRFqQb7ZbP9JAv+QF1Ky5plydhMR/IrqWDm+TQ== +"dedent@^0.7.0": + "integrity" "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==" + "resolved" "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz" + "version" "0.7.0" + +"deep-is@~0.1.3": + "integrity" "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==" + "resolved" "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz" + "version" "0.1.4" + +"deepmerge@^4.2.2": + "integrity" "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==" + "resolved" "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz" + "version" "4.2.2" + +"define-properties@^1.1.3": + "integrity" "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==" + "resolved" "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz" + "version" "1.1.4" dependencies: - ast-types "^0.13.2" - escodegen "^1.8.1" - esprima "^4.0.0" - vm2 "^3.9.8" + "has-property-descriptors" "^1.0.0" + "object-keys" "^1.1.1" -delayed-stream@~1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz" - integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== - -delegates@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz" - integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ== - -denque@^2.0.1: - version "2.1.0" - resolved "https://registry.yarnpkg.com/denque/-/denque-2.1.0.tgz#e93e1a6569fb5e66f16a3c2a2964617d349d6ab1" - integrity sha512-HVQE3AAb/pxF8fQAoiqpvg9i3evqug3hoiwakOyZAwJm+6vZehbkYXZ0l4JxS+I3QxM97v5aaRNhj8v5oBhekw== - -depd@2.0.0, depd@~2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz" - integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== - -depd@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" - integrity sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ== - -destroy@1.2.0: - version "1.2.0" - resolved "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz" - integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== - -detect-libc@^2.0.0: - version "2.0.1" - resolved "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz" - integrity sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w== - -detect-newline@^3.0.0: - version "3.1.0" - resolved "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz" - integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA== - -dezalgo@1.0.3: - version "1.0.3" - resolved "https://registry.npmjs.org/dezalgo/-/dezalgo-1.0.3.tgz" - integrity sha512-K7i4zNfT2kgQz3GylDw40ot9GAE47sFZ9EXHFSPP6zONLgH6kWXE0KWJchkbQJLBkRazq4APwZ4OwiFFlT95OQ== +"degenerator@^3.0.2": + "integrity" "sha512-c0mef3SNQo56t6urUU6tdQAs+ThoD0o9B9MJ8HEt7NQcGEILCRFqQb7ZbP9JAv+QF1Ky5plydhMR/IrqWDm+TQ==" + "resolved" "https://registry.npmjs.org/degenerator/-/degenerator-3.0.2.tgz" + "version" "3.0.2" dependencies: - asap "^2.0.0" - wrappy "1" + "ast-types" "^0.13.2" + "escodegen" "^1.8.1" + "esprima" "^4.0.0" + "vm2" "^3.9.8" -diff-sequences@^28.1.1: - version "28.1.1" - resolved "https://registry.npmjs.org/diff-sequences/-/diff-sequences-28.1.1.tgz" - integrity sha512-FU0iFaH/E23a+a718l8Qa/19bF9p06kgE0KipMOMadwa3SjnaElKzPaUC0vnibs6/B/9ni97s61mcejk8W1fQw== +"delayed-stream@~1.0.0": + "integrity" "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==" + "resolved" "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz" + "version" "1.0.0" -diff@^4.0.1: - version "4.0.2" - resolved "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz" - integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== +"delegates@^1.0.0": + "integrity" "sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==" + "resolved" "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz" + "version" "1.0.0" -dom-serializer@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz" - integrity sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg== +"denque@^1.4.1": + "integrity" "sha512-XwE+iZ4D6ZUB7mfYRMb5wByE8L74HCn30FBN7sWnXksWc1LO1bPDl67pBR9o/kC4z/xSNAwkMYcGgqDV3BE3Hw==" + "resolved" "https://registry.npmjs.org/denque/-/denque-1.5.1.tgz" + "version" "1.5.1" + +"denque@^2.0.1": + "integrity" "sha512-HVQE3AAb/pxF8fQAoiqpvg9i3evqug3hoiwakOyZAwJm+6vZehbkYXZ0l4JxS+I3QxM97v5aaRNhj8v5oBhekw==" + "resolved" "https://registry.npmjs.org/denque/-/denque-2.1.0.tgz" + "version" "2.1.0" + +"depd@^1.1.2": + "integrity" "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==" + "resolved" "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz" + "version" "1.1.2" + +"depd@~2.0.0", "depd@2.0.0": + "integrity" "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==" + "resolved" "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz" + "version" "2.0.0" + +"destroy@1.2.0": + "integrity" "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==" + "resolved" "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz" + "version" "1.2.0" + +"detect-libc@^2.0.0": + "integrity" "sha512-463v3ZeIrcWtdgIg6vI6XUncguvr2TnGl4SzDXinkt9mSLpBJKXT3mW6xT3VQdDN11+WVs29pgvivTc4Lp8v+w==" + "resolved" "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.1.tgz" + "version" "2.0.1" + +"detect-newline@^3.0.0": + "integrity" "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==" + "resolved" "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz" + "version" "3.1.0" + +"dezalgo@1.0.3": + "integrity" "sha512-K7i4zNfT2kgQz3GylDw40ot9GAE47sFZ9EXHFSPP6zONLgH6kWXE0KWJchkbQJLBkRazq4APwZ4OwiFFlT95OQ==" + "resolved" "https://registry.npmjs.org/dezalgo/-/dezalgo-1.0.3.tgz" + "version" "1.0.3" dependencies: - domelementtype "^2.3.0" - domhandler "^5.0.2" - entities "^4.2.0" + "asap" "^2.0.0" + "wrappy" "1" -domelementtype@^2.3.0: - version "2.3.0" - resolved "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz" - integrity sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw== +"diff-sequences@^28.1.1": + "integrity" "sha512-FU0iFaH/E23a+a718l8Qa/19bF9p06kgE0KipMOMadwa3SjnaElKzPaUC0vnibs6/B/9ni97s61mcejk8W1fQw==" + "resolved" "https://registry.npmjs.org/diff-sequences/-/diff-sequences-28.1.1.tgz" + "version" "28.1.1" -domhandler@^5.0.1, domhandler@^5.0.2, domhandler@^5.0.3: - version "5.0.3" - resolved "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz" - integrity sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w== +"diff@^4.0.1": + "integrity" "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==" + "resolved" "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz" + "version" "4.0.2" + +"dom-serializer@^2.0.0": + "integrity" "sha512-wIkAryiqt/nV5EQKqQpo3SToSOV9J0DnbJqwK7Wv/Trc92zIAYZ4FlMu+JPFW1DfGFt81ZTCGgDEabffXeLyJg==" + "resolved" "https://registry.npmjs.org/dom-serializer/-/dom-serializer-2.0.0.tgz" + "version" "2.0.0" dependencies: - domelementtype "^2.3.0" + "domelementtype" "^2.3.0" + "domhandler" "^5.0.2" + "entities" "^4.2.0" -domutils@^3.0.1: - version "3.0.1" - resolved "https://registry.npmjs.org/domutils/-/domutils-3.0.1.tgz" - integrity sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q== +"domelementtype@^2.3.0": + "integrity" "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==" + "resolved" "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz" + "version" "2.3.0" + +"domhandler@^5.0.1", "domhandler@^5.0.2", "domhandler@^5.0.3": + "integrity" "sha512-cgwlv/1iFQiFnU96XXgROh8xTeetsnJiDsTc7TYCLFd9+/WNkIqPTxiM/8pSd8VIrhXGTf1Ny1q1hquVqDJB5w==" + "resolved" "https://registry.npmjs.org/domhandler/-/domhandler-5.0.3.tgz" + "version" "5.0.3" dependencies: - dom-serializer "^2.0.0" - domelementtype "^2.3.0" - domhandler "^5.0.1" + "domelementtype" "^2.3.0" -dotenv@*, dotenv@^16.0.0, dotenv@^16.0.1: - version "16.0.1" - resolved "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz" - integrity sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ== - -dynamic-dedupe@^0.3.0: - version "0.3.0" - resolved "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz" - integrity sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ== +"domutils@^3.0.1": + "integrity" "sha512-z08c1l761iKhDFtfXO04C7kTdPBLi41zwOZl00WS8b5eiaebNpY00HKbztwBq+e3vyqWNwWF3mP9YLUeqIrF+Q==" + "resolved" "https://registry.npmjs.org/domutils/-/domutils-3.0.1.tgz" + "version" "3.0.1" dependencies: - xtend "^4.0.0" + "dom-serializer" "^2.0.0" + "domelementtype" "^2.3.0" + "domhandler" "^5.0.1" -ecdsa-sig-formatter@1.0.11: - version "1.0.11" - resolved "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz" - integrity sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ== +"dotenv@*", "dotenv@^16.0.0", "dotenv@^16.0.1": + "integrity" "sha512-1K6hR6wtk2FviQ4kEiSjFiH5rpzEVi8WW0x96aztHVMhEspNpc4DVOUTEHtEva5VThQ8IaBX1Pe4gSzpVVUsKQ==" + "resolved" "https://registry.npmjs.org/dotenv/-/dotenv-16.0.1.tgz" + "version" "16.0.1" + +"dynamic-dedupe@^0.3.0": + "integrity" "sha512-ssuANeD+z97meYOqd50e04Ze5qp4bPqo8cCkI4TRjZkzAUgIDTrXV1R8QCdINpiI+hw14+rYazvTRdQrz0/rFQ==" + "resolved" "https://registry.npmjs.org/dynamic-dedupe/-/dynamic-dedupe-0.3.0.tgz" + "version" "0.3.0" dependencies: - safe-buffer "^5.0.1" + "xtend" "^4.0.0" -ee-first@1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" - integrity sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow== - -electron-to-chromium@^1.4.188: - version "1.4.192" - resolved "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.192.tgz" - integrity sha512-8nCXyIQY9An88NXAp+PuPy5h3/w5ZY7Iu2lag65Q0XREprcat5F8gKhoHsBUnQcFuCRnmevpR8yEBYRU3d2HDw== - -emittery@^0.10.2: - version "0.10.2" - resolved "https://registry.npmjs.org/emittery/-/emittery-0.10.2.tgz" - integrity sha512-aITqOwnLanpHLNXZJENbOgjUBeHocD+xsSJmNrjovKBW5HbSpW3d1pEls7GFQPUWXiwG9+0P4GtHfEqC/4M0Iw== - -emoji-regex@^8.0.0: - version "8.0.0" - resolved "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz" - integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== - -encodeurl@~1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz" - integrity sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w== - -encoding@^0.1.12: - version "0.1.13" - resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.13.tgz#56574afdd791f54a8e9b2785c0582a2d26210fa9" - integrity sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A== +"ecdsa-sig-formatter@1.0.11": + "integrity" "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==" + "resolved" "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz" + "version" "1.0.11" dependencies: - iconv-lite "^0.6.2" + "safe-buffer" "^5.0.1" -entities@2.2.0: - version "2.2.0" - resolved "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz" - integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A== +"ee-first@1.1.1": + "integrity" "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" + "resolved" "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" + "version" "1.1.1" -entities@^4.2.0, entities@^4.3.0: - version "4.3.1" - resolved "https://registry.npmjs.org/entities/-/entities-4.3.1.tgz" - integrity sha512-o4q/dYJlmyjP2zfnaWDUC6A3BQFmVTX+tZPezK7k0GLSU9QYCauscf5Y+qcEPzKL+EixVouYDgLQK5H9GrLpkg== +"electron-to-chromium@^1.4.188": + "integrity" "sha512-8nCXyIQY9An88NXAp+PuPy5h3/w5ZY7Iu2lag65Q0XREprcat5F8gKhoHsBUnQcFuCRnmevpR8yEBYRU3d2HDw==" + "resolved" "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.192.tgz" + "version" "1.4.192" -env-paths@^2.2.0: - version "2.2.1" - resolved "https://registry.yarnpkg.com/env-paths/-/env-paths-2.2.1.tgz#420399d416ce1fbe9bc0a07c62fa68d67fd0f8f2" - integrity sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A== +"emittery@^0.10.2": + "integrity" "sha512-aITqOwnLanpHLNXZJENbOgjUBeHocD+xsSJmNrjovKBW5HbSpW3d1pEls7GFQPUWXiwG9+0P4GtHfEqC/4M0Iw==" + "resolved" "https://registry.npmjs.org/emittery/-/emittery-0.10.2.tgz" + "version" "0.10.2" -err-code@^2.0.2: - version "2.0.3" - resolved "https://registry.yarnpkg.com/err-code/-/err-code-2.0.3.tgz#23c2f3b756ffdfc608d30e27c9a941024807e7f9" - integrity sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA== +"emoji-regex@^8.0.0": + "integrity" "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" + "resolved" "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz" + "version" "8.0.0" -error-ex@^1.3.1: - version "1.3.2" - resolved "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz" - integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== +"encodeurl@~1.0.2": + "integrity" "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==" + "resolved" "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz" + "version" "1.0.2" + +"encoding@^0.1.0", "encoding@^0.1.12": + "integrity" "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==" + "resolved" "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz" + "version" "0.1.13" dependencies: - is-arrayish "^0.2.1" + "iconv-lite" "^0.6.2" -escalade@^3.1.1: - version "3.1.1" - resolved "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz" - integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw== +"entities@^4.2.0": + "integrity" "sha512-o4q/dYJlmyjP2zfnaWDUC6A3BQFmVTX+tZPezK7k0GLSU9QYCauscf5Y+qcEPzKL+EixVouYDgLQK5H9GrLpkg==" + "resolved" "https://registry.npmjs.org/entities/-/entities-4.3.1.tgz" + "version" "4.3.1" -escape-html@~1.0.3: - version "1.0.3" - resolved "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz" - integrity sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow== +"entities@^4.3.0": + "integrity" "sha512-o4q/dYJlmyjP2zfnaWDUC6A3BQFmVTX+tZPezK7k0GLSU9QYCauscf5Y+qcEPzKL+EixVouYDgLQK5H9GrLpkg==" + "resolved" "https://registry.npmjs.org/entities/-/entities-4.3.1.tgz" + "version" "4.3.1" -escape-string-regexp@^1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz" - integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== +"entities@2.2.0": + "integrity" "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==" + "resolved" "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz" + "version" "2.2.0" -escape-string-regexp@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz" - integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== +"env-paths@^2.2.0": + "integrity" "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==" + "resolved" "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz" + "version" "2.2.1" -escodegen@^1.8.1: - version "1.14.3" - resolved "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz" - integrity sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw== +"err-code@^2.0.2": + "integrity" "sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==" + "resolved" "https://registry.npmjs.org/err-code/-/err-code-2.0.3.tgz" + "version" "2.0.3" + +"error-ex@^1.3.1": + "integrity" "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==" + "resolved" "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz" + "version" "1.3.2" dependencies: - esprima "^4.0.1" - estraverse "^4.2.0" - esutils "^2.0.2" - optionator "^0.8.1" + "is-arrayish" "^0.2.1" + +"escalade@^3.1.1": + "integrity" "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==" + "resolved" "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz" + "version" "3.1.1" + +"escape-html@~1.0.3": + "integrity" "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" + "resolved" "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz" + "version" "1.0.3" + +"escape-string-regexp@^1.0.5": + "integrity" "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==" + "resolved" "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz" + "version" "1.0.5" + +"escape-string-regexp@^2.0.0": + "integrity" "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==" + "resolved" "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz" + "version" "2.0.0" + +"escodegen@^1.8.1": + "integrity" "sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==" + "resolved" "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz" + "version" "1.14.3" + dependencies: + "esprima" "^4.0.1" + "estraverse" "^4.2.0" + "esutils" "^2.0.2" + "optionator" "^0.8.1" optionalDependencies: - source-map "~0.6.1" + "source-map" "~0.6.1" -esprima@^4.0.0, esprima@^4.0.1: - version "4.0.1" - resolved "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz" - integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== +"esprima@^4.0.0", "esprima@^4.0.1": + "integrity" "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" + "resolved" "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz" + "version" "4.0.1" -estraverse@^4.2.0: - version "4.3.0" - resolved "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz" - integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw== +"estraverse@^4.2.0": + "integrity" "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==" + "resolved" "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz" + "version" "4.3.0" -esutils@^2.0.2: - version "2.0.3" - resolved "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz" - integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== +"esutils@^2.0.2": + "integrity" "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" + "resolved" "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz" + "version" "2.0.3" -etag@~1.8.1: - version "1.8.1" - resolved "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz" - integrity sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg== +"etag@~1.8.1": + "integrity" "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==" + "resolved" "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz" + "version" "1.8.1" -execa@^5.0.0: - version "5.1.1" - resolved "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz" - integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== +"execa@^5.0.0": + "integrity" "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==" + "resolved" "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz" + "version" "5.1.1" dependencies: - cross-spawn "^7.0.3" - get-stream "^6.0.0" - human-signals "^2.1.0" - is-stream "^2.0.0" - merge-stream "^2.0.0" - npm-run-path "^4.0.1" - onetime "^5.1.2" - signal-exit "^3.0.3" - strip-final-newline "^2.0.0" + "cross-spawn" "^7.0.3" + "get-stream" "^6.0.0" + "human-signals" "^2.1.0" + "is-stream" "^2.0.0" + "merge-stream" "^2.0.0" + "npm-run-path" "^4.0.1" + "onetime" "^5.1.2" + "signal-exit" "^3.0.3" + "strip-final-newline" "^2.0.0" -exif-be-gone@^1.3.0: - version "1.3.0" - resolved "https://registry.npmjs.org/exif-be-gone/-/exif-be-gone-1.3.0.tgz" - integrity sha512-6s/SnuWviwtP6TB3Gc2Nc2GIWYCIs3N9V4Md773EWIfC4uOR+O3thZXO4ElbJJOvjtDNR4FVoMVNKgZWRKiQNQ== +"exif-be-gone@^1.3.0", "exif-be-gone@^1.3.1": + "integrity" "sha512-lHvNqbaTsH0WzhzfxxiTh9KwmXjAfiiTfY6UVmUZXJsaU62ccURy8beEVYFKSmNfvf0n6srLIFi0NDBWvhYUlQ==" + "resolved" "https://registry.npmjs.org/exif-be-gone/-/exif-be-gone-1.3.1.tgz" + "version" "1.3.1" dependencies: "@types/stream-buffers" "^3.0.3" -exit@^0.1.2: - version "0.1.2" - resolved "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz" - integrity sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ== +"exit@^0.1.2": + "integrity" "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==" + "resolved" "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz" + "version" "0.1.2" -expect@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/expect/-/expect-28.1.3.tgz" - integrity sha512-eEh0xn8HlsuOBxFgIss+2mX85VAS4Qy3OSkjV7rlBWljtA4oWH37glVGyOZSZvErDT/yBywZdPGwCXuTvSG85g== +"expect@^28.1.3": + "integrity" "sha512-eEh0xn8HlsuOBxFgIss+2mX85VAS4Qy3OSkjV7rlBWljtA4oWH37glVGyOZSZvErDT/yBywZdPGwCXuTvSG85g==" + "resolved" "https://registry.npmjs.org/expect/-/expect-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/expect-utils" "^28.1.3" - jest-get-type "^28.0.2" - jest-matcher-utils "^28.1.3" - jest-message-util "^28.1.3" - jest-util "^28.1.3" + "jest-get-type" "^28.0.2" + "jest-matcher-utils" "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-util" "^28.1.3" -express-async-errors@^3.1.1: - version "3.1.1" - resolved "https://registry.npmjs.org/express-async-errors/-/express-async-errors-3.1.1.tgz" - integrity sha512-h6aK1da4tpqWSbyCa3FxB/V6Ehd4EEB15zyQq9qe75OZBp0krinNKuH4rAY+S/U/2I36vdLAUFSjQJ+TFmODng== +"express-async-errors@^3.1.1": + "integrity" "sha512-h6aK1da4tpqWSbyCa3FxB/V6Ehd4EEB15zyQq9qe75OZBp0krinNKuH4rAY+S/U/2I36vdLAUFSjQJ+TFmODng==" + "resolved" "https://registry.npmjs.org/express-async-errors/-/express-async-errors-3.1.1.tgz" + "version" "3.1.1" -express@^4.17.1: - version "4.18.1" - resolved "https://registry.npmjs.org/express/-/express-4.18.1.tgz" - integrity sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q== +"express@^4.16.2", "express@^4.17.1": + "integrity" "sha512-zZBcOX9TfehHQhtupq57OF8lFZ3UZi08Y97dwFCkD8p9d/d2Y3M+ykKcwaMDEL+4qyUolgBDX6AblpR3fL212Q==" + "resolved" "https://registry.npmjs.org/express/-/express-4.18.1.tgz" + "version" "4.18.1" dependencies: - accepts "~1.3.8" - array-flatten "1.1.1" - body-parser "1.20.0" - content-disposition "0.5.4" - content-type "~1.0.4" - cookie "0.5.0" - cookie-signature "1.0.6" - debug "2.6.9" - depd "2.0.0" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - finalhandler "1.2.0" - fresh "0.5.2" - http-errors "2.0.0" - merge-descriptors "1.0.1" - methods "~1.1.2" - on-finished "2.4.1" - parseurl "~1.3.3" - path-to-regexp "0.1.7" - proxy-addr "~2.0.7" - qs "6.10.3" - range-parser "~1.2.1" - safe-buffer "5.2.1" - send "0.18.0" - serve-static "1.15.0" - setprototypeof "1.2.0" - statuses "2.0.1" - type-is "~1.6.18" - utils-merge "1.0.1" - vary "~1.1.2" + "accepts" "~1.3.8" + "array-flatten" "1.1.1" + "body-parser" "1.20.0" + "content-disposition" "0.5.4" + "content-type" "~1.0.4" + "cookie" "0.5.0" + "cookie-signature" "1.0.6" + "debug" "2.6.9" + "depd" "2.0.0" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "etag" "~1.8.1" + "finalhandler" "1.2.0" + "fresh" "0.5.2" + "http-errors" "2.0.0" + "merge-descriptors" "1.0.1" + "methods" "~1.1.2" + "on-finished" "2.4.1" + "parseurl" "~1.3.3" + "path-to-regexp" "0.1.7" + "proxy-addr" "~2.0.7" + "qs" "6.10.3" + "range-parser" "~1.2.1" + "safe-buffer" "5.2.1" + "send" "0.18.0" + "serve-static" "1.15.0" + "setprototypeof" "1.2.0" + "statuses" "2.0.1" + "type-is" "~1.6.18" + "utils-merge" "1.0.1" + "vary" "~1.1.2" -fast-deep-equal@^3.1.1: - version "3.1.3" - resolved "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz" - integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== +"fast-deep-equal@^3.1.1": + "integrity" "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" + "resolved" "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz" + "version" "3.1.3" -fast-json-stable-stringify@^2.0.0: - version "2.1.0" - resolved "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz" - integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== +"fast-json-stable-stringify@^2.0.0": + "integrity" "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" + "resolved" "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz" + "version" "2.1.0" -fast-levenshtein@~2.0.6: - version "2.0.6" - resolved "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz" - integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== +"fast-levenshtein@~2.0.6": + "integrity" "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==" + "resolved" "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz" + "version" "2.0.6" -fast-safe-stringify@^2.1.1: - version "2.1.1" - resolved "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz" - integrity sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA== +"fast-safe-stringify@^2.1.1": + "integrity" "sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA==" + "resolved" "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz" + "version" "2.1.1" -fast-xml-parser@3.19.0: - version "3.19.0" - resolved "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-3.19.0.tgz" - integrity sha512-4pXwmBplsCPv8FOY1WRakF970TjNGnGnfbOnLqjlYvMiF1SR3yOHyxMR/YCXpPTOspNF5gwudqktIP4VsWkvBg== +"fast-xml-parser@3.19.0": + "integrity" "sha512-4pXwmBplsCPv8FOY1WRakF970TjNGnGnfbOnLqjlYvMiF1SR3yOHyxMR/YCXpPTOspNF5gwudqktIP4VsWkvBg==" + "resolved" "https://registry.npmjs.org/fast-xml-parser/-/fast-xml-parser-3.19.0.tgz" + "version" "3.19.0" -fb-watchman@^2.0.0: - version "2.0.1" - resolved "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz" - integrity sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg== +"fb-watchman@^2.0.0": + "integrity" "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==" + "resolved" "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz" + "version" "2.0.1" dependencies: - bser "2.1.1" + "bser" "2.1.1" -file-type@16.5: - version "16.5.4" - resolved "https://registry.npmjs.org/file-type/-/file-type-16.5.4.tgz" - integrity sha512-/yFHK0aGjFEgDJjEKP0pWCplsPFPhwyfwevf/pVxiN0tmE4L9LmwWxWukdJSHdoCli4VgQLehjJtwQBnqmsKcw== +"file-type@16.5": + "integrity" "sha512-/yFHK0aGjFEgDJjEKP0pWCplsPFPhwyfwevf/pVxiN0tmE4L9LmwWxWukdJSHdoCli4VgQLehjJtwQBnqmsKcw==" + "resolved" "https://registry.npmjs.org/file-type/-/file-type-16.5.4.tgz" + "version" "16.5.4" dependencies: - readable-web-to-node-stream "^3.0.0" - strtok3 "^6.2.4" - token-types "^4.1.1" + "readable-web-to-node-stream" "^3.0.0" + "strtok3" "^6.2.4" + "token-types" "^4.1.1" -file-uri-to-path@2: - version "2.0.0" - resolved "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz" - integrity sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg== +"file-uri-to-path@2": + "integrity" "sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg==" + "resolved" "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz" + "version" "2.0.0" -fill-range@^7.0.1: - version "7.0.1" - resolved "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz" - integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== +"fill-range@^7.0.1": + "integrity" "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==" + "resolved" "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz" + "version" "7.0.1" dependencies: - to-regex-range "^5.0.1" + "to-regex-range" "^5.0.1" -finalhandler@1.2.0: - version "1.2.0" - resolved "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz" - integrity sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg== +"finalhandler@1.2.0": + "integrity" "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==" + "resolved" "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz" + "version" "1.2.0" dependencies: - debug "2.6.9" - encodeurl "~1.0.2" - escape-html "~1.0.3" - on-finished "2.4.1" - parseurl "~1.3.3" - statuses "2.0.1" - unpipe "~1.0.0" + "debug" "2.6.9" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "on-finished" "2.4.1" + "parseurl" "~1.3.3" + "statuses" "2.0.1" + "unpipe" "~1.0.0" -find-up@^4.0.0, find-up@^4.1.0: - version "4.1.0" - resolved "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz" - integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== +"find-up@^4.0.0", "find-up@^4.1.0": + "integrity" "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==" + "resolved" "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz" + "version" "4.1.0" dependencies: - locate-path "^5.0.0" - path-exists "^4.0.0" + "locate-path" "^5.0.0" + "path-exists" "^4.0.0" -find-yarn-workspace-root@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/find-yarn-workspace-root/-/find-yarn-workspace-root-2.0.0.tgz" - integrity sha512-1IMnbjt4KzsQfnhnzNd8wUEgXZ44IzZaZmnLYx7D5FZlaHt2gW20Cri8Q+E/t5tIj4+epTBub+2Zxu/vNILzqQ== +"find-yarn-workspace-root@^2.0.0": + "integrity" "sha512-1IMnbjt4KzsQfnhnzNd8wUEgXZ44IzZaZmnLYx7D5FZlaHt2gW20Cri8Q+E/t5tIj4+epTBub+2Zxu/vNILzqQ==" + "resolved" "https://registry.npmjs.org/find-yarn-workspace-root/-/find-yarn-workspace-root-2.0.0.tgz" + "version" "2.0.0" dependencies: - micromatch "^4.0.2" + "micromatch" "^4.0.2" -form-data@^3.0.0: - version "3.0.1" - resolved "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz" - integrity sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg== +"form-data@^3.0.0": + "integrity" "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==" + "resolved" "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz" + "version" "3.0.1" dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.8" - mime-types "^2.1.12" + "asynckit" "^0.4.0" + "combined-stream" "^1.0.8" + "mime-types" "^2.1.12" -form-data@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz" - integrity sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww== +"form-data@^4.0.0": + "integrity" "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==" + "resolved" "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz" + "version" "4.0.0" dependencies: - asynckit "^0.4.0" - combined-stream "^1.0.8" - mime-types "^2.1.12" + "asynckit" "^0.4.0" + "combined-stream" "^1.0.8" + "mime-types" "^2.1.12" -formidable@^2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/formidable/-/formidable-2.0.1.tgz" - integrity sha512-rjTMNbp2BpfQShhFbR3Ruk3qk2y9jKpvMW78nJgx8QKtxjDVrwbZG+wvDOmVbifHyOUOQJXxqEy6r0faRrPzTQ== +"formidable@^2.0.1": + "integrity" "sha512-rjTMNbp2BpfQShhFbR3Ruk3qk2y9jKpvMW78nJgx8QKtxjDVrwbZG+wvDOmVbifHyOUOQJXxqEy6r0faRrPzTQ==" + "resolved" "https://registry.npmjs.org/formidable/-/formidable-2.0.1.tgz" + "version" "2.0.1" dependencies: - dezalgo "1.0.3" - hexoid "1.0.0" - once "1.4.0" - qs "6.9.3" + "dezalgo" "1.0.3" + "hexoid" "1.0.0" + "once" "1.4.0" + "qs" "6.9.3" -forwarded@0.2.0: - version "0.2.0" - resolved "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz" - integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== +"forwarded@0.2.0": + "integrity" "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" + "resolved" "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz" + "version" "0.2.0" -fresh@0.5.2: - version "0.5.2" - resolved "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz" - integrity sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q== +"fresh@0.5.2": + "integrity" "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==" + "resolved" "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz" + "version" "0.5.2" -fs-extra@^7.0.1: - version "7.0.1" - resolved "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz" - integrity sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw== +"fs-extra@^7.0.1": + "integrity" "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==" + "resolved" "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz" + "version" "7.0.1" dependencies: - graceful-fs "^4.1.2" - jsonfile "^4.0.0" - universalify "^0.1.0" + "graceful-fs" "^4.1.2" + "jsonfile" "^4.0.0" + "universalify" "^0.1.0" -fs-extra@^8.1.0: - version "8.1.0" - resolved "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz" - integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g== +"fs-extra@^8.1.0": + "integrity" "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==" + "resolved" "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz" + "version" "8.1.0" dependencies: - graceful-fs "^4.2.0" - jsonfile "^4.0.0" - universalify "^0.1.0" + "graceful-fs" "^4.2.0" + "jsonfile" "^4.0.0" + "universalify" "^0.1.0" -fs-minipass@^2.0.0: - version "2.1.0" - resolved "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz" - integrity sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg== +"fs-minipass@^2.0.0": + "integrity" "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==" + "resolved" "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz" + "version" "2.1.0" dependencies: - minipass "^3.0.0" + "minipass" "^3.0.0" -fs.realpath@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz" - integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== +"fs.realpath@^1.0.0": + "integrity" "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" + "resolved" "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz" + "version" "1.0.0" -fsevents@^2.3.2, 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== - -ftp@^0.3.10: - version "0.3.10" - resolved "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz" - integrity sha512-faFVML1aBx2UoDStmLwv2Wptt4vw5x03xxX172nhA5Y5HBshW5JweqQ2W4xL4dezQTG8inJsuYcpPHHU3X5OTQ== +"ftp@^0.3.10": + "integrity" "sha512-faFVML1aBx2UoDStmLwv2Wptt4vw5x03xxX172nhA5Y5HBshW5JweqQ2W4xL4dezQTG8inJsuYcpPHHU3X5OTQ==" + "resolved" "https://registry.npmjs.org/ftp/-/ftp-0.3.10.tgz" + "version" "0.3.10" dependencies: - readable-stream "1.1.x" - xregexp "2.0.0" + "readable-stream" "1.1.x" + "xregexp" "2.0.0" -function-bind@^1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz" - integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== +"function-bind@^1.1.1": + "integrity" "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + "resolved" "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz" + "version" "1.1.1" -gauge@^3.0.0: - version "3.0.2" - resolved "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz" - integrity sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q== +"gauge@^3.0.0": + "integrity" "sha512-+5J6MS/5XksCuXq++uFRsnUd7Ovu1XenbeuIuNRJxYWjgQbPuFhT14lAvsWfqfAmnwluf1OwMjz39HjfLPci0Q==" + "resolved" "https://registry.npmjs.org/gauge/-/gauge-3.0.2.tgz" + "version" "3.0.2" dependencies: - aproba "^1.0.3 || ^2.0.0" - color-support "^1.1.2" - console-control-strings "^1.0.0" - has-unicode "^2.0.1" - object-assign "^4.1.1" - signal-exit "^3.0.0" - string-width "^4.2.3" - strip-ansi "^6.0.1" - wide-align "^1.1.2" + "aproba" "^1.0.3 || ^2.0.0" + "color-support" "^1.1.2" + "console-control-strings" "^1.0.0" + "has-unicode" "^2.0.1" + "object-assign" "^4.1.1" + "signal-exit" "^3.0.0" + "string-width" "^4.2.3" + "strip-ansi" "^6.0.1" + "wide-align" "^1.1.2" -gauge@^4.0.3: - version "4.0.4" - resolved "https://registry.yarnpkg.com/gauge/-/gauge-4.0.4.tgz#52ff0652f2bbf607a989793d53b751bef2328dce" - integrity sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg== +"gauge@^4.0.3": + "integrity" "sha512-f9m+BEN5jkg6a0fZjleidjN51VE1X+mPFQ2DJ0uv1V39oCLCbsGe6yjbBnp7eK7z/+GAon99a3nHuqbuuthyPg==" + "resolved" "https://registry.npmjs.org/gauge/-/gauge-4.0.4.tgz" + "version" "4.0.4" dependencies: - aproba "^1.0.3 || ^2.0.0" - color-support "^1.1.3" - console-control-strings "^1.1.0" - has-unicode "^2.0.1" - signal-exit "^3.0.7" - string-width "^4.2.3" - strip-ansi "^6.0.1" - wide-align "^1.1.5" + "aproba" "^1.0.3 || ^2.0.0" + "color-support" "^1.1.3" + "console-control-strings" "^1.1.0" + "has-unicode" "^2.0.1" + "signal-exit" "^3.0.7" + "string-width" "^4.2.3" + "strip-ansi" "^6.0.1" + "wide-align" "^1.1.5" -generate-function@^2.3.1: - version "2.3.1" - resolved "https://registry.yarnpkg.com/generate-function/-/generate-function-2.3.1.tgz#f069617690c10c868e73b8465746764f97c3479f" - integrity sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ== +"generate-function@^2.3.1": + "integrity" "sha512-eeB5GfMNeevm/GRYq20ShmsaGcmI81kIX2K9XQx5miC8KdHaC6Jm0qQ8ZNeGOi7wYB8OsdxKs+Y2oVuTFuVwKQ==" + "resolved" "https://registry.npmjs.org/generate-function/-/generate-function-2.3.1.tgz" + "version" "2.3.1" dependencies: - is-property "^1.0.2" + "is-property" "^1.0.2" -gensync@^1.0.0-beta.2: - version "1.0.0-beta.2" - resolved "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz" - integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg== +"gensync@^1.0.0-beta.2": + "integrity" "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==" + "resolved" "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz" + "version" "1.0.0-beta.2" -get-caller-file@^2.0.5: - version "2.0.5" - resolved "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz" - integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== +"get-caller-file@^2.0.5": + "integrity" "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" + "resolved" "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz" + "version" "2.0.5" -get-intrinsic@^1.0.2, get-intrinsic@^1.1.1: - version "1.1.2" - resolved "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz" - integrity sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA== +"get-intrinsic@^1.0.2", "get-intrinsic@^1.1.1": + "integrity" "sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA==" + "resolved" "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.2.tgz" + "version" "1.1.2" dependencies: - function-bind "^1.1.1" - has "^1.0.3" - has-symbols "^1.0.3" + "function-bind" "^1.1.1" + "has" "^1.0.3" + "has-symbols" "^1.0.3" -get-package-type@^0.1.0: - version "0.1.0" - resolved "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz" - integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== +"get-package-type@^0.1.0": + "integrity" "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==" + "resolved" "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz" + "version" "0.1.0" -get-stream@^6.0.0: - version "6.0.1" - resolved "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz" - integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== +"get-stream@^6.0.0": + "integrity" "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==" + "resolved" "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz" + "version" "6.0.1" -get-uri@3: - version "3.0.2" - resolved "https://registry.npmjs.org/get-uri/-/get-uri-3.0.2.tgz" - integrity sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg== +"get-uri@3": + "integrity" "sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg==" + "resolved" "https://registry.npmjs.org/get-uri/-/get-uri-3.0.2.tgz" + "version" "3.0.2" dependencies: "@tootallnate/once" "1" - data-uri-to-buffer "3" - debug "4" - file-uri-to-path "2" - fs-extra "^8.1.0" - ftp "^0.3.10" + "data-uri-to-buffer" "3" + "debug" "4" + "file-uri-to-path" "2" + "fs-extra" "^8.1.0" + "ftp" "^0.3.10" -glob-parent@~5.1.2: - version "5.1.2" - resolved "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz" - integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== +"glob-parent@~5.1.2": + "integrity" "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==" + "resolved" "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz" + "version" "5.1.2" dependencies: - is-glob "^4.0.1" + "is-glob" "^4.0.1" -glob@^7.0.0, glob@^7.1.3, glob@^7.1.4, glob@^7.1.7, glob@^7.2.0: - version "7.2.3" - resolved "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz" - integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== +"glob@^7.0.0", "glob@^7.1.3", "glob@^7.1.4", "glob@^7.1.7", "glob@^7.2.0": + "integrity" "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==" + "resolved" "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz" + "version" "7.2.3" 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" + "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" -glob@^8.0.3: - version "8.0.3" - resolved "https://registry.yarnpkg.com/glob/-/glob-8.0.3.tgz#415c6eb2deed9e502c68fa44a272e6da6eeca42e" - integrity sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ== +"glob@^8.0.3": + "integrity" "sha512-ull455NHSHI/Y1FqGaaYFaLGkNMMJbavMrEGFXG/PGrg6y7sutWHUHrz6gy6WEBH6akM1M414dWKCNs+IhKdiQ==" + "resolved" "https://registry.npmjs.org/glob/-/glob-8.0.3.tgz" + "version" "8.0.3" dependencies: - fs.realpath "^1.0.0" - inflight "^1.0.4" - inherits "2" - minimatch "^5.0.1" - once "^1.3.0" + "fs.realpath" "^1.0.0" + "inflight" "^1.0.4" + "inherits" "2" + "minimatch" "^5.0.1" + "once" "^1.3.0" -global-prefix@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz" - integrity sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg== +"global-prefix@^3.0.0": + "integrity" "sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==" + "resolved" "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz" + "version" "3.0.0" dependencies: - ini "^1.3.5" - kind-of "^6.0.2" - which "^1.3.1" + "ini" "^1.3.5" + "kind-of" "^6.0.2" + "which" "^1.3.1" -globals@^11.1.0: - version "11.12.0" - resolved "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz" - integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== +"globals@^11.1.0": + "integrity" "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" + "resolved" "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz" + "version" "11.12.0" -graceful-fs@^4.1.11, graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.6, graceful-fs@^4.2.9: - version "4.2.10" - resolved "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz" - integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== +"graceful-fs@^4.1.11", "graceful-fs@^4.1.2", "graceful-fs@^4.1.6", "graceful-fs@^4.2.0", "graceful-fs@^4.2.6", "graceful-fs@^4.2.9": + "integrity" "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==" + "resolved" "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz" + "version" "4.2.10" -has-flag@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz" - integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== +"has-flag@^3.0.0": + "integrity" "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==" + "resolved" "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz" + "version" "3.0.0" -has-flag@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz" - integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== +"has-flag@^4.0.0": + "integrity" "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" + "resolved" "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz" + "version" "4.0.0" -has-property-descriptors@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz" - integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== +"has-property-descriptors@^1.0.0": + "integrity" "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==" + "resolved" "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz" + "version" "1.0.0" dependencies: - get-intrinsic "^1.1.1" + "get-intrinsic" "^1.1.1" -has-symbols@^1.0.1, has-symbols@^1.0.3: - version "1.0.3" - resolved "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz" - integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== +"has-symbols@^1.0.1", "has-symbols@^1.0.3": + "integrity" "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==" + "resolved" "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz" + "version" "1.0.3" -has-unicode@^2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz" - integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ== +"has-unicode@^2.0.1": + "integrity" "sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==" + "resolved" "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz" + "version" "2.0.1" -has@^1.0.3: - version "1.0.3" - resolved "https://registry.npmjs.org/has/-/has-1.0.3.tgz" - integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== +"has@^1.0.3": + "integrity" "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==" + "resolved" "https://registry.npmjs.org/has/-/has-1.0.3.tgz" + "version" "1.0.3" dependencies: - function-bind "^1.1.1" + "function-bind" "^1.1.1" -helmet@^4.4.1: - version "4.6.0" - resolved "https://registry.npmjs.org/helmet/-/helmet-4.6.0.tgz" - integrity sha512-HVqALKZlR95ROkrnesdhbbZJFi/rIVSoNq6f3jA/9u6MIbTsPh3xZwihjeI5+DO/2sOV6HMHooXcEOuwskHpTg== +"helmet@^4.4.1": + "integrity" "sha512-HVqALKZlR95ROkrnesdhbbZJFi/rIVSoNq6f3jA/9u6MIbTsPh3xZwihjeI5+DO/2sOV6HMHooXcEOuwskHpTg==" + "resolved" "https://registry.npmjs.org/helmet/-/helmet-4.6.0.tgz" + "version" "4.6.0" -hexoid@1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/hexoid/-/hexoid-1.0.0.tgz" - integrity sha512-QFLV0taWQOZtvIRIAdBChesmogZrtuXvVWsFHZTk2SU+anspqZ2vMnoLg7IE1+Uk16N19APic1BuF8bC8c2m5g== +"hexoid@1.0.0": + "integrity" "sha512-QFLV0taWQOZtvIRIAdBChesmogZrtuXvVWsFHZTk2SU+anspqZ2vMnoLg7IE1+Uk16N19APic1BuF8bC8c2m5g==" + "resolved" "https://registry.npmjs.org/hexoid/-/hexoid-1.0.0.tgz" + "version" "1.0.0" -highlight.js@^10.7.1: - version "10.7.3" - resolved "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz" - integrity sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A== +"highlight.js@^10.7.1": + "integrity" "sha512-tzcUFauisWKNHaRkN4Wjl/ZA07gENAjFl3J/c480dprkGTg5EQstgaNFqBfUqCq54kZRIEcreTsAgF/m2quD7A==" + "resolved" "https://registry.npmjs.org/highlight.js/-/highlight.js-10.7.3.tgz" + "version" "10.7.3" -html-escaper@^2.0.0: - version "2.0.2" - resolved "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz" - integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== +"html-escaper@^2.0.0": + "integrity" "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==" + "resolved" "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz" + "version" "2.0.2" -htmlparser2@^8.0.1: - version "8.0.1" - resolved "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.1.tgz" - integrity sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA== +"htmlparser2@^8.0.1": + "integrity" "sha512-4lVbmc1diZC7GUJQtRQ5yBAeUCL1exyMwmForWkRLnwyzWBFxN633SALPMGYaWZvKe9j1pRZJpauvmxENSp/EA==" + "resolved" "https://registry.npmjs.org/htmlparser2/-/htmlparser2-8.0.1.tgz" + "version" "8.0.1" dependencies: - domelementtype "^2.3.0" - domhandler "^5.0.2" - domutils "^3.0.1" - entities "^4.3.0" + "domelementtype" "^2.3.0" + "domhandler" "^5.0.2" + "domutils" "^3.0.1" + "entities" "^4.3.0" -http-cache-semantics@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" - integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== +"http-cache-semantics@^4.1.0": + "integrity" "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" + "resolved" "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz" + "version" "4.1.0" -http-errors@2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz" - integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== +"http-errors@2.0.0": + "integrity" "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==" + "resolved" "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz" + "version" "2.0.0" dependencies: - depd "2.0.0" - inherits "2.0.4" - setprototypeof "1.2.0" - statuses "2.0.1" - toidentifier "1.0.1" + "depd" "2.0.0" + "inherits" "2.0.4" + "setprototypeof" "1.2.0" + "statuses" "2.0.1" + "toidentifier" "1.0.1" -http-proxy-agent@^4.0.0, http-proxy-agent@^4.0.1: - version "4.0.1" - resolved "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz" - integrity sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg== +"http-proxy-agent@^4.0.0", "http-proxy-agent@^4.0.1": + "integrity" "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==" + "resolved" "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz" + "version" "4.0.1" dependencies: "@tootallnate/once" "1" - agent-base "6" - debug "4" + "agent-base" "6" + "debug" "4" -https-proxy-agent@5, https-proxy-agent@^5.0.0: - version "5.0.1" - resolved "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz" - integrity sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA== +"https-proxy-agent@^5.0.0", "https-proxy-agent@5": + "integrity" "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==" + "resolved" "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz" + "version" "5.0.1" dependencies: - agent-base "6" - debug "4" + "agent-base" "6" + "debug" "4" -human-signals@^2.1.0: - version "2.1.0" - resolved "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz" - integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== +"human-signals@^2.1.0": + "integrity" "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==" + "resolved" "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz" + "version" "2.1.0" -humanize-ms@^1.2.1: - version "1.2.1" - resolved "https://registry.yarnpkg.com/humanize-ms/-/humanize-ms-1.2.1.tgz#c46e3159a293f6b896da29316d8b6fe8bb79bbed" - integrity sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ== +"humanize-ms@^1.2.1": + "integrity" "sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==" + "resolved" "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz" + "version" "1.2.1" dependencies: - ms "^2.0.0" + "ms" "^2.0.0" -i18next-http-middleware@^3.1.3: - version "3.2.1" - resolved "https://registry.npmjs.org/i18next-http-middleware/-/i18next-http-middleware-3.2.1.tgz" - integrity sha512-zBwXxDChT0YLoTXIR6jRuqnUUhXW0Iw7egoTnNXyaDRtTbfWNXwU0a53ThyuRPQ+k+tXu3ZMNKRzfLuononaRw== +"i18next-http-middleware@^3.1.3": + "integrity" "sha512-zBwXxDChT0YLoTXIR6jRuqnUUhXW0Iw7egoTnNXyaDRtTbfWNXwU0a53ThyuRPQ+k+tXu3ZMNKRzfLuononaRw==" + "resolved" "https://registry.npmjs.org/i18next-http-middleware/-/i18next-http-middleware-3.2.1.tgz" + "version" "3.2.1" -i18next-node-fs-backend@^2.1.3: - version "2.1.3" - resolved "https://registry.npmjs.org/i18next-node-fs-backend/-/i18next-node-fs-backend-2.1.3.tgz" - integrity sha512-CreMFiVl3ChlMc5ys/e0QfuLFOZyFcL40Jj6jaKD6DxZ/GCUMxPI9BpU43QMWUgC7r+PClpxg2cGXAl0CjG04g== +"i18next-node-fs-backend@^2.1.3": + "integrity" "sha512-CreMFiVl3ChlMc5ys/e0QfuLFOZyFcL40Jj6jaKD6DxZ/GCUMxPI9BpU43QMWUgC7r+PClpxg2cGXAl0CjG04g==" + "resolved" "https://registry.npmjs.org/i18next-node-fs-backend/-/i18next-node-fs-backend-2.1.3.tgz" + "version" "2.1.3" dependencies: - js-yaml "3.13.1" - json5 "2.0.0" + "js-yaml" "3.13.1" + "json5" "2.0.0" -i18next@>=17.0.11, i18next@^21.8.14: - version "21.8.14" - resolved "https://registry.npmjs.org/i18next/-/i18next-21.8.14.tgz" - integrity sha512-4Yi+DtexvMm/Yw3Q9fllzY12SgLk+Mcmar+rCAccsOPul/2UmnBzoHbTGn/L48IPkFcmrNaH7xTLboBWIbH6pw== +"i18next@^21.8.14", "i18next@^21.9.0", "i18next@>=17.0.11": + "integrity" "sha512-B+6/yd7rCpJidyPuBaEApUECx7G8Ai6+tqYhrChsY4MmQqJhG7qJ4eT6Lm1OnRhieVelEtfxh4aAQktdNVZtDA==" + "resolved" "https://registry.npmjs.org/i18next/-/i18next-21.9.0.tgz" + "version" "21.9.0" dependencies: "@babel/runtime" "^7.17.2" -iconv-lite@0.4.24: - version "0.4.24" - resolved "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz" - integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== +"iconv-lite@^0.6.2": + "integrity" "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==" + "resolved" "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz" + "version" "0.6.3" dependencies: - safer-buffer ">= 2.1.2 < 3" + "safer-buffer" ">= 2.1.2 < 3.0.0" -iconv-lite@^0.6.2, iconv-lite@^0.6.3: - version "0.6.3" - resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501" - integrity sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw== +"iconv-lite@^0.6.3": + "integrity" "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==" + "resolved" "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz" + "version" "0.6.3" dependencies: - safer-buffer ">= 2.1.2 < 3.0.0" + "safer-buffer" ">= 2.1.2 < 3.0.0" -ieee754@^1.2.1: - version "1.2.1" - resolved "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz" - integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== - -image-size@^1.0.0: - version "1.0.2" - resolved "https://registry.npmjs.org/image-size/-/image-size-1.0.2.tgz" - integrity sha512-xfOoWjceHntRb3qFCrh5ZFORYH8XCdYpASltMhZ/Q0KZiOwjdE/Yl2QCiWdwD+lygV5bMCvauzgu5PxBX/Yerg== +"iconv-lite@0.4.24": + "integrity" "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==" + "resolved" "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz" + "version" "0.4.24" dependencies: - queue "6.0.2" + "safer-buffer" ">= 2.1.2 < 3" -import-local@^3.0.2: - version "3.1.0" - resolved "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz" - integrity sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg== +"ieee754@^1.2.1": + "integrity" "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==" + "resolved" "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz" + "version" "1.2.1" + +"image-size@^1.0.0": + "integrity" "sha512-xfOoWjceHntRb3qFCrh5ZFORYH8XCdYpASltMhZ/Q0KZiOwjdE/Yl2QCiWdwD+lygV5bMCvauzgu5PxBX/Yerg==" + "resolved" "https://registry.npmjs.org/image-size/-/image-size-1.0.2.tgz" + "version" "1.0.2" dependencies: - pkg-dir "^4.2.0" - resolve-cwd "^3.0.0" + "queue" "6.0.2" -imurmurhash@^0.1.4: - version "0.1.4" - resolved "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz" - integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== - -indent-string@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/indent-string/-/indent-string-4.0.0.tgz#624f8f4497d619b2d9768531d58f4122854d7251" - integrity sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg== - -infer-owner@^1.0.4: - version "1.0.4" - resolved "https://registry.yarnpkg.com/infer-owner/-/infer-owner-1.0.4.tgz#c4cefcaa8e51051c2a40ba2ce8a3d27295af9467" - integrity sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A== - -inflight@^1.0.4: - version "1.0.6" - resolved "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz" - integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== +"import-local@^3.0.2": + "integrity" "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==" + "resolved" "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz" + "version" "3.1.0" dependencies: - once "^1.3.0" - wrappy "1" + "pkg-dir" "^4.2.0" + "resolve-cwd" "^3.0.0" -inherits@2, inherits@2.0.4, inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3: - version "2.0.4" - resolved "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz" - integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== +"imurmurhash@^0.1.4": + "integrity" "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==" + "resolved" "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz" + "version" "0.1.4" -ini@^1.3.5: - version "1.3.8" - resolved "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz" - integrity sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew== +"indent-string@^4.0.0": + "integrity" "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==" + "resolved" "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz" + "version" "4.0.0" -interpret@^1.0.0: - version "1.4.0" - resolved "https://registry.npmjs.org/interpret/-/interpret-1.4.0.tgz" - integrity sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA== +"infer-owner@^1.0.4": + "integrity" "sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==" + "resolved" "https://registry.npmjs.org/infer-owner/-/infer-owner-1.0.4.tgz" + "version" "1.0.4" -ip@^1.1.5: - version "1.1.8" - resolved "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz" - integrity sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg== - -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.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz" - integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== - -is-arrayish@^0.2.1: - version "0.2.1" - resolved "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz" - integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== - -is-binary-path@~2.1.0: - version "2.1.0" - resolved "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz" - integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== +"inflight@^1.0.4": + "integrity" "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==" + "resolved" "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz" + "version" "1.0.6" dependencies: - binary-extensions "^2.0.0" + "once" "^1.3.0" + "wrappy" "1" -is-ci@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz" - integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== +"inherits@^2.0.1", "inherits@^2.0.3", "inherits@~2.0.1", "inherits@~2.0.3", "inherits@2", "inherits@2.0.4": + "integrity" "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + "resolved" "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz" + "version" "2.0.4" + +"ini@^1.3.5": + "integrity" "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==" + "resolved" "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz" + "version" "1.3.8" + +"interpret@^1.0.0": + "integrity" "sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA==" + "resolved" "https://registry.npmjs.org/interpret/-/interpret-1.4.0.tgz" + "version" "1.4.0" + +"ip@^1.1.5": + "integrity" "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg==" + "resolved" "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz" + "version" "1.1.8" + +"ipaddr.js@1.9.1": + "integrity" "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" + "resolved" "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz" + "version" "1.9.1" + +"is-arrayish@^0.2.1": + "integrity" "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==" + "resolved" "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz" + "version" "0.2.1" + +"is-binary-path@~2.1.0": + "integrity" "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==" + "resolved" "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz" + "version" "2.1.0" dependencies: - ci-info "^2.0.0" + "binary-extensions" "^2.0.0" -is-core-module@^2.9.0: - version "2.9.0" - resolved "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz" - integrity sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A== +"is-ci@^2.0.0": + "integrity" "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==" + "resolved" "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz" + "version" "2.0.0" dependencies: - has "^1.0.3" + "ci-info" "^2.0.0" -is-docker@^2.0.0: - version "2.2.1" - resolved "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz" - integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ== - -is-extglob@^2.1.1: - version "2.1.1" - resolved "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz" - integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== - -is-fullwidth-code-point@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz" - integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== - -is-generator-fn@^2.0.0: - version "2.1.0" - resolved "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz" - integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== - -is-glob@^4.0.1, is-glob@~4.0.1: - version "4.0.3" - resolved "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz" - integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== +"is-core-module@^2.9.0": + "integrity" "sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A==" + "resolved" "https://registry.npmjs.org/is-core-module/-/is-core-module-2.9.0.tgz" + "version" "2.9.0" dependencies: - is-extglob "^2.1.1" + "has" "^1.0.3" -is-lambda@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/is-lambda/-/is-lambda-1.0.1.tgz#3d9877899e6a53efc0160504cde15f82e6f061d5" - integrity sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ== +"is-docker@^2.0.0": + "integrity" "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==" + "resolved" "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz" + "version" "2.2.1" -is-number@^7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz" - integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== +"is-extglob@^2.1.1": + "integrity" "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==" + "resolved" "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz" + "version" "2.1.1" -is-property@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/is-property/-/is-property-1.0.2.tgz#57fe1c4e48474edd65b09911f26b1cd4095dda84" - integrity sha512-Ks/IoX00TtClbGQr4TWXemAnktAQvYB7HzcCxDGqEZU6oCmb2INHuOoKxbtR+HFkmYWBKv/dOZtGRiAjDhj92g== +"is-fullwidth-code-point@^3.0.0": + "integrity" "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" + "resolved" "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz" + "version" "3.0.0" -is-stream@^2.0.0: - version "2.0.1" - resolved "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz" - integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== +"is-generator-fn@^2.0.0": + "integrity" "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==" + "resolved" "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz" + "version" "2.1.0" -is-wsl@^2.1.1: - version "2.2.0" - resolved "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz" - integrity sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww== +"is-glob@^4.0.1", "is-glob@~4.0.1": + "integrity" "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==" + "resolved" "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz" + "version" "4.0.3" dependencies: - is-docker "^2.0.0" + "is-extglob" "^2.1.1" -isarray@0.0.1: - version "0.0.1" - resolved "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz" - integrity sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ== +"is-lambda@^1.0.1": + "integrity" "sha512-z7CMFGNrENq5iFB9Bqo64Xk6Y9sg+epq1myIcdHaGnbMTYOxvzsEtdYqQUylB7LxfkvgrrjP32T6Ywciio9UIQ==" + "resolved" "https://registry.npmjs.org/is-lambda/-/is-lambda-1.0.1.tgz" + "version" "1.0.1" -isarray@~1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz" - integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ== +"is-number@^7.0.0": + "integrity" "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" + "resolved" "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz" + "version" "7.0.0" -isexe@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz" - integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== +"is-property@^1.0.2": + "integrity" "sha512-Ks/IoX00TtClbGQr4TWXemAnktAQvYB7HzcCxDGqEZU6oCmb2INHuOoKxbtR+HFkmYWBKv/dOZtGRiAjDhj92g==" + "resolved" "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz" + "version" "1.0.2" -istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: - version "3.2.0" - resolved "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz" - integrity sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw== +"is-stream@^2.0.0": + "integrity" "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==" + "resolved" "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz" + "version" "2.0.1" -istanbul-lib-instrument@^5.0.4, istanbul-lib-instrument@^5.1.0: - version "5.2.0" - resolved "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.0.tgz" - integrity sha512-6Lthe1hqXHBNsqvgDzGO6l03XNeu3CrG4RqQ1KM9+l5+jNGpEJfIELx1NS3SEHmJQA8np/u+E4EPRKRiu6m19A== +"is-wsl@^2.1.1": + "integrity" "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==" + "resolved" "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz" + "version" "2.2.0" + dependencies: + "is-docker" "^2.0.0" + +"isarray@~1.0.0": + "integrity" "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" + "resolved" "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz" + "version" "1.0.0" + +"isarray@0.0.1": + "integrity" "sha512-D2S+3GLxWH+uhrNEcoh/fnmYeP8E8/zHl644d/jdA0g2uyXvy3sb0qxotE+ne0LtccHknQzWwZEzhak7oJ0COQ==" + "resolved" "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz" + "version" "0.0.1" + +"isexe@^2.0.0": + "integrity" "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==" + "resolved" "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz" + "version" "2.0.0" + +"istanbul-lib-coverage@^3.0.0", "istanbul-lib-coverage@^3.2.0": + "integrity" "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==" + "resolved" "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz" + "version" "3.2.0" + +"istanbul-lib-instrument@^5.0.4", "istanbul-lib-instrument@^5.1.0": + "integrity" "sha512-6Lthe1hqXHBNsqvgDzGO6l03XNeu3CrG4RqQ1KM9+l5+jNGpEJfIELx1NS3SEHmJQA8np/u+E4EPRKRiu6m19A==" + "resolved" "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.0.tgz" + "version" "5.2.0" dependencies: "@babel/core" "^7.12.3" "@babel/parser" "^7.14.7" "@istanbuljs/schema" "^0.1.2" - istanbul-lib-coverage "^3.2.0" - semver "^6.3.0" + "istanbul-lib-coverage" "^3.2.0" + "semver" "^6.3.0" -istanbul-lib-report@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz" - integrity sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw== +"istanbul-lib-report@^3.0.0": + "integrity" "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==" + "resolved" "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz" + "version" "3.0.0" dependencies: - istanbul-lib-coverage "^3.0.0" - make-dir "^3.0.0" - supports-color "^7.1.0" + "istanbul-lib-coverage" "^3.0.0" + "make-dir" "^3.0.0" + "supports-color" "^7.1.0" -istanbul-lib-source-maps@^4.0.0: - version "4.0.1" - resolved "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz" - integrity sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw== +"istanbul-lib-source-maps@^4.0.0": + "integrity" "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==" + "resolved" "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz" + "version" "4.0.1" dependencies: - debug "^4.1.1" - istanbul-lib-coverage "^3.0.0" - source-map "^0.6.1" + "debug" "^4.1.1" + "istanbul-lib-coverage" "^3.0.0" + "source-map" "^0.6.1" -istanbul-reports@^3.1.3: - version "3.1.5" - resolved "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz" - integrity sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w== +"istanbul-reports@^3.1.3": + "integrity" "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==" + "resolved" "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz" + "version" "3.1.5" dependencies: - html-escaper "^2.0.0" - istanbul-lib-report "^3.0.0" + "html-escaper" "^2.0.0" + "istanbul-lib-report" "^3.0.0" -jest-changed-files@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-28.1.3.tgz" - integrity sha512-esaOfUWJXk2nfZt9SPyC8gA1kNfdKLkQWyzsMlqq8msYSlNKfmZxfRgZn4Cd4MGVUF+7v6dBs0d5TOAKa7iIiA== +"jest-changed-files@^28.1.3": + "integrity" "sha512-esaOfUWJXk2nfZt9SPyC8gA1kNfdKLkQWyzsMlqq8msYSlNKfmZxfRgZn4Cd4MGVUF+7v6dBs0d5TOAKa7iIiA==" + "resolved" "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-28.1.3.tgz" + "version" "28.1.3" dependencies: - execa "^5.0.0" - p-limit "^3.1.0" + "execa" "^5.0.0" + "p-limit" "^3.1.0" -jest-circus@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-circus/-/jest-circus-28.1.3.tgz" - integrity sha512-cZ+eS5zc79MBwt+IhQhiEp0OeBddpc1n8MBo1nMB8A7oPMKEO+Sre+wHaLJexQUj9Ya/8NOBY0RESUgYjB6fow== +"jest-circus@^28.1.3": + "integrity" "sha512-cZ+eS5zc79MBwt+IhQhiEp0OeBddpc1n8MBo1nMB8A7oPMKEO+Sre+wHaLJexQUj9Ya/8NOBY0RESUgYjB6fow==" + "resolved" "https://registry.npmjs.org/jest-circus/-/jest-circus-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/environment" "^28.1.3" "@jest/expect" "^28.1.3" "@jest/test-result" "^28.1.3" "@jest/types" "^28.1.3" "@types/node" "*" - chalk "^4.0.0" - co "^4.6.0" - dedent "^0.7.0" - is-generator-fn "^2.0.0" - jest-each "^28.1.3" - jest-matcher-utils "^28.1.3" - jest-message-util "^28.1.3" - jest-runtime "^28.1.3" - jest-snapshot "^28.1.3" - jest-util "^28.1.3" - p-limit "^3.1.0" - pretty-format "^28.1.3" - slash "^3.0.0" - stack-utils "^2.0.3" + "chalk" "^4.0.0" + "co" "^4.6.0" + "dedent" "^0.7.0" + "is-generator-fn" "^2.0.0" + "jest-each" "^28.1.3" + "jest-matcher-utils" "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-runtime" "^28.1.3" + "jest-snapshot" "^28.1.3" + "jest-util" "^28.1.3" + "p-limit" "^3.1.0" + "pretty-format" "^28.1.3" + "slash" "^3.0.0" + "stack-utils" "^2.0.3" -jest-cli@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-cli/-/jest-cli-28.1.3.tgz" - integrity sha512-roY3kvrv57Azn1yPgdTebPAXvdR2xfezaKKYzVxZ6It/5NCxzJym6tUI5P1zkdWhfUYkxEI9uZWcQdaFLo8mJQ== +"jest-cli@^28.1.3": + "integrity" "sha512-roY3kvrv57Azn1yPgdTebPAXvdR2xfezaKKYzVxZ6It/5NCxzJym6tUI5P1zkdWhfUYkxEI9uZWcQdaFLo8mJQ==" + "resolved" "https://registry.npmjs.org/jest-cli/-/jest-cli-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/core" "^28.1.3" "@jest/test-result" "^28.1.3" "@jest/types" "^28.1.3" - chalk "^4.0.0" - exit "^0.1.2" - graceful-fs "^4.2.9" - import-local "^3.0.2" - jest-config "^28.1.3" - jest-util "^28.1.3" - jest-validate "^28.1.3" - prompts "^2.0.1" - yargs "^17.3.1" + "chalk" "^4.0.0" + "exit" "^0.1.2" + "graceful-fs" "^4.2.9" + "import-local" "^3.0.2" + "jest-config" "^28.1.3" + "jest-util" "^28.1.3" + "jest-validate" "^28.1.3" + "prompts" "^2.0.1" + "yargs" "^17.3.1" -jest-config@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-config/-/jest-config-28.1.3.tgz" - integrity sha512-MG3INjByJ0J4AsNBm7T3hsuxKQqFIiRo/AUqb1q9LRKI5UU6Aar9JHbr9Ivn1TVwfUD9KirRoM/T6u8XlcQPHQ== +"jest-config@^28.1.3": + "integrity" "sha512-MG3INjByJ0J4AsNBm7T3hsuxKQqFIiRo/AUqb1q9LRKI5UU6Aar9JHbr9Ivn1TVwfUD9KirRoM/T6u8XlcQPHQ==" + "resolved" "https://registry.npmjs.org/jest-config/-/jest-config-28.1.3.tgz" + "version" "28.1.3" dependencies: "@babel/core" "^7.11.6" "@jest/test-sequencer" "^28.1.3" "@jest/types" "^28.1.3" - babel-jest "^28.1.3" - chalk "^4.0.0" - ci-info "^3.2.0" - deepmerge "^4.2.2" - glob "^7.1.3" - graceful-fs "^4.2.9" - jest-circus "^28.1.3" - jest-environment-node "^28.1.3" - jest-get-type "^28.0.2" - jest-regex-util "^28.0.2" - jest-resolve "^28.1.3" - jest-runner "^28.1.3" - jest-util "^28.1.3" - jest-validate "^28.1.3" - micromatch "^4.0.4" - parse-json "^5.2.0" - pretty-format "^28.1.3" - slash "^3.0.0" - strip-json-comments "^3.1.1" + "babel-jest" "^28.1.3" + "chalk" "^4.0.0" + "ci-info" "^3.2.0" + "deepmerge" "^4.2.2" + "glob" "^7.1.3" + "graceful-fs" "^4.2.9" + "jest-circus" "^28.1.3" + "jest-environment-node" "^28.1.3" + "jest-get-type" "^28.0.2" + "jest-regex-util" "^28.0.2" + "jest-resolve" "^28.1.3" + "jest-runner" "^28.1.3" + "jest-util" "^28.1.3" + "jest-validate" "^28.1.3" + "micromatch" "^4.0.4" + "parse-json" "^5.2.0" + "pretty-format" "^28.1.3" + "slash" "^3.0.0" + "strip-json-comments" "^3.1.1" -jest-diff@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-diff/-/jest-diff-28.1.3.tgz" - integrity sha512-8RqP1B/OXzjjTWkqMX67iqgwBVJRgCyKD3L9nq+6ZqJMdvjE8RgHktqZ6jNrkdMT+dJuYNI3rhQpxaz7drJHfw== +"jest-diff@^28.1.3": + "integrity" "sha512-8RqP1B/OXzjjTWkqMX67iqgwBVJRgCyKD3L9nq+6ZqJMdvjE8RgHktqZ6jNrkdMT+dJuYNI3rhQpxaz7drJHfw==" + "resolved" "https://registry.npmjs.org/jest-diff/-/jest-diff-28.1.3.tgz" + "version" "28.1.3" dependencies: - chalk "^4.0.0" - diff-sequences "^28.1.1" - jest-get-type "^28.0.2" - pretty-format "^28.1.3" + "chalk" "^4.0.0" + "diff-sequences" "^28.1.1" + "jest-get-type" "^28.0.2" + "pretty-format" "^28.1.3" -jest-docblock@^28.1.1: - version "28.1.1" - resolved "https://registry.npmjs.org/jest-docblock/-/jest-docblock-28.1.1.tgz" - integrity sha512-3wayBVNiOYx0cwAbl9rwm5kKFP8yHH3d/fkEaL02NPTkDojPtheGB7HZSFY4wzX+DxyrvhXz0KSCVksmCknCuA== +"jest-docblock@^28.1.1": + "integrity" "sha512-3wayBVNiOYx0cwAbl9rwm5kKFP8yHH3d/fkEaL02NPTkDojPtheGB7HZSFY4wzX+DxyrvhXz0KSCVksmCknCuA==" + "resolved" "https://registry.npmjs.org/jest-docblock/-/jest-docblock-28.1.1.tgz" + "version" "28.1.1" dependencies: - detect-newline "^3.0.0" + "detect-newline" "^3.0.0" -jest-each@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-each/-/jest-each-28.1.3.tgz" - integrity sha512-arT1z4sg2yABU5uogObVPvSlSMQlDA48owx07BDPAiasW0yYpYHYOo4HHLz9q0BVzDVU4hILFjzJw0So9aCL/g== +"jest-each@^28.1.3": + "integrity" "sha512-arT1z4sg2yABU5uogObVPvSlSMQlDA48owx07BDPAiasW0yYpYHYOo4HHLz9q0BVzDVU4hILFjzJw0So9aCL/g==" + "resolved" "https://registry.npmjs.org/jest-each/-/jest-each-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" - chalk "^4.0.0" - jest-get-type "^28.0.2" - jest-util "^28.1.3" - pretty-format "^28.1.3" + "chalk" "^4.0.0" + "jest-get-type" "^28.0.2" + "jest-util" "^28.1.3" + "pretty-format" "^28.1.3" -jest-environment-node@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-28.1.3.tgz" - integrity sha512-ugP6XOhEpjAEhGYvp5Xj989ns5cB1K6ZdjBYuS30umT4CQEETaxSiPcZ/E1kFktX4GkrcM4qu07IIlDYX1gp+A== +"jest-environment-node@^28.1.3": + "integrity" "sha512-ugP6XOhEpjAEhGYvp5Xj989ns5cB1K6ZdjBYuS30umT4CQEETaxSiPcZ/E1kFktX4GkrcM4qu07IIlDYX1gp+A==" + "resolved" "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/environment" "^28.1.3" "@jest/fake-timers" "^28.1.3" "@jest/types" "^28.1.3" "@types/node" "*" - jest-mock "^28.1.3" - jest-util "^28.1.3" + "jest-mock" "^28.1.3" + "jest-util" "^28.1.3" -jest-expect-message@^1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/jest-expect-message/-/jest-expect-message-1.0.2.tgz" - integrity sha512-WFiXMgwS2lOqQZt1iJMI/hOXpUm32X+ApsuzYcQpW5m16Pv6/Gd9kgC+Q+Q1YVNU04kYcAOv9NXMnjg6kKUy6Q== +"jest-expect-message@^1.0.2": + "integrity" "sha512-WFiXMgwS2lOqQZt1iJMI/hOXpUm32X+ApsuzYcQpW5m16Pv6/Gd9kgC+Q+Q1YVNU04kYcAOv9NXMnjg6kKUy6Q==" + "resolved" "https://registry.npmjs.org/jest-expect-message/-/jest-expect-message-1.0.2.tgz" + "version" "1.0.2" -jest-get-type@^28.0.2: - version "28.0.2" - resolved "https://registry.npmjs.org/jest-get-type/-/jest-get-type-28.0.2.tgz" - integrity sha512-ioj2w9/DxSYHfOm5lJKCdcAmPJzQXmbM/Url3rhlghrPvT3tt+7a/+oXc9azkKmLvoiXjtV83bEWqi+vs5nlPA== +"jest-get-type@^28.0.2": + "integrity" "sha512-ioj2w9/DxSYHfOm5lJKCdcAmPJzQXmbM/Url3rhlghrPvT3tt+7a/+oXc9azkKmLvoiXjtV83bEWqi+vs5nlPA==" + "resolved" "https://registry.npmjs.org/jest-get-type/-/jest-get-type-28.0.2.tgz" + "version" "28.0.2" -jest-haste-map@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-28.1.3.tgz" - integrity sha512-3S+RQWDXccXDKSWnkHa/dPwt+2qwA8CJzR61w3FoYCvoo3Pn8tvGcysmMF0Bj0EX5RYvAI2EIvC57OmotfdtKA== +"jest-haste-map@^28.1.3": + "integrity" "sha512-3S+RQWDXccXDKSWnkHa/dPwt+2qwA8CJzR61w3FoYCvoo3Pn8tvGcysmMF0Bj0EX5RYvAI2EIvC57OmotfdtKA==" + "resolved" "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" "@types/graceful-fs" "^4.1.3" "@types/node" "*" - anymatch "^3.0.3" - fb-watchman "^2.0.0" - graceful-fs "^4.2.9" - jest-regex-util "^28.0.2" - jest-util "^28.1.3" - jest-worker "^28.1.3" - micromatch "^4.0.4" - walker "^1.0.8" + "anymatch" "^3.0.3" + "fb-watchman" "^2.0.0" + "graceful-fs" "^4.2.9" + "jest-regex-util" "^28.0.2" + "jest-util" "^28.1.3" + "jest-worker" "^28.1.3" + "micromatch" "^4.0.4" + "walker" "^1.0.8" optionalDependencies: - fsevents "^2.3.2" + "fsevents" "^2.3.2" -jest-leak-detector@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-28.1.3.tgz" - integrity sha512-WFVJhnQsiKtDEo5lG2mM0v40QWnBM+zMdHHyJs8AWZ7J0QZJS59MsyKeJHWhpBZBH32S48FOVvGyOFT1h0DlqA== +"jest-leak-detector@^28.1.3": + "integrity" "sha512-WFVJhnQsiKtDEo5lG2mM0v40QWnBM+zMdHHyJs8AWZ7J0QZJS59MsyKeJHWhpBZBH32S48FOVvGyOFT1h0DlqA==" + "resolved" "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-28.1.3.tgz" + "version" "28.1.3" dependencies: - jest-get-type "^28.0.2" - pretty-format "^28.1.3" + "jest-get-type" "^28.0.2" + "pretty-format" "^28.1.3" -jest-matcher-utils@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-28.1.3.tgz" - integrity sha512-kQeJ7qHemKfbzKoGjHHrRKH6atgxMk8Enkk2iPQ3XwO6oE/KYD8lMYOziCkeSB9G4adPM4nR1DE8Tf5JeWH6Bw== +"jest-matcher-utils@^28.1.3": + "integrity" "sha512-kQeJ7qHemKfbzKoGjHHrRKH6atgxMk8Enkk2iPQ3XwO6oE/KYD8lMYOziCkeSB9G4adPM4nR1DE8Tf5JeWH6Bw==" + "resolved" "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-28.1.3.tgz" + "version" "28.1.3" dependencies: - chalk "^4.0.0" - jest-diff "^28.1.3" - jest-get-type "^28.0.2" - pretty-format "^28.1.3" + "chalk" "^4.0.0" + "jest-diff" "^28.1.3" + "jest-get-type" "^28.0.2" + "pretty-format" "^28.1.3" -jest-message-util@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-message-util/-/jest-message-util-28.1.3.tgz" - integrity sha512-PFdn9Iewbt575zKPf1286Ht9EPoJmYT7P0kY+RibeYZ2XtOr53pDLEFoTWXbd1h4JiGiWpTBC84fc8xMXQMb7g== +"jest-message-util@^28.1.3": + "integrity" "sha512-PFdn9Iewbt575zKPf1286Ht9EPoJmYT7P0kY+RibeYZ2XtOr53pDLEFoTWXbd1h4JiGiWpTBC84fc8xMXQMb7g==" + "resolved" "https://registry.npmjs.org/jest-message-util/-/jest-message-util-28.1.3.tgz" + "version" "28.1.3" dependencies: "@babel/code-frame" "^7.12.13" "@jest/types" "^28.1.3" "@types/stack-utils" "^2.0.0" - chalk "^4.0.0" - graceful-fs "^4.2.9" - micromatch "^4.0.4" - pretty-format "^28.1.3" - slash "^3.0.0" - stack-utils "^2.0.3" + "chalk" "^4.0.0" + "graceful-fs" "^4.2.9" + "micromatch" "^4.0.4" + "pretty-format" "^28.1.3" + "slash" "^3.0.0" + "stack-utils" "^2.0.3" -jest-mock@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-mock/-/jest-mock-28.1.3.tgz" - integrity sha512-o3J2jr6dMMWYVH4Lh/NKmDXdosrsJgi4AviS8oXLujcjpCMBb1FMsblDnOXKZKfSiHLxYub1eS0IHuRXsio9eA== +"jest-mock@^28.1.3": + "integrity" "sha512-o3J2jr6dMMWYVH4Lh/NKmDXdosrsJgi4AviS8oXLujcjpCMBb1FMsblDnOXKZKfSiHLxYub1eS0IHuRXsio9eA==" + "resolved" "https://registry.npmjs.org/jest-mock/-/jest-mock-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" "@types/node" "*" -jest-pnp-resolver@^1.2.2: - version "1.2.2" - resolved "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz" - integrity sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w== +"jest-pnp-resolver@^1.2.2": + "integrity" "sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w==" + "resolved" "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz" + "version" "1.2.2" -jest-regex-util@^28.0.2: - version "28.0.2" - resolved "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-28.0.2.tgz" - integrity sha512-4s0IgyNIy0y9FK+cjoVYoxamT7Zeo7MhzqRGx7YDYmaQn1wucY9rotiGkBzzcMXTtjrCAP/f7f+E0F7+fxPNdw== +"jest-regex-util@^28.0.2": + "integrity" "sha512-4s0IgyNIy0y9FK+cjoVYoxamT7Zeo7MhzqRGx7YDYmaQn1wucY9rotiGkBzzcMXTtjrCAP/f7f+E0F7+fxPNdw==" + "resolved" "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-28.0.2.tgz" + "version" "28.0.2" -jest-resolve-dependencies@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-28.1.3.tgz" - integrity sha512-qa0QO2Q0XzQoNPouMbCc7Bvtsem8eQgVPNkwn9LnS+R2n8DaVDPL/U1gngC0LTl1RYXJU0uJa2BMC2DbTfFrHA== +"jest-resolve-dependencies@^28.1.3": + "integrity" "sha512-qa0QO2Q0XzQoNPouMbCc7Bvtsem8eQgVPNkwn9LnS+R2n8DaVDPL/U1gngC0LTl1RYXJU0uJa2BMC2DbTfFrHA==" + "resolved" "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-28.1.3.tgz" + "version" "28.1.3" dependencies: - jest-regex-util "^28.0.2" - jest-snapshot "^28.1.3" + "jest-regex-util" "^28.0.2" + "jest-snapshot" "^28.1.3" -jest-resolve@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-resolve/-/jest-resolve-28.1.3.tgz" - integrity sha512-Z1W3tTjE6QaNI90qo/BJpfnvpxtaFTFw5CDgwpyE/Kz8U/06N1Hjf4ia9quUhCh39qIGWF1ZuxFiBiJQwSEYKQ== +"jest-resolve@*", "jest-resolve@^28.1.3": + "integrity" "sha512-Z1W3tTjE6QaNI90qo/BJpfnvpxtaFTFw5CDgwpyE/Kz8U/06N1Hjf4ia9quUhCh39qIGWF1ZuxFiBiJQwSEYKQ==" + "resolved" "https://registry.npmjs.org/jest-resolve/-/jest-resolve-28.1.3.tgz" + "version" "28.1.3" dependencies: - chalk "^4.0.0" - graceful-fs "^4.2.9" - jest-haste-map "^28.1.3" - jest-pnp-resolver "^1.2.2" - jest-util "^28.1.3" - jest-validate "^28.1.3" - resolve "^1.20.0" - resolve.exports "^1.1.0" - slash "^3.0.0" + "chalk" "^4.0.0" + "graceful-fs" "^4.2.9" + "jest-haste-map" "^28.1.3" + "jest-pnp-resolver" "^1.2.2" + "jest-util" "^28.1.3" + "jest-validate" "^28.1.3" + "resolve" "^1.20.0" + "resolve.exports" "^1.1.0" + "slash" "^3.0.0" -jest-runner@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-runner/-/jest-runner-28.1.3.tgz" - integrity sha512-GkMw4D/0USd62OVO0oEgjn23TM+YJa2U2Wu5zz9xsQB1MxWKDOlrnykPxnMsN0tnJllfLPinHTka61u0QhaxBA== +"jest-runner@^28.1.3": + "integrity" "sha512-GkMw4D/0USd62OVO0oEgjn23TM+YJa2U2Wu5zz9xsQB1MxWKDOlrnykPxnMsN0tnJllfLPinHTka61u0QhaxBA==" + "resolved" "https://registry.npmjs.org/jest-runner/-/jest-runner-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/console" "^28.1.3" "@jest/environment" "^28.1.3" @@ -4496,26 +4554,26 @@ jest-runner@^28.1.3: "@jest/transform" "^28.1.3" "@jest/types" "^28.1.3" "@types/node" "*" - chalk "^4.0.0" - emittery "^0.10.2" - graceful-fs "^4.2.9" - jest-docblock "^28.1.1" - jest-environment-node "^28.1.3" - jest-haste-map "^28.1.3" - jest-leak-detector "^28.1.3" - jest-message-util "^28.1.3" - jest-resolve "^28.1.3" - jest-runtime "^28.1.3" - jest-util "^28.1.3" - jest-watcher "^28.1.3" - jest-worker "^28.1.3" - p-limit "^3.1.0" - source-map-support "0.5.13" + "chalk" "^4.0.0" + "emittery" "^0.10.2" + "graceful-fs" "^4.2.9" + "jest-docblock" "^28.1.1" + "jest-environment-node" "^28.1.3" + "jest-haste-map" "^28.1.3" + "jest-leak-detector" "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-resolve" "^28.1.3" + "jest-runtime" "^28.1.3" + "jest-util" "^28.1.3" + "jest-watcher" "^28.1.3" + "jest-worker" "^28.1.3" + "p-limit" "^3.1.0" + "source-map-support" "0.5.13" -jest-runtime@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-runtime/-/jest-runtime-28.1.3.tgz" - integrity sha512-NU+881ScBQQLc1JHG5eJGU7Ui3kLKrmwCPPtYsJtBykixrM2OhVQlpMmFWJjMyDfdkGgBMNjXCGB/ebzsgNGQw== +"jest-runtime@^28.1.3": + "integrity" "sha512-NU+881ScBQQLc1JHG5eJGU7Ui3kLKrmwCPPtYsJtBykixrM2OhVQlpMmFWJjMyDfdkGgBMNjXCGB/ebzsgNGQw==" + "resolved" "https://registry.npmjs.org/jest-runtime/-/jest-runtime-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/environment" "^28.1.3" "@jest/fake-timers" "^28.1.3" @@ -4524,26 +4582,26 @@ jest-runtime@^28.1.3: "@jest/test-result" "^28.1.3" "@jest/transform" "^28.1.3" "@jest/types" "^28.1.3" - chalk "^4.0.0" - cjs-module-lexer "^1.0.0" - collect-v8-coverage "^1.0.0" - execa "^5.0.0" - glob "^7.1.3" - graceful-fs "^4.2.9" - jest-haste-map "^28.1.3" - jest-message-util "^28.1.3" - jest-mock "^28.1.3" - jest-regex-util "^28.0.2" - jest-resolve "^28.1.3" - jest-snapshot "^28.1.3" - jest-util "^28.1.3" - slash "^3.0.0" - strip-bom "^4.0.0" + "chalk" "^4.0.0" + "cjs-module-lexer" "^1.0.0" + "collect-v8-coverage" "^1.0.0" + "execa" "^5.0.0" + "glob" "^7.1.3" + "graceful-fs" "^4.2.9" + "jest-haste-map" "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-mock" "^28.1.3" + "jest-regex-util" "^28.0.2" + "jest-resolve" "^28.1.3" + "jest-snapshot" "^28.1.3" + "jest-util" "^28.1.3" + "slash" "^3.0.0" + "strip-bom" "^4.0.0" -jest-snapshot@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-28.1.3.tgz" - integrity sha512-4lzMgtiNlc3DU/8lZfmqxN3AYD6GGLbl+72rdBpXvcV+whX7mDrREzkPdp2RnmfIiWBg1YbuFSkXduF2JcafJg== +"jest-snapshot@^28.1.3": + "integrity" "sha512-4lzMgtiNlc3DU/8lZfmqxN3AYD6GGLbl+72rdBpXvcV+whX7mDrREzkPdp2RnmfIiWBg1YbuFSkXduF2JcafJg==" + "resolved" "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-28.1.3.tgz" + "version" "28.1.3" dependencies: "@babel/core" "^7.11.6" "@babel/generator" "^7.7.2" @@ -4555,2248 +4613,2358 @@ jest-snapshot@^28.1.3: "@jest/types" "^28.1.3" "@types/babel__traverse" "^7.0.6" "@types/prettier" "^2.1.5" - babel-preset-current-node-syntax "^1.0.0" - chalk "^4.0.0" - expect "^28.1.3" - graceful-fs "^4.2.9" - jest-diff "^28.1.3" - jest-get-type "^28.0.2" - jest-haste-map "^28.1.3" - jest-matcher-utils "^28.1.3" - jest-message-util "^28.1.3" - jest-util "^28.1.3" - natural-compare "^1.4.0" - pretty-format "^28.1.3" - semver "^7.3.5" + "babel-preset-current-node-syntax" "^1.0.0" + "chalk" "^4.0.0" + "expect" "^28.1.3" + "graceful-fs" "^4.2.9" + "jest-diff" "^28.1.3" + "jest-get-type" "^28.0.2" + "jest-haste-map" "^28.1.3" + "jest-matcher-utils" "^28.1.3" + "jest-message-util" "^28.1.3" + "jest-util" "^28.1.3" + "natural-compare" "^1.4.0" + "pretty-format" "^28.1.3" + "semver" "^7.3.5" -jest-util@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-util/-/jest-util-28.1.3.tgz" - integrity sha512-XdqfpHwpcSRko/C35uLYFM2emRAltIIKZiJ9eAmhjsj0CqZMa0p1ib0R5fWIqGhn1a103DebTbpqIaP1qCQ6tQ== +"jest-util@^28.1.3": + "integrity" "sha512-XdqfpHwpcSRko/C35uLYFM2emRAltIIKZiJ9eAmhjsj0CqZMa0p1ib0R5fWIqGhn1a103DebTbpqIaP1qCQ6tQ==" + "resolved" "https://registry.npmjs.org/jest-util/-/jest-util-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" "@types/node" "*" - chalk "^4.0.0" - ci-info "^3.2.0" - graceful-fs "^4.2.9" - picomatch "^2.2.3" + "chalk" "^4.0.0" + "ci-info" "^3.2.0" + "graceful-fs" "^4.2.9" + "picomatch" "^2.2.3" -jest-validate@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-validate/-/jest-validate-28.1.3.tgz" - integrity sha512-SZbOGBWEsaTxBGCOpsRWlXlvNkvTkY0XxRfh7zYmvd8uL5Qzyg0CHAXiXKROflh801quA6+/DsT4ODDthOC/OA== +"jest-validate@^28.1.3": + "integrity" "sha512-SZbOGBWEsaTxBGCOpsRWlXlvNkvTkY0XxRfh7zYmvd8uL5Qzyg0CHAXiXKROflh801quA6+/DsT4ODDthOC/OA==" + "resolved" "https://registry.npmjs.org/jest-validate/-/jest-validate-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/types" "^28.1.3" - camelcase "^6.2.0" - chalk "^4.0.0" - jest-get-type "^28.0.2" - leven "^3.1.0" - pretty-format "^28.1.3" + "camelcase" "^6.2.0" + "chalk" "^4.0.0" + "jest-get-type" "^28.0.2" + "leven" "^3.1.0" + "pretty-format" "^28.1.3" -jest-watcher@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-watcher/-/jest-watcher-28.1.3.tgz" - integrity sha512-t4qcqj9hze+jviFPUN3YAtAEeFnr/azITXQEMARf5cMwKY2SMBRnCQTXLixTl20OR6mLh9KLMrgVJgJISym+1g== +"jest-watcher@^28.1.3": + "integrity" "sha512-t4qcqj9hze+jviFPUN3YAtAEeFnr/azITXQEMARf5cMwKY2SMBRnCQTXLixTl20OR6mLh9KLMrgVJgJISym+1g==" + "resolved" "https://registry.npmjs.org/jest-watcher/-/jest-watcher-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/test-result" "^28.1.3" "@jest/types" "^28.1.3" "@types/node" "*" - ansi-escapes "^4.2.1" - chalk "^4.0.0" - emittery "^0.10.2" - jest-util "^28.1.3" - string-length "^4.0.1" + "ansi-escapes" "^4.2.1" + "chalk" "^4.0.0" + "emittery" "^0.10.2" + "jest-util" "^28.1.3" + "string-length" "^4.0.1" -jest-worker@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest-worker/-/jest-worker-28.1.3.tgz" - integrity sha512-CqRA220YV/6jCo8VWvAt1KKx6eek1VIHMPeLEbpcfSfkEeWyBNppynM/o6q+Wmw+sOhos2ml34wZbSX3G13//g== +"jest-worker@^28.1.3": + "integrity" "sha512-CqRA220YV/6jCo8VWvAt1KKx6eek1VIHMPeLEbpcfSfkEeWyBNppynM/o6q+Wmw+sOhos2ml34wZbSX3G13//g==" + "resolved" "https://registry.npmjs.org/jest-worker/-/jest-worker-28.1.3.tgz" + "version" "28.1.3" dependencies: "@types/node" "*" - merge-stream "^2.0.0" - supports-color "^8.0.0" + "merge-stream" "^2.0.0" + "supports-color" "^8.0.0" -jest@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/jest/-/jest-28.1.3.tgz" - integrity sha512-N4GT5on8UkZgH0O5LUavMRV1EDEhNTL0KEfRmDIeZHSV7p2XgLoY9t9VDUgL6o+yfdgYHVxuz81G8oB9VG5uyA== +"jest@^28.1.3": + "integrity" "sha512-N4GT5on8UkZgH0O5LUavMRV1EDEhNTL0KEfRmDIeZHSV7p2XgLoY9t9VDUgL6o+yfdgYHVxuz81G8oB9VG5uyA==" + "resolved" "https://registry.npmjs.org/jest/-/jest-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/core" "^28.1.3" "@jest/types" "^28.1.3" - import-local "^3.0.2" - jest-cli "^28.1.3" + "import-local" "^3.0.2" + "jest-cli" "^28.1.3" -js-tokens@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz" - integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== +"js-tokens@^4.0.0": + "integrity" "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" + "resolved" "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz" + "version" "4.0.0" -js-yaml@3.13.1, js-yaml@^3.13.1: - version "3.13.1" - resolved "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz" - integrity sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw== +"js-yaml@^3.13.1", "js-yaml@3.13.1": + "integrity" "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==" + "resolved" "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz" + "version" "3.13.1" dependencies: - argparse "^1.0.7" - esprima "^4.0.0" + "argparse" "^1.0.7" + "esprima" "^4.0.0" -js-yaml@^4.1.0: - version "4.1.0" - resolved "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz" - integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== +"js-yaml@^4.1.0": + "integrity" "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==" + "resolved" "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz" + "version" "4.1.0" dependencies: - argparse "^2.0.1" + "argparse" "^2.0.1" -jsesc@^2.5.1: - version "2.5.2" - resolved "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz" - integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== +"jsesc@^2.5.1": + "integrity" "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==" + "resolved" "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz" + "version" "2.5.2" -jsesc@~0.5.0: - version "0.5.0" - resolved "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz" - integrity sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA== +"jsesc@~0.5.0": + "integrity" "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==" + "resolved" "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz" + "version" "0.5.0" -json-parse-even-better-errors@^2.3.0: - version "2.3.1" - resolved "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz" - integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== +"json-parse-even-better-errors@^2.3.0": + "integrity" "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" + "resolved" "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz" + "version" "2.3.1" -json-schema-traverse@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz" - integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== +"json-schema-traverse@^1.0.0": + "integrity" "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==" + "resolved" "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz" + "version" "1.0.0" -json5@2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/json5/-/json5-2.0.0.tgz" - integrity sha512-0EdQvHuLm7yJ7lyG5dp7Q3X2ku++BG5ZHaJ5FTnaXpKqDrw4pMxel5Bt3oAYMthnrthFBdnZ1FcsXTPyrQlV0w== +"json5@^2.2.1": + "integrity" "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==" + "resolved" "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz" + "version" "2.2.1" + +"json5@2.0.0": + "integrity" "sha512-0EdQvHuLm7yJ7lyG5dp7Q3X2ku++BG5ZHaJ5FTnaXpKqDrw4pMxel5Bt3oAYMthnrthFBdnZ1FcsXTPyrQlV0w==" + "resolved" "https://registry.npmjs.org/json5/-/json5-2.0.0.tgz" + "version" "2.0.0" dependencies: - minimist "^1.2.0" + "minimist" "^1.2.0" -json5@^2.2.1: - version "2.2.1" - resolved "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz" - integrity sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA== - -jsonfile@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz" - integrity sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg== +"jsonfile@^4.0.0": + "integrity" "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==" + "resolved" "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz" + "version" "4.0.0" optionalDependencies: - graceful-fs "^4.1.6" + "graceful-fs" "^4.1.6" -jsonwebtoken@^8.5.1: - version "8.5.1" - resolved "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz" - integrity sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w== +"jsonwebtoken@^8.5.1": + "integrity" "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==" + "resolved" "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz" + "version" "8.5.1" dependencies: - jws "^3.2.2" - lodash.includes "^4.3.0" - lodash.isboolean "^3.0.3" - lodash.isinteger "^4.0.4" - lodash.isnumber "^3.0.3" - lodash.isplainobject "^4.0.6" - lodash.isstring "^4.0.1" - lodash.once "^4.0.0" - ms "^2.1.1" - semver "^5.6.0" + "jws" "^3.2.2" + "lodash.includes" "^4.3.0" + "lodash.isboolean" "^3.0.3" + "lodash.isinteger" "^4.0.4" + "lodash.isnumber" "^3.0.3" + "lodash.isplainobject" "^4.0.6" + "lodash.isstring" "^4.0.1" + "lodash.once" "^4.0.0" + "ms" "^2.1.1" + "semver" "^5.6.0" -jwa@^1.4.1: - version "1.4.1" - resolved "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz" - integrity sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA== +"jwa@^1.4.1": + "integrity" "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==" + "resolved" "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz" + "version" "1.4.1" dependencies: - buffer-equal-constant-time "1.0.1" - ecdsa-sig-formatter "1.0.11" - safe-buffer "^5.0.1" + "buffer-equal-constant-time" "1.0.1" + "ecdsa-sig-formatter" "1.0.11" + "safe-buffer" "^5.0.1" -jws@^3.2.2: - version "3.2.2" - resolved "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz" - integrity sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA== +"jws@^3.2.2": + "integrity" "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==" + "resolved" "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz" + "version" "3.2.2" dependencies: - jwa "^1.4.1" - safe-buffer "^5.0.1" + "jwa" "^1.4.1" + "safe-buffer" "^5.0.1" -kind-of@^6.0.2: - version "6.0.3" - resolved "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz" - integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== +"kind-of@^6.0.2": + "integrity" "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + "resolved" "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz" + "version" "6.0.3" -klaw-sync@^6.0.0: - version "6.0.0" - resolved "https://registry.npmjs.org/klaw-sync/-/klaw-sync-6.0.0.tgz" - integrity sha512-nIeuVSzdCCs6TDPTqI8w1Yre34sSq7AkZ4B3sfOBbI2CgVSB4Du4aLQijFU2+lhAFCwt9+42Hel6lQNIv6AntQ== +"klaw-sync@^6.0.0": + "integrity" "sha512-nIeuVSzdCCs6TDPTqI8w1Yre34sSq7AkZ4B3sfOBbI2CgVSB4Du4aLQijFU2+lhAFCwt9+42Hel6lQNIv6AntQ==" + "resolved" "https://registry.npmjs.org/klaw-sync/-/klaw-sync-6.0.0.tgz" + "version" "6.0.0" dependencies: - graceful-fs "^4.1.11" + "graceful-fs" "^4.1.11" -kleur@^3.0.3: - version "3.0.3" - resolved "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" - integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== +"kleur@^3.0.3": + "integrity" "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==" + "resolved" "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" + "version" "3.0.3" -lambert-server@^1.2.12: - version "1.2.12" - resolved "https://registry.npmjs.org/lambert-server/-/lambert-server-1.2.12.tgz" - integrity sha512-TY6k60KLVfBpPrl9lcrN54RJdTBg9f8JqJPoHg5d/FMLnnwwQtT4budpoQjyLDwBLhS+zpXo0aBCwnnGgTVGaw== +"lambert-server@^1.2.12": + "integrity" "sha512-TY6k60KLVfBpPrl9lcrN54RJdTBg9f8JqJPoHg5d/FMLnnwwQtT4budpoQjyLDwBLhS+zpXo0aBCwnnGgTVGaw==" + "resolved" "https://registry.npmjs.org/lambert-server/-/lambert-server-1.2.12.tgz" + "version" "1.2.12" dependencies: - body-parser "^1.19.0" - chalk "^4.1.1" - express "^4.17.1" - express-async-errors "^3.1.1" - helmet "^4.4.1" - missing-native-js-functions "^1.2.11" + "body-parser" "^1.19.0" + "chalk" "^4.1.1" + "express" "^4.17.1" + "express-async-errors" "^3.1.1" + "helmet" "^4.4.1" + "missing-native-js-functions" "^1.2.11" -leven@^3.1.0: - version "3.1.0" - resolved "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz" - integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== +"leven@^3.1.0": + "integrity" "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==" + "resolved" "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz" + "version" "3.1.0" -levn@~0.3.0: - version "0.3.0" - resolved "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz" - integrity sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA== +"levn@~0.3.0": + "integrity" "sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA==" + "resolved" "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz" + "version" "0.3.0" dependencies: - prelude-ls "~1.1.2" - type-check "~0.3.2" + "prelude-ls" "~1.1.2" + "type-check" "~0.3.2" -lines-and-columns@^1.1.6: - version "1.2.4" - resolved "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz" - integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== +"lines-and-columns@^1.1.6": + "integrity" "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" + "resolved" "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz" + "version" "1.2.4" -locate-path@^5.0.0: - version "5.0.0" - resolved "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz" - integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== +"locate-path@^5.0.0": + "integrity" "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==" + "resolved" "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz" + "version" "5.0.0" dependencies: - p-locate "^4.1.0" + "p-locate" "^4.1.0" -lodash.debounce@^4.0.8: - version "4.0.8" - resolved "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz" - integrity sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow== +"lodash.debounce@^4.0.8": + "integrity" "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==" + "resolved" "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz" + "version" "4.0.8" -lodash.includes@^4.3.0: - version "4.3.0" - resolved "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz" - integrity sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w== +"lodash.includes@^4.3.0": + "integrity" "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" + "resolved" "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz" + "version" "4.3.0" -lodash.isboolean@^3.0.3: - version "3.0.3" - resolved "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz" - integrity sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg== +"lodash.isboolean@^3.0.3": + "integrity" "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" + "resolved" "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz" + "version" "3.0.3" -lodash.isinteger@^4.0.4: - version "4.0.4" - resolved "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz" - integrity sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA== +"lodash.isinteger@^4.0.4": + "integrity" "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" + "resolved" "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz" + "version" "4.0.4" -lodash.isnumber@^3.0.3: - version "3.0.3" - resolved "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz" - integrity sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw== +"lodash.isnumber@^3.0.3": + "integrity" "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" + "resolved" "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz" + "version" "3.0.3" -lodash.isplainobject@^4.0.6: - version "4.0.6" - resolved "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz" - integrity sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA== +"lodash.isplainobject@^4.0.6": + "integrity" "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" + "resolved" "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz" + "version" "4.0.6" -lodash.isstring@^4.0.1: - version "4.0.1" - resolved "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz" - integrity sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw== +"lodash.isstring@^4.0.1": + "integrity" "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" + "resolved" "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz" + "version" "4.0.1" -lodash.once@^4.0.0: - version "4.1.1" - resolved "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz" - integrity sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg== +"lodash.once@^4.0.0": + "integrity" "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" + "resolved" "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz" + "version" "4.1.1" -long@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/long/-/long-4.0.0.tgz#9a7b71cfb7d361a194ea555241c92f7468d5bf28" - integrity sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA== +"long@^4.0.0": + "integrity" "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" + "resolved" "https://registry.npmjs.org/long/-/long-4.0.0.tgz" + "version" "4.0.0" -lru-cache@^4.1.3: - version "4.1.5" - resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.5.tgz#8bbe50ea85bed59bc9e33dcab8235ee9bcf443cd" - integrity sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g== +"lru_map@^0.3.3": + "integrity" "sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ==" + "resolved" "https://registry.npmjs.org/lru_map/-/lru_map-0.3.3.tgz" + "version" "0.3.3" + +"lru-cache@^4.1.3": + "integrity" "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==" + "resolved" "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz" + "version" "4.1.5" dependencies: - pseudomap "^1.0.2" - yallist "^2.1.2" + "pseudomap" "^1.0.2" + "yallist" "^2.1.2" -lru-cache@^5.1.1: - version "5.1.1" - resolved "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz" - integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w== +"lru-cache@^5.1.1": + "integrity" "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==" + "resolved" "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz" + "version" "5.1.1" dependencies: - yallist "^3.0.2" + "yallist" "^3.0.2" -lru-cache@^6.0.0: - version "6.0.0" - resolved "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz" - integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== +"lru-cache@^6.0.0": + "integrity" "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==" + "resolved" "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz" + "version" "6.0.0" dependencies: - yallist "^4.0.0" + "yallist" "^4.0.0" -lru_map@^0.3.3: - version "0.3.3" - resolved "https://registry.npmjs.org/lru_map/-/lru_map-0.3.3.tgz" - integrity sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ== - -make-dir@^3.0.0, make-dir@^3.1.0: - version "3.1.0" - resolved "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz" - integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== +"make-dir@^3.0.0", "make-dir@^3.1.0": + "integrity" "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==" + "resolved" "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz" + "version" "3.1.0" dependencies: - semver "^6.0.0" + "semver" "^6.0.0" -make-error@^1.1.1: - version "1.3.6" - resolved "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz" - integrity sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw== +"make-error@^1.1.1": + "integrity" "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==" + "resolved" "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz" + "version" "1.3.6" -make-fetch-happen@^9.1.0: - version "9.1.0" - resolved "https://registry.yarnpkg.com/make-fetch-happen/-/make-fetch-happen-9.1.0.tgz#53085a09e7971433e6765f7971bf63f4e05cb968" - integrity sha512-+zopwDy7DNknmwPQplem5lAZX/eCOzSvSNNcSKm5eVwTkOBzoktEfXsa9L23J/GIRhxRsaxzkPEhrJEpE2F4Gg== +"make-fetch-happen@^9.1.0": + "integrity" "sha512-+zopwDy7DNknmwPQplem5lAZX/eCOzSvSNNcSKm5eVwTkOBzoktEfXsa9L23J/GIRhxRsaxzkPEhrJEpE2F4Gg==" + "resolved" "https://registry.npmjs.org/make-fetch-happen/-/make-fetch-happen-9.1.0.tgz" + "version" "9.1.0" dependencies: - agentkeepalive "^4.1.3" - cacache "^15.2.0" - http-cache-semantics "^4.1.0" - http-proxy-agent "^4.0.1" - https-proxy-agent "^5.0.0" - is-lambda "^1.0.1" - lru-cache "^6.0.0" - minipass "^3.1.3" - minipass-collect "^1.0.2" - minipass-fetch "^1.3.2" - minipass-flush "^1.0.5" - minipass-pipeline "^1.2.4" - negotiator "^0.6.2" - promise-retry "^2.0.1" - socks-proxy-agent "^6.0.0" - ssri "^8.0.0" + "agentkeepalive" "^4.1.3" + "cacache" "^15.2.0" + "http-cache-semantics" "^4.1.0" + "http-proxy-agent" "^4.0.1" + "https-proxy-agent" "^5.0.0" + "is-lambda" "^1.0.1" + "lru-cache" "^6.0.0" + "minipass" "^3.1.3" + "minipass-collect" "^1.0.2" + "minipass-fetch" "^1.3.2" + "minipass-flush" "^1.0.5" + "minipass-pipeline" "^1.2.4" + "negotiator" "^0.6.2" + "promise-retry" "^2.0.1" + "socks-proxy-agent" "^6.0.0" + "ssri" "^8.0.0" -makeerror@1.0.12: - version "1.0.12" - resolved "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz" - integrity sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg== +"makeerror@1.0.12": + "integrity" "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==" + "resolved" "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz" + "version" "1.0.12" dependencies: - tmpl "1.0.5" + "tmpl" "1.0.5" -media-typer@0.3.0: - version "0.3.0" - resolved "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz" - integrity sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ== +"media-typer@0.3.0": + "integrity" "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==" + "resolved" "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz" + "version" "0.3.0" -merge-descriptors@1.0.1: - version "1.0.1" - resolved "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz" - integrity sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w== +"memory-pager@^1.0.2": + "integrity" "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==" + "resolved" "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz" + "version" "1.5.0" -merge-stream@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz" - integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== +"merge-descriptors@1.0.1": + "integrity" "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" + "resolved" "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz" + "version" "1.0.1" -methods@^1.1.2, methods@~1.1.2: - version "1.1.2" - resolved "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" - integrity sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w== +"merge-stream@^2.0.0": + "integrity" "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==" + "resolved" "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz" + "version" "2.0.0" -micromatch@^4.0.2, micromatch@^4.0.4: - version "4.0.5" - resolved "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz" - integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== +"methods@^1.1.2", "methods@~1.1.2": + "integrity" "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==" + "resolved" "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" + "version" "1.1.2" + +"micromatch@^4.0.2", "micromatch@^4.0.4": + "integrity" "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==" + "resolved" "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz" + "version" "4.0.5" dependencies: - braces "^3.0.2" - picomatch "^2.3.1" + "braces" "^3.0.2" + "picomatch" "^2.3.1" -mime-db@1.52.0: - version "1.52.0" - resolved "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz" - integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== +"mime-db@1.52.0": + "integrity" "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==" + "resolved" "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz" + "version" "1.52.0" -mime-types@^2.1.12, mime-types@~2.1.24, mime-types@~2.1.34: - version "2.1.35" - resolved "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz" - integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== +"mime-types@^2.1.12", "mime-types@~2.1.24", "mime-types@~2.1.34": + "integrity" "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==" + "resolved" "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz" + "version" "2.1.35" dependencies: - mime-db "1.52.0" + "mime-db" "1.52.0" -mime@1.6.0: - version "1.6.0" - resolved "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz" - integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== +"mime@1.6.0": + "integrity" "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" + "resolved" "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz" + "version" "1.6.0" -mime@2.6.0: - version "2.6.0" - resolved "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz" - integrity sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg== +"mime@2.6.0": + "integrity" "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==" + "resolved" "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz" + "version" "2.6.0" -mimic-fn@^2.1.0: - version "2.1.0" - resolved "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz" - integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== +"mimic-fn@^2.1.0": + "integrity" "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" + "resolved" "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz" + "version" "2.1.0" -mimic-response@^2.0.0: - version "2.1.0" - resolved "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz" - integrity sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA== +"mimic-response@^2.0.0": + "integrity" "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==" + "resolved" "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz" + "version" "2.1.0" -minimatch@^3.0.4, minimatch@^3.1.1: - version "3.1.2" - resolved "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz" - integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== +"minimatch@^3.0.4", "minimatch@^3.1.1": + "integrity" "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==" + "resolved" "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz" + "version" "3.1.2" dependencies: - brace-expansion "^1.1.7" + "brace-expansion" "^1.1.7" -minimatch@^5.0.1: - version "5.1.0" - resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-5.1.0.tgz#1717b464f4971b144f6aabe8f2d0b8e4511e09c7" - integrity sha512-9TPBGGak4nHfGZsPBohm9AWg6NoT7QTCehS3BIJABslyZbzxfV78QM2Y6+i741OPZIafFAaiiEMh5OyIrJPgtg== +"minimatch@^5.0.1": + "integrity" "sha512-9TPBGGak4nHfGZsPBohm9AWg6NoT7QTCehS3BIJABslyZbzxfV78QM2Y6+i741OPZIafFAaiiEMh5OyIrJPgtg==" + "resolved" "https://registry.npmjs.org/minimatch/-/minimatch-5.1.0.tgz" + "version" "5.1.0" dependencies: - brace-expansion "^2.0.1" + "brace-expansion" "^2.0.1" -minimist@^1.2.0, minimist@^1.2.6: - version "1.2.6" - resolved "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz" - integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== +"minimist@^1.2.0", "minimist@^1.2.6": + "integrity" "sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q==" + "resolved" "https://registry.npmjs.org/minimist/-/minimist-1.2.6.tgz" + "version" "1.2.6" -minipass-collect@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/minipass-collect/-/minipass-collect-1.0.2.tgz#22b813bf745dc6edba2576b940022ad6edc8c617" - integrity sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA== +"minipass-collect@^1.0.2": + "integrity" "sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA==" + "resolved" "https://registry.npmjs.org/minipass-collect/-/minipass-collect-1.0.2.tgz" + "version" "1.0.2" dependencies: - minipass "^3.0.0" + "minipass" "^3.0.0" -minipass-fetch@^1.3.2: - version "1.4.1" - resolved "https://registry.yarnpkg.com/minipass-fetch/-/minipass-fetch-1.4.1.tgz#d75e0091daac1b0ffd7e9d41629faff7d0c1f1b6" - integrity sha512-CGH1eblLq26Y15+Azk7ey4xh0J/XfJfrCox5LDJiKqI2Q2iwOLOKrlmIaODiSQS8d18jalF6y2K2ePUm0CmShw== +"minipass-fetch@^1.3.2": + "integrity" "sha512-CGH1eblLq26Y15+Azk7ey4xh0J/XfJfrCox5LDJiKqI2Q2iwOLOKrlmIaODiSQS8d18jalF6y2K2ePUm0CmShw==" + "resolved" "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-1.4.1.tgz" + "version" "1.4.1" dependencies: - minipass "^3.1.0" - minipass-sized "^1.0.3" - minizlib "^2.0.0" + "minipass" "^3.1.0" + "minipass-sized" "^1.0.3" + "minizlib" "^2.0.0" optionalDependencies: - encoding "^0.1.12" + "encoding" "^0.1.12" -minipass-flush@^1.0.5: - version "1.0.5" - resolved "https://registry.yarnpkg.com/minipass-flush/-/minipass-flush-1.0.5.tgz#82e7135d7e89a50ffe64610a787953c4c4cbb373" - integrity sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw== +"minipass-flush@^1.0.5": + "integrity" "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==" + "resolved" "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz" + "version" "1.0.5" dependencies: - minipass "^3.0.0" + "minipass" "^3.0.0" -minipass-pipeline@^1.2.2, minipass-pipeline@^1.2.4: - version "1.2.4" - resolved "https://registry.yarnpkg.com/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz#68472f79711c084657c067c5c6ad93cddea8214c" - integrity sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A== +"minipass-pipeline@^1.2.2", "minipass-pipeline@^1.2.4": + "integrity" "sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A==" + "resolved" "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz" + "version" "1.2.4" dependencies: - minipass "^3.0.0" + "minipass" "^3.0.0" -minipass-sized@^1.0.3: - version "1.0.3" - resolved "https://registry.yarnpkg.com/minipass-sized/-/minipass-sized-1.0.3.tgz#70ee5a7c5052070afacfbc22977ea79def353b70" - integrity sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g== +"minipass-sized@^1.0.3": + "integrity" "sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g==" + "resolved" "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz" + "version" "1.0.3" dependencies: - minipass "^3.0.0" + "minipass" "^3.0.0" -minipass@^3.0.0, minipass@^3.1.0, minipass@^3.1.1, minipass@^3.1.3: - version "3.3.4" - resolved "https://registry.npmjs.org/minipass/-/minipass-3.3.4.tgz" - integrity sha512-I9WPbWHCGu8W+6k1ZiGpPu0GkoKBeorkfKNuAFBNS1HNFJvke82sxvI5bzcCNpWPorkOO5QQ+zomzzwRxejXiw== +"minipass@^3.0.0", "minipass@^3.1.0", "minipass@^3.1.1", "minipass@^3.1.3": + "integrity" "sha512-I9WPbWHCGu8W+6k1ZiGpPu0GkoKBeorkfKNuAFBNS1HNFJvke82sxvI5bzcCNpWPorkOO5QQ+zomzzwRxejXiw==" + "resolved" "https://registry.npmjs.org/minipass/-/minipass-3.3.4.tgz" + "version" "3.3.4" dependencies: - yallist "^4.0.0" + "yallist" "^4.0.0" -minizlib@^2.0.0, minizlib@^2.1.1: - version "2.1.2" - resolved "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz" - integrity sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg== +"minizlib@^2.0.0", "minizlib@^2.1.1": + "integrity" "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==" + "resolved" "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz" + "version" "2.1.2" dependencies: - minipass "^3.0.0" - yallist "^4.0.0" + "minipass" "^3.0.0" + "yallist" "^4.0.0" -missing-native-js-functions@^1.2.11, missing-native-js-functions@^1.2.18: - version "1.2.18" - resolved "https://registry.npmjs.org/missing-native-js-functions/-/missing-native-js-functions-1.2.18.tgz" - integrity sha512-TZr1muzDE4kfu0LHDzg63O7m2qW3Gpyc875ki8+YlSRj+4ibZRv0ySQ0cSB06GoBL9ejeehLmkQnybLpp9jYcg== +"missing-native-js-functions@^1.2.11", "missing-native-js-functions@^1.2.18": + "integrity" "sha512-TZr1muzDE4kfu0LHDzg63O7m2qW3Gpyc875ki8+YlSRj+4ibZRv0ySQ0cSB06GoBL9ejeehLmkQnybLpp9jYcg==" + "resolved" "https://registry.npmjs.org/missing-native-js-functions/-/missing-native-js-functions-1.2.18.tgz" + "version" "1.2.18" -mkdirp@^0.5.4: - version "0.5.6" - resolved "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz" - integrity sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw== +"mkdirp@^0.5.4": + "integrity" "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==" + "resolved" "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz" + "version" "0.5.6" dependencies: - minimist "^1.2.6" + "minimist" "^1.2.6" -mkdirp@^1.0.3, mkdirp@^1.0.4: - version "1.0.4" - resolved "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz" - integrity sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw== +"mkdirp@^1.0.3": + "integrity" "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" + "resolved" "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz" + "version" "1.0.4" -morgan@^1.10.0: - version "1.10.0" - resolved "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz" - integrity sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ== +"mkdirp@^1.0.4": + "integrity" "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" + "resolved" "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz" + "version" "1.0.4" + +"mongodb@^3.6.0": + "integrity" "sha512-Psm+g3/wHXhjBEktkxXsFMZvd3nemI0r3IPsE0bU+4//PnvNWKkzhZcEsbPcYiWqe8XqXJJEg4Tgtr7Raw67Yw==" + "resolved" "https://registry.npmjs.org/mongodb/-/mongodb-3.7.3.tgz" + "version" "3.7.3" dependencies: - basic-auth "~2.0.1" - debug "2.6.9" - depd "~2.0.0" - on-finished "~2.3.0" - on-headers "~1.0.2" + "bl" "^2.2.1" + "bson" "^1.1.4" + "denque" "^1.4.1" + "optional-require" "^1.1.8" + "safe-buffer" "^5.1.2" + optionalDependencies: + "saslprep" "^1.0.0" -ms@2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz" - integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== - -ms@2.1.2, ms@^2.1.1: - version "2.1.2" - resolved "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" - integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== - -ms@2.1.3, ms@^2.0.0: - version "2.1.3" - resolved "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" - integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== - -multer@^1.4.5-lts.1: - version "1.4.5-lts.1" - resolved "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.1.tgz" - integrity sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ== +"morgan@^1.10.0": + "integrity" "sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==" + "resolved" "https://registry.npmjs.org/morgan/-/morgan-1.10.0.tgz" + "version" "1.10.0" dependencies: - append-field "^1.0.0" - busboy "^1.0.0" - concat-stream "^1.5.2" - mkdirp "^0.5.4" - object-assign "^4.1.1" - type-is "^1.6.4" - xtend "^4.0.0" + "basic-auth" "~2.0.1" + "debug" "2.6.9" + "depd" "~2.0.0" + "on-finished" "~2.3.0" + "on-headers" "~1.0.2" -mysql2@^2.3.3: - version "2.3.3" - resolved "https://registry.yarnpkg.com/mysql2/-/mysql2-2.3.3.tgz#944f3deca4b16629052ff8614fbf89d5552545a0" - integrity sha512-wxJUev6LgMSgACDkb/InIFxDprRa6T95+VEoR+xPvtngtccNH2dGjEB/fVZ8yg1gWv1510c9CvXuJHi5zUm0ZA== +"ms@^2.0.0", "ms@^2.1.1", "ms@2.1.2": + "integrity" "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + "resolved" "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz" + "version" "2.1.2" + +"ms@2.0.0": + "integrity" "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" + "resolved" "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz" + "version" "2.0.0" + +"ms@2.1.3": + "integrity" "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" + "resolved" "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz" + "version" "2.1.3" + +"multer@^1.4.5-lts.1": + "integrity" "sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ==" + "resolved" "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.1.tgz" + "version" "1.4.5-lts.1" dependencies: - denque "^2.0.1" - generate-function "^2.3.1" - iconv-lite "^0.6.3" - long "^4.0.0" - lru-cache "^6.0.0" - named-placeholders "^1.1.2" - seq-queue "^0.0.5" - sqlstring "^2.3.2" + "append-field" "^1.0.0" + "busboy" "^1.0.0" + "concat-stream" "^1.5.2" + "mkdirp" "^0.5.4" + "object-assign" "^4.1.1" + "type-is" "^1.6.4" + "xtend" "^4.0.0" -mz@^2.4.0: - version "2.7.0" - resolved "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz" - integrity sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q== +"mysql2@^2.2.5", "mysql2@^2.3.3": + "integrity" "sha512-wxJUev6LgMSgACDkb/InIFxDprRa6T95+VEoR+xPvtngtccNH2dGjEB/fVZ8yg1gWv1510c9CvXuJHi5zUm0ZA==" + "resolved" "https://registry.npmjs.org/mysql2/-/mysql2-2.3.3.tgz" + "version" "2.3.3" dependencies: - any-promise "^1.0.0" - object-assign "^4.0.1" - thenify-all "^1.0.0" + "denque" "^2.0.1" + "generate-function" "^2.3.1" + "iconv-lite" "^0.6.3" + "long" "^4.0.0" + "lru-cache" "^6.0.0" + "named-placeholders" "^1.1.2" + "seq-queue" "^0.0.5" + "sqlstring" "^2.3.2" -named-placeholders@^1.1.2: - version "1.1.2" - resolved "https://registry.yarnpkg.com/named-placeholders/-/named-placeholders-1.1.2.tgz#ceb1fbff50b6b33492b5cf214ccf5e39cef3d0e8" - integrity sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA== +"mz@^2.4.0": + "integrity" "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==" + "resolved" "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz" + "version" "2.7.0" dependencies: - lru-cache "^4.1.3" + "any-promise" "^1.0.0" + "object-assign" "^4.0.1" + "thenify-all" "^1.0.0" -nan@^2.15.0: - version "2.16.0" - resolved "https://registry.npmjs.org/nan/-/nan-2.16.0.tgz" - integrity sha512-UdAqHyFngu7TfQKsCBgAA6pWDkT8MAO7d0jyOecVhN5354xbLqdn8mV9Tat9gepAupm0bt2DbeaSC8vS52MuFA== +"named-placeholders@^1.1.2": + "integrity" "sha512-wiFWqxoLL3PGVReSZpjLVxyJ1bRqe+KKJVbr4hGs1KWfTZTQyezHFBbuKj9hsizHyGV2ne7EMjHdxEGAybD5SA==" + "resolved" "https://registry.npmjs.org/named-placeholders/-/named-placeholders-1.1.2.tgz" + "version" "1.1.2" + dependencies: + "lru-cache" "^4.1.3" -natural-compare@^1.4.0: - version "1.4.0" - resolved "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz" - integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== +"nan@^2.15.0": + "integrity" "sha512-UdAqHyFngu7TfQKsCBgAA6pWDkT8MAO7d0jyOecVhN5354xbLqdn8mV9Tat9gepAupm0bt2DbeaSC8vS52MuFA==" + "resolved" "https://registry.npmjs.org/nan/-/nan-2.16.0.tgz" + "version" "2.16.0" -negotiator@0.6.3, negotiator@^0.6.2: - version "0.6.3" - resolved "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz" - integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== +"natural-compare@^1.4.0": + "integrity" "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==" + "resolved" "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz" + "version" "1.4.0" -netmask@^2.0.2: - version "2.0.2" - resolved "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz" - integrity sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg== +"negotiator@^0.6.2", "negotiator@0.6.3": + "integrity" "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==" + "resolved" "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz" + "version" "0.6.3" -nice-try@^1.0.4: - version "1.0.5" - resolved "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz" - integrity sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ== +"netmask@^2.0.2": + "integrity" "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==" + "resolved" "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz" + "version" "2.0.2" -node-2fa@^2.0.3: - version "2.0.3" - resolved "https://registry.npmjs.org/node-2fa/-/node-2fa-2.0.3.tgz" - integrity sha512-PQldrOhjuoZyoydMvMSctllPN1ZPZ1/NwkEcgYwY9faVqE/OymxR+3awPpbWZxm6acLKqvmNqQmdqTsqYyflFw== +"nice-try@^1.0.4": + "integrity" "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" + "resolved" "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz" + "version" "1.0.5" + +"node-2fa@^2.0.3": + "integrity" "sha512-PQldrOhjuoZyoydMvMSctllPN1ZPZ1/NwkEcgYwY9faVqE/OymxR+3awPpbWZxm6acLKqvmNqQmdqTsqYyflFw==" + "resolved" "https://registry.npmjs.org/node-2fa/-/node-2fa-2.0.3.tgz" + "version" "2.0.3" dependencies: "@types/notp" "^2.0.0" - notp "^2.0.3" - thirty-two "1.0.2" - tslib "^2.1.0" + "notp" "^2.0.3" + "thirty-two" "1.0.2" + "tslib" "^2.1.0" -node-addon-api@^3.1.0: - version "3.2.1" - resolved "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz" - integrity sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A== +"node-addon-api@^3.1.0": + "integrity" "sha512-mmcei9JghVNDYydghQmeDX8KoAm0FAiYyIcUt/N4nhyAipB17pllZQDOJD2fotxABnt4Mdz+dKTO7eftLg4d0A==" + "resolved" "https://registry.npmjs.org/node-addon-api/-/node-addon-api-3.2.1.tgz" + "version" "3.2.1" -node-addon-api@^4.2.0: - version "4.3.0" - resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-4.3.0.tgz#52a1a0b475193e0928e98e0426a0d1254782b77f" - integrity sha512-73sE9+3UaLYYFmDsFZnqCInzPyh3MqIwZO9cw58yIqAZhONrrabrYyYe3TuIqtIiOuTXVhsGau8hcrhhwSsDIQ== +"node-addon-api@^4.2.0": + "integrity" "sha512-73sE9+3UaLYYFmDsFZnqCInzPyh3MqIwZO9cw58yIqAZhONrrabrYyYe3TuIqtIiOuTXVhsGau8hcrhhwSsDIQ==" + "resolved" "https://registry.npmjs.org/node-addon-api/-/node-addon-api-4.3.0.tgz" + "version" "4.3.0" -node-fetch@^2.6.7: - version "2.6.7" - resolved "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz" - integrity sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ== +"node-fetch@^2.6.7": + "integrity" "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==" + "resolved" "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz" + "version" "2.6.7" dependencies: - whatwg-url "^5.0.0" + "whatwg-url" "^5.0.0" -node-gyp@8.x: - version "8.4.1" - resolved "https://registry.yarnpkg.com/node-gyp/-/node-gyp-8.4.1.tgz#3d49308fc31f768180957d6b5746845fbd429937" - integrity sha512-olTJRgUtAb/hOXG0E93wZDs5YiJlgbXxTwQAFHyNlRsXQnYzUaF2aGgujZbw+hR8aF4ZG/rST57bWMWD16jr9w== +"node-gyp@8.x": + "integrity" "sha512-olTJRgUtAb/hOXG0E93wZDs5YiJlgbXxTwQAFHyNlRsXQnYzUaF2aGgujZbw+hR8aF4ZG/rST57bWMWD16jr9w==" + "resolved" "https://registry.npmjs.org/node-gyp/-/node-gyp-8.4.1.tgz" + "version" "8.4.1" dependencies: - env-paths "^2.2.0" - glob "^7.1.4" - graceful-fs "^4.2.6" - make-fetch-happen "^9.1.0" - nopt "^5.0.0" - npmlog "^6.0.0" - rimraf "^3.0.2" - semver "^7.3.5" - tar "^6.1.2" - which "^2.0.2" + "env-paths" "^2.2.0" + "glob" "^7.1.4" + "graceful-fs" "^4.2.6" + "make-fetch-happen" "^9.1.0" + "nopt" "^5.0.0" + "npmlog" "^6.0.0" + "rimraf" "^3.0.2" + "semver" "^7.3.5" + "tar" "^6.1.2" + "which" "^2.0.2" -node-int64@^0.4.0: - version "0.4.0" - resolved "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz" - integrity sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw== +"node-int64@^0.4.0": + "integrity" "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==" + "resolved" "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz" + "version" "0.4.0" -node-releases@^2.0.6: - version "2.0.6" - resolved "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz" - integrity sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg== +"node-releases@^2.0.6": + "integrity" "sha512-PiVXnNuFm5+iYkLBNeq5211hvO38y63T0i2KKh2KnUs3RpzJ+JtODFjkD8yjLwnDkTYF1eKXheUwdssR+NRZdg==" + "resolved" "https://registry.npmjs.org/node-releases/-/node-releases-2.0.6.tgz" + "version" "2.0.6" -nopt@^5.0.0: - version "5.0.0" - resolved "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz" - integrity sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ== +"nopt@^5.0.0": + "integrity" "sha512-Tbj67rffqceeLpcRXrT7vKAN8CwfPeIBgM7E6iBkmKLV7bEMwpGgYLGv0jACUsECaa/vuxP0IjEont6umdMgtQ==" + "resolved" "https://registry.npmjs.org/nopt/-/nopt-5.0.0.tgz" + "version" "5.0.0" dependencies: - abbrev "1" + "abbrev" "1" -normalize-path@^3.0.0, normalize-path@~3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" - integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== +"normalize-path@^3.0.0", "normalize-path@~3.0.0": + "integrity" "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" + "resolved" "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz" + "version" "3.0.0" -notp@^2.0.3: - version "2.0.3" - resolved "https://registry.npmjs.org/notp/-/notp-2.0.3.tgz" - integrity sha512-oBig/2uqkjQ5AkBuw4QJYwkEWa/q+zHxI5/I5z6IeP2NT0alpJFsP/trrfCC+9xOAgQSZXssNi962kp5KBmypQ== +"notp@^2.0.3": + "integrity" "sha512-oBig/2uqkjQ5AkBuw4QJYwkEWa/q+zHxI5/I5z6IeP2NT0alpJFsP/trrfCC+9xOAgQSZXssNi962kp5KBmypQ==" + "resolved" "https://registry.npmjs.org/notp/-/notp-2.0.3.tgz" + "version" "2.0.3" -npm-run-path@^4.0.1: - version "4.0.1" - resolved "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz" - integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== +"npm-run-path@^4.0.1": + "integrity" "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==" + "resolved" "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz" + "version" "4.0.1" dependencies: - path-key "^3.0.0" + "path-key" "^3.0.0" -npmlog@^5.0.1: - version "5.0.1" - resolved "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz" - integrity sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw== +"npmlog@^5.0.1": + "integrity" "sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw==" + "resolved" "https://registry.npmjs.org/npmlog/-/npmlog-5.0.1.tgz" + "version" "5.0.1" dependencies: - are-we-there-yet "^2.0.0" - console-control-strings "^1.1.0" - gauge "^3.0.0" - set-blocking "^2.0.0" + "are-we-there-yet" "^2.0.0" + "console-control-strings" "^1.1.0" + "gauge" "^3.0.0" + "set-blocking" "^2.0.0" -npmlog@^6.0.0: - version "6.0.2" - resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-6.0.2.tgz#c8166017a42f2dea92d6453168dd865186a70830" - integrity sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg== +"npmlog@^6.0.0": + "integrity" "sha512-/vBvz5Jfr9dT/aFWd0FIRf+T/Q2WBsLENygUaFUqstqsycmZAP/t5BvFJTK0viFmSUxiUKTUplWy5vt+rvKIxg==" + "resolved" "https://registry.npmjs.org/npmlog/-/npmlog-6.0.2.tgz" + "version" "6.0.2" dependencies: - are-we-there-yet "^3.0.0" - console-control-strings "^1.1.0" - gauge "^4.0.3" - set-blocking "^2.0.0" + "are-we-there-yet" "^3.0.0" + "console-control-strings" "^1.1.0" + "gauge" "^4.0.3" + "set-blocking" "^2.0.0" -nth-check@^2.0.1: - version "2.1.1" - resolved "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz" - integrity sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w== +"nth-check@^2.0.1": + "integrity" "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==" + "resolved" "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz" + "version" "2.1.1" dependencies: - boolbase "^1.0.0" + "boolbase" "^1.0.0" -object-assign@^4.0.1, object-assign@^4.1.1: - version "4.1.1" - resolved "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz" - integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== +"object-assign@^4.0.1", "object-assign@^4.1.1": + "integrity" "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==" + "resolved" "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz" + "version" "4.1.1" -object-inspect@^1.9.0: - version "1.12.2" - resolved "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz" - integrity sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ== +"object-inspect@^1.9.0": + "integrity" "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==" + "resolved" "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz" + "version" "1.12.2" -object-keys@^1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz" - integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== +"object-keys@^1.1.1": + "integrity" "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==" + "resolved" "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz" + "version" "1.1.1" -object.assign@^4.1.0: - version "4.1.2" - resolved "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz" - integrity sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ== +"object.assign@^4.1.0": + "integrity" "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==" + "resolved" "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz" + "version" "4.1.2" dependencies: - call-bind "^1.0.0" - define-properties "^1.1.3" - has-symbols "^1.0.1" - object-keys "^1.1.1" + "call-bind" "^1.0.0" + "define-properties" "^1.1.3" + "has-symbols" "^1.0.1" + "object-keys" "^1.1.1" -on-finished@2.4.1: - version "2.4.1" - resolved "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz" - integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== +"on-finished@~2.3.0": + "integrity" "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==" + "resolved" "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz" + "version" "2.3.0" dependencies: - ee-first "1.1.1" + "ee-first" "1.1.1" -on-finished@~2.3.0: - version "2.3.0" - resolved "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz" - integrity sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww== +"on-finished@2.4.1": + "integrity" "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==" + "resolved" "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz" + "version" "2.4.1" dependencies: - ee-first "1.1.1" + "ee-first" "1.1.1" -on-headers@~1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz" - integrity sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA== +"on-headers@~1.0.2": + "integrity" "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" + "resolved" "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz" + "version" "1.0.2" -once@1.4.0, once@^1.3.0, once@^1.3.1: - version "1.4.0" - resolved "https://registry.npmjs.org/once/-/once-1.4.0.tgz" - integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== +"once@^1.3.0", "once@^1.3.1", "once@1.4.0": + "integrity" "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==" + "resolved" "https://registry.npmjs.org/once/-/once-1.4.0.tgz" + "version" "1.4.0" dependencies: - wrappy "1" + "wrappy" "1" -onetime@^5.1.2: - version "5.1.2" - resolved "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz" - integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== +"onetime@^5.1.2": + "integrity" "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==" + "resolved" "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz" + "version" "5.1.2" dependencies: - mimic-fn "^2.1.0" + "mimic-fn" "^2.1.0" -open@^7.4.2: - version "7.4.2" - resolved "https://registry.npmjs.org/open/-/open-7.4.2.tgz" - integrity sha512-MVHddDVweXZF3awtlAS+6pgKLlm/JgxZ90+/NBurBoQctVOOB/zDdVjcyPzQ+0laDGbsWgrRkflI65sQeOgT9Q== +"open@^7.4.2": + "integrity" "sha512-MVHddDVweXZF3awtlAS+6pgKLlm/JgxZ90+/NBurBoQctVOOB/zDdVjcyPzQ+0laDGbsWgrRkflI65sQeOgT9Q==" + "resolved" "https://registry.npmjs.org/open/-/open-7.4.2.tgz" + "version" "7.4.2" dependencies: - is-docker "^2.0.0" - is-wsl "^2.1.1" + "is-docker" "^2.0.0" + "is-wsl" "^2.1.1" -optionator@^0.8.1: - version "0.8.3" - resolved "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz" - integrity sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA== +"optional-require@^1.1.8": + "integrity" "sha512-jq83qaUb0wNg9Krv1c5OQ+58EK+vHde6aBPzLvPPqJm89UQWsvSuFy9X/OSNJnFeSOKo7btE0n8Nl2+nE+z5nA==" + "resolved" "https://registry.npmjs.org/optional-require/-/optional-require-1.1.8.tgz" + "version" "1.1.8" dependencies: - deep-is "~0.1.3" - fast-levenshtein "~2.0.6" - levn "~0.3.0" - prelude-ls "~1.1.2" - type-check "~0.3.2" - word-wrap "~1.2.3" + "require-at" "^1.0.6" -os-tmpdir@~1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz" - integrity sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g== - -p-limit@^2.2.0: - version "2.3.0" - resolved "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz" - integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== +"optionator@^0.8.1": + "integrity" "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==" + "resolved" "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz" + "version" "0.8.3" dependencies: - p-try "^2.0.0" + "deep-is" "~0.1.3" + "fast-levenshtein" "~2.0.6" + "levn" "~0.3.0" + "prelude-ls" "~1.1.2" + "type-check" "~0.3.2" + "word-wrap" "~1.2.3" -p-limit@^3.1.0: - version "3.1.0" - resolved "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz" - integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== +"os-tmpdir@~1.0.2": + "integrity" "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==" + "resolved" "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz" + "version" "1.0.2" + +"p-limit@^2.2.0": + "integrity" "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==" + "resolved" "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz" + "version" "2.3.0" dependencies: - yocto-queue "^0.1.0" + "p-try" "^2.0.0" -p-locate@^4.1.0: - version "4.1.0" - resolved "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz" - integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== +"p-limit@^3.1.0": + "integrity" "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==" + "resolved" "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz" + "version" "3.1.0" dependencies: - p-limit "^2.2.0" + "yocto-queue" "^0.1.0" -p-map@^4.0.0: - version "4.0.0" - resolved "https://registry.yarnpkg.com/p-map/-/p-map-4.0.0.tgz#bb2f95a5eda2ec168ec9274e06a747c3e2904d2b" - integrity sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ== +"p-locate@^4.1.0": + "integrity" "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==" + "resolved" "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz" + "version" "4.1.0" dependencies: - aggregate-error "^3.0.0" + "p-limit" "^2.2.0" -p-try@^2.0.0: - version "2.2.0" - resolved "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz" - integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== +"p-map@^4.0.0": + "integrity" "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==" + "resolved" "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz" + "version" "4.0.0" + dependencies: + "aggregate-error" "^3.0.0" -pac-proxy-agent@^5.0.0: - version "5.0.0" - resolved "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz" - integrity sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ== +"p-try@^2.0.0": + "integrity" "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" + "resolved" "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz" + "version" "2.2.0" + +"pac-proxy-agent@^5.0.0": + "integrity" "sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ==" + "resolved" "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz" + "version" "5.0.0" dependencies: "@tootallnate/once" "1" - agent-base "6" - debug "4" - get-uri "3" - http-proxy-agent "^4.0.1" - https-proxy-agent "5" - pac-resolver "^5.0.0" - raw-body "^2.2.0" - socks-proxy-agent "5" + "agent-base" "6" + "debug" "4" + "get-uri" "3" + "http-proxy-agent" "^4.0.1" + "https-proxy-agent" "5" + "pac-resolver" "^5.0.0" + "raw-body" "^2.2.0" + "socks-proxy-agent" "5" -pac-resolver@^5.0.0: - version "5.0.1" - resolved "https://registry.npmjs.org/pac-resolver/-/pac-resolver-5.0.1.tgz" - integrity sha512-cy7u00ko2KVgBAjuhevqpPeHIkCIqPe1v24cydhWjmeuzaBfmUWFCZJ1iAh5TuVzVZoUzXIW7K8sMYOZ84uZ9Q== +"pac-resolver@^5.0.0": + "integrity" "sha512-cy7u00ko2KVgBAjuhevqpPeHIkCIqPe1v24cydhWjmeuzaBfmUWFCZJ1iAh5TuVzVZoUzXIW7K8sMYOZ84uZ9Q==" + "resolved" "https://registry.npmjs.org/pac-resolver/-/pac-resolver-5.0.1.tgz" + "version" "5.0.1" dependencies: - degenerator "^3.0.2" - ip "^1.1.5" - netmask "^2.0.2" + "degenerator" "^3.0.2" + "ip" "^1.1.5" + "netmask" "^2.0.2" -packet-reader@1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/packet-reader/-/packet-reader-1.0.0.tgz#9238e5480dedabacfe1fe3f2771063f164157d74" - integrity sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ== +"packet-reader@1.0.0": + "integrity" "sha512-HAKu/fG3HpHFO0AA8WE8q2g+gBJaZ9MG7fcKk+IJPLTGAD6Psw4443l+9DGRbOIh3/aXr7Phy0TjilYivJo5XQ==" + "resolved" "https://registry.npmjs.org/packet-reader/-/packet-reader-1.0.0.tgz" + "version" "1.0.0" -parse-json@^5.2.0: - version "5.2.0" - resolved "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz" - integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== +"parse-json@^5.2.0": + "integrity" "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==" + "resolved" "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz" + "version" "5.2.0" dependencies: "@babel/code-frame" "^7.0.0" - error-ex "^1.3.1" - json-parse-even-better-errors "^2.3.0" - lines-and-columns "^1.1.6" + "error-ex" "^1.3.1" + "json-parse-even-better-errors" "^2.3.0" + "lines-and-columns" "^1.1.6" -parse5-htmlparser2-tree-adapter@^6.0.0: - version "6.0.1" - resolved "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz" - integrity sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA== +"parse5-htmlparser2-tree-adapter@^6.0.0": + "integrity" "sha512-qPuWvbLgvDGilKc5BoicRovlT4MtYT6JfJyBOMDsKoiT+GiuP5qyrPCnR9HcPECIJJmZh5jRndyNThnhhb/vlA==" + "resolved" "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-6.0.1.tgz" + "version" "6.0.1" dependencies: - parse5 "^6.0.1" + "parse5" "^6.0.1" -parse5-htmlparser2-tree-adapter@^7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz" - integrity sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g== +"parse5-htmlparser2-tree-adapter@^7.0.0": + "integrity" "sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g==" + "resolved" "https://registry.npmjs.org/parse5-htmlparser2-tree-adapter/-/parse5-htmlparser2-tree-adapter-7.0.0.tgz" + "version" "7.0.0" dependencies: - domhandler "^5.0.2" - parse5 "^7.0.0" + "domhandler" "^5.0.2" + "parse5" "^7.0.0" -parse5@^5.1.1: - version "5.1.1" - resolved "https://registry.npmjs.org/parse5/-/parse5-5.1.1.tgz" - integrity sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug== +"parse5@^5.1.1": + "integrity" "sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug==" + "resolved" "https://registry.npmjs.org/parse5/-/parse5-5.1.1.tgz" + "version" "5.1.1" -parse5@^6.0.1: - version "6.0.1" - resolved "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz" - integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== +"parse5@^6.0.1": + "integrity" "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==" + "resolved" "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz" + "version" "6.0.1" -parse5@^7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/parse5/-/parse5-7.0.0.tgz" - integrity sha512-y/t8IXSPWTuRZqXc0ajH/UwDj4mnqLEbSttNbThcFhGrZuOyoyvNBO85PBp2jQa55wY9d07PBNjsK8ZP3K5U6g== +"parse5@^7.0.0": + "integrity" "sha512-y/t8IXSPWTuRZqXc0ajH/UwDj4mnqLEbSttNbThcFhGrZuOyoyvNBO85PBp2jQa55wY9d07PBNjsK8ZP3K5U6g==" + "resolved" "https://registry.npmjs.org/parse5/-/parse5-7.0.0.tgz" + "version" "7.0.0" dependencies: - entities "^4.3.0" + "entities" "^4.3.0" -parseurl@~1.3.3: - version "1.3.3" - resolved "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz" - integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== +"parseurl@~1.3.3": + "integrity" "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" + "resolved" "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz" + "version" "1.3.3" -patch-package@^6.4.7: - version "6.4.7" - resolved "https://registry.npmjs.org/patch-package/-/patch-package-6.4.7.tgz" - integrity sha512-S0vh/ZEafZ17hbhgqdnpunKDfzHQibQizx9g8yEf5dcVk3KOflOfdufRXQX8CSEkyOQwuM/bNz1GwKvFj54kaQ== +"patch-package@^6.4.7": + "integrity" "sha512-S0vh/ZEafZ17hbhgqdnpunKDfzHQibQizx9g8yEf5dcVk3KOflOfdufRXQX8CSEkyOQwuM/bNz1GwKvFj54kaQ==" + "resolved" "https://registry.npmjs.org/patch-package/-/patch-package-6.4.7.tgz" + "version" "6.4.7" dependencies: "@yarnpkg/lockfile" "^1.1.0" - chalk "^2.4.2" - cross-spawn "^6.0.5" - find-yarn-workspace-root "^2.0.0" - fs-extra "^7.0.1" - is-ci "^2.0.0" - klaw-sync "^6.0.0" - minimist "^1.2.0" - open "^7.4.2" - rimraf "^2.6.3" - semver "^5.6.0" - slash "^2.0.0" - tmp "^0.0.33" + "chalk" "^2.4.2" + "cross-spawn" "^6.0.5" + "find-yarn-workspace-root" "^2.0.0" + "fs-extra" "^7.0.1" + "is-ci" "^2.0.0" + "klaw-sync" "^6.0.0" + "minimist" "^1.2.0" + "open" "^7.4.2" + "rimraf" "^2.6.3" + "semver" "^5.6.0" + "slash" "^2.0.0" + "tmp" "^0.0.33" -path-equal@^1.1.2: - version "1.2.2" - resolved "https://registry.npmjs.org/path-equal/-/path-equal-1.2.2.tgz" - integrity sha512-AUJvbcle1Zgb1TgtftHYknlrgrSYyI1ytrYgSbKUHSybwqUDnbD2cw9PIWivuMvsN+GTXmr/DRN4VBXpHG6aGg== +"path-equal@^1.1.2": + "integrity" "sha512-AUJvbcle1Zgb1TgtftHYknlrgrSYyI1ytrYgSbKUHSybwqUDnbD2cw9PIWivuMvsN+GTXmr/DRN4VBXpHG6aGg==" + "resolved" "https://registry.npmjs.org/path-equal/-/path-equal-1.2.2.tgz" + "version" "1.2.2" -path-exists@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz" - integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== +"path-exists@^4.0.0": + "integrity" "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" + "resolved" "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz" + "version" "4.0.0" -path-is-absolute@^1.0.0: - version "1.0.1" - resolved "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz" - integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== +"path-is-absolute@^1.0.0": + "integrity" "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==" + "resolved" "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz" + "version" "1.0.1" -path-key@^2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz" - integrity sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw== +"path-key@^2.0.1": + "integrity" "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==" + "resolved" "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz" + "version" "2.0.1" -path-key@^3.0.0, path-key@^3.1.0: - version "3.1.1" - resolved "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz" - integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== +"path-key@^3.0.0", "path-key@^3.1.0": + "integrity" "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==" + "resolved" "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz" + "version" "3.1.1" -path-parse@^1.0.7: - version "1.0.7" - resolved "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz" - integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== +"path-parse@^1.0.7": + "integrity" "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" + "resolved" "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz" + "version" "1.0.7" -path-to-regexp@0.1.7: - version "0.1.7" - resolved "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" - integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== +"path-to-regexp@0.1.7": + "integrity" "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" + "resolved" "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" + "version" "0.1.7" -peek-readable@^4.1.0: - version "4.1.0" - resolved "https://registry.npmjs.org/peek-readable/-/peek-readable-4.1.0.tgz" - integrity sha512-ZI3LnwUv5nOGbQzD9c2iDG6toheuXSZP5esSHBjopsXH4dg19soufvpUGA3uohi5anFtGb2lhAVdHzH6R/Evvg== +"peek-readable@^4.1.0": + "integrity" "sha512-ZI3LnwUv5nOGbQzD9c2iDG6toheuXSZP5esSHBjopsXH4dg19soufvpUGA3uohi5anFtGb2lhAVdHzH6R/Evvg==" + "resolved" "https://registry.npmjs.org/peek-readable/-/peek-readable-4.1.0.tgz" + "version" "4.1.0" -pg-connection-string@^2.5.0: - version "2.5.0" - resolved "https://registry.yarnpkg.com/pg-connection-string/-/pg-connection-string-2.5.0.tgz#538cadd0f7e603fc09a12590f3b8a452c2c0cf34" - integrity sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ== +"pg-connection-string@^2.5.0": + "integrity" "sha512-r5o/V/ORTA6TmUnyWZR9nCj1klXCO2CEKNRlVuJptZe85QuhFayC7WeMic7ndayT5IRIR0S0xFxFi2ousartlQ==" + "resolved" "https://registry.npmjs.org/pg-connection-string/-/pg-connection-string-2.5.0.tgz" + "version" "2.5.0" -pg-int8@1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/pg-int8/-/pg-int8-1.0.1.tgz#943bd463bf5b71b4170115f80f8efc9a0c0eb78c" - integrity sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw== +"pg-int8@1.0.1": + "integrity" "sha512-WCtabS6t3c8SkpDBUlb1kjOs7l66xsGdKpIPZsg4wR+B3+u9UAum2odSsF9tnvxg80h4ZxLWMy4pRjOsFIqQpw==" + "resolved" "https://registry.npmjs.org/pg-int8/-/pg-int8-1.0.1.tgz" + "version" "1.0.1" -pg-pool@^3.5.1: - version "3.5.1" - resolved "https://registry.yarnpkg.com/pg-pool/-/pg-pool-3.5.1.tgz#f499ce76f9bf5097488b3b83b19861f28e4ed905" - integrity sha512-6iCR0wVrro6OOHFsyavV+i6KYL4lVNyYAB9RD18w66xSzN+d8b66HiwuP30Gp1SH5O9T82fckkzsRjlrhD0ioQ== +"pg-pool@^3.5.1": + "integrity" "sha512-6iCR0wVrro6OOHFsyavV+i6KYL4lVNyYAB9RD18w66xSzN+d8b66HiwuP30Gp1SH5O9T82fckkzsRjlrhD0ioQ==" + "resolved" "https://registry.npmjs.org/pg-pool/-/pg-pool-3.5.1.tgz" + "version" "3.5.1" -pg-protocol@^1.5.0: - version "1.5.0" - resolved "https://registry.yarnpkg.com/pg-protocol/-/pg-protocol-1.5.0.tgz#b5dd452257314565e2d54ab3c132adc46565a6a0" - integrity sha512-muRttij7H8TqRNu/DxrAJQITO4Ac7RmX3Klyr/9mJEOBeIpgnF8f9jAfRz5d3XwQZl5qBjF9gLsUtMPJE0vezQ== +"pg-protocol@^1.5.0": + "integrity" "sha512-muRttij7H8TqRNu/DxrAJQITO4Ac7RmX3Klyr/9mJEOBeIpgnF8f9jAfRz5d3XwQZl5qBjF9gLsUtMPJE0vezQ==" + "resolved" "https://registry.npmjs.org/pg-protocol/-/pg-protocol-1.5.0.tgz" + "version" "1.5.0" -pg-types@^2.1.0: - version "2.2.0" - resolved "https://registry.yarnpkg.com/pg-types/-/pg-types-2.2.0.tgz#2d0250d636454f7cfa3b6ae0382fdfa8063254a3" - integrity sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA== +"pg-types@^2.1.0": + "integrity" "sha512-qTAAlrEsl8s4OiEQY69wDvcMIdQN6wdz5ojQiOy6YRMuynxenON0O5oCpJI6lshc6scgAY8qvJ2On/p+CXY0GA==" + "resolved" "https://registry.npmjs.org/pg-types/-/pg-types-2.2.0.tgz" + "version" "2.2.0" dependencies: - pg-int8 "1.0.1" - postgres-array "~2.0.0" - postgres-bytea "~1.0.0" - postgres-date "~1.0.4" - postgres-interval "^1.1.0" + "pg-int8" "1.0.1" + "postgres-array" "~2.0.0" + "postgres-bytea" "~1.0.0" + "postgres-date" "~1.0.4" + "postgres-interval" "^1.1.0" -pg@^8.7.3: - version "8.7.3" - resolved "https://registry.yarnpkg.com/pg/-/pg-8.7.3.tgz#8a5bdd664ca4fda4db7997ec634c6e5455b27c44" - integrity sha512-HPmH4GH4H3AOprDJOazoIcpI49XFsHCe8xlrjHkWiapdbHK+HLtbm/GQzXYAZwmPju/kzKhjaSfMACG+8cgJcw== +"pg@^8.5.1", "pg@^8.7.3", "pg@>=8.0": + "integrity" "sha512-HPmH4GH4H3AOprDJOazoIcpI49XFsHCe8xlrjHkWiapdbHK+HLtbm/GQzXYAZwmPju/kzKhjaSfMACG+8cgJcw==" + "resolved" "https://registry.npmjs.org/pg/-/pg-8.7.3.tgz" + "version" "8.7.3" dependencies: - buffer-writer "2.0.0" - packet-reader "1.0.0" - pg-connection-string "^2.5.0" - pg-pool "^3.5.1" - pg-protocol "^1.5.0" - pg-types "^2.1.0" - pgpass "1.x" + "buffer-writer" "2.0.0" + "packet-reader" "1.0.0" + "pg-connection-string" "^2.5.0" + "pg-pool" "^3.5.1" + "pg-protocol" "^1.5.0" + "pg-types" "^2.1.0" + "pgpass" "1.x" -pgpass@1.x: - version "1.0.5" - resolved "https://registry.yarnpkg.com/pgpass/-/pgpass-1.0.5.tgz#9b873e4a564bb10fa7a7dbd55312728d422a223d" - integrity sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug== +"pgpass@1.x": + "integrity" "sha512-FdW9r/jQZhSeohs1Z3sI1yxFQNFvMcnmfuj4WBMUTxOrAyLMaTcE1aAMBiTlbMNaXvBCQuVi0R7hd8udDSP7ug==" + "resolved" "https://registry.npmjs.org/pgpass/-/pgpass-1.0.5.tgz" + "version" "1.0.5" dependencies: - split2 "^4.1.0" + "split2" "^4.1.0" -picocolors@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz" - integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== +"picocolors@^1.0.0": + "integrity" "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" + "resolved" "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz" + "version" "1.0.0" -picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.3, picomatch@^2.3.1: - version "2.3.1" - resolved "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz" - integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== +"picomatch@^2.0.4", "picomatch@^2.2.1", "picomatch@^2.2.3", "picomatch@^2.3.1": + "integrity" "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==" + "resolved" "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz" + "version" "2.3.1" -pirates@^4.0.4: - version "4.0.5" - resolved "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz" - integrity sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ== +"pirates@^4.0.4": + "integrity" "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==" + "resolved" "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz" + "version" "4.0.5" -pkg-dir@^4.2.0: - version "4.2.0" - resolved "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz" - integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== +"pkg-dir@^4.2.0": + "integrity" "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==" + "resolved" "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz" + "version" "4.2.0" dependencies: - find-up "^4.0.0" + "find-up" "^4.0.0" -postgres-array@~2.0.0: - version "2.0.0" - resolved "https://registry.yarnpkg.com/postgres-array/-/postgres-array-2.0.0.tgz#48f8fce054fbc69671999329b8834b772652d82e" - integrity sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA== +"postgres-array@~2.0.0": + "integrity" "sha512-VpZrUqU5A69eQyW2c5CA1jtLecCsN2U/bD6VilrFDWq5+5UIEVO7nazS3TEcHf1zuPYO/sqGvUvW62g86RXZuA==" + "resolved" "https://registry.npmjs.org/postgres-array/-/postgres-array-2.0.0.tgz" + "version" "2.0.0" -postgres-bytea@~1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/postgres-bytea/-/postgres-bytea-1.0.0.tgz#027b533c0aa890e26d172d47cf9ccecc521acd35" - integrity sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w== +"postgres-bytea@~1.0.0": + "integrity" "sha512-xy3pmLuQqRBZBXDULy7KbaitYqLcmxigw14Q5sj8QBVLqEwXfeybIKVWiqAXTlcvdvb0+xkOtDbfQMOf4lST1w==" + "resolved" "https://registry.npmjs.org/postgres-bytea/-/postgres-bytea-1.0.0.tgz" + "version" "1.0.0" -postgres-date@~1.0.4: - version "1.0.7" - resolved "https://registry.yarnpkg.com/postgres-date/-/postgres-date-1.0.7.tgz#51bc086006005e5061c591cee727f2531bf641a8" - integrity sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q== +"postgres-date@~1.0.4": + "integrity" "sha512-suDmjLVQg78nMK2UZ454hAG+OAW+HQPZ6n++TNDUX+L0+uUlLywnoxJKDou51Zm+zTCjrCl0Nq6J9C5hP9vK/Q==" + "resolved" "https://registry.npmjs.org/postgres-date/-/postgres-date-1.0.7.tgz" + "version" "1.0.7" -postgres-interval@^1.1.0: - version "1.2.0" - resolved "https://registry.yarnpkg.com/postgres-interval/-/postgres-interval-1.2.0.tgz#b460c82cb1587507788819a06aa0fffdb3544695" - integrity sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ== +"postgres-interval@^1.1.0": + "integrity" "sha512-9ZhXKM/rw350N1ovuWHbGxnGh/SNJ4cnxHiM0rxE4VN41wsg8P8zWn9hv/buK00RP4WvlOyr/RBDiptyxVbkZQ==" + "resolved" "https://registry.npmjs.org/postgres-interval/-/postgres-interval-1.2.0.tgz" + "version" "1.2.0" dependencies: - xtend "^4.0.0" + "xtend" "^4.0.0" -prelude-ls@~1.1.2: - version "1.1.2" - resolved "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz" - integrity sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w== +"prelude-ls@~1.1.2": + "integrity" "sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w==" + "resolved" "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz" + "version" "1.1.2" -pretty-format@^28.1.3: - version "28.1.3" - resolved "https://registry.npmjs.org/pretty-format/-/pretty-format-28.1.3.tgz" - integrity sha512-8gFb/To0OmxHR9+ZTb14Df2vNxdGCX8g1xWGUTqUw5TiZvcQf5sHKObd5UcPyLLyowNwDAMTF3XWOG1B6mxl1Q== +"pretty-format@^28.1.3": + "integrity" "sha512-8gFb/To0OmxHR9+ZTb14Df2vNxdGCX8g1xWGUTqUw5TiZvcQf5sHKObd5UcPyLLyowNwDAMTF3XWOG1B6mxl1Q==" + "resolved" "https://registry.npmjs.org/pretty-format/-/pretty-format-28.1.3.tgz" + "version" "28.1.3" dependencies: "@jest/schemas" "^28.1.3" - ansi-regex "^5.0.1" - ansi-styles "^5.0.0" - react-is "^18.0.0" + "ansi-regex" "^5.0.1" + "ansi-styles" "^5.0.0" + "react-is" "^18.0.0" -process-nextick-args@~2.0.0: - version "2.0.1" - resolved "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz" - integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== +"process-nextick-args@~2.0.0": + "integrity" "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + "resolved" "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz" + "version" "2.0.1" -promise-inflight@^1.0.1: - version "1.0.1" - resolved "https://registry.yarnpkg.com/promise-inflight/-/promise-inflight-1.0.1.tgz#98472870bf228132fcbdd868129bad12c3c029e3" - integrity sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g== +"promise-inflight@^1.0.1": + "integrity" "sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==" + "resolved" "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz" + "version" "1.0.1" -promise-retry@^2.0.1: - version "2.0.1" - resolved "https://registry.yarnpkg.com/promise-retry/-/promise-retry-2.0.1.tgz#ff747a13620ab57ba688f5fc67855410c370da22" - integrity sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g== +"promise-retry@^2.0.1": + "integrity" "sha512-y+WKFlBR8BGXnsNlIHFGPZmyDf3DFMoLhaflAnyZgV6rG6xu+JwesTo2Q9R6XwYmtmwAFCkAk3e35jEdoeh/3g==" + "resolved" "https://registry.npmjs.org/promise-retry/-/promise-retry-2.0.1.tgz" + "version" "2.0.1" dependencies: - err-code "^2.0.2" - retry "^0.12.0" + "err-code" "^2.0.2" + "retry" "^0.12.0" -prompts@^2.0.1: - version "2.4.2" - resolved "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz" - integrity sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q== +"prompts@^2.0.1": + "integrity" "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==" + "resolved" "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz" + "version" "2.4.2" dependencies: - kleur "^3.0.3" - sisteransi "^1.0.5" + "kleur" "^3.0.3" + "sisteransi" "^1.0.5" -proxy-addr@~2.0.7: - version "2.0.7" - resolved "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz" - integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== +"proxy-addr@~2.0.7": + "integrity" "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==" + "resolved" "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz" + "version" "2.0.7" dependencies: - forwarded "0.2.0" - ipaddr.js "1.9.1" + "forwarded" "0.2.0" + "ipaddr.js" "1.9.1" -proxy-agent@^5.0.0: - version "5.0.0" - resolved "https://registry.npmjs.org/proxy-agent/-/proxy-agent-5.0.0.tgz" - integrity sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g== +"proxy-agent@^5.0.0": + "integrity" "sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g==" + "resolved" "https://registry.npmjs.org/proxy-agent/-/proxy-agent-5.0.0.tgz" + "version" "5.0.0" dependencies: - agent-base "^6.0.0" - debug "4" - http-proxy-agent "^4.0.0" - https-proxy-agent "^5.0.0" - lru-cache "^5.1.1" - pac-proxy-agent "^5.0.0" - proxy-from-env "^1.0.0" - socks-proxy-agent "^5.0.0" + "agent-base" "^6.0.0" + "debug" "4" + "http-proxy-agent" "^4.0.0" + "https-proxy-agent" "^5.0.0" + "lru-cache" "^5.1.1" + "pac-proxy-agent" "^5.0.0" + "proxy-from-env" "^1.0.0" + "socks-proxy-agent" "^5.0.0" -proxy-from-env@^1.0.0: - version "1.1.0" - resolved "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz" - integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== +"proxy-from-env@^1.0.0": + "integrity" "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==" + "resolved" "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz" + "version" "1.1.0" -pseudomap@^1.0.2: - version "1.0.2" - resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3" - integrity sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ== +"pseudomap@^1.0.2": + "integrity" "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==" + "resolved" "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz" + "version" "1.0.2" -punycode@^2.1.0: - version "2.1.1" - resolved "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz" - integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== +"punycode@^2.1.0": + "integrity" "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" + "resolved" "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz" + "version" "2.1.1" -qs@6.10.3, qs@^6.10.3: - version "6.10.3" - resolved "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz" - integrity sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ== +"qs@^6.10.3", "qs@6.10.3": + "integrity" "sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ==" + "resolved" "https://registry.npmjs.org/qs/-/qs-6.10.3.tgz" + "version" "6.10.3" dependencies: - side-channel "^1.0.4" + "side-channel" "^1.0.4" -qs@6.9.3: - version "6.9.3" - resolved "https://registry.npmjs.org/qs/-/qs-6.9.3.tgz" - integrity sha512-EbZYNarm6138UKKq46tdx08Yo/q9ZhFoAXAI1meAFd2GtbRDhbZY2WQSICskT0c5q99aFzLG1D4nvTk9tqfXIw== +"qs@6.9.3": + "integrity" "sha512-EbZYNarm6138UKKq46tdx08Yo/q9ZhFoAXAI1meAFd2GtbRDhbZY2WQSICskT0c5q99aFzLG1D4nvTk9tqfXIw==" + "resolved" "https://registry.npmjs.org/qs/-/qs-6.9.3.tgz" + "version" "6.9.3" -querystringify@^2.1.1: - version "2.2.0" - resolved "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz" - integrity sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ== +"querystringify@^2.1.1": + "integrity" "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==" + "resolved" "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz" + "version" "2.2.0" -queue@6.0.2: - version "6.0.2" - resolved "https://registry.npmjs.org/queue/-/queue-6.0.2.tgz" - integrity sha512-iHZWu+q3IdFZFX36ro/lKBkSvfkztY5Y7HMiPlOUjhupPcG2JMfst2KKEpu5XndviX/3UhFbRngUPNKtgvtZiA== +"queue@6.0.2": + "integrity" "sha512-iHZWu+q3IdFZFX36ro/lKBkSvfkztY5Y7HMiPlOUjhupPcG2JMfst2KKEpu5XndviX/3UhFbRngUPNKtgvtZiA==" + "resolved" "https://registry.npmjs.org/queue/-/queue-6.0.2.tgz" + "version" "6.0.2" dependencies: - inherits "~2.0.3" + "inherits" "~2.0.3" -range-parser@~1.2.1: - version "1.2.1" - resolved "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz" - integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== +"range-parser@~1.2.1": + "integrity" "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" + "resolved" "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz" + "version" "1.2.1" -raw-body@2.5.1, raw-body@^2.2.0: - version "2.5.1" - resolved "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz" - integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== +"raw-body@^2.2.0", "raw-body@2.5.1": + "integrity" "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==" + "resolved" "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz" + "version" "2.5.1" dependencies: - bytes "3.1.2" - http-errors "2.0.0" - iconv-lite "0.4.24" - unpipe "1.0.0" + "bytes" "3.1.2" + "http-errors" "2.0.0" + "iconv-lite" "0.4.24" + "unpipe" "1.0.0" -react-is@^18.0.0: - version "18.2.0" - resolved "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz" - integrity sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w== +"react-is@^18.0.0": + "integrity" "sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==" + "resolved" "https://registry.npmjs.org/react-is/-/react-is-18.2.0.tgz" + "version" "18.2.0" -readable-stream@1.1.x, "readable-stream@1.x >=1.1.9": - version "1.1.14" - resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz" - integrity sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ== +"readable-stream@^2.2.2": + "integrity" "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==" + "resolved" "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz" + "version" "2.3.7" dependencies: - core-util-is "~1.0.0" - inherits "~2.0.1" - isarray "0.0.1" - string_decoder "~0.10.x" + "core-util-is" "~1.0.0" + "inherits" "~2.0.3" + "isarray" "~1.0.0" + "process-nextick-args" "~2.0.0" + "safe-buffer" "~5.1.1" + "string_decoder" "~1.1.1" + "util-deprecate" "~1.0.1" -readable-stream@^2.2.2: - version "2.3.7" - resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz" - integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== +"readable-stream@^2.3.5": + "integrity" "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==" + "resolved" "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz" + "version" "2.3.7" dependencies: - core-util-is "~1.0.0" - inherits "~2.0.3" - isarray "~1.0.0" - process-nextick-args "~2.0.0" - safe-buffer "~5.1.1" - string_decoder "~1.1.1" - util-deprecate "~1.0.1" + "core-util-is" "~1.0.0" + "inherits" "~2.0.3" + "isarray" "~1.0.0" + "process-nextick-args" "~2.0.0" + "safe-buffer" "~5.1.1" + "string_decoder" "~1.1.1" + "util-deprecate" "~1.0.1" -readable-stream@^3.6.0: - version "3.6.0" - resolved "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz" - integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== +"readable-stream@^3.6.0": + "integrity" "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==" + "resolved" "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz" + "version" "3.6.0" dependencies: - inherits "^2.0.3" - string_decoder "^1.1.1" - util-deprecate "^1.0.1" + "inherits" "^2.0.3" + "string_decoder" "^1.1.1" + "util-deprecate" "^1.0.1" -readable-web-to-node-stream@^3.0.0: - version "3.0.2" - resolved "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz" - integrity sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw== +"readable-stream@1.1.x", "readable-stream@1.x >=1.1.9": + "integrity" "sha512-+MeVjFf4L44XUkhM1eYbD8fyEsxcV81pqMSR5gblfcLCHfZvbrqy4/qYHE+/R5HoBUT11WV5O08Cr1n3YXkWVQ==" + "resolved" "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz" + "version" "1.1.14" dependencies: - readable-stream "^3.6.0" + "core-util-is" "~1.0.0" + "inherits" "~2.0.1" + "isarray" "0.0.1" + "string_decoder" "~0.10.x" -readdirp@~3.6.0: - version "3.6.0" - resolved "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz" - integrity sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA== +"readable-web-to-node-stream@^3.0.0": + "integrity" "sha512-ePeK6cc1EcKLEhJFt/AebMCLL+GgSKhuygrZ/GLaKZYEecIgIECf4UaUuaByiGtzckwR4ain9VzUh95T1exYGw==" + "resolved" "https://registry.npmjs.org/readable-web-to-node-stream/-/readable-web-to-node-stream-3.0.2.tgz" + "version" "3.0.2" dependencies: - picomatch "^2.2.1" + "readable-stream" "^3.6.0" -rechoir@^0.6.2: - version "0.6.2" - resolved "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz" - integrity sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw== +"readdirp@~3.6.0": + "integrity" "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==" + "resolved" "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz" + "version" "3.6.0" dependencies: - resolve "^1.1.6" + "picomatch" "^2.2.1" -reflect-metadata@^0.1.13: - version "0.1.13" - resolved "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz" - integrity sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg== - -regenerate-unicode-properties@^10.0.1: - version "10.0.1" - resolved "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz" - integrity sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw== +"rechoir@^0.6.2": + "integrity" "sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw==" + "resolved" "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz" + "version" "0.6.2" dependencies: - regenerate "^1.4.2" + "resolve" "^1.1.6" -regenerate@^1.4.2: - version "1.4.2" - resolved "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz" - integrity sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A== +"reflect-metadata@^0.1.13": + "integrity" "sha512-Ts1Y/anZELhSsjMcU605fU9RE4Oi3p5ORujwbIKXfWa+0Zxs510Qrmrce5/Jowq3cHSZSJqBjypxmHarc+vEWg==" + "resolved" "https://registry.npmjs.org/reflect-metadata/-/reflect-metadata-0.1.13.tgz" + "version" "0.1.13" -regenerator-runtime@^0.13.4: - version "0.13.9" - resolved "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz" - integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== +"regenerate-unicode-properties@^10.0.1": + "integrity" "sha512-vn5DU6yg6h8hP/2OkQo3K7uVILvY4iu0oI4t3HFa81UPkhGJwkRwM10JEc3upjdhHjs/k8GJY1sRBhk5sr69Bw==" + "resolved" "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.0.1.tgz" + "version" "10.0.1" + dependencies: + "regenerate" "^1.4.2" -regenerator-transform@^0.15.0: - version "0.15.0" - resolved "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz" - integrity sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg== +"regenerate@^1.4.2": + "integrity" "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==" + "resolved" "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz" + "version" "1.4.2" + +"regenerator-runtime@^0.13.4": + "integrity" "sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA==" + "resolved" "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz" + "version" "0.13.9" + +"regenerator-transform@^0.15.0": + "integrity" "sha512-LsrGtPmbYg19bcPHwdtmXwbW+TqNvtY4riE3P83foeHRroMbH6/2ddFBfab3t7kbzc7v7p4wbkIecHImqt0QNg==" + "resolved" "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.0.tgz" + "version" "0.15.0" dependencies: "@babel/runtime" "^7.8.4" -regexpu-core@^5.1.0: - version "5.1.0" - resolved "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz" - integrity sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA== +"regexpu-core@^5.1.0": + "integrity" "sha512-bb6hk+xWd2PEOkj5It46A16zFMs2mv86Iwpdu94la4S3sJ7C973h2dHpYKwIBGaWSO7cIRJ+UX0IeMaWcO4qwA==" + "resolved" "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.1.0.tgz" + "version" "5.1.0" dependencies: - regenerate "^1.4.2" - regenerate-unicode-properties "^10.0.1" - regjsgen "^0.6.0" - regjsparser "^0.8.2" - unicode-match-property-ecmascript "^2.0.0" - unicode-match-property-value-ecmascript "^2.0.0" + "regenerate" "^1.4.2" + "regenerate-unicode-properties" "^10.0.1" + "regjsgen" "^0.6.0" + "regjsparser" "^0.8.2" + "unicode-match-property-ecmascript" "^2.0.0" + "unicode-match-property-value-ecmascript" "^2.0.0" -regjsgen@^0.6.0: - version "0.6.0" - resolved "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz" - integrity sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA== +"regjsgen@^0.6.0": + "integrity" "sha512-ozE883Uigtqj3bx7OhL1KNbCzGyW2NQZPl6Hs09WTvCuZD5sTI4JY58bkbQWa/Y9hxIsvJ3M8Nbf7j54IqeZbA==" + "resolved" "https://registry.npmjs.org/regjsgen/-/regjsgen-0.6.0.tgz" + "version" "0.6.0" -regjsparser@^0.8.2: - version "0.8.4" - resolved "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz" - integrity sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA== +"regjsparser@^0.8.2": + "integrity" "sha512-J3LABycON/VNEu3abOviqGHuB/LOtOQj8SKmfP9anY5GfAVw/SPjwzSjxGjbZXIxbGfqTHtJw58C2Li/WkStmA==" + "resolved" "https://registry.npmjs.org/regjsparser/-/regjsparser-0.8.4.tgz" + "version" "0.8.4" dependencies: - jsesc "~0.5.0" + "jsesc" "~0.5.0" -require-directory@^2.1.1: - version "2.1.1" - resolved "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz" - integrity sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q== +"require-at@^1.0.6": + "integrity" "sha512-7i1auJbMUrXEAZCOQ0VNJgmcT2VOKPRl2YGJwgpHpC9CE91Mv4/4UYIUm4chGJaI381ZDq1JUicFii64Hapd8g==" + "resolved" "https://registry.npmjs.org/require-at/-/require-at-1.0.6.tgz" + "version" "1.0.6" -require-from-string@^2.0.2: - version "2.0.2" - resolved "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz" - integrity sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw== +"require-directory@^2.1.1": + "integrity" "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==" + "resolved" "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz" + "version" "2.1.1" -requires-port@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz" - integrity sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ== +"require-from-string@^2.0.2": + "integrity" "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==" + "resolved" "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz" + "version" "2.0.2" -resolve-cwd@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz" - integrity sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg== +"requires-port@^1.0.0": + "integrity" "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==" + "resolved" "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz" + "version" "1.0.0" + +"resolve-cwd@^3.0.0": + "integrity" "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==" + "resolved" "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz" + "version" "3.0.0" dependencies: - resolve-from "^5.0.0" + "resolve-from" "^5.0.0" -resolve-from@^5.0.0: - version "5.0.0" - resolved "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz" - integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw== +"resolve-from@^5.0.0": + "integrity" "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==" + "resolved" "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz" + "version" "5.0.0" -resolve.exports@^1.1.0: - version "1.1.0" - resolved "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz" - integrity sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ== +"resolve.exports@^1.1.0": + "integrity" "sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ==" + "resolved" "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz" + "version" "1.1.0" -resolve@^1.0.0, resolve@^1.1.6, resolve@^1.12.0, resolve@^1.14.2, resolve@^1.20.0, resolve@^1.22.1: - version "1.22.1" - resolved "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz" - integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw== +"resolve@^1.0.0", "resolve@^1.1.6", "resolve@^1.12.0", "resolve@^1.14.2", "resolve@^1.20.0", "resolve@^1.22.1": + "integrity" "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==" + "resolved" "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz" + "version" "1.22.1" dependencies: - is-core-module "^2.9.0" - path-parse "^1.0.7" - supports-preserve-symlinks-flag "^1.0.0" + "is-core-module" "^2.9.0" + "path-parse" "^1.0.7" + "supports-preserve-symlinks-flag" "^1.0.0" -retry@^0.12.0: - version "0.12.0" - resolved "https://registry.yarnpkg.com/retry/-/retry-0.12.0.tgz#1b42a6266a21f07421d1b0b54b7dc167b01c013b" - integrity sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow== +"retry@^0.12.0": + "integrity" "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==" + "resolved" "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz" + "version" "0.12.0" -rimraf@^2.6.1, rimraf@^2.6.3: - version "2.7.1" - resolved "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz" - integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== +"rimraf@^2.6.1": + "integrity" "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==" + "resolved" "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz" + "version" "2.7.1" dependencies: - glob "^7.1.3" + "glob" "^7.1.3" -rimraf@^3.0.0, rimraf@^3.0.2: - version "3.0.2" - resolved "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz" - integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== +"rimraf@^2.6.3": + "integrity" "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==" + "resolved" "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz" + "version" "2.7.1" dependencies: - glob "^7.1.3" + "glob" "^7.1.3" -safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1, safe-buffer@~5.1.2: - version "5.1.2" - resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" - integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== +"rimraf@^3.0.0", "rimraf@^3.0.2": + "integrity" "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==" + "resolved" "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz" + "version" "3.0.2" + dependencies: + "glob" "^7.1.3" -safe-buffer@5.2.1, safe-buffer@^5.0.1, safe-buffer@~5.2.0: - version "5.2.1" - resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" - integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== +"safe-buffer@^5.0.1", "safe-buffer@^5.1.2", "safe-buffer@~5.2.0", "safe-buffer@5.2.1": + "integrity" "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" + "resolved" "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" + "version" "5.2.1" -safe-stable-stringify@^2.2.0: - version "2.3.1" - resolved "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.3.1.tgz" - integrity sha512-kYBSfT+troD9cDA85VDnHZ1rpHC50O0g1e6WlGHVCz/g+JS+9WKLj+XwFYyR8UbrZN8ll9HUpDAAddY58MGisg== +"safe-buffer@^5.1.1", "safe-buffer@~5.1.0", "safe-buffer@~5.1.1": + "integrity" "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + "resolved" "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" + "version" "5.1.2" + +"safe-buffer@~5.1.2": + "integrity" "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + "resolved" "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" + "version" "5.1.2" + +"safe-buffer@5.1.2": + "integrity" "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + "resolved" "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz" + "version" "5.1.2" + +"safe-stable-stringify@^2.2.0": + "integrity" "sha512-kYBSfT+troD9cDA85VDnHZ1rpHC50O0g1e6WlGHVCz/g+JS+9WKLj+XwFYyR8UbrZN8ll9HUpDAAddY58MGisg==" + "resolved" "https://registry.npmjs.org/safe-stable-stringify/-/safe-stable-stringify-2.3.1.tgz" + "version" "2.3.1" "safer-buffer@>= 2.1.2 < 3", "safer-buffer@>= 2.1.2 < 3.0.0": - version "2.1.2" - resolved "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz" - integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + "integrity" "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" + "resolved" "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz" + "version" "2.1.2" -sax@>=0.6.0: - version "1.2.4" - resolved "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz" - integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== - -semver@7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz" - integrity sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A== - -semver@^5.5.0, semver@^5.6.0: - version "5.7.1" - resolved "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz" - integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== - -semver@^6.0.0, semver@^6.1.1, semver@^6.1.2, semver@^6.3.0: - version "6.3.0" - resolved "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz" - integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== - -semver@^7.3.5, semver@^7.3.7: - version "7.3.7" - resolved "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz" - integrity sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g== +"saslprep@^1.0.0": + "integrity" "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==" + "resolved" "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz" + "version" "1.0.3" dependencies: - lru-cache "^6.0.0" + "sparse-bitfield" "^3.0.3" -send@0.18.0: - version "0.18.0" - resolved "https://registry.npmjs.org/send/-/send-0.18.0.tgz" - integrity sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg== +"sax@>=0.6.0": + "integrity" "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" + "resolved" "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz" + "version" "1.2.4" + +"semver@^5.5.0", "semver@^5.6.0": + "integrity" "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + "resolved" "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz" + "version" "5.7.1" + +"semver@^6.0.0", "semver@^6.1.1", "semver@^6.1.2", "semver@^6.3.0": + "integrity" "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + "resolved" "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz" + "version" "6.3.0" + +"semver@^7.3.5": + "integrity" "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==" + "resolved" "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz" + "version" "7.3.7" dependencies: - debug "2.6.9" - depd "2.0.0" - destroy "1.2.0" - encodeurl "~1.0.2" - escape-html "~1.0.3" - etag "~1.8.1" - fresh "0.5.2" - http-errors "2.0.0" - mime "1.6.0" - ms "2.1.3" - on-finished "2.4.1" - range-parser "~1.2.1" - statuses "2.0.1" + "lru-cache" "^6.0.0" -seq-queue@^0.0.5: - version "0.0.5" - resolved "https://registry.yarnpkg.com/seq-queue/-/seq-queue-0.0.5.tgz#d56812e1c017a6e4e7c3e3a37a1da6d78dd3c93e" - integrity sha512-hr3Wtp/GZIc/6DAGPDcV4/9WoZhjrkXsi5B/07QgX8tsdc6ilr7BFM6PM6rbdAX1kFSDYeZGLipIZZKyQP0O5Q== - -serve-static@1.15.0: - version "1.15.0" - resolved "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz" - integrity sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g== +"semver@^7.3.7": + "integrity" "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==" + "resolved" "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz" + "version" "7.3.7" dependencies: - encodeurl "~1.0.2" - escape-html "~1.0.3" - parseurl "~1.3.3" - send "0.18.0" + "lru-cache" "^6.0.0" -set-blocking@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz" - integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw== +"semver@7.0.0": + "integrity" "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==" + "resolved" "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz" + "version" "7.0.0" -setprototypeof@1.2.0: - version "1.2.0" - resolved "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz" - integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw== - -sha.js@^2.4.11: - version "2.4.11" - resolved "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz" - integrity sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ== +"send@0.18.0": + "integrity" "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==" + "resolved" "https://registry.npmjs.org/send/-/send-0.18.0.tgz" + "version" "0.18.0" dependencies: - inherits "^2.0.1" - safe-buffer "^5.0.1" + "debug" "2.6.9" + "depd" "2.0.0" + "destroy" "1.2.0" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "etag" "~1.8.1" + "fresh" "0.5.2" + "http-errors" "2.0.0" + "mime" "1.6.0" + "ms" "2.1.3" + "on-finished" "2.4.1" + "range-parser" "~1.2.1" + "statuses" "2.0.1" -shebang-command@^1.2.0: - version "1.2.0" - resolved "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz" - integrity sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg== +"seq-queue@^0.0.5": + "integrity" "sha512-hr3Wtp/GZIc/6DAGPDcV4/9WoZhjrkXsi5B/07QgX8tsdc6ilr7BFM6PM6rbdAX1kFSDYeZGLipIZZKyQP0O5Q==" + "resolved" "https://registry.npmjs.org/seq-queue/-/seq-queue-0.0.5.tgz" + "version" "0.0.5" + +"serve-static@1.15.0": + "integrity" "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==" + "resolved" "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz" + "version" "1.15.0" dependencies: - shebang-regex "^1.0.0" + "encodeurl" "~1.0.2" + "escape-html" "~1.0.3" + "parseurl" "~1.3.3" + "send" "0.18.0" -shebang-command@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz" - integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== +"set-blocking@^2.0.0": + "integrity" "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==" + "resolved" "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz" + "version" "2.0.0" + +"setprototypeof@1.2.0": + "integrity" "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" + "resolved" "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz" + "version" "1.2.0" + +"sha.js@^2.4.11": + "integrity" "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==" + "resolved" "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz" + "version" "2.4.11" dependencies: - shebang-regex "^3.0.0" + "inherits" "^2.0.1" + "safe-buffer" "^5.0.1" -shebang-regex@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz" - integrity sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ== - -shebang-regex@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz" - integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== - -shelljs@^0.8.5: - version "0.8.5" - resolved "https://registry.yarnpkg.com/shelljs/-/shelljs-0.8.5.tgz#de055408d8361bed66c669d2f000538ced8ee20c" - integrity sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow== +"shebang-command@^1.2.0": + "integrity" "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==" + "resolved" "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz" + "version" "1.2.0" dependencies: - glob "^7.0.0" - interpret "^1.0.0" - rechoir "^0.6.2" + "shebang-regex" "^1.0.0" -side-channel@^1.0.4: - version "1.0.4" - resolved "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz" - integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== +"shebang-command@^2.0.0": + "integrity" "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==" + "resolved" "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz" + "version" "2.0.0" dependencies: - call-bind "^1.0.0" - get-intrinsic "^1.0.2" - object-inspect "^1.9.0" + "shebang-regex" "^3.0.0" -signal-exit@^3.0.0, signal-exit@^3.0.3, signal-exit@^3.0.7: - version "3.0.7" - resolved "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz" - integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ== +"shebang-regex@^1.0.0": + "integrity" "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==" + "resolved" "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz" + "version" "1.0.0" -simple-concat@^1.0.0: - version "1.0.1" - resolved "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz" - integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== +"shebang-regex@^3.0.0": + "integrity" "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==" + "resolved" "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz" + "version" "3.0.0" -simple-get@^3.0.3: - version "3.1.1" - resolved "https://registry.npmjs.org/simple-get/-/simple-get-3.1.1.tgz" - integrity sha512-CQ5LTKGfCpvE1K0n2us+kuMPbk/q0EKl82s4aheV9oXjFEz6W/Y7oQFVJuU6QG77hRT4Ghb5RURteF5vnWjupA== +"shelljs@^0.8.5": + "integrity" "sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==" + "resolved" "https://registry.npmjs.org/shelljs/-/shelljs-0.8.5.tgz" + "version" "0.8.5" dependencies: - decompress-response "^4.2.0" - once "^1.3.1" - simple-concat "^1.0.0" + "glob" "^7.0.0" + "interpret" "^1.0.0" + "rechoir" "^0.6.2" -sisteransi@^1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz" - integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg== - -slash@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz" - integrity sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A== - -slash@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz" - integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== - -smart-buffer@^4.2.0: - version "4.2.0" - resolved "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz" - integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg== - -socks-proxy-agent@5, socks-proxy-agent@^5.0.0: - version "5.0.1" - resolved "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz" - integrity sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ== +"side-channel@^1.0.4": + "integrity" "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==" + "resolved" "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz" + "version" "1.0.4" dependencies: - agent-base "^6.0.2" - debug "4" - socks "^2.3.3" + "call-bind" "^1.0.0" + "get-intrinsic" "^1.0.2" + "object-inspect" "^1.9.0" -socks-proxy-agent@^6.0.0: - version "6.2.1" - resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-6.2.1.tgz#2687a31f9d7185e38d530bef1944fe1f1496d6ce" - integrity sha512-a6KW9G+6B3nWZ1yB8G7pJwL3ggLy1uTzKAgCb7ttblwqdz9fMGJUuTy3uFzEP48FAs9FLILlmzDlE2JJhVQaXQ== +"signal-exit@^3.0.0", "signal-exit@^3.0.3", "signal-exit@^3.0.7": + "integrity" "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" + "resolved" "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz" + "version" "3.0.7" + +"simple-concat@^1.0.0": + "integrity" "sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==" + "resolved" "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.1.tgz" + "version" "1.0.1" + +"simple-get@^3.0.3": + "integrity" "sha512-CQ5LTKGfCpvE1K0n2us+kuMPbk/q0EKl82s4aheV9oXjFEz6W/Y7oQFVJuU6QG77hRT4Ghb5RURteF5vnWjupA==" + "resolved" "https://registry.npmjs.org/simple-get/-/simple-get-3.1.1.tgz" + "version" "3.1.1" dependencies: - agent-base "^6.0.2" - debug "^4.3.3" - socks "^2.6.2" + "decompress-response" "^4.2.0" + "once" "^1.3.1" + "simple-concat" "^1.0.0" -socks@^2.3.3: - version "2.6.2" - resolved "https://registry.npmjs.org/socks/-/socks-2.6.2.tgz" - integrity sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA== +"sisteransi@^1.0.5": + "integrity" "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==" + "resolved" "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz" + "version" "1.0.5" + +"slash@^2.0.0": + "integrity" "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==" + "resolved" "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz" + "version" "2.0.0" + +"slash@^3.0.0": + "integrity" "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==" + "resolved" "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz" + "version" "3.0.0" + +"smart-buffer@^4.2.0": + "integrity" "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==" + "resolved" "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz" + "version" "4.2.0" + +"socks-proxy-agent@^5.0.0", "socks-proxy-agent@5": + "integrity" "sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ==" + "resolved" "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz" + "version" "5.0.1" dependencies: - ip "^1.1.5" - smart-buffer "^4.2.0" + "agent-base" "^6.0.2" + "debug" "4" + "socks" "^2.3.3" -socks@^2.6.2: - version "2.7.0" - resolved "https://registry.yarnpkg.com/socks/-/socks-2.7.0.tgz#f9225acdb841e874dca25f870e9130990f3913d0" - integrity sha512-scnOe9y4VuiNUULJN72GrM26BNOjVsfPXI+j+98PkyEfsIXroa5ofyjT+FzGvn/xHs73U2JtoBYAVx9Hl4quSA== +"socks-proxy-agent@^6.0.0": + "integrity" "sha512-a6KW9G+6B3nWZ1yB8G7pJwL3ggLy1uTzKAgCb7ttblwqdz9fMGJUuTy3uFzEP48FAs9FLILlmzDlE2JJhVQaXQ==" + "resolved" "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-6.2.1.tgz" + "version" "6.2.1" dependencies: - ip "^2.0.0" - smart-buffer "^4.2.0" + "agent-base" "^6.0.2" + "debug" "^4.3.3" + "socks" "^2.6.2" -source-map-support@0.5.13: - version "0.5.13" - resolved "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz" - integrity sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w== +"socks@^2.3.3", "socks@^2.6.2": + "integrity" "sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA==" + "resolved" "https://registry.npmjs.org/socks/-/socks-2.6.2.tgz" + "version" "2.6.2" dependencies: - buffer-from "^1.0.0" - source-map "^0.6.0" + "ip" "^1.1.5" + "smart-buffer" "^4.2.0" -source-map-support@^0.5.12: - version "0.5.21" - resolved "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz" - integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== +"source-map-support@^0.5.12": + "integrity" "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==" + "resolved" "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz" + "version" "0.5.21" dependencies: - buffer-from "^1.0.0" - source-map "^0.6.0" + "buffer-from" "^1.0.0" + "source-map" "^0.6.0" -source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: - version "0.6.1" - resolved "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" - integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== +"source-map-support@0.5.13": + "integrity" "sha512-SHSKFHadjVA5oR4PPqhtAVdcBWwRYVd6g6cAXnIbRiIwc2EhPrTuKUBdSLvlEKyIP3GCf89fltvcZiP9MMFA1w==" + "resolved" "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.13.tgz" + "version" "0.5.13" + dependencies: + "buffer-from" "^1.0.0" + "source-map" "^0.6.0" -split2@^4.1.0: - version "4.1.0" - resolved "https://registry.yarnpkg.com/split2/-/split2-4.1.0.tgz#101907a24370f85bb782f08adaabe4e281ecf809" - integrity sha512-VBiJxFkxiXRlUIeyMQi8s4hgvKCSjtknJv/LVYbrgALPwf5zSKmEwV9Lst25AkvMDnvxODugjdl6KZgwKM1WYQ== +"source-map@^0.6.0", "source-map@^0.6.1", "source-map@~0.6.1": + "integrity" "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + "resolved" "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz" + "version" "0.6.1" -sprintf-js@~1.0.2: - version "1.0.3" - resolved "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz" - integrity sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g== +"sparse-bitfield@^3.0.3": + "integrity" "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==" + "resolved" "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz" + "version" "3.0.3" + dependencies: + "memory-pager" "^1.0.2" -sqlite3@^5.0.11: - version "5.0.11" - resolved "https://registry.yarnpkg.com/sqlite3/-/sqlite3-5.0.11.tgz#102c835d70be66da9d95a383fd6ea084a082ef7f" - integrity sha512-4akFOr7u9lJEeAWLJxmwiV43DJcGV7w3ab7SjQFAFaTVyknY3rZjvXTKIVtWqUoY4xwhjwoHKYs2HDW2SoHVsA== +"split2@^4.1.0": + "integrity" "sha512-VBiJxFkxiXRlUIeyMQi8s4hgvKCSjtknJv/LVYbrgALPwf5zSKmEwV9Lst25AkvMDnvxODugjdl6KZgwKM1WYQ==" + "resolved" "https://registry.npmjs.org/split2/-/split2-4.1.0.tgz" + "version" "4.1.0" + +"sprintf-js@~1.0.2": + "integrity" "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==" + "resolved" "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz" + "version" "1.0.3" + +"sqlite3@^5.0.11", "sqlite3@^5.0.3": + "integrity" "sha512-4akFOr7u9lJEeAWLJxmwiV43DJcGV7w3ab7SjQFAFaTVyknY3rZjvXTKIVtWqUoY4xwhjwoHKYs2HDW2SoHVsA==" + "resolved" "https://registry.npmjs.org/sqlite3/-/sqlite3-5.0.11.tgz" + "version" "5.0.11" dependencies: "@mapbox/node-pre-gyp" "^1.0.0" - node-addon-api "^4.2.0" - tar "^6.1.11" + "node-addon-api" "^4.2.0" + "tar" "^6.1.11" optionalDependencies: - node-gyp "8.x" + "node-gyp" "8.x" -sqlstring@^2.3.2: - version "2.3.3" - resolved "https://registry.yarnpkg.com/sqlstring/-/sqlstring-2.3.3.tgz#2ddc21f03bce2c387ed60680e739922c65751d0c" - integrity sha512-qC9iz2FlN7DQl3+wjwn3802RTyjCx7sDvfQEXchwa6CWOx07/WVfh91gBmQ9fahw8snwGEWU3xGzOt4tFyHLxg== +"sqlstring@^2.3.2": + "integrity" "sha512-qC9iz2FlN7DQl3+wjwn3802RTyjCx7sDvfQEXchwa6CWOx07/WVfh91gBmQ9fahw8snwGEWU3xGzOt4tFyHLxg==" + "resolved" "https://registry.npmjs.org/sqlstring/-/sqlstring-2.3.3.tgz" + "version" "2.3.3" -ssri@^8.0.0, ssri@^8.0.1: - version "8.0.1" - resolved "https://registry.yarnpkg.com/ssri/-/ssri-8.0.1.tgz#638e4e439e2ffbd2cd289776d5ca457c4f51a2af" - integrity sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ== +"ssri@^8.0.0", "ssri@^8.0.1": + "integrity" "sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ==" + "resolved" "https://registry.npmjs.org/ssri/-/ssri-8.0.1.tgz" + "version" "8.0.1" dependencies: - minipass "^3.1.1" + "minipass" "^3.1.1" -stack-utils@^2.0.3: - version "2.0.5" - resolved "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz" - integrity sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA== +"stack-utils@^2.0.3": + "integrity" "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==" + "resolved" "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz" + "version" "2.0.5" dependencies: - escape-string-regexp "^2.0.0" + "escape-string-regexp" "^2.0.0" -statuses@2.0.1: - version "2.0.1" - resolved "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz" - integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== +"statuses@2.0.1": + "integrity" "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==" + "resolved" "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz" + "version" "2.0.1" -streamsearch@^1.1.0: - version "1.1.0" - resolved "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz" - integrity sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg== +"streamsearch@^1.1.0": + "integrity" "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==" + "resolved" "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz" + "version" "1.1.0" -string-length@^4.0.1: - version "4.0.2" - resolved "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz" - integrity sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ== +"string_decoder@^1.1.1": + "integrity" "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==" + "resolved" "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz" + "version" "1.3.0" dependencies: - char-regex "^1.0.2" - strip-ansi "^6.0.0" + "safe-buffer" "~5.2.0" -"string-width@^1.0.2 || 2 || 3 || 4", string-width@^4.1.0, string-width@^4.2.0, string-width@^4.2.3: - version "4.2.3" - resolved "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz" - integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== +"string_decoder@~0.10.x": + "integrity" "sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==" + "resolved" "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz" + "version" "0.10.31" + +"string_decoder@~1.1.1": + "integrity" "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==" + "resolved" "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz" + "version" "1.1.1" dependencies: - emoji-regex "^8.0.0" - is-fullwidth-code-point "^3.0.0" - strip-ansi "^6.0.1" + "safe-buffer" "~5.1.0" -string_decoder@^1.1.1: - version "1.3.0" - resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz" - integrity sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA== +"string-length@^4.0.1": + "integrity" "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==" + "resolved" "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz" + "version" "4.0.2" dependencies: - safe-buffer "~5.2.0" + "char-regex" "^1.0.2" + "strip-ansi" "^6.0.0" -string_decoder@~0.10.x: - version "0.10.31" - resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz" - integrity sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ== - -string_decoder@~1.1.1: - version "1.1.1" - resolved "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz" - integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== +"string-width@^1.0.2 || 2 || 3 || 4", "string-width@^4.1.0", "string-width@^4.2.0", "string-width@^4.2.3": + "integrity" "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==" + "resolved" "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz" + "version" "4.2.3" dependencies: - safe-buffer "~5.1.0" + "emoji-regex" "^8.0.0" + "is-fullwidth-code-point" "^3.0.0" + "strip-ansi" "^6.0.1" -strip-ansi@^6.0.0, strip-ansi@^6.0.1: - version "6.0.1" - resolved "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz" - integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== +"strip-ansi@^6.0.0", "strip-ansi@^6.0.1": + "integrity" "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==" + "resolved" "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz" + "version" "6.0.1" dependencies: - ansi-regex "^5.0.1" + "ansi-regex" "^5.0.1" -strip-bom@^3.0.0: - version "3.0.0" - resolved "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz" - integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== +"strip-bom@^3.0.0": + "integrity" "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==" + "resolved" "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz" + "version" "3.0.0" -strip-bom@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz" - integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== +"strip-bom@^4.0.0": + "integrity" "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==" + "resolved" "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz" + "version" "4.0.0" -strip-final-newline@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz" - integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== +"strip-final-newline@^2.0.0": + "integrity" "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==" + "resolved" "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz" + "version" "2.0.0" -strip-json-comments@^2.0.0: - version "2.0.1" - resolved "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz" - integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ== +"strip-json-comments@^2.0.0": + "integrity" "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==" + "resolved" "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz" + "version" "2.0.1" -strip-json-comments@^3.1.1: - version "3.1.1" - resolved "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz" - integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== +"strip-json-comments@^3.1.1": + "integrity" "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==" + "resolved" "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz" + "version" "3.1.1" -strtok3@^6.2.4: - version "6.3.0" - resolved "https://registry.npmjs.org/strtok3/-/strtok3-6.3.0.tgz" - integrity sha512-fZtbhtvI9I48xDSywd/somNqgUHl2L2cstmXCCif0itOf96jeW18MBSyrLuNicYQVkvpOxkZtkzujiTJ9LW5Jw== +"strtok3@^6.2.4": + "integrity" "sha512-fZtbhtvI9I48xDSywd/somNqgUHl2L2cstmXCCif0itOf96jeW18MBSyrLuNicYQVkvpOxkZtkzujiTJ9LW5Jw==" + "resolved" "https://registry.npmjs.org/strtok3/-/strtok3-6.3.0.tgz" + "version" "6.3.0" dependencies: "@tokenizer/token" "^0.3.0" - peek-readable "^4.1.0" + "peek-readable" "^4.1.0" -superagent@^8.0.0: - version "8.0.0" - resolved "https://registry.npmjs.org/superagent/-/superagent-8.0.0.tgz" - integrity sha512-iudipXEel+SzlP9y29UBWGDjB+Zzag+eeA1iLosaR2YHBRr1Q1kC29iBrF2zIVD9fqVbpZnXkN/VJmwFMVyNWg== +"superagent@^8.0.0": + "integrity" "sha512-iudipXEel+SzlP9y29UBWGDjB+Zzag+eeA1iLosaR2YHBRr1Q1kC29iBrF2zIVD9fqVbpZnXkN/VJmwFMVyNWg==" + "resolved" "https://registry.npmjs.org/superagent/-/superagent-8.0.0.tgz" + "version" "8.0.0" dependencies: - component-emitter "^1.3.0" - cookiejar "^2.1.3" - debug "^4.3.4" - fast-safe-stringify "^2.1.1" - form-data "^4.0.0" - formidable "^2.0.1" - methods "^1.1.2" - mime "2.6.0" - qs "^6.10.3" - readable-stream "^3.6.0" - semver "^7.3.7" + "component-emitter" "^1.3.0" + "cookiejar" "^2.1.3" + "debug" "^4.3.4" + "fast-safe-stringify" "^2.1.1" + "form-data" "^4.0.0" + "formidable" "^2.0.1" + "methods" "^1.1.2" + "mime" "2.6.0" + "qs" "^6.10.3" + "readable-stream" "^3.6.0" + "semver" "^7.3.7" -supertest@^6.1.6: - version "6.2.4" - resolved "https://registry.npmjs.org/supertest/-/supertest-6.2.4.tgz" - integrity sha512-M8xVnCNv+q2T2WXVzxDECvL2695Uv2uUj2O0utxsld/HRyJvOU8W9f1gvsYxSNU4wmIe0/L/ItnpU4iKq0emDA== +"supertest@^6.1.6": + "integrity" "sha512-M8xVnCNv+q2T2WXVzxDECvL2695Uv2uUj2O0utxsld/HRyJvOU8W9f1gvsYxSNU4wmIe0/L/ItnpU4iKq0emDA==" + "resolved" "https://registry.npmjs.org/supertest/-/supertest-6.2.4.tgz" + "version" "6.2.4" dependencies: - methods "^1.1.2" - superagent "^8.0.0" + "methods" "^1.1.2" + "superagent" "^8.0.0" -supports-color@^5.3.0: - version "5.5.0" - resolved "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz" - integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== +"supports-color@^5.3.0": + "integrity" "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==" + "resolved" "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz" + "version" "5.5.0" dependencies: - has-flag "^3.0.0" + "has-flag" "^3.0.0" -supports-color@^7.0.0, supports-color@^7.1.0: - version "7.2.0" - resolved "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz" - integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== +"supports-color@^7.0.0": + "integrity" "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==" + "resolved" "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz" + "version" "7.2.0" dependencies: - has-flag "^4.0.0" + "has-flag" "^4.0.0" -supports-color@^8.0.0: - version "8.1.1" - resolved "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz" - integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== +"supports-color@^7.1.0": + "integrity" "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==" + "resolved" "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz" + "version" "7.2.0" dependencies: - has-flag "^4.0.0" + "has-flag" "^4.0.0" -supports-hyperlinks@^2.0.0: - version "2.2.0" - resolved "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz" - integrity sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ== +"supports-color@^8.0.0": + "integrity" "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==" + "resolved" "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz" + "version" "8.1.1" dependencies: - has-flag "^4.0.0" - supports-color "^7.0.0" + "has-flag" "^4.0.0" -supports-preserve-symlinks-flag@^1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz" - integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== - -tar@^6.0.2, tar@^6.1.11, tar@^6.1.2: - version "6.1.11" - resolved "https://registry.npmjs.org/tar/-/tar-6.1.11.tgz" - integrity sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA== +"supports-hyperlinks@^2.0.0": + "integrity" "sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ==" + "resolved" "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz" + "version" "2.2.0" dependencies: - chownr "^2.0.0" - fs-minipass "^2.0.0" - minipass "^3.0.0" - minizlib "^2.1.1" - mkdirp "^1.0.3" - yallist "^4.0.0" + "has-flag" "^4.0.0" + "supports-color" "^7.0.0" -terminal-link@^2.0.0: - version "2.1.1" - resolved "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz" - integrity sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ== +"supports-preserve-symlinks-flag@^1.0.0": + "integrity" "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" + "resolved" "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz" + "version" "1.0.0" + +"tar@^6.0.2", "tar@^6.1.11", "tar@^6.1.2": + "integrity" "sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA==" + "resolved" "https://registry.npmjs.org/tar/-/tar-6.1.11.tgz" + "version" "6.1.11" dependencies: - ansi-escapes "^4.2.1" - supports-hyperlinks "^2.0.0" + "chownr" "^2.0.0" + "fs-minipass" "^2.0.0" + "minipass" "^3.0.0" + "minizlib" "^2.1.1" + "mkdirp" "^1.0.3" + "yallist" "^4.0.0" -test-exclude@^6.0.0: - version "6.0.0" - resolved "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz" - integrity sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w== +"terminal-link@^2.0.0": + "integrity" "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==" + "resolved" "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz" + "version" "2.1.1" + dependencies: + "ansi-escapes" "^4.2.1" + "supports-hyperlinks" "^2.0.0" + +"test-exclude@^6.0.0": + "integrity" "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==" + "resolved" "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz" + "version" "6.0.0" dependencies: "@istanbuljs/schema" "^0.1.2" - glob "^7.1.4" - minimatch "^3.0.4" + "glob" "^7.1.4" + "minimatch" "^3.0.4" -thenify-all@^1.0.0: - version "1.6.0" - resolved "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz" - integrity sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA== +"thenify-all@^1.0.0": + "integrity" "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==" + "resolved" "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz" + "version" "1.6.0" dependencies: - thenify ">= 3.1.0 < 4" + "thenify" ">= 3.1.0 < 4" "thenify@>= 3.1.0 < 4": - version "3.3.1" - resolved "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz" - integrity sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw== + "integrity" "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==" + "resolved" "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz" + "version" "3.3.1" dependencies: - any-promise "^1.0.0" + "any-promise" "^1.0.0" -thirty-two@1.0.2: - version "1.0.2" - resolved "https://registry.npmjs.org/thirty-two/-/thirty-two-1.0.2.tgz" - integrity sha512-OEI0IWCe+Dw46019YLl6V10Us5bi574EvlJEOcAkB29IzQ/mYD1A6RyNHLjZPiHCmuodxvgF6U+vZO1L15lxVA== +"thirty-two@1.0.2": + "integrity" "sha512-OEI0IWCe+Dw46019YLl6V10Us5bi574EvlJEOcAkB29IzQ/mYD1A6RyNHLjZPiHCmuodxvgF6U+vZO1L15lxVA==" + "resolved" "https://registry.npmjs.org/thirty-two/-/thirty-two-1.0.2.tgz" + "version" "1.0.2" -tmp@^0.0.33: - version "0.0.33" - resolved "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz" - integrity sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw== +"tmp@^0.0.33": + "integrity" "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==" + "resolved" "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz" + "version" "0.0.33" dependencies: - os-tmpdir "~1.0.2" + "os-tmpdir" "~1.0.2" -tmpl@1.0.5: - version "1.0.5" - resolved "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz" - integrity sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw== +"tmpl@1.0.5": + "integrity" "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==" + "resolved" "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz" + "version" "1.0.5" -to-fast-properties@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz" - integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== +"to-fast-properties@^2.0.0": + "integrity" "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==" + "resolved" "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz" + "version" "2.0.0" -to-regex-range@^5.0.1: - version "5.0.1" - resolved "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz" - integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== +"to-regex-range@^5.0.1": + "integrity" "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==" + "resolved" "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz" + "version" "5.0.1" dependencies: - is-number "^7.0.0" + "is-number" "^7.0.0" -toidentifier@1.0.1: - version "1.0.1" - resolved "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz" - integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== +"toidentifier@1.0.1": + "integrity" "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==" + "resolved" "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz" + "version" "1.0.1" -token-types@^4.1.1: - version "4.2.1" - resolved "https://registry.npmjs.org/token-types/-/token-types-4.2.1.tgz" - integrity sha512-6udB24Q737UD/SDsKAHI9FCRP7Bqc9D/MQUV02ORQg5iskjtLJlZJNdN4kKtcdtwCeWIwIHDGaUsTsCCAa8sFQ== +"token-types@^4.1.1": + "integrity" "sha512-6udB24Q737UD/SDsKAHI9FCRP7Bqc9D/MQUV02ORQg5iskjtLJlZJNdN4kKtcdtwCeWIwIHDGaUsTsCCAa8sFQ==" + "resolved" "https://registry.npmjs.org/token-types/-/token-types-4.2.1.tgz" + "version" "4.2.1" dependencies: "@tokenizer/token" "^0.3.0" - ieee754 "^1.2.1" + "ieee754" "^1.2.1" -tr46@~0.0.3: - version "0.0.3" - resolved "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz" - integrity sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw== +"tr46@~0.0.3": + "integrity" "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==" + "resolved" "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz" + "version" "0.0.3" -tree-kill@^1.2.2: - version "1.2.2" - resolved "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz" - integrity sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A== +"tree-kill@^1.2.2": + "integrity" "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==" + "resolved" "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz" + "version" "1.2.2" -ts-node-dev@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz" - integrity sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w== +"ts-node-dev@^2.0.0": + "integrity" "sha512-ywMrhCfH6M75yftYvrvNarLEY+SUXtUvU8/0Z6llrHQVBx12GiFk5sStF8UdfE/yfzk9IAq7O5EEbTQsxlBI8w==" + "resolved" "https://registry.npmjs.org/ts-node-dev/-/ts-node-dev-2.0.0.tgz" + "version" "2.0.0" 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" + "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.2.1, ts-node@^10.4.0: - version "10.9.1" - resolved "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz" - integrity sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw== +"ts-node@^10.2.1", "ts-node@^10.4.0", "ts-node@^10.7.0", "ts-node@>=9.0.0": + "integrity" "sha512-NtVysVPkxxrwFGUUxGYhfux8k78pQB3JqYBXlLRZgdGUqTO5wU/UyHop5p70iEbGhB7q5KmiZiU0Y3KlJrScEw==" + "resolved" "https://registry.npmjs.org/ts-node/-/ts-node-10.9.1.tgz" + "version" "10.9.1" 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" + "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" -ts-patch@^2.0.2: - version "2.0.2" - resolved "https://registry.yarnpkg.com/ts-patch/-/ts-patch-2.0.2.tgz#be9dc294ced6f53d6a8912f1f6ac98af23a715cd" - integrity sha512-NbgdS/J/ylaARJVaF1w4cPw378yvw6C1026fU5NKC2GO4jCwRlkuE/G7gwknNMHwkAOhwamKjuzkuLw/u4KlBg== +"ts-patch@^2.0.1", "ts-patch@^2.0.2": + "integrity" "sha512-NbgdS/J/ylaARJVaF1w4cPw378yvw6C1026fU5NKC2GO4jCwRlkuE/G7gwknNMHwkAOhwamKjuzkuLw/u4KlBg==" + "resolved" "https://registry.npmjs.org/ts-patch/-/ts-patch-2.0.2.tgz" + "version" "2.0.2" dependencies: - chalk "^4.1.2" - glob "^8.0.3" - global-prefix "^3.0.0" - minimist "^1.2.6" - resolve "^1.22.1" - shelljs "^0.8.5" - strip-ansi "^6.0.1" + "chalk" "^4.1.2" + "glob" "^8.0.3" + "global-prefix" "^3.0.0" + "minimist" "^1.2.6" + "resolve" "^1.22.1" + "shelljs" "^0.8.5" + "strip-ansi" "^6.0.1" -tsconfig@^7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz" - integrity sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw== +"tsconfig@^7.0.0": + "integrity" "sha512-vZXmzPrL+EmC4T/4rVlT2jNVMWCi/O4DIiSj3UHg1OE5kCKbk4mfrXc6dZksLgRM/TZlKnousKH9bbTazUWRRw==" + "resolved" "https://registry.npmjs.org/tsconfig/-/tsconfig-7.0.0.tgz" + "version" "7.0.0" 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" + "strip-bom" "^3.0.0" + "strip-json-comments" "^2.0.0" -tslib@^1.11.1, tslib@^1.9.3: - version "1.14.1" - resolved "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz" - integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== +"tslib@^1.11.1": + "integrity" "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" + "resolved" "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz" + "version" "1.14.1" -tslib@^2.0.1, tslib@^2.1.0, tslib@^2.3.1: - version "2.4.0" - resolved "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz" - integrity sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ== +"tslib@^1.9.3": + "integrity" "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==" + "resolved" "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz" + "version" "1.14.1" -type-check@~0.3.2: - version "0.3.2" - resolved "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz" - integrity sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg== +"tslib@^2.0.1", "tslib@^2.1.0", "tslib@^2.3.1": + "integrity" "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==" + "resolved" "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz" + "version" "2.4.0" + +"type-check@~0.3.2": + "integrity" "sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg==" + "resolved" "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz" + "version" "0.3.2" dependencies: - prelude-ls "~1.1.2" + "prelude-ls" "~1.1.2" -type-detect@4.0.8: - version "4.0.8" - resolved "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz" - integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== +"type-detect@4.0.8": + "integrity" "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==" + "resolved" "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz" + "version" "4.0.8" -type-fest@^0.21.3: - version "0.21.3" - resolved "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz" - integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== +"type-fest@^0.21.3": + "integrity" "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==" + "resolved" "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz" + "version" "0.21.3" -type-is@^1.6.4, type-is@~1.6.18: - version "1.6.18" - resolved "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz" - integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== +"type-is@^1.6.4", "type-is@~1.6.18": + "integrity" "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==" + "resolved" "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz" + "version" "1.6.18" dependencies: - media-typer "0.3.0" - mime-types "~2.1.24" + "media-typer" "0.3.0" + "mime-types" "~2.1.24" -typedarray@^0.0.6: - version "0.0.6" - resolved "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz" - integrity sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA== +"typedarray@^0.0.6": + "integrity" "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==" + "resolved" "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz" + "version" "0.0.6" -typeorm@^0.3.7: - version "0.3.7" - resolved "https://registry.npmjs.org/typeorm/-/typeorm-0.3.7.tgz" - integrity sha512-MsPJeP6Zuwfe64c++l80+VRqpGEGxf0CkztIEnehQ+CMmQPSHjOnFbFxwBuZ2jiLqZTjLk2ZqQdVF0RmvxNF3Q== +"typeorm@^0.3.7": + "integrity" "sha512-MsPJeP6Zuwfe64c++l80+VRqpGEGxf0CkztIEnehQ+CMmQPSHjOnFbFxwBuZ2jiLqZTjLk2ZqQdVF0RmvxNF3Q==" + "resolved" "https://registry.npmjs.org/typeorm/-/typeorm-0.3.7.tgz" + "version" "0.3.7" dependencies: "@sqltools/formatter" "^1.2.2" - app-root-path "^3.0.0" - buffer "^6.0.3" - chalk "^4.1.0" - cli-highlight "^2.1.11" - date-fns "^2.28.0" - debug "^4.3.3" - dotenv "^16.0.0" - glob "^7.2.0" - js-yaml "^4.1.0" - mkdirp "^1.0.4" - reflect-metadata "^0.1.13" - sha.js "^2.4.11" - tslib "^2.3.1" - uuid "^8.3.2" - xml2js "^0.4.23" - yargs "^17.3.1" + "app-root-path" "^3.0.0" + "buffer" "^6.0.3" + "chalk" "^4.1.0" + "cli-highlight" "^2.1.11" + "date-fns" "^2.28.0" + "debug" "^4.3.3" + "dotenv" "^16.0.0" + "glob" "^7.2.0" + "js-yaml" "^4.1.0" + "mkdirp" "^1.0.4" + "reflect-metadata" "^0.1.13" + "sha.js" "^2.4.11" + "tslib" "^2.3.1" + "uuid" "^8.3.2" + "xml2js" "^0.4.23" + "yargs" "^17.3.1" -typescript-json-schema@^0.54.0: - version "0.54.0" - resolved "https://registry.npmjs.org/typescript-json-schema/-/typescript-json-schema-0.54.0.tgz" - integrity sha512-/MNhm1pjdxXiVspjjyRCrQAA1B768cRzHU83aIqN5vQqQEW2NgyyKOfcguiRIMM64lseIZIelegnHOHEu7YDCg== +"typescript-json-schema@^0.54.0": + "integrity" "sha512-/MNhm1pjdxXiVspjjyRCrQAA1B768cRzHU83aIqN5vQqQEW2NgyyKOfcguiRIMM64lseIZIelegnHOHEu7YDCg==" + "resolved" "https://registry.npmjs.org/typescript-json-schema/-/typescript-json-schema-0.54.0.tgz" + "version" "0.54.0" dependencies: "@types/json-schema" "^7.0.9" "@types/node" "^16.9.2" - glob "^7.1.7" - path-equal "^1.1.2" - safe-stable-stringify "^2.2.0" - ts-node "^10.2.1" - typescript "~4.6.0" - yargs "^17.1.1" + "glob" "^7.1.7" + "path-equal" "^1.1.2" + "safe-stable-stringify" "^2.2.0" + "ts-node" "^10.2.1" + "typescript" "~4.6.0" + "yargs" "^17.1.1" -typescript@^4.1.2: - version "4.7.4" - resolved "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz" - integrity sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ== +"typescript@*", "typescript@^4.1.2", "typescript@^4.2.3", "typescript@^4.4.2", "typescript@^4.7.4", "typescript@>=2.7", "typescript@>=3.7.2", "typescript@>=4.0.0": + "integrity" "sha512-C0WQT0gezHuw6AdY1M2jxUO83Rjf0HP7Sk1DtXj6j1EwkQNZrHAg2XPWlq62oqEhYvONq5pkC2Y9oPljWToLmQ==" + "resolved" "https://registry.npmjs.org/typescript/-/typescript-4.7.4.tgz" + "version" "4.7.4" -typescript@~4.6.0: - version "4.6.4" - resolved "https://registry.npmjs.org/typescript/-/typescript-4.6.4.tgz" - integrity sha512-9ia/jWHIEbo49HfjrLGfKbZSuWo9iTMwXO+Ca3pRsSpbsMbc7/IU8NKdCZVRRBafVPGnoJeFL76ZOAA84I9fEg== +"typescript@~4.6.0": + "integrity" "sha512-9ia/jWHIEbo49HfjrLGfKbZSuWo9iTMwXO+Ca3pRsSpbsMbc7/IU8NKdCZVRRBafVPGnoJeFL76ZOAA84I9fEg==" + "resolved" "https://registry.npmjs.org/typescript/-/typescript-4.6.4.tgz" + "version" "4.6.4" -unicode-canonical-property-names-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz" - integrity sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ== +"unicode-canonical-property-names-ecmascript@^2.0.0": + "integrity" "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==" + "resolved" "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz" + "version" "2.0.0" -unicode-match-property-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz" - integrity sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q== +"unicode-match-property-ecmascript@^2.0.0": + "integrity" "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==" + "resolved" "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz" + "version" "2.0.0" dependencies: - unicode-canonical-property-names-ecmascript "^2.0.0" - unicode-property-aliases-ecmascript "^2.0.0" + "unicode-canonical-property-names-ecmascript" "^2.0.0" + "unicode-property-aliases-ecmascript" "^2.0.0" -unicode-match-property-value-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz" - integrity sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw== +"unicode-match-property-value-ecmascript@^2.0.0": + "integrity" "sha512-7Yhkc0Ye+t4PNYzOGKedDhXbYIBe1XEQYQxOPyhcXNMJ0WCABqqj6ckydd6pWRZTHV4GuCPKdBAUiMc60tsKVw==" + "resolved" "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.0.0.tgz" + "version" "2.0.0" -unicode-property-aliases-ecmascript@^2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz" - integrity sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ== +"unicode-property-aliases-ecmascript@^2.0.0": + "integrity" "sha512-5Zfuy9q/DFr4tfO7ZPeVXb1aPoeQSdeFMLpYuFebehDAhbuevLs5yxSZmIFN1tP5F9Wl4IpJrYojg85/zgyZHQ==" + "resolved" "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.0.0.tgz" + "version" "2.0.0" -unique-filename@^1.1.1: - version "1.1.1" - resolved "https://registry.yarnpkg.com/unique-filename/-/unique-filename-1.1.1.tgz#1d69769369ada0583103a1e6ae87681b56573230" - integrity sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ== +"unique-filename@^1.1.1": + "integrity" "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==" + "resolved" "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz" + "version" "1.1.1" dependencies: - unique-slug "^2.0.0" + "unique-slug" "^2.0.0" -unique-slug@^2.0.0: - version "2.0.2" - resolved "https://registry.yarnpkg.com/unique-slug/-/unique-slug-2.0.2.tgz#baabce91083fc64e945b0f3ad613e264f7cd4e6c" - integrity sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w== +"unique-slug@^2.0.0": + "integrity" "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==" + "resolved" "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz" + "version" "2.0.2" dependencies: - imurmurhash "^0.1.4" + "imurmurhash" "^0.1.4" -universalify@^0.1.0: - version "0.1.2" - resolved "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz" - integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg== +"universalify@^0.1.0": + "integrity" "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" + "resolved" "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz" + "version" "0.1.2" -unpipe@1.0.0, unpipe@~1.0.0: - version "1.0.0" - resolved "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" - integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== +"unpipe@~1.0.0", "unpipe@1.0.0": + "integrity" "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==" + "resolved" "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz" + "version" "1.0.0" -update-browserslist-db@^1.0.4: - version "1.0.4" - resolved "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.4.tgz" - integrity sha512-jnmO2BEGUjsMOe/Fg9u0oczOe/ppIDZPebzccl1yDWGLFP16Pa1/RM5wEoKYPG2zstNcDuAStejyxsOuKINdGA== +"update-browserslist-db@^1.0.4": + "integrity" "sha512-jnmO2BEGUjsMOe/Fg9u0oczOe/ppIDZPebzccl1yDWGLFP16Pa1/RM5wEoKYPG2zstNcDuAStejyxsOuKINdGA==" + "resolved" "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.4.tgz" + "version" "1.0.4" dependencies: - escalade "^3.1.1" - picocolors "^1.0.0" + "escalade" "^3.1.1" + "picocolors" "^1.0.0" -uri-js@^4.2.2: - version "4.4.1" - resolved "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz" - integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== +"uri-js@^4.2.2": + "integrity" "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==" + "resolved" "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz" + "version" "4.4.1" dependencies: - punycode "^2.1.0" + "punycode" "^2.1.0" -url-parse@~1.5.10: - version "1.5.10" - resolved "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz" - integrity sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ== +"url-parse@~1.5.10": + "integrity" "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==" + "resolved" "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz" + "version" "1.5.10" dependencies: - querystringify "^2.1.1" - requires-port "^1.0.0" + "querystringify" "^2.1.1" + "requires-port" "^1.0.0" -util-deprecate@^1.0.1, util-deprecate@~1.0.1: - version "1.0.2" - resolved "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz" - integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw== +"util-deprecate@^1.0.1", "util-deprecate@~1.0.1": + "integrity" "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" + "resolved" "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz" + "version" "1.0.2" -utils-merge@1.0.1: - version "1.0.1" - resolved "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz" - integrity sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA== +"utils-merge@1.0.1": + "integrity" "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==" + "resolved" "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz" + "version" "1.0.1" -uuid@^8.3.2: - version "8.3.2" - resolved "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz" - integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg== +"uuid@^8.3.2": + "integrity" "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==" + "resolved" "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz" + "version" "8.3.2" -v8-compile-cache-lib@^3.0.1: - version "3.0.1" - resolved "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz" - integrity sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg== +"v8-compile-cache-lib@^3.0.1": + "integrity" "sha512-wa7YjyUGfNZngI/vtK0UHAN+lgDCxBPCylVXGp0zu59Fz5aiGtNXaq3DhIov063MorB+VfufLh3JlF2KdTK3xg==" + "resolved" "https://registry.npmjs.org/v8-compile-cache-lib/-/v8-compile-cache-lib-3.0.1.tgz" + "version" "3.0.1" -v8-to-istanbul@^9.0.1: - version "9.0.1" - resolved "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.0.1.tgz" - integrity sha512-74Y4LqY74kLE6IFyIjPtkSTWzUZmj8tdHT9Ii/26dvQ6K9Dl2NbEfj0XgU2sHCtKgt5VupqhlO/5aWuqS+IY1w== +"v8-to-istanbul@^9.0.1": + "integrity" "sha512-74Y4LqY74kLE6IFyIjPtkSTWzUZmj8tdHT9Ii/26dvQ6K9Dl2NbEfj0XgU2sHCtKgt5VupqhlO/5aWuqS+IY1w==" + "resolved" "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-9.0.1.tgz" + "version" "9.0.1" dependencies: "@jridgewell/trace-mapping" "^0.3.12" "@types/istanbul-lib-coverage" "^2.0.1" - convert-source-map "^1.6.0" + "convert-source-map" "^1.6.0" -vary@~1.1.2: - version "1.1.2" - resolved "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz" - integrity sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg== +"vary@~1.1.2": + "integrity" "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==" + "resolved" "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz" + "version" "1.1.2" -vm2@^3.9.8: - version "3.9.10" - resolved "https://registry.npmjs.org/vm2/-/vm2-3.9.10.tgz" - integrity sha512-AuECTSvwu2OHLAZYhG716YzwodKCIJxB6u1zG7PgSQwIgAlEaoXH52bxdcvT8GkGjnYK7r7yWDW0m0sOsPuBjQ== +"vm2@^3.9.8": + "integrity" "sha512-AuECTSvwu2OHLAZYhG716YzwodKCIJxB6u1zG7PgSQwIgAlEaoXH52bxdcvT8GkGjnYK7r7yWDW0m0sOsPuBjQ==" + "resolved" "https://registry.npmjs.org/vm2/-/vm2-3.9.10.tgz" + "version" "3.9.10" dependencies: - acorn "^8.7.0" - acorn-walk "^8.2.0" + "acorn" "^8.7.0" + "acorn-walk" "^8.2.0" -walker@^1.0.8: - version "1.0.8" - resolved "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz" - integrity sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ== +"walker@^1.0.8": + "integrity" "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==" + "resolved" "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz" + "version" "1.0.8" dependencies: - makeerror "1.0.12" + "makeerror" "1.0.12" -webidl-conversions@^3.0.0: - version "3.0.1" - resolved "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz" - integrity sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ== +"webidl-conversions@^3.0.0": + "integrity" "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==" + "resolved" "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz" + "version" "3.0.1" -whatwg-url@^5.0.0: - version "5.0.0" - resolved "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz" - integrity sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw== +"whatwg-url@^5.0.0": + "integrity" "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==" + "resolved" "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz" + "version" "5.0.0" dependencies: - tr46 "~0.0.3" - webidl-conversions "^3.0.0" + "tr46" "~0.0.3" + "webidl-conversions" "^3.0.0" -which@^1.2.9, which@^1.3.1: - version "1.3.1" - resolved "https://registry.npmjs.org/which/-/which-1.3.1.tgz" - integrity sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ== +"which@^1.2.9": + "integrity" "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==" + "resolved" "https://registry.npmjs.org/which/-/which-1.3.1.tgz" + "version" "1.3.1" dependencies: - isexe "^2.0.0" + "isexe" "^2.0.0" -which@^2.0.1, which@^2.0.2: - version "2.0.2" - resolved "https://registry.npmjs.org/which/-/which-2.0.2.tgz" - integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== +"which@^1.3.1": + "integrity" "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==" + "resolved" "https://registry.npmjs.org/which/-/which-1.3.1.tgz" + "version" "1.3.1" dependencies: - isexe "^2.0.0" + "isexe" "^2.0.0" -wide-align@^1.1.2, wide-align@^1.1.5: - version "1.1.5" - resolved "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz" - integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg== +"which@^2.0.1", "which@^2.0.2": + "integrity" "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==" + "resolved" "https://registry.npmjs.org/which/-/which-2.0.2.tgz" + "version" "2.0.2" dependencies: - string-width "^1.0.2 || 2 || 3 || 4" + "isexe" "^2.0.0" -word-wrap@~1.2.3: - version "1.2.3" - resolved "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz" - integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== - -wrap-ansi@^7.0.0: - version "7.0.0" - resolved "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz" - integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== +"wide-align@^1.1.2", "wide-align@^1.1.5": + "integrity" "sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==" + "resolved" "https://registry.npmjs.org/wide-align/-/wide-align-1.1.5.tgz" + "version" "1.1.5" dependencies: - ansi-styles "^4.0.0" - string-width "^4.1.0" - strip-ansi "^6.0.0" + "string-width" "^1.0.2 || 2 || 3 || 4" -wrappy@1: - version "1.0.2" - resolved "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz" - integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== +"word-wrap@~1.2.3": + "integrity" "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==" + "resolved" "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz" + "version" "1.2.3" -write-file-atomic@^4.0.1: - version "4.0.1" - resolved "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.1.tgz" - integrity sha512-nSKUxgAbyioruk6hU87QzVbY279oYT6uiwgDoujth2ju4mJ+TZau7SQBhtbTmUyuNYTuXnSyRn66FV0+eCgcrQ== +"wrap-ansi@^7.0.0": + "integrity" "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==" + "resolved" "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz" + "version" "7.0.0" dependencies: - imurmurhash "^0.1.4" - signal-exit "^3.0.7" + "ansi-styles" "^4.0.0" + "string-width" "^4.1.0" + "strip-ansi" "^6.0.0" -ws@^8.8.1: - version "8.8.1" - resolved "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz" - integrity sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA== +"wrappy@1": + "integrity" "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" + "resolved" "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz" + "version" "1.0.2" -xml2js@^0.4.23: - version "0.4.23" - resolved "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz" - integrity sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug== +"write-file-atomic@^4.0.1": + "integrity" "sha512-nSKUxgAbyioruk6hU87QzVbY279oYT6uiwgDoujth2ju4mJ+TZau7SQBhtbTmUyuNYTuXnSyRn66FV0+eCgcrQ==" + "resolved" "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.1.tgz" + "version" "4.0.1" dependencies: - sax ">=0.6.0" - xmlbuilder "~11.0.0" + "imurmurhash" "^0.1.4" + "signal-exit" "^3.0.7" -xmlbuilder@~11.0.0: - version "11.0.1" - resolved "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz" - integrity sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA== +"ws@^8.8.1": + "integrity" "sha512-bGy2JzvzkPowEJV++hF07hAD6niYSr0JzBNo/J29WsB57A2r7Wlc1UFcTR9IzrPvuNVO4B8LGqF8qcpsVOhJCA==" + "resolved" "https://registry.npmjs.org/ws/-/ws-8.8.1.tgz" + "version" "8.8.1" -xregexp@2.0.0: - version "2.0.0" - resolved "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz" - integrity sha512-xl/50/Cf32VsGq/1R8jJE5ajH1yMCQkpmoS10QbFZWl2Oor4H0Me64Pu2yxvsRWK3m6soJbmGfzSR7BYmDcWAA== - -xtend@^4.0.0: - version "4.0.2" - resolved "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz" - integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== - -y18n@^5.0.5: - version "5.0.8" - resolved "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz" - integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== - -yallist@^2.1.2: - version "2.1.2" - resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52" - integrity sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A== - -yallist@^3.0.2: - version "3.1.1" - resolved "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz" - integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== - -yallist@^4.0.0: - version "4.0.0" - resolved "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz" - integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== - -yargs-parser@^20.2.2: - version "20.2.9" - resolved "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz" - integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w== - -yargs-parser@^21.0.0: - version "21.0.1" - resolved "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.0.1.tgz" - integrity sha512-9BK1jFpLzJROCI5TzwZL/TU4gqjK5xiHV/RfWLOahrjAko/e4DJkRDZQXfvqAsiZzzYhgAzbgz6lg48jcm4GLg== - -yargs@^16.0.0: - version "16.2.0" - resolved "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz" - integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== +"xml2js@^0.4.23": + "integrity" "sha512-ySPiMjM0+pLDftHgXY4By0uswI3SPKLDw/i3UXbnO8M/p28zqexCUoPmQFrYD+/1BzhGJSs2i1ERWKJAtiLrug==" + "resolved" "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz" + "version" "0.4.23" dependencies: - cliui "^7.0.2" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.0" - y18n "^5.0.5" - yargs-parser "^20.2.2" + "sax" ">=0.6.0" + "xmlbuilder" "~11.0.0" -yargs@^17.1.1, yargs@^17.3.1: - version "17.5.1" - resolved "https://registry.npmjs.org/yargs/-/yargs-17.5.1.tgz" - integrity sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA== +"xmlbuilder@~11.0.0": + "integrity" "sha512-fDlsI/kFEx7gLvbecc0/ohLG50fugQp8ryHzMTuW9vSa1GJ0XYWKnhsUx7oie3G98+r56aTQIUB4kht42R3JvA==" + "resolved" "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-11.0.1.tgz" + "version" "11.0.1" + +"xregexp@2.0.0": + "integrity" "sha512-xl/50/Cf32VsGq/1R8jJE5ajH1yMCQkpmoS10QbFZWl2Oor4H0Me64Pu2yxvsRWK3m6soJbmGfzSR7BYmDcWAA==" + "resolved" "https://registry.npmjs.org/xregexp/-/xregexp-2.0.0.tgz" + "version" "2.0.0" + +"xtend@^4.0.0": + "integrity" "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" + "resolved" "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz" + "version" "4.0.2" + +"y18n@^5.0.5": + "integrity" "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==" + "resolved" "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz" + "version" "5.0.8" + +"yallist@^2.1.2": + "integrity" "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==" + "resolved" "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz" + "version" "2.1.2" + +"yallist@^3.0.2": + "integrity" "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" + "resolved" "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz" + "version" "3.1.1" + +"yallist@^4.0.0": + "integrity" "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" + "resolved" "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz" + "version" "4.0.0" + +"yargs-parser@^20.2.2": + "integrity" "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==" + "resolved" "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz" + "version" "20.2.9" + +"yargs-parser@^21.0.0": + "integrity" "sha512-9BK1jFpLzJROCI5TzwZL/TU4gqjK5xiHV/RfWLOahrjAko/e4DJkRDZQXfvqAsiZzzYhgAzbgz6lg48jcm4GLg==" + "resolved" "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.0.1.tgz" + "version" "21.0.1" + +"yargs@^16.0.0": + "integrity" "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==" + "resolved" "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz" + "version" "16.2.0" dependencies: - cliui "^7.0.2" - escalade "^3.1.1" - get-caller-file "^2.0.5" - require-directory "^2.1.1" - string-width "^4.2.3" - y18n "^5.0.5" - yargs-parser "^21.0.0" + "cliui" "^7.0.2" + "escalade" "^3.1.1" + "get-caller-file" "^2.0.5" + "require-directory" "^2.1.1" + "string-width" "^4.2.0" + "y18n" "^5.0.5" + "yargs-parser" "^20.2.2" -yn@3.1.1: - version "3.1.1" - resolved "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz" - integrity sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q== +"yargs@^17.1.1": + "integrity" "sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA==" + "resolved" "https://registry.npmjs.org/yargs/-/yargs-17.5.1.tgz" + "version" "17.5.1" + dependencies: + "cliui" "^7.0.2" + "escalade" "^3.1.1" + "get-caller-file" "^2.0.5" + "require-directory" "^2.1.1" + "string-width" "^4.2.3" + "y18n" "^5.0.5" + "yargs-parser" "^21.0.0" -yocto-queue@^0.1.0: - version "0.1.0" - resolved "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz" - integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== +"yargs@^17.3.1": + "integrity" "sha512-t6YAJcxDkNX7NFYiVtKvWUz8l+PaKTLiL63mJYWR2GnHq2gjEWISzsLp9wg3aY36dY1j+gfIEL3pIF+XlJJfbA==" + "resolved" "https://registry.npmjs.org/yargs/-/yargs-17.5.1.tgz" + "version" "17.5.1" + dependencies: + "cliui" "^7.0.2" + "escalade" "^3.1.1" + "get-caller-file" "^2.0.5" + "require-directory" "^2.1.1" + "string-width" "^4.2.3" + "y18n" "^5.0.5" + "yargs-parser" "^21.0.0" + +"yn@3.1.1": + "integrity" "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==" + "resolved" "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz" + "version" "3.1.1" + +"yocto-queue@^0.1.0": + "integrity" "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==" + "resolved" "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz" + "version" "0.1.0" From 95108eedf08b544cd5295889949fae140beb39ce Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 15 Aug 2022 07:54:00 +0200 Subject: [PATCH 225/238] oops.. move migrations to right folder --- .../migrations/mariadb/1660540527213-sync_migrations.ts | 0 src/{ => util}/migrations/sqlite/1660538628956-sync_migrations.ts | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename src/{ => util}/migrations/mariadb/1660540527213-sync_migrations.ts (100%) rename src/{ => util}/migrations/sqlite/1660538628956-sync_migrations.ts (100%) diff --git a/src/migrations/mariadb/1660540527213-sync_migrations.ts b/src/util/migrations/mariadb/1660540527213-sync_migrations.ts similarity index 100% rename from src/migrations/mariadb/1660540527213-sync_migrations.ts rename to src/util/migrations/mariadb/1660540527213-sync_migrations.ts diff --git a/src/migrations/sqlite/1660538628956-sync_migrations.ts b/src/util/migrations/sqlite/1660538628956-sync_migrations.ts similarity index 100% rename from src/migrations/sqlite/1660538628956-sync_migrations.ts rename to src/util/migrations/sqlite/1660538628956-sync_migrations.ts From 6d9ea1a7bc9d44a547fe1566393e122ae252eb8c Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 15 Aug 2022 09:47:49 +0200 Subject: [PATCH 226/238] Fix nullables, fix user settings hanging stuff --- scripts/db_migrations.sh | 6 +- src/gateway/opcodes/Identify.ts | 2 +- src/util/entities/User.ts | 6 +- .../mariadb/1660549252130-fix_nullables.ts | 30 +++ .../postgres/1660549242936-fix_nullables.ts | 30 +++ .../sqlite/1660549233583-fix_nullables.ts | 240 ++++++++++++++++++ 6 files changed, 307 insertions(+), 7 deletions(-) create mode 100644 src/util/migrations/mariadb/1660549252130-fix_nullables.ts create mode 100644 src/util/migrations/postgres/1660549242936-fix_nullables.ts create mode 100644 src/util/migrations/sqlite/1660549233583-fix_nullables.ts diff --git a/scripts/db_migrations.sh b/scripts/db_migrations.sh index 894048782..9ec8230a5 100755 --- a/scripts/db_migrations.sh +++ b/scripts/db_migrations.sh @@ -19,9 +19,9 @@ make_migration() { mkdir "src/util/migrations/$2" 2>/dev/null # npm run build clean logerrors pretty-errors THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle - THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "src/migrations/$2/$FILENAME" -d src/util/util/Database.ts -p - npm run build clean logerrors pretty-errors - THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle + THREADS=1 DATABASE="$1" DB_MIGRATE=a npx typeorm-ts-node-commonjs migration:generate "src/util/migrations/$2/$FILENAME" -d src/util/util/Database.ts -p + #npm run build clean logerrors pretty-errors + #THREADS=1 DATABASE="$1" DB_MIGRATE=a npm run start:bundle } npm i sqlite3 diff --git a/src/gateway/opcodes/Identify.ts b/src/gateway/opcodes/Identify.ts index d5dae7b04..44db598c4 100644 --- a/src/gateway/opcodes/Identify.ts +++ b/src/gateway/opcodes/Identify.ts @@ -105,7 +105,7 @@ export async function onIdentify(this: WebSocket, data: Payload) { if (!user.settings) { //settings may not exist after updating... user.settings = new UserSettings(); user.settings.id = user.id; - await user.settings.save(); + //await (user.settings as UserSettings).save(); } if (!identify.intents) identify.intents = "30064771071"; diff --git a/src/util/entities/User.ts b/src/util/entities/User.ts index 61343e818..5432f2989 100644 --- a/src/util/entities/User.ts +++ b/src/util/entities/User.ts @@ -97,7 +97,7 @@ export class User extends BaseClass { @Column() bot: boolean = false; // if user is bot - @Column() + @Column({ nullable: true }) bio: string; // short description of the user (max 190 chars -> should be configurable) @Column() @@ -106,7 +106,7 @@ export class User extends BaseClass { @Column({ select: false }) nsfw_allowed: boolean = true; // if the user can do age-restricted actions (NSFW channels/guilds/commands) // TODO: depending on age - @Column({ select: false }) + @Column({ select: false, nullable: true }) mfa_enabled: boolean; // if multi factor authentication is enabled @Column({ select: false, nullable: true }) @@ -281,8 +281,8 @@ export class User extends BaseClass { settings: { ...new UserSettings(), locale: language } }); + //await (user.settings as UserSettings).save(); await user.save(); - await user.settings.save(); setImmediate(async () => { if (Config.get().guild.autoJoin.enabled) { diff --git a/src/util/migrations/mariadb/1660549252130-fix_nullables.ts b/src/util/migrations/mariadb/1660549252130-fix_nullables.ts new file mode 100644 index 000000000..c9456b546 --- /dev/null +++ b/src/util/migrations/mariadb/1660549252130-fix_nullables.ts @@ -0,0 +1,30 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class fixNullables1660549252130 implements MigrationInterface { + name = 'fixNullables1660549252130' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + DROP INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` + `); + await queryRunner.query(` + ALTER TABLE \`users\` CHANGE \`bio\` \`bio\` varchar(255) NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` CHANGE \`mfa_enabled\` \`mfa_enabled\` tinyint NULL + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE \`users\` CHANGE \`mfa_enabled\` \`mfa_enabled\` tinyint NOT NULL + `); + await queryRunner.query(` + ALTER TABLE \`users\` CHANGE \`bio\` \`bio\` varchar(255) NOT NULL + `); + await queryRunner.query(` + CREATE UNIQUE INDEX \`IDX_76ba283779c8441fd5ff819c8c\` ON \`users\` (\`settingsId\`) + `); + } + +} diff --git a/src/util/migrations/postgres/1660549242936-fix_nullables.ts b/src/util/migrations/postgres/1660549242936-fix_nullables.ts new file mode 100644 index 000000000..b9a0194d5 --- /dev/null +++ b/src/util/migrations/postgres/1660549242936-fix_nullables.ts @@ -0,0 +1,30 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class fixNullables1660549242936 implements MigrationInterface { + name = 'fixNullables1660549242936' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + ALTER COLUMN "bio" DROP NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "users" + ALTER COLUMN "mfa_enabled" DROP NOT NULL + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + ALTER COLUMN "mfa_enabled" + SET NOT NULL + `); + await queryRunner.query(` + ALTER TABLE "users" + ALTER COLUMN "bio" + SET NOT NULL + `); + } + +} diff --git a/src/util/migrations/sqlite/1660549233583-fix_nullables.ts b/src/util/migrations/sqlite/1660549233583-fix_nullables.ts new file mode 100644 index 000000000..68f650c76 --- /dev/null +++ b/src/util/migrations/sqlite/1660549233583-fix_nullables.ts @@ -0,0 +1,240 @@ +import { MigrationInterface, QueryRunner } from "typeorm"; + +export class fixNullables1660549233583 implements MigrationInterface { + name = 'fixNullables1660549233583' + + public async up(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + CREATE TABLE "temporary_users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId"), + CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" FOREIGN KEY ("settingsId") REFERENCES "user_settings" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "temporary_users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + FROM "users" + `); + await queryRunner.query(` + DROP TABLE "users" + `); + await queryRunner.query(` + ALTER TABLE "temporary_users" + RENAME TO "users" + `); + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query(` + ALTER TABLE "users" + RENAME TO "temporary_users" + `); + await queryRunner.query(` + CREATE TABLE "users" ( + "id" varchar PRIMARY KEY NOT NULL, + "username" varchar NOT NULL, + "discriminator" varchar NOT NULL, + "avatar" varchar, + "accent_color" integer, + "banner" varchar, + "phone" varchar, + "desktop" boolean NOT NULL, + "mobile" boolean NOT NULL, + "premium" boolean NOT NULL, + "premium_type" integer NOT NULL, + "bot" boolean NOT NULL, + "bio" varchar NOT NULL, + "system" boolean NOT NULL, + "nsfw_allowed" boolean NOT NULL, + "mfa_enabled" boolean NOT NULL, + "totp_secret" varchar, + "totp_last_ticket" varchar, + "created_at" datetime NOT NULL, + "premium_since" datetime, + "verified" boolean NOT NULL, + "disabled" boolean NOT NULL, + "deleted" boolean NOT NULL, + "email" varchar, + "flags" varchar NOT NULL, + "public_flags" integer NOT NULL, + "rights" bigint NOT NULL, + "data" text NOT NULL, + "fingerprints" text NOT NULL, + "extended_settings" text NOT NULL, + "notes" text NOT NULL, + "settingsId" varchar, + CONSTRAINT "UQ_b1dd13b6ed980004a795ca184a6" UNIQUE ("settingsId"), + CONSTRAINT "FK_76ba283779c8441fd5ff819c8cf" FOREIGN KEY ("settingsId") REFERENCES "user_settings" ("id") ON DELETE NO ACTION ON UPDATE NO ACTION + ) + `); + await queryRunner.query(` + INSERT INTO "users"( + "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + ) + SELECT "id", + "username", + "discriminator", + "avatar", + "accent_color", + "banner", + "phone", + "desktop", + "mobile", + "premium", + "premium_type", + "bot", + "bio", + "system", + "nsfw_allowed", + "mfa_enabled", + "totp_secret", + "totp_last_ticket", + "created_at", + "premium_since", + "verified", + "disabled", + "deleted", + "email", + "flags", + "public_flags", + "rights", + "data", + "fingerprints", + "extended_settings", + "notes", + "settingsId" + FROM "temporary_users" + `); + await queryRunner.query(` + DROP TABLE "temporary_users" + `); + } + +} From 15b1dee513a96107363e9a76a132324f6f338b1e Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 15 Aug 2022 10:02:26 +0200 Subject: [PATCH 227/238] change dev panel path, we missed this one... --- src/api/middlewares/TestClient.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/api/middlewares/TestClient.ts b/src/api/middlewares/TestClient.ts index a47ff396e..c8ea57f62 100644 --- a/src/api/middlewares/TestClient.ts +++ b/src/api/middlewares/TestClient.ts @@ -79,7 +79,7 @@ export default function TestClient(app: Application) { if(!useTestClient) return res.send("Test client is disabled on this instance. Use a stand-alone client to connect this instance.") - res.send(fs.readFileSync(path.join(__dirname, "..", "..", "client_test", "developers.html"), { encoding: "utf8" })); + res.send(fs.readFileSync(path.join(__dirname, "..", "..", "..", "assets", "developers.html"), { encoding: "utf8" })); }); app.get("*", (req: Request, res: Response) => { const { useTestClient } = Config.get().client; From 9d145575181bd1cbe9d5ad4c20cb5c886c8b443a Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Wed, 10 Aug 2022 01:50:23 +0200 Subject: [PATCH 228/238] New translations auth.json (German) --- api/locales/de/auth.json | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/api/locales/de/auth.json b/api/locales/de/auth.json index a78d4d60b..20e6dafff 100644 --- a/api/locales/de/auth.json +++ b/api/locales/de/auth.json @@ -1,18 +1,18 @@ { "login": { - "INVALID_LOGIN": "E-Mail or Phone not found", - "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled", - "INVALID_TOTP_CODE": "Invalid two-factor code.", - "INVALID_TOTP_SECRET": "Invalid two-factor secret." + "INVALID_LOGIN": "E-Mail oder Telefonnummer nicht gefunden", + "INVALID_PASSWORD": "Ungültiges Passwort", + "ACCOUNT_DISABLED": "Dieses Konto ist deaktiviert", + "INVALID_TOTP_CODE": "Ungültiger Zwei-Faktor-Code.", + "INVALID_TOTP_SECRET": "Ungültiges Zwei-Faktor-Secret." }, "register": { - "REGISTRATION_DISABLED": "New user registration is disabled", - "INVITE_ONLY": "You must be invited to register", - "EMAIL_INVALID": "Invalid Email", - "EMAIL_ALREADY_REGISTERED": "Email is already registered", - "DATE_OF_BIRTH_UNDERAGE": "You need to be {{years}} years or older", - "CONSENT_REQUIRED": "You must agree to the Terms of Service and Privacy Policy.", - "USERNAME_TOO_MANY_USERS": "Too many users have this username, please try another" + "REGISTRATION_DISABLED": "Die Registrierung neuer Benutzer ist deaktiviert", + "INVITE_ONLY": "Du musst eingeladen werden, um dich zu registrieren", + "EMAIL_INVALID": "Ungültige E-Mail Adresse", + "EMAIL_ALREADY_REGISTERED": "Die E-Mail Adresse wird bereits verwendet", + "DATE_OF_BIRTH_UNDERAGE": "Du musst mindestens {{years}} Jahre alt sein", + "CONSENT_REQUIRED": "Du musst den Nutzungsbedingungen und den Datenschutzbestimmungen zustimmen.", + "USERNAME_TOO_MANY_USERS": "Dieser Name wird von zu vielen Nutzern verwendet, bitte wähle einen anderen" } } From fd52864093879354d1e9164e2f43763220915a44 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Wed, 10 Aug 2022 01:50:24 +0200 Subject: [PATCH 229/238] New translations common.json (German) --- api/locales/de/common.json | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/api/locales/de/common.json b/api/locales/de/common.json index 8bb9c0421..97634a29a 100644 --- a/api/locales/de/common.json +++ b/api/locales/de/common.json @@ -1,18 +1,18 @@ { "field": { - "BASE_TYPE_REQUIRED": "This field is required", - "BASE_TYPE_STRING": "This field must be a string", - "BASE_TYPE_NUMBER": "This field must be a number", - "BASE_TYPE_BIGINT": "This field must be a bigint", - "BASE_TYPE_BOOLEAN": "This field must be a boolean", - "BASE_TYPE_CHOICES": "This field must be one of ({{types}})", - "BASE_TYPE_CLASS": "This field must be an instance of {{type}}", - "BASE_TYPE_OBJECT": "This field must be an object", - "BASE_TYPE_ARRAY": "This field must be an array", - "UNKOWN_FIELD": "Unknown key: {{key}}", - "BASE_TYPE_CONSTANT": "This field must be {{value}}", - "EMAIL_TYPE_INVALID_EMAIL": "Not a well-formed email address", - "DATE_TYPE_PARSE": "Could not parse {{date}}. Should be ISO8601", - "BASE_TYPE_BAD_LENGTH": "Must be between {{length}} in length" + "BASE_TYPE_REQUIRED": "Dieses Feld ist erforderlich", + "BASE_TYPE_STRING": "Dieses Feld muss ein String sein", + "BASE_TYPE_NUMBER": "Dieses Feld muss eine Zahl sein", + "BASE_TYPE_BIGINT": "Dieses Feld muss ein Bigint sein", + "BASE_TYPE_BOOLEAN": "Dieses Feld muss ein Boolean sein", + "BASE_TYPE_CHOICES": "Dieses Feld muss eines von ({{types}}) sein", + "BASE_TYPE_CLASS": "Dieses Feld muss eine Instanz von {{type}} sein", + "BASE_TYPE_OBJECT": "Dieses Feld muss ein Objekt sein", + "BASE_TYPE_ARRAY": "Dieses Feld muss ein Array sein", + "UNKOWN_FIELD": "Unbekanntes Feld: {{key}}", + "BASE_TYPE_CONSTANT": "Dieses Feld muss {{value}} sein", + "EMAIL_TYPE_INVALID_EMAIL": "Keine wohlgeformte E-Mail-Adresse", + "DATE_TYPE_PARSE": "Konnte {{date}} nicht verarbeiten. Es muss dem ISO8601 Standard entsprechen", + "BASE_TYPE_BAD_LENGTH": "Muss zwischen {{length}} lang sein" } } From d6c00709c5cc0e284979803bba8252cc63ac205b Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Thu, 11 Aug 2022 19:37:46 +0200 Subject: [PATCH 230/238] New translations auth.json (Dutch) --- api/locales/nl/auth.json | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/api/locales/nl/auth.json b/api/locales/nl/auth.json index a78d4d60b..ab295edd4 100644 --- a/api/locales/nl/auth.json +++ b/api/locales/nl/auth.json @@ -1,18 +1,18 @@ { "login": { - "INVALID_LOGIN": "E-Mail or Phone not found", - "INVALID_PASSWORD": "Invalid Password", + "INVALID_LOGIN": "E-mailadres of telefoon niet gevonden", + "INVALID_PASSWORD": "Ongeldig wachtwoord", "ACCOUNT_DISABLED": "This account is disabled", "INVALID_TOTP_CODE": "Invalid two-factor code.", "INVALID_TOTP_SECRET": "Invalid two-factor secret." }, "register": { - "REGISTRATION_DISABLED": "New user registration is disabled", - "INVITE_ONLY": "You must be invited to register", - "EMAIL_INVALID": "Invalid Email", - "EMAIL_ALREADY_REGISTERED": "Email is already registered", - "DATE_OF_BIRTH_UNDERAGE": "You need to be {{years}} years or older", - "CONSENT_REQUIRED": "You must agree to the Terms of Service and Privacy Policy.", - "USERNAME_TOO_MANY_USERS": "Too many users have this username, please try another" + "REGISTRATION_DISABLED": "Registratie voor nieuwe gebruikers is uitgeschakeld", + "INVITE_ONLY": "U moet worden uitgenodigd om te registreren", + "EMAIL_INVALID": "Email is ongeldig", + "EMAIL_ALREADY_REGISTERED": "Dit e-mailadres is al geregistreerd", + "DATE_OF_BIRTH_UNDERAGE": "Je moet {{years}} jaar of ouder zijn", + "CONSENT_REQUIRED": "U moet akkoord gaan met de Algemene Voorwaarden en het Privacybeleid.", + "USERNAME_TOO_MANY_USERS": "Te veel gebruikers hebben deze gebruikersnaam, gelieve een andere te proberen" } } From 517aad85d65fdd0a0d2f29b57db0a204f57fd4e5 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Thu, 11 Aug 2022 19:37:47 +0200 Subject: [PATCH 231/238] New translations common.json (Dutch) --- api/locales/nl/common.json | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/api/locales/nl/common.json b/api/locales/nl/common.json index 8bb9c0421..6f411c02d 100644 --- a/api/locales/nl/common.json +++ b/api/locales/nl/common.json @@ -1,18 +1,18 @@ { "field": { - "BASE_TYPE_REQUIRED": "This field is required", + "BASE_TYPE_REQUIRED": "Dit veld is verplicht", "BASE_TYPE_STRING": "This field must be a string", - "BASE_TYPE_NUMBER": "This field must be a number", + "BASE_TYPE_NUMBER": "Dit veld moet een getal zijn", "BASE_TYPE_BIGINT": "This field must be a bigint", "BASE_TYPE_BOOLEAN": "This field must be a boolean", - "BASE_TYPE_CHOICES": "This field must be one of ({{types}})", - "BASE_TYPE_CLASS": "This field must be an instance of {{type}}", - "BASE_TYPE_OBJECT": "This field must be an object", - "BASE_TYPE_ARRAY": "This field must be an array", + "BASE_TYPE_CHOICES": "Dit veld moet een van ({{types}}) zijn", + "BASE_TYPE_CLASS": "Dit veld moet een exemplaar zijn van {{type}}", + "BASE_TYPE_OBJECT": "Dit veld moet een object zijn", + "BASE_TYPE_ARRAY": "Dit veld moet een array zijn", "UNKOWN_FIELD": "Unknown key: {{key}}", - "BASE_TYPE_CONSTANT": "This field must be {{value}}", - "EMAIL_TYPE_INVALID_EMAIL": "Not a well-formed email address", - "DATE_TYPE_PARSE": "Could not parse {{date}}. Should be ISO8601", - "BASE_TYPE_BAD_LENGTH": "Must be between {{length}} in length" + "BASE_TYPE_CONSTANT": "Dit veld moet {{value}} zijn", + "EMAIL_TYPE_INVALID_EMAIL": "Niet een geldig e-mailadres", + "DATE_TYPE_PARSE": "Kan {{date}} niet parsen. Moet ISO8601 zijn", + "BASE_TYPE_BAD_LENGTH": "Moet tussen {{length}} in lengte zijn" } } From 8e3e28040b827cc5b13e57b8aff14e3b24fcdd1b Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 13 Aug 2022 17:50:17 +0200 Subject: [PATCH 232/238] New translations auth.json (Belarusian) --- api/locales/be/auth.json | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/api/locales/be/auth.json b/api/locales/be/auth.json index a78d4d60b..4bb36eeb3 100644 --- a/api/locales/be/auth.json +++ b/api/locales/be/auth.json @@ -1,18 +1,18 @@ { "login": { - "INVALID_LOGIN": "E-Mail or Phone not found", - "INVALID_PASSWORD": "Invalid Password", - "ACCOUNT_DISABLED": "This account is disabled", - "INVALID_TOTP_CODE": "Invalid two-factor code.", - "INVALID_TOTP_SECRET": "Invalid two-factor secret." + "INVALID_LOGIN": "Дадзены адрас электроннай пошты ці тэлефона не знойдзены", + "INVALID_PASSWORD": "Няправільны пароль", + "ACCOUNT_DISABLED": "Гэты ўліковы запіс адключаны", + "INVALID_TOTP_CODE": "Няправільны код двухфактарнай аўтэнтыфікацыі.", + "INVALID_TOTP_SECRET": "Няправільны сакрэтны код двухфактарнай аўтэнтыфікацыі." }, "register": { - "REGISTRATION_DISABLED": "New user registration is disabled", - "INVITE_ONLY": "You must be invited to register", - "EMAIL_INVALID": "Invalid Email", - "EMAIL_ALREADY_REGISTERED": "Email is already registered", - "DATE_OF_BIRTH_UNDERAGE": "You need to be {{years}} years or older", - "CONSENT_REQUIRED": "You must agree to the Terms of Service and Privacy Policy.", - "USERNAME_TOO_MANY_USERS": "Too many users have this username, please try another" + "REGISTRATION_DISABLED": "Рэгістрацыя новых карыстальнікаў адключана", + "INVITE_ONLY": "Вас павінны запрасіць, каб зарэгістравацца", + "EMAIL_INVALID": "Няправільны адрас электроннай пошты", + "EMAIL_ALREADY_REGISTERED": "Дадзены адрас электроннай пошты ўжо зарэгістраваны", + "DATE_OF_BIRTH_UNDERAGE": "Вам павінна быць не менш за {{years}} гадоў", + "CONSENT_REQUIRED": "Вы павінны пагадзіцца з Умовамі прадастаўлення паслуг і Палітыкай прыватнасці.", + "USERNAME_TOO_MANY_USERS": "Занадта шмат карыстальнікаў маюць гэтае імя карыстальніка, калі ласка, паспрабуйце іншае" } } From c85671f53a301bc9e29b83cfb456375ab33256fd Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 13 Aug 2022 17:50:18 +0200 Subject: [PATCH 233/238] New translations common.json (Belarusian) --- api/locales/be/common.json | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/api/locales/be/common.json b/api/locales/be/common.json index 8bb9c0421..09be0d401 100644 --- a/api/locales/be/common.json +++ b/api/locales/be/common.json @@ -1,9 +1,9 @@ { "field": { - "BASE_TYPE_REQUIRED": "This field is required", - "BASE_TYPE_STRING": "This field must be a string", - "BASE_TYPE_NUMBER": "This field must be a number", - "BASE_TYPE_BIGINT": "This field must be a bigint", + "BASE_TYPE_REQUIRED": "Гэта поле з'яўляецца абавязковым", + "BASE_TYPE_STRING": "Гэта поле павінна быць радком", + "BASE_TYPE_NUMBER": "Гэта поле павінна быць лікам", + "BASE_TYPE_BIGINT": "Гэта поле павінна быць bigint", "BASE_TYPE_BOOLEAN": "This field must be a boolean", "BASE_TYPE_CHOICES": "This field must be one of ({{types}})", "BASE_TYPE_CLASS": "This field must be an instance of {{type}}", From 246bdb2d8f55f0b61373c7b13b807923b586bf7d Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 13 Aug 2022 17:50:18 +0200 Subject: [PATCH 234/238] New translations auth.json (Russian) --- api/locales/ru/auth.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/api/locales/ru/auth.json b/api/locales/ru/auth.json index be7ac8456..7967e238d 100644 --- a/api/locales/ru/auth.json +++ b/api/locales/ru/auth.json @@ -3,8 +3,8 @@ "INVALID_LOGIN": "Данный адрес электронной почты или телефона не найден", "INVALID_PASSWORD": "Неверный пароль", "ACCOUNT_DISABLED": "Этот аккаунт отключён", - "INVALID_TOTP_CODE": "Invalid two-factor code.", - "INVALID_TOTP_SECRET": "Invalid two-factor secret." + "INVALID_TOTP_CODE": "Неверный код двухфакторной аутентификации.", + "INVALID_TOTP_SECRET": "Неверный секретный код двухфакторной аутентификации." }, "register": { "REGISTRATION_DISABLED": "Регистрация новых пользователей отключена", From c0f3c91b71a901eec5adf9180771cf2da93044b7 Mon Sep 17 00:00:00 2001 From: Samuel <34555296+Flam3rboy@users.noreply.github.com> Date: Sat, 13 Aug 2022 17:50:19 +0200 Subject: [PATCH 235/238] New translations common.json (Russian) --- api/locales/ru/common.json | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/api/locales/ru/common.json b/api/locales/ru/common.json index 35a74cfa4..578aba05c 100644 --- a/api/locales/ru/common.json +++ b/api/locales/ru/common.json @@ -1,18 +1,18 @@ { "field": { "BASE_TYPE_REQUIRED": "Это поле является обязательным", - "BASE_TYPE_STRING": "This field must be a string", - "BASE_TYPE_NUMBER": "This field must be a number", - "BASE_TYPE_BIGINT": "This field must be a bigint", - "BASE_TYPE_BOOLEAN": "This field must be a boolean", + "BASE_TYPE_STRING": "Это поле должно быть строкой", + "BASE_TYPE_NUMBER": "Это поле должно быть числом", + "BASE_TYPE_BIGINT": "Это поле должно быть bigint", + "BASE_TYPE_BOOLEAN": "Это поле должно быть булевым значением", "BASE_TYPE_CHOICES": "Это поле должно быть одним из ({{types}})", "BASE_TYPE_CLASS": "Это поле должно быть экземпляром {{type}}", - "BASE_TYPE_OBJECT": "This field must be an object", - "BASE_TYPE_ARRAY": "This field must be an array", - "UNKOWN_FIELD": "Unknown key: {{key}}", + "BASE_TYPE_OBJECT": "Это поле должно быть объектом", + "BASE_TYPE_ARRAY": "Это поле должно быть массивом", + "UNKOWN_FIELD": "Неизвестное поле: {{key}}", "BASE_TYPE_CONSTANT": "Это поле должно быть {{value}}", "EMAIL_TYPE_INVALID_EMAIL": "Неправильный формат адреса электронной почты", - "DATE_TYPE_PARSE": "Could not parse {{date}}. Should be ISO8601", + "DATE_TYPE_PARSE": "Не удалось разобрать {{date}}. Дата должна быть в формате ISO8601", "BASE_TYPE_BAD_LENGTH": "Длина должна быть между {{length}} в длину" } } From 03ba7e40c52445e807ca9d3a76cc8f63a27ff21a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Erkin=20Alp=20G=C3=BCney?= Date: Tue, 16 Aug 2022 19:17:29 +0300 Subject: [PATCH 236/238] Fix the latest SKU errors and further debranding --- .../skus/#sku_id/subscription-plans.ts | 47 ++++++++++++------- 1 file changed, 29 insertions(+), 18 deletions(-) diff --git a/src/api/routes/store/published-listings/skus/#sku_id/subscription-plans.ts b/src/api/routes/store/published-listings/skus/#sku_id/subscription-plans.ts index 723a51607..e7f44ded3 100644 --- a/src/api/routes/store/published-listings/skus/#sku_id/subscription-plans.ts +++ b/src/api/routes/store/published-listings/skus/#sku_id/subscription-plans.ts @@ -9,23 +9,23 @@ const skus = new Map([ [ { id: "511651856145973248", - name: "Premium Monthly (Legacy)", + name: "Individual Premium Tier 2 Monthly (Legacy)", interval: 1, interval_count: 1, tax_inclusive: true, sku_id: "521842865731534868", - currency: "usd", + currency: "eur", price: 0, price_tier: null }, { id: "511651860671627264", - name: "Premium Yearly (Legacy)", + name: "Individiual Premium Tier 2 Yearly (Legacy)", interval: 2, interval_count: 1, tax_inclusive: true, sku_id: "521842865731534868", - currency: "usd", + currency: "eur", price: 0, price_tier: null } @@ -36,23 +36,34 @@ const skus = new Map([ [ { id: "511651871736201216", - name: "Premium Classic Monthly", + name: "Individual Premium Tier 1 Monthly", interval: 1, interval_count: 1, tax_inclusive: true, sku_id: "521846918637420545", - currency: "usd", + currency: "eur", price: 0, price_tier: null }, { id: "511651876987469824", - name: "Premium Classic Yearly", + name: "Individual Premum Tier 1 Yearly", interval: 2, interval_count: 1, tax_inclusive: true, sku_id: "521846918637420545", - currency: "usd", + currency: "eur", + price: 0, + price_tier: null + }, + { + id: "978380684370378761", + name: "Individual Premum Tier 0", + interval: 2, + interval_count: 1, + tax_inclusive: true, + sku_id: "521846918637420545", + currency: "eur", price: 0, price_tier: null } @@ -63,34 +74,34 @@ const skus = new Map([ [ { id: "642251038925127690", - name: "Premium Quarterly", + name: "Individual Premium Tier 2 Quarterly", interval: 1, interval_count: 3, tax_inclusive: true, sku_id: "521847234246082599", - currency: "usd", + currency: "eur", price: 0, price_tier: null }, { id: "511651880837840896", - name: "Premium Monthly", + name: "Individual Premium Tier 2 Monthly", interval: 1, interval_count: 1, tax_inclusive: true, sku_id: "521847234246082599", - currency: "usd", + currency: "eur", price: 0, price_tier: null }, { id: "511651885459963904", - name: "Premium Yearly", + name: "Individual Premium Tier 2 Yearly", interval: 2, interval_count: 1, tax_inclusive: true, sku_id: "521847234246082599", - currency: "usd", + currency: "eur", price: 0, price_tier: null } @@ -101,25 +112,25 @@ const skus = new Map([ [ { id: "590665532894740483", - name: "Server Boost Monthly", + name: "Crowd Premium Monthly", interval: 1, interval_count: 1, tax_inclusive: true, sku_id: "590663762298667008", discount_price: 0, - currency: "usd", + currency: "eur", price: 0, price_tier: null }, { id: "590665538238152709", - name: "Server Boost Yearly", + name: "Crowd Premium Yearly", interval: 2, interval_count: 1, tax_inclusive: true, sku_id: "590663762298667008", discount_price: 0, - currency: "usd", + currency: "eur", price: 0, price_tier: null } From f070bac69ac15ca9b6bfdd4d22bb0a8b2a1ede97 Mon Sep 17 00:00:00 2001 From: Puyodead1 Date: Wed, 17 Aug 2022 02:10:10 -0400 Subject: [PATCH 237/238] remove duplicate key --- .prettierrc | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/.prettierrc b/.prettierrc index 7d715cbaa..0defea238 100644 --- a/.prettierrc +++ b/.prettierrc @@ -2,6 +2,5 @@ "tabWidth": 4, "useTabs": true, "printWidth": 140, - "trailingComma": "none", - "useTabs": true + "trailingComma": "none" } \ No newline at end of file From 6fb3e77397fd46f10894de08f77e0f36bc3256e8 Mon Sep 17 00:00:00 2001 From: David Sundberg <111130321+DavidStarDev@users.noreply.github.com> Date: Wed, 17 Aug 2022 15:57:54 +0200 Subject: [PATCH 238/238] Create docker-compose-dev.yml --- docker-compose-dev.yml | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 docker-compose-dev.yml diff --git a/docker-compose-dev.yml b/docker-compose-dev.yml new file mode 100644 index 000000000..80429042c --- /dev/null +++ b/docker-compose-dev.yml @@ -0,0 +1,2 @@ + +The Docker image is coming with the dashboard. The planned release date is 2022-12-24.

7zI)bM*AClsUpcc0|38}y$_@eS~5d@ZNu117&BNbYXS6> zJxyVw^ZsR#tZ!x1GG1qovNQg!OjcHBK2etA0X1rP?GB@D z!?k0LEggq^bvmnzm#o*MopoEONo>#I4-~r}b%RA?F3)w_=cSJ=63th9ef~pb6bn|3>_;Es*-^XVb>jW1 zKj0fJrE(l>l;u)lr3fs9kwt9W`J~h0lfdo?Tpa-FN>xQB*3CV!aiqA{!%d^_YTb_is7VL3Ae$~v_%Uy=Eue&-D`(fYY5EDrBdkO8B3Pb z76g}6Uw7;PXB_`|gaeJ!{#qAh)bjNsy0Bz)n-wp)cj)c$ZD$qNtE^wzG&rwAsf}6~ zv}dcTx~=&uXC*PVFVCjfEbcoCCZO=6R-L+lY{h8e%E3>kgiGNX zkN3(^ty)#^Rl8v*6ISX5swa`yd{KSZRtMK!q6S9Z@q-#CPRj1DzX6mR_=2E?K-ZK1 zT=}Mi;jBttXyXuJEIpialN}${ zv~^mU8e3wDaf{=g*$nBLy)BK0j@%&u4!<%!$V98Fh;3{p3lpj)tdpye{$Wb+SvNnN z-Lo}uDrG?#Lx`sp`aQ9mqPbMhqy|+?e0w{b$YmVODZ>GMAJLl+!{NqQVjJ4Au@q-S zsVOU3AmE%&EmkVgmLp>~ZY`*}Nqg(I%vVB{Z?`-0-mhT2QOysgdvkBhl~i*#l)mTs z5bL@on+mj8VUlF`)FEWx#C{2#zeD|3QvmW?(DIZWu>; z+nKfEad)V$s`G=*asy&$O*hqkylOh8)DsP(q$d#6i~MCp1z>Q$z7%#dz9FUI#O_?L zhXP()+RVPTQ!a%s_GYaHT9L#7Qf!6?{cw0u-s#KxH=~6(i)dz9r+0U+)l_CNwkx#^ zK@sL9Ch%}us%=LQA3H`1dciikmTdPYn{^CbS|Zi%F2jhDq=pX@8C+v;&GFJ?Eoeh` zHIaK#w1V5>#s+-uN8Yvq{u{dbPSp<2bvWF{FaRx!^gg{ikyrQSvAiV-?7Dpl>Kz@> zVvD62til841v@WYxehE}QkxA%rz%VvYmTdfxpx3F4B(LcVc&7Y_Rvd@OR=Qu)xEi^ z*McO#sq`?QYf}Rk$2P65`pHf8R)I)@lUaB|12y^4JmUgFeOtHt2L|1lT*joF@<%4! zQ0`WRNn0i>vz8g*m5RGsGp#+hJXW<`?36neTjd!(64e}Zn5iIepWJ_M^-bR?`^2#T~;yBpWQ4-=DtJ$4Ro|8dM2*#%GT17Ca!kU zrZlJ-hmO|SdQc6&-tNOHw=$~MWMGeKZMU{wx>!vFYcrBg)IGn197cVm z>-u)BEBiD_2MhV8Z}G!BI;*wYd!cczF@y)LOrns&mumSOlR!ImBK?!od820% zN(|F@+hM3y+qKo@5_gB@N*)X=OwX%S&pFF;MMZj8J_@ye>8Sjonls^c)+}fg1ioIZavR#( zixY%sO9W`IGzzhi0u}0#EWbTp!jZq|;MV|+bh2XeW-R}cAdc>IRj!}9oU=AgZ^@J!j17+ohDy3}c`+d_m_ zO|4t+bTDx>lGZV#@f2L_sFJd1n0jl~YSfo72XqpvwG@z_kNP$lmQ~BGOplXwg&vdU zVIjUdI2Wc}7hN0Hdigrzv}2I!b;&wA=PAPeN{vzk%M&SmxpiY|(QBgmiisMeYG zVy`nb>SZsT88epX?kMpGxDwyo_v5&#hRs1wb<(s=t+fiDx};zn-PMoc+Wk~H!= zja^h5kSn=8cKhmp**Sh=OftGembcrDrXFnu^NArE6;@>W++ealSwH;b@3N3rkoRo$ zXX>zawEEY!4*AoinjyAHon#^L{c33t(^HY7d6Mm48o_QX?pGFUHbg4#8F{iCqmQX+Uy_G5wGi9M%5VDhO1)7b zyZbU;o-A4ur>w&eKDAZiNQK{#?TMuemc^8ts&4?g*9Wyah5aw*CBY0hfU5Gc68HyJ z{Xxv{f$j~*F5mSw3P}EJ#8EV_bbGr46scLg297OD+nwr^h}H*72la{U&P;>8k`bub zgb_VY~dF&2iU6v|zbF{`? z2!{(}W!e|xh{F8AeiW`ELoFK=vj`S?Krn2w(VSyngk{YOtwd&`3;{y{MRhT_e>0R4|b``}%v zbE>OhLA&lZai;E%c2VUZO#L2)9SG>e>QR0#n1c3k!&@2ToRUz zdD>v6#DpOGgVLl=1&!;ueZDp4pL_ukyUDn}jlL9?qyD1&z~7rPf-hx0Lp-}-F#7G_ z%Dfl;-2&POWvXoO^lqzG+GW-t)af=QdYD#Tjwf8D)2mp#yQx7OW*b`dawXVzYlI9y zU<1(`J58FH%hs;HuWtCIYHh^BLb=-J1t!5Kocd>|T=jzI$>Ho8`}PXS)WVtSm0#yq z-rkKUb=f9uOgS9<@?0u)CcIK{7@{+53%FA?%ST2nA5vA5n_Jf3OLSDCjcR>bqO8`Y z%?svC5tfSGrz#0EQW$pY4vDCFY)99~VgbwEnNZOh%IaX;`*Vh&;On>3R-s(zLNjC6 z^=TG`eLGK;mG=#MLLZu1awH~c-fx3L9?Y_0m zGh&EQ*@KU~MGcVQfqCVo+UfYDs7EJOE&5ZHEzATepa@ZP2Bkh3&!AGr{{gR^2{7Gx#!p5 zoj?sjLC)H#wir&Amn&?G_vP zX^*P%2T>nr&?5&By2Iv{(6wZz4+3ivy{?VAnS}eWdgR1?38{A`m#sX^X6$C})4SGq zyt}~VMpxTXqj*7wBfZ~C))PLQQa;Nn?pDKhC3iFpqaB_Oj*E7`iC2$ns^V9mKsvNb z9e0q7_6jelD_*RHwPfUZSw&cGPMv`e;K09&KZJR^jb=qx6k%kQ-l?#H8?-QU8LEfp z_2$Ts`daG%t&Gp`H?zdvX&Sl%ZMtJSGta%%wr)L>kU+B3!ANg>?LFm}86&%pYSOsS25Z=y#!QqWdk^7NVmEW&_-+(Y7`jBY5Nig3Qeq`^WMEp&rO^xCl#}Or_K@WX+Jl}T$ zgh){CvTUy>zI=JjI2Y)AluIu@sEl9((&4zHh^02A;=O6TYMYJq=D4H1!>XC8^+_dN z%=daH+L$x0@-BBNp=8;gE4aYXJeqSB6U~fWlS%q1J z!0v}52a@-7$#DpSG|x1%qj!CZ{K@y#$Jn^rt5&MQVbT!eI&q{NbMLK2u3PEOCGf)0 z*m85&ZL6xd=l0{oZ8f%%g$=~L9Fej9{=JO+%fdK!( z>B%nO>!G`}>BC5nQ(47HZGCo+d?Kg-mF1WQKybf^6ruv@Tn(QBESVNLPx^*508~^5 z=|2Mk<0i~4P=u0oBAM;j^=W1g6^(Wwf22Xmw$gHwS8gsW@ zfB^yH7c?lY%Svd}Y?SQ7kwm}wTSnYdMVz>Q1#JEIp|LG=T~kNJUqprz^vE5*34%GU zkin4LiX4ByR$E^p#j*)QLFZxO=nZl`p4DcH$V+G{<+aQJtQ z`T2)t$t!droCXMgcA5%fYQIT8aQY9zyLU8i_?-Rxk3zgGh8Y3?A{R>eb-73|_sx53e4eL9z=d$C~q13G? zy~@V0Ds-h(vB_4O)0J>H;=-NZPWxL+r$+59Mq(9ik_0ILt#+6>uTHUvQee!$U>iUb z1O%6-t(@pMf0<)NqjF9ZvxQ%tWk>m4mNn$<@~$iR)~Q<5CMq$}-ZEf(x) zPn&k7jY(}yPwK*45o&UrX?l4cI1P!)=McQU%dmXVeOelvs+}xytqSe8>JpM z99I9WS#TkkE&kkw_0}Xn4yV=;MSDm>yNsT?E@jXQho1w;&BlguRjNCz@xxxT)8?iv z28sbH!o*6)La$A<_GW)16Pi9>O?i2!FU4Jz@Hgsi;xDHKfgxMXyp@M#|A`Jqw9tyt z-;Z?msxlzg;6ab(lW5xI{SB-bn@qo}kI zQXvYq2TVE=Qxb{_s^xB4HTW*T%wBxPg0o+&v(Gc>9=L-1#&4qz8L^BlmTnrE5EMln z03jNNPDmutNDc-oj#O+{4|$9?EtYsWlp*xu003#740iG1S0nBD?XSKNM8Ev#n!8)p5)&wmQ9-PsU|NAS@~7M&f)2qMFFGam3ezY;PFTZSOWm zQqgvlP0yf5#to)gGV9N}Fm**Jv)5#6!LGvQpt~hg|1Zw^bt&iY@e}VYbKU=#V?QU# z_nbSu2poj_;~fj*T60qBl=NfR0;g4)bKKGhL~nmEMs;s2@+zI)7fdOfd3BY6%$P(XRm|vz0PBNTA{Fyx zMBrE07IFCgdos0C6e}Qqa3XMMPXPlv-iDYt+8w(DQEng8^#zmpi$JntI#6!|6&9;3 zPMKF&oJ^G$BIrYx2K6jxfTn?dn}^7VWqd$XVfiTdTI`xtdgJxRUn$TcJKnba<5*!E zvB}Y+a%BK$eQRaBW5i)Q>1!IZaXUg!tg!=!ElugBnT&^hIX&=1ovIvmj@n|NYdM-? z>+AWv@mX_c`gz>ovFP;9MJeLleYok7&=X0!MAkmF*?v(44*z-uSPewqu=+pevKQ%M zB)cl~pFKMZ$gTdeJ0m>PJ0Ax`8}uy@D%d7a2!4g3ZM`HO`v<Uk4cUTs}jJ;HFD zT!e3A`jub?;L0qakLTH9{v^fbp9yBGIX}tFhhqI!>#HM;T6i#BQZ0*4{^I*&=an{ z{BwnLiuFT?57N(9v^xYZe=#a@X(+Hj-lVf2UVI9}Kj^4DD*s*h@kB1?a7G#A10@+> zUjXEfus&3RnnBH$)S|H*l=S6J>DPwkg$MHSc7gA@HuDyOpYzE0C(Hcaf`%#s)yYX_ zOT9jQYfU3*s#;d)3A+KY*F;@e4dex>8#2{mnU$?htN2ij7sIkxj@CV4wH@z*3ScRY zy>e$UXNb0qg)Lj|HJgSwN<4zB?loyLnqIw(_qrkb{h_G_&u1C}L%zQDZ%AHPl79mz zJQSZTl7Lk!Hh5d(+DEGDFw4A| z_;`}!BJU1GKyKSa&I+k(gI9w)I!{@nLxhWJvmUGqtS8O@o zukwH8zQ?^stcHyN;b&pcn;%#8AYDgR*bo07mO*Dg~ocpRNHnM3oQ-b z<0IlmzdRQ!RBdsCDuyhKOR^a)$^W?^{~$B<(|qr{`zyN}6U%tc{+nO%shxdde@61k z{p@L`+>13?W3gY(%13>oN-muMh}&vug&pTmt6b(P-KghWwY}gc8h7Y>V8rE}Cb=Vb z2}T20^D?&W{C6R}mj7FHqW^(beffvKc%O&SG9&l{#rigSk=rIYv+fi_2AFov^*rc> zKWP295`-bLczIDB4;(|9bw~Naw7XY7O6S)Cf4}Ti8zn>E1E#uNI!t5dxREx> zfR0*Z*qF4WpfvHeAu*rWWg4;-f~`i=ow=;|!M3~syxaARnJFu*q-`sul<_;8t5g=S zuej(mlZW3pA`g;=*!M?A_>S_0eRr>B>?>A-vd~oq@wSyXHphoOuzM0uYo;rIb#XoZ z!!L)(+m@b1Wl*#8m*~%Mp&)Ac^3fwerb6v7#eRp_=UTcTR76MM_d6qQg+BCO)Q@#- zcQjWi%q0#-siSvSmLi$;WzegPyd;`<7KdqcWu|nio7Qov05Y@?RaneV-C?P9J#f#j ziGPKkXS&wW4Djqxc3D8c{c5TJqqnzk_<#Qcsi99>)z6k6WCm2+ZAtaf5JB#VQ2-8Z+j&HBbzg65==IGcMw-G zS7|X8-fq{7xkj5isOoPF5;>LqU602`qwug~#vuK*#&)u4ji$q18K3rj^PN)(NI^bK zYXoD}ggIYOLXqw69paGgd0WfesQFtrEe@y>R*SRBRoL*0BmURl*{Hb8!_19xYk3`| zbqdA8KLW((A484Q>>G3QHWPvTEh~fnIQ^PSHsi0q9q9k^3=~~N_VOj(0dJg&Um?m? zK35t1^>>EO_xC>#rrrg`>R0^z^!;E*?k22aJ}e?vDCBtr5$U@o5pTJ@h03{tU2 zevyd#%)^wd99=NPZyP>AHC0QNq z>-^f=xQx)S!DjLkiJI0&eAKWS(JtV4Av!LEzHwwqo!a(b>MXyAbqWymZ$_m&*DBYt zP2k4;wpfc0^5N9ssr!r6sYw~KZPO9Nyn^3L) zmkJ({f*s1%kbV5k*_w>xZP#p!OJvaRTF}>0>$RGS)Dc&ENyj_E##>h1n%$40C9Q6T z`<*qcaswz_)An=l@FETtAmHcVo=C(M$C`f~3JruX{0h?~RkyB;5bBgtw7~5#2{T3glsx*@cc`T)~$mxu_godfcWZc+m0MFY{n-nsDzFYg_4e}sc z|A}*ysn)-93*a1Gzg*iV&jDIJAy@bVR|FJk=H>Kx80=Hy@y`^(<${0MHgw;Ao1y&G z4VIC3qZVY(6x%Swy(yJz<36s!j1~qOPWGmUS6O8mE`m{&X>)E`akWy7oCf|j?qSDD zzd|DlDN|)7Y^NY zjQwi2F0h2oCVj!F0$9?QM)$WhqR6U3^v*UndYqZu@9IN|b+x__du^`Y9Im+fur)T7 zzM*a6fbDhSUPw5#&2(+}fULNN-k#E+rS*@UevclGCx8W?Qmsm0#jREelLM;GrpG8~ zwXWLv`8K??V6U1sJ0_XWaBJ}tF#KjSU-CS|t+=;`Zjo@IvG3c<5Pt9t(VY7?FZ^UA z-<*V^_cll7n8sh#i%5pdOcB?jw%C zdD*4>UB4E#4c_urb8%R~`uk+~&ZS+e5QVq%rn}5ny|XL}_*@)!IG?{STI8JG-MQ^y8v#a3yiN6+yU3}Q?jVq)2WZ3R(l4XBI zlWTJrtzrP`Kk91DUR96MdY}@GY0sA%urYBhQMeH|Q|oVmh@Y_hd{)owGU)wsP#im7X z!|7xZ!6dlqgrWkfC+W*hTc1Ng(R$0zCM67j#rxqz!>WVIV7)vp>tm{q)qArsJ$`M! zKv5L%^Wl<1nuYu_b_b+jz3|^mv64l>Ib^7*E-op9<6yE?>f6|>R+;j;TcPH}B+!_t zKU`M@+vbl)XqcfKou@SaQpYyG7!+KX{;@LayWZYVX@KPrb|&&Rb0 zOC2k%;I5y{Q?(*B0e`-Yi*uo6O|}d1t?`&;v+~Ne{LG*(;)@l3(c#yt=;mM{PasEr z`TPCdnxBn_Fz^S1977nzhjL!QIxa-?$;?CZpxg2DnI^e0mH&J zyYgC1oW>*Fir3S{6S1B3~frjv(aA##7M0J&+l zBhPvS#adk}n+}?7GSZQ!7Pz;Ht?;&v)`9nY2q5C&w-;7M3~fgCAlrs_w-x}PTVku- z$MU{QaQw0y9s@j7jPBIzgTreq zM&a%_XKD*guVDq(Ger8IX%(cizjQ()AcfWne=>djt}wQ=B;tOfI!IbOF$Q(pogSeI zb~(idJy*wDe%$VfT!{@jv3{(oooO=!ToPrlDYu~8)25qYX}i_dNvBfP*k%wq@dg_? z1uOM_vZMeseMjes6Ym>%eHsSjWPf2PR4-qSw$cO01`@S?{(j5vKX_^-*uj zh3~=;Pyyw}j&@2leP!x{k(S*h&wbp;vmh4`!MwIt#iHLUksFd3i?8319kX`|#RF_A zS!!%oINuudoMyQ+CGgk`IsvF~)7VbdTqO4PsyX+Uew=J1)3rz50jK(SZEP!(s9|Dl zkqzm^x^ZL(PPVJf;nfT-xJ^-~Z6U89r+bOQKUj@7>AcTR;)PD2h#aUG>|OM4#~+x5@VfqcvNMlHQQw znq+zHCr-K1!lvZdG~V{9z0Yi0rfITtIlJcIR{Y-~ryY6mY7Jo?l(c=OYH~N^JL~3# zWVW~0Z}_NAC~6u}!ynYUfle+uL08?)=lX`J9@YyBKfqXc#!+GtYk;HcV!QQZ$tB%^ zC$!Q^ZyxWc(y^LEdX0$i?xtE7ha~6g!?zhK7)yBCHppgQ95Vkp%MQ7HH%aT*wE!V3 zRPA%NI=6#9vt8euwJX2w-L_xf`EU$xOtDXo;VntntJ|k<3;L0B5!Bjdi>}YBwv&?n z6k|wsR;#p`(uA4o>ap1rs3m1+ZR=2;AN`3y3`ZqJ+Yo}->O&+?g$7cX-&N}`)M|Y| zCK#a}C);aCv_ND1(~X1tLcs@R=9x&Nef%dM;%WcAIm+X1hF)$x+k^+TIfm5<9ubzcCt5a?HWAacILV{h{}Mf%GgtR%-Jq) z%f86_8468)5T6_9PlWX|aV)m70~HDSQ{{lldQRwPp9)-bBA0P9rwoDyWD0B#@<*S? za%*+0#-*r1S0|Ii3S)~sBvfa6wzeL8{+F`ze-++zA@tNn&l_gIrTN;>K9NJqJv{_V z0LT<97o97(o$S_n%*8#28aJ`!mJ@~~KO3dJmQrq%8MQtSCJT&lR>#EZyTNYROtexc zh;ypc8)6~8kJjn%a0pvUy4@|s_O!DPujlHsVHw$|=u9i3JNXjvx^wa_1v=~x zv@*GYzo2!1z#E}q*@l+Nvfn*o!cZ8-5Hy`Z>U%YriDqTe7b%6Jd%Jo9P~O9Je@R=C z7#~L_EmH|;L#v~(9j0X;lk4$x+a8JAsX z?~&iKB^YJ|voX#hb(=y%7uc603vVc%S(MYy46AoT42flcJFO;Z*nRB4j%~f0Vp@ye zNphIrED=ppvpHiqcI6E=YiFk_CP~CeC*H)GRM}NJD@L%^9w|*EXze8wcFV44{Hj!5 zD%}72FU9^Y+Uezs1TVA~U7#q>s^T3yUdAOv@XRCh7^DbMdUJ##A~@D|9P5;pQ{9N0 z{6ttwFh6IGRZNeW4K~VtNs|o~?-BzR8<*H}+b2~3!?yRi}xGjX>-KyooyRop-B5OeZ zo%(dDEDHF3S;TN9c;b6b9fTYqq`Xe(!YC~_XpT4Qt=J3=c>=Q>c4q&eTYRkqvyomH z(wAS4ruXG=EzcAhx}m-eL_Q&XzoN@GLdFy|nZI5evYU=Z%+0&K25g zW6@tnM`6mUgSHVvI3-<#7n;(1)9nBt$d#2GKvxHVNyx9mQ!Yi!l!^y$zwM7?bss6Shsd zTVHw;a^6)Bb8qjbGuquj9$en-2!)p`N@^2j?;1=kxQroN3|it1zfO~zA4C%+8@_a& z^D)pFj}X-?5?bUylRsfl=`(^L1&&}xEukzKEv>U3DK!|GoQq6RW)K->MJ`_K9xWg8 z3eN-qxf$e_NAFB8TVYNb^f03H=G<|C5H;9_Oow4V5&a%zMC73CZfv4Qt|#+03(?>s zVVe_bJv4SOf-g{M_E=uXHG8^q%ETTb@Qmk4N~3xxbIa~{UpZv6iE|s`!6SaIy)2xK!nJjN=j07tgbCf z+F%oH7-kWAjz-4|uui}0u?YO61PTnU=VJa)ZvL>vNca46>C4c~Jz3b}`xoGL$cPr6?M2+;_YHy4 z#KcRNX`@@Cf~L?N!1%@|oBZNz2lmefuqB?~bQiVxsq8{gO-2qDbbgpQ97S;{@~5ed zB(mNa59&jI2X#a?TMFo9@L3E$Z%DGUZbob{Y=IUb^&? zlG}9`doX<^slA$rD&GZgg%?|bz|MXgGgv*1sH0_kDQxIhpD3QzaC(+4pm=XwdV1i= zx~0%Vw$n{UL!w!$dIOg}T(oDAA(?k_6`i`+LKecqZgJlS2V)?G)(3xnvX2*>9%Nr* zJ#cCUW_Oli;!Nl_oXWv^bB~p9`vsy!Uhy+KpnOt;j5K7O zpw}9)6*8}vQ-N+J7v73~ej&r6pwq=l{Pi9}V*GT%7HDReyjbWR-ShQ6M|=0p4|1RX zklZ}~a96JcVMnh|K=Go^q2k@FZ|fTdPzXyS%&qK#g;g8R=~Ws=cBAJGXY@ufd!43l zGHPsMqoApa^mLKLoAs;`mW@S;bQ)rKsPRE_$apQLvK-Gt^)nx{&;#4&F2w_T^6>jt z>_McEsKX!7cPO#+nkD2<%XgEGSc&&NGw;6Zqo_?eI`V`gaMsA`TD`DD)T~aw)bN)g z0Ai1+?r4sSn8zwJ~r&f}ER~;dM&=yJzIF?ZKD%gI`n;kC}!t-0VZ@+!PE2;52I%C+aG+Cq{9woWz` z45s!$5W6rAby^roQz3il83S)7^L^^m{i1qh;Q4#9%7b@e*Da^rBw(DXJ2;%1}@ED9t%tE#uzX}D7va4OxJR+vU< z*=%=NqI#@vS5Y~hFXmLAZ8&k-cRRt`V8^~ zz63+M&_kR$(*_Yldi6D*G7&uDFk>&VqTXntRt8a4ZY z7IG8T-peEAuw)x;sVflijFj4Sn`p8Gxhg4Q9AZw~p!Zi1EMU_ITmlB2QF$Mfjids%R9CVz?#@&z;R-TpiD&ZkWNQVU)Q0++8(GBy|K!~X?1xEC3?XUW|* zJg@{6hknVDD?wn%^~qb*EAr=m6A)a)NdIYt5R&h2LkAhL(-HMia0EycXfg698VxF& zBU{^T=7-*PA?&Nfpci+g$bT8lP69Are;~bU0(!OQJfBI7w)$H|{F`pJj$hxEZTvgM zT-`VIRG|S;cDXBA-YDG!wQaMK&dLs3O}89g>83c(S3FlTW4uycCP5bh7fzoVRNF$; zc3r-QDf|diHq{{=t0XQ%*W+c>+jIS7IdK602M~*FA~ztOU9N2yJ^7+q=w!j&j4;ep z8{*z+>+^c#Q>E9XF6#8JP>#FEuz2dNvQQoLW#w6dD*ciW&|2W51@eS$MMmtb>N}4D z=$k4PZ0bG1J`6^TVsAuT_mrhF*KONqaY79z#ZtZADlv+|9a5?p2-9la;-cl2o(HSW zps~edV(cC(6a5-ZF1Qs@hTzV$eO=?7*DIhbO2$c4m3vZ52ySZm!=1w}xwVHHCGSdv ze^b6k7QCaLX~9>hf~Wm|_{zc$73}!asL@kB{AIl2kuXTa(3~|1&#cHVr#LjxV$8BHDXxj z6Rs@u3?6(yMZ(%~JHbM>bL0RGsKt(2@uUQWK<&_;MC;JPfHjjvKaquG#?DxI*cmP- zl7E2O520SLYN(ibnubHN{^hlDK(x?$(ci4woV6jj2>B$+dEw>gs!J z+qRWr2q%0F4-faWwcH!!j-SMt9`sx#72LkM-OcAPL|RF-%P9~dz}t{Z?&V|=k1c8{ zfm+|w*jKS*#1f;M27aLgzDVpT5&Y@Scva@-n^>ua0!XR;0c>Bfz-tBo>(L2sPdtNy zc}*i$2XC&gGDJSi38CaNmtG)+Gmlq-xRR!mVw{+5V-jWzxz2hZ1u$L|DYCY}CbAv+ zhn?rfogpgRaB`RZ@qC$iD>U;#A)JoYoxJacTU6)KDg>Mg*fcukiRS9qRK+p`yNWQ5 z@r%*6!v@TDL!h|@4irxJOCxpL_D0Dd4B2{Z5YdIzQd#e@ROA<$mCv(7cNAx`>Trt| zC5)7$R~d)Tru<3AH&F4m+VA`3jKN^_e5+P(rx9L|9C;(^Q(7%e-6w&%5jJqhXZy{T zEXD7xeH5?};3!gkAn$Q!)G^c3iKsi5t17!(zjF#HRJ$4j`e)EXo{g_u8oj|;S z<7HsH7o@5*7D&nU#v_NFaxIcY#jKz7xVh6>qXxV7*}jCVkJ`~NobD!QBZnC@<=A~s zM9cnY&l~A(K!TD+p57Yrumtidm4L{%tENHpFOl_rk#)}vA4IuY+kbP7bsY~N?)rCw zMW;T1_lV~jX=|_eWEuBX@c?Al>wDw#HX|=J_xsS#|5q0T0-Ss+;0(B~n($x$DFJ6x ziOL}HAth4KDx35PCcd4u{9)V*Bh~l-8(^?6ScuI=2&nP6OSO_`(uoSTP(j@`k<;R- zr}pP`YYwp#MeDX*Y*@pj3#MygVi*$K(jQrb130q^bTHie1NDEUF zXy?mZ-=pE`%hq3d5%qdPv1-@HbgDNi@vH*CXU8)+pIxjqM8!C@*q+ql6T}15U*4$E z4St{Z#j2sf`?r+f>lx2FNybQ$ApQ>s z+c|II53tdD0Dz6&UueWek-#%+d_XZ$xExJp(PEN1P`jhp`$>1q&JuO81wl3^94`xa zjT9BaQWUp>V{8cI6&rmn2esz9ldSi;?>x7$Rr^!euAdsRmd1Y45-9`Y?zC;CD=MN%#1- zvi>z?ea{y^?H*jmzR8vqHxesO6k0ARV6+>>o&8uh6PFJ8qcp;MsIE-KVcNkISppdu zk{e4bvqFZ0smt{#ESQoCI+|E(KDEjbZkdPHiXtT~@0+*16=2UxbfrFMtnKedLVZVoJk~m)In@+-w;Nrt> zNK!N3B*E%-d)$_kIY~edH=0=wXGn;3LlB-iPKEYeJ>HLe`ERe`o6hIi9zA8FZ?5_7 z?P4`7;G5c9RW|m{{eJ3v&t@(~<(cflxU*a2K#_IU%;JEz9Ad4JI4Dyy?-Wr|c!_Wn zcybKN)PVMr(-`gbKmmn`J0)X2F~;kb7!MacvYk%Qa&QY|ePooYMXhtj&qnla6?45` zPvPH2^k-H)l~*FkKFGQUNoz^uJI?cTQE+7O>d<^^#q$gR;KN6lAk_}q#QM--)(O^E=h7?t*TorIt=w`&(k#lr@5{v z+QY1q7UScD)hC$6_V(FoxI}{OQel?E0^iJ9teeCtXjC1)S{K|5#dlE&Qm7M9vk$0@ z4@&bi)$fIXUs3H0>J!ACzM~m_jXooU-BC7-0=c)H`)X_M=PebLHZ;WzgbgC$V_Y&o z;kdPi5}?gdd+U~&XJU2&5d+qoXM*bMZ3tS0=wJa&cU<4=H)7>lf65@v+{NyfA@`_i z&e)Dw^$d*B=g7ydQRnZo^JU};*O$L5Em3V_yk^}jL-P*kEFgL;w9ris-cHFZJ7%3N zp-sAo7RkBWrGh!x-}jucst{ejN424W6JwZOF83HB<-&9$&i&O`Bm#kqs7?13>((4| zj#QqP47Wx9U(HsuAD^l;=Vj(e9o7T0uawMrrFi30-_yZS|MQ+s6>b0Py_UK?8EJK8 z+`62bpMfH_(OY%+{rt)^YpZ2|z#y6jTDZM|;~Su&*4@-T0rT-4U|br0;>UOIKJaRS z&Y^({MY;xx`n^@L$2UXr)RX=C3;|W*#z_l*J&XF;FM!w2oU!x8qo!9M@~C=TfeluW zEnkN^Kf$1@cHT~rj?W%2RWQ|Dia>r&5IE(V?5pLe#9Exz&Gx>2QBD#IM&@VpZDduiiunHNo8Gv2e|P%r^k^mBCy{%v zf1AD11jLQ1?;+g${>P8Hd*cS+#p4fg&-V_;d(_m+yW60j&oY-l?%*p0QKc`*sp(wR z$o*JVmH2ZL0$`?r3BK6Yx=BIx>OI|&{_TOL-s;(NiG9F-PrTEcUif7PDfaI?q}Z=q zB*5ffxJbn?Q_5bRp>uU&FoDz2MY<)ZzyX~M+?W*eB{fAvbq1RJj+vG?KRBH^w>Oam zY3kj~5?4sDOUDj|`9nrLA_N&SN49Br@`qid#;(QpJ%t+wK4t6gne^YYp}$}b|BO|u ze83k<_ulyY+oXJIE&gp%9#=87o%`=GDc@A)^N;0G10e5iLWPzNozRT@Gc}QI!d~e?U}jg ziW@f2Y&bh6TsCUC^me_2kBG)g|F=UsS=Zt?sUp9++Hrn z9kmRzNFMpwmnN#xa`maJBn5G@tZv`*$r}I57(kWg^JO@rsUz{kc4=Pr$rAB5i1!>$ zMa1WKnh`SuwTtz3Rv1Uo-j)X|Z%?u9NT3#Nbtx8wkTKZWvBR~W&IKG{xFUwEZr?X) z(ppLJ`ZzvzEJ+mSQ@j`vQyq*EAx zdqRl{&?iKyZZ)G4TS7S}wLtkCl8RPvml!*pEkbGwQy(T>TmV&d_?>5Oye^Dxd2E;! zg9FF(cuE^iI$-bVXbwp;EOeK1u+ow}Wwp|_x6&ssHt?%e^VhO+4fy;3QLkgY3f27% z<-O|k#WT%%jVJyL;XU&+x_f3t_OBy5eViPRCWjs?cPGWXBTiMBP)sWuqSIiZ!KxZ- zNU_wQsbhd6!9AGTLW}l}4kBjNU5RWMZS{e!o69KES!1_NcM|K|mCSfS_D^)mi&(+4 zH_k%#nS1l>mAHUTI31hs%9gL>QM>D092-*ztU zLylKg{X{=q@7L?$+sB_b0PlzT4Te4kw*EXvSAafY=~_)R;^_{x@3wM!b|{BrEE8(W zUAPcPm}G}`ITaYtvsNkOsLPpXu*7!Jl2WyWO02qV4OEZ8)A-QC`9n+TW)k6#GH8h& z?JeABul$DptH}ZTWtFA=4uk#zPXj(W18K_BfLW`ueBb=Ef6LD6Y?CL}`G)9c;`6iK z+8Nd-5_G=X%pVA2i6)0yyl;=CcqktOjUmt;awyV+33q1uB0)!U-&@E#-5$>e^PcUx zi|**Km=B3wrIMQf7h`Rj_5|`YbOtokh#1LF+KCb=ZbW z$EL+`&TzAGXDZWJ94jG&F?5%-BBqhke#v2ZX{G<)<&g(p>8=-eY25SS z(u9{RHC|Kev9OIOrrn5rzQY-x_*4xYrTf$)7u1q4z?t{Y5;br8f!`MJ=U@P(p5JJu z-H(&8VgSXB4*E-+Vdk4)P-@%G0fCT?u!dXf^&~IWo5Y34RWctCQv&SrZq^b>4;E=Z zT`!ZtU~YA0@o=YDW@L=DZ8rUqJ`bmJpQO4~A(&67^4`-mwBo*mC~&WS!PULT;A67d zGr{|HWBnD7Muz%+Qtt%dGiUeyh0{#0-LhWz zp`Y->FG%SL=0ijhK>pLTet`It<`2&_qy6|WHfMu)jX>K08*G+PPO8*^T>79Lg`AaG zSEf08f}|Fy2KbI$D4msmJkr6Wg><+!D3Yo4@u?zoHnq4Fq9q(i(qpVJBkwIvv#O)0?BY>sUnS5m-k=&KS=#SB2QOi{UUCwH7I{G_-&f*0_Q>yFI*K8-h$P z_d15J=R;(SQ5-tsr&fQaulipmhF2!=+m!x2aeTVd{j;R{2m(;(}N;_qi9`7Y$sC5%moa}ZxA0_0>n1hpxV~z@eAJbw?xYh5> z!@bK+q+T29PaCN{;9WM#B@I(80_`>G!a48K32%b>`Pe&`6svy}FqCG`gg zfYKkXH6yeGY5)ci$Ia)HR<8|n(Yo8~@mavm6xu&*RN;)!qkz z-z%m>vLE}~mLEC`cZe-Wd7>KBMxi@pBME$R5bETj+`E}q0zG;9cFO3%H@&{}3Dq0= zH8n>6h}FD~e4$%&+gLI@KgT;mbv(2a)mtb0VW~>o+%&N~Sz04whPY8yw28jAq-ben z6xnEFbKG<{-|n5+M(T^H#pE4p&lI@Y-gFRXZhg6|XuN1Rccj#T>i9^^@8JFY5sp6~ zK6d~vRJgm;On9&|+vLn}ITk=i$S_J;dReMmXPI;PYUP){77l%0UHJW?*U2_Q4;ivZ zu-qj0YRLEkB<6d0s*Vz@#q|m}UL@_b?C%>1&+l>e(=^$i#qmcF0LvdQHp8=2O!vt! zCkMk}I64qBGvEh9Zt3sB$oe*6l<@2>##R>ObcZ}SU_ zfTS*wjy*C{X5u1VvSr&UsCF70#zshzwm+R67S8d=PqwC!MhH4r+*P)Rj*0|c+F0;5 zo9}sZHgT|Q=UI-o`wa;I{nd%1y@LN968o<2rX@EtH3a8gF~U2 zE^!&u+qPg#80Dj05~Pro6#HU1@obb_&chI*+UC*_aCErwLtiLcLg+~pHaJE|`a7b2 zHFBpk-Jdzi(UdT^%=zbM-F}#0FTquWeEC2#0w3rtc9u&@0ECkM!|M6IKQh$B^A)k=ZzF*;`PW5`{PUj?Y#8 zFoGJ1>~GTPO7B{xJ?$$S_+=NpiAb|eK;lA&SH;9?NKV15Z{=XhRx}*Pl zNbkx2{$4YAj!T)C$#~YALRq$e@eSHyrw~6R4*f$ZuUWATj!=_rj0munMKDKfJzyuZ z)p9QFoRLO3%bgNpk=2FLHs0@PvM}lT!H=$Be@se0p62~yRC)mQo=guno6(69x)}?n zNRSN0wmh(qatuvNyE_pFyylJzAg1O zZ9$CkgoyTdxxVY1_(JdAG2iJ_GdKyZOR4kfkn(Rz_V)$w!2s2xO!VO~_lI);==oBhFN#}av;OKan+WmPq0Sh3FklJllEleuKHt>#f=0xVV zbuBEYhz2FM4Z|2{#Jbty=wDBycPHcj9EEOR9>{aM(Tp~r<&v`L%_wHE>_H$Sb%_iQ zgxZ~xl%S}EkRq!dVN9_OGIlsR6{L=i_m4&|fDZ|}-H=_^_of|(KLm^3CRL50i|cIk zuP}|@7og`w2>uw2o`8E#t0xaMqgkJqxRnqO*W66r&nEqDOsg3-nFy$bM3O6cEk`Jp zDb{J@L>|D5y5DKrcnm6_(=F25tQ=4TU#D}-?QZAlUYHcB6&sBV+K(A3$3LHd{e$SQ zAUtBcy4DQI2-tFf`9r64xy{^91J_VpogLU4M#<2jXmwy*It1moEf78|$qXYeo#_gj zImrR$hS{TZ7(=3EXMmBFAF1S&x>vNbW6^ zGGjK&_1z)R*9S*X!)Vauf~ij~aouhQuGyI%chGF8fi}1X-~_Ad=AJQIK;Te{AN;6M z`N^Y4ua;$xG_T9Me=I`xNZn75G5^Q{t0rZAocSZ%W}?d~kxXV5va%(a5=~k;vS_KT z#3UWLZJn6r;AoMzE*A>bp6^>hw>`-^f<4EUD@HHS1p&d%(PDNCvZ0-J(K{SD3`1YV z37^Wrm(_NFoHx#HZLAXjROy!wt^EQ&oQpdAF(qCn>O9DLT}%v!`qvp6DYMr_%OU(h z*)3LK0IQfS;pm>GNz-yhdEgWfh0Ma((Rx%RVavvNd z*Bb=XBEWjTvkUbL7{2n+pTqG9!~>R37n@1kCY*P?m8`oG98SGuW+ee<4+YQx+orZ% zQ0<)oUdbM;n`C~52`N(?=4QGBn{S3Y*!iVJNe6hw^cK6lufn}a3mQtf-&Cdk&ljRo zt*t*tUoidyalw^llokC=Ac>$K^&0fJY0>4#=wSq#GaJ;S#=5fV(kXBvLDa+NOpDxT zOV3Cga#OTXMH!?B=q5q$V%qL5jkzVXL{_I`YxFOcp!1pkKZoB6zypG-OU*EB$Yp<$ zjkY^sRs<@s;9K3H*Is~@2^}k0a%nUkKrIVh?wM?=421zED_j1+Z8H8Schb*}Gir-O(caF2-79PLeI0Zwt^)kZKZeE|l=ry2U2ld^^+>k$V(&?wmQXXq7Y?R_ zt2#=fU3r6)3dE31AglVCHg`5cMZ8J!;iMByXa+x$nU~K93m;FYJfOyEUuv&YS!*|1 zfHt+#zqf{}lQ7Onq5$G0hW@j3c?JZK<=N$CR3Tj7whp`Dh#cd7>@Rh76R+r83#Y9G z5_p&_jO~ueF5II$Fkv6_6L^PEDvxhK#panP=36X5SYAP699j)I+jCdNypbaLj-T~Y zr-&NLSdGqy;)Q>Jj`t8QM7+P&jDn%1O5Lek3=LU`aC+iK%QTwXvUOPOY@J(@Mo#~0Ro`%hilEKyeu%s-WpacZ1R0SwI&1-C|;V%(SD8DR0kUJds^R_ ze7c=75WMiM014TJp_Ky{%Z~PJ>J**SErDl{ZHS#cnrvz8l{vaDo_gOtahL`@VLw~{3lRHUQhpY_PhbEfKe^fr)d!}H`DWnJQZd^M z_(9Jx7P{2$X4563;)i582xqLNIjps9YY3=GDF{fLq~~*XpG)8X4L;W3HYoQk5@SeU z8HpbUS*ww)`GkkBJbp@oiOe@GR;1uu4)K1cyrD|DN6od;=%1s>3B&_QP8XX|gcql! zG+$3mkyv(*nnMnhcrh`!A+wNlv&T;v6}8IlwsgldE?E{j33oFnQ`enwce-V51ZSe~ z5Go`y?fW!Hk@KR#UEA*$(bP{U(h$#I#8`h8|or0tK zNWGo*F=qIwBlQGjH~#;2X5n)%6|$aI)c|N}kZ0J+HiNCBOBlZC&lkO6uuf1lPCHPm zBPG`6;FHs>?CgDXy9lhPz>r|BSaVPFdlHhu(hA{~wm)vO`m_w$y_hn5?B2Df{>ZFN znelya?+GSv0srq~@^0`7e|JBdG1nRy)8cGHZqa=^j5o!J9@YfqBVMwh&@ip$)ZO0f%j`Q`CJ=rojj-PQaYFi_84?~k(Q@ZY$YTtIYhD%ODNoEb2F=V zEy}-K5i}?HQ%m{TvDAB1y;x+_R{W>fJRg;zS7b;}8 zpz;JAlkisKj-Az##Au_%E{^S~udTf($0oQM6PQ5zo~Kw^qB?6pD&4i z4nnAd$mgADJKDLuqKoxGQV_tXud1mIDmUx;NTZJsk}rED>%Od=`5jI?PpArKK6hV! zmlf{-JRq?Sp*CVhWVb4u5*e?ev6wj1eI|plR#PJNRE#MDT%pXqrx6&+YBWJ+5pda4 z$Q#2*Fq9eJhex!}ZMj)Q6Wl-x=c6FBChc*fP0ACyrMeE%yMF7);c1|!EnWTu^L_+$ zMgGTI&Dc009T$|L5Hu&;vlv4f@<_6xbYu3( z$svRcZHf0ctug4GWkGxtBOd4i?SkA(8mDJbW({35ZYengIbpbE_I(orvIa6w}i z^0@P;A4BLnp8pdpdINAp?r%m%bVtc((3?{$ ztsnY<%F9qWK-wEtkt3dyvE10D1!iI{)17Zj3l?dM5+mSMt!~SjkIVh*67tJc%y*dg zPwxoUy5|AN1?LZ!0p1%V=g^iojtI;RjUehCY>p&$xt4;8!(v}WGpgigWRf~0JfP%Y zPIz-t2i2#y^G=t}cM@$7qa|r?(?Mo!sG}|GY-_^c@=tN@t$ybxm79OpqTKxtLd1-hgyTamaAOV6jn0q*39Lhz>35d;REEXI?*VYoCcJ0y`;@v{MNaGlx>!aMW?q9(1RKI-Qnj8ngIO+u^U) zx!*z`*sS=_X5$GOex{eHpmSf=D>^@X0YGa5t3-DDF*|K{Wv)F6A{OK=vV7X- zS3P^!-=~;Nm@onnsqOJl$kDuIZSn2sfbtvJBIW|*GApso8acL2tUz@3qWMa? zuR8UUh=A+Ojv^F2+nT&2q+`w=KNf zt_a2*G$KR&jSmjZ$*|q! zG{yUNv`?`A8ytQ&Ho*SfuV%c>>9CH8>(+GOLrxzo&RB+DgyEX$%h1Bnr8X1!U zKROecolIT4uO$gs@Qq6rN~E!LAQ8SLYV5r4N_@9;N6g^m2G1ADRR;RS0qv$hGZ`J6 zIDHzD?EQ^&FHLzHbL->409iLEZ>J%@DE2X>uo1HyaV=RFa>k{L@p0=}oA$_E`)W@| zc03b^OVj~D1s_|}`O!*dL<&`>U?(9g34=@xm+5*WAld=;!hK&{F`Jim?ex)xc`zLC z|7oA`Jo|_9UYF^)ft0+dQX)NDKh&>cr#;GVBknqKjk)Wu6Y8)pP>1-C<@bgyo9v6$ zgzsdn(IiqW2L;9BmeFF%u;Z9fC$rXkflo+jH1BFg#4XyJZP%X+#h|t56$>+3L@Rfl zjJ!jy+n+&|3cc-ZT`&-R&NH1~oO)DuGx0$?u^NM&FD9Gs6wPxM$8^6G`(lD`;kirY zV`tJ`&o>5|#V!QSvlA#eu}zl1Izl=|czXiM8g85(I-*wmFo4vK%`rO|Dtkpc?=r7T ziCyM?CpCZl^UNsc!=V3pdgh>cS|la@$tgWe=dx*ie#Foma4ZM(a&iOHkrLDQ-V!M~ zXs7;w+<7LC10g5%Ot&d-AltO#zGW6cE+>+4-`TK5X&;S1ouJK$a| z`=>k$RSPsv)jY+lCsNy%fBbd%w$sml-1jZRz~~q1{iCT8sK*0xU;q174{?(L&|cI8 z6?_hndFrbK;!7Q*{RSP2ywl1Igw;V+ytUVpI$kU*v-wKeX5`TDEw4+BoPL%D`MeE! zj)N+^<|qjxd%CzGRb?! zYCOr)fMBAhKi=v=zMQO#g3U{b-RfMo97IyE!}~!;pKJE0?Lu_!4Sj{-qI6Ad5h&A^ z2lbe)6pvY=*s@FJ#U8gNkW-ALPBid`+AdE!lL=epjl7@iy?8#Ea3w95l$_=hz7ASV z`ugLo9_;1BkvH?esEZ9@z$UEuyOL-#!Px9BvK5|RKE0Yi#gjEhUX+vZ{(s*Zv?9E zHPnyq-uj=+I4^DWb51%d|8H{A=YRlfeSY)AYv@gEo|=km4!XXs32+Lf*rJ`;j$x7( z+*1}xm$sp{V=bnW+zs0hz3dvQ>F=a)#D~zf;spdKhwx+}?>jTr?a2iA7h zfY&M)=jJYd;xU~kmr0HZ{AxdX^MlGKs@V;QCieH$sW?Y5W5GaY`7v7Z3CG4_+2 z&6FrJT$f4*gfv`n??RjQzNa4z$z^OrEAhkjkoukNIHTaBGCSrS|f@pI>jE$@mV$4X^JmpD_AW z!OekaVD8993bSos6Uy4}_|2N{5TgQ%GD$2Z2dU^E6iZ#~RT~_H>n-O=CxHFLiVq#n z=kr!DXerK;wDOiT;sj#2wEUORqWk5_8(0OsUB6noc)Sm$>TG-)EKnYoAFs&t6!ddR zIIkXlO%guBxe@H+y=GJ+wq%&nN|}=gZ3_l;?2(56%~1q&>XdxT5~dD)z&LGYPVBH; zVZ?EoMOaw$0%0g)P>c&o4EAe7W?LM<5t!W(v4htU)L)PT!v}i%Edx}QWaqY;`rwNF z7Iq(i+)(>)qZwWiLUaP@Xze!eXf3WYG(K!-ec5+M+f9OX!~Mk7*L9Z`N| zfVxPIJc<^boxco7!`LczCnsi;#BeM`76Qd>APwKrFXx~D*i!eS=jDg)BNe~KwC`cu zu=@UbGo;$~q!;gx^Hm6g_LvjIYaI+3D@Mx|Zo|7C&!M(GXo=&p+qZ{yyWCQHBwU$r zH@4hkhz8%CH*^%p%-;7a2UA@yCP<+(EWEwlI`pz{H>w=Xzh_p9I-X=lsg zz+qxpn*PY4awXk+LsFrq8aQ!flWu=d@S@p6Hygx1hE5>+VJwe#;6yU3I|nhLWO;^U zospZlEyuQ&pi<4^8WsTD6Q*W#lir7TQ`N`!i9_*8i0N#--ZRm~@w?eG|5&bzfp(!kuC#2re zW*ViztOkkHI2^DTWAR3mX9SGJV_h1JV~$m0%a4yCEU+uAzajg(xz;)0Dc#=W&tlUT zia+qjbFuv`EAx&8Z@77PxtTKbk;odb&>;wja2^Z#PSq!2XJf;tvs_2^YBENc{c*An z76*>sOt6W!T=qvvpXAhOnA_yq@nvs38O@gQVZVZ`5$H~6zB~Z*3zqwZ4E+h@ej>4V zc>d&xW+;b+<#H3GLy8`=6MAEs;fzQ6V~geqYyyvPaAwbx6-D0`66qgg(8<^B>}ja& zt!WDuymda_gWwC?1uNloJM;{+1qaekqx=)?^9~CLs4In(j)-|5+yVyEGd4{ReoeE0;*cVu0czoE= zG#=w~CGxpF)}fb~FG$mrnzqL4fB?A;W3$CWJ4hMsrkj{Ud*NEA`f!JWjfCBho6&kY zz~9lK$8=|$- zxF3f&r1i0VQ82-3Ui7IALOCUwFx-%4)-BvioRBKajnaxb;WZlj$;O@HJ0P@r-gm8W zSe>Un;qY-2??Qr_Z{H)V{Wo^qQ*Df}dOU!t`d_e{2Zs0(Nz24+>3t`d(MnEX$)3X@ zCSuuyLJlIhgHxeX5-Qj|0_$&T4^oz>c8flc6HuMWCgs+Y8Z5%ToQnAfDHMCX!vbxa zUY9YSAnA^lHHzM`$3Ol$)ujOpRX41Rv;$aGoKXq(MJ_b|$6s*@nk#~(I6yZ*di_MF z-gB<}`47l`Aj}h_SCsnpmhwA-SIEDI^HvY}B@xy-u}joeMyW(XtrZd{$x=uVUDy}f zkTBchD$z&!FEDoAR9HD7C921L}=H&5JV|+q{ z(}$j8rGFtnpwQE<kv4>k(HLmd`gtYa$zLvhlzovm~XlxRcRYfCIiwgu89|oDRLPSOyKe-(6eBmFFra^ zH#?LZi;+3oyE;AA9e;xN94^h^hmZasu1`L_Q|E?!E1BCM4Q(mAy;b7kHyy|l_1Y{&7Qt>8LnMq&|L~^40Q3{ z&JLUT5qN<^XUa2%++Ixf{vsGsJ$5uH9j*hqXOuSIofC%%IAKFKSR0>x#QWe<&3e^0 zpB=r|sFzI;4XbvApYR@N&+u!kcM7qciF<eX*+nIXksyw?Lda1*3p-G{W zL)7V4y3w#Tq z?zZ@00k>9>fpS}Iv?fueCE9+ed^HjMBlT+aE0p(P?e`@y3X#F)eU&9Gt`>_Bf}@EF>Nx3aI)a zZJJWC_K4)bkz&`%Pjc z4>uDC70;!u;RMvs^wynal8tx$VhH+H&L>!}MNz(|m2Fv~rv5VOciP6BSp>*r)8pc! zFJ_<=2!ypZoA^izy&=+*B{$PbCk z2WU?S@$fy(grh&{3aV}^b0}pz&>W=)NkqE{juLUO*B;s{kNe$nGw(6diU~p5?-pr! z@T6lDY#-Fd=#S#9wc6ubu3XM?VUz4*ltx5tTTd?R3L|!}K|g z()4O=X$H|AL4Abc(2cd&`y6|4_R5xf-KXm-=c%DOx)H;WOz&SthcmDjBsf3O2>Ww? z-XBF1WI1riRl&g=LEHSk4XHVnIr4ZIQHLWgySsQW7Hn#x$eVm=bd~8WmDN>b7n?jC zs|jht8I*(5CGz?(u?x5Me1`SzWsl(ZuwLb~ z)?hv&{CcaxH30X;0u53zQ07cTxKPGiu~V>GfU3hej^kEuFkV9DJRG>5I*@#UpjOUm z9*uWh80Wabu`|<3LhcIdp|weo-8{7L?#{^f+~N0dUE$~{uJ3kkpE)-y2ab`+=7P!Lx$-mHfzS zLi}Y@>}A5^L!$HTi>_y0-<=Q!F6(y_Bp>%8rCIW_y&Ki{9|1u1NjbK2Mk zHGHbGzO@QCY3zR=z`e#mz~1ryj}PEJHw)(z9?vz@ujP2w>|3d)YV2m#U^P1&ARFDP zi+C)fhGE83mVnYKog_vO)OMm^kxo|$Ih*cUgFze9!?5e<_+}r@XCvzv@|!*}njq0s z?(o3hA54Iwzi#d?-csLQrq(3>n=XMx>bpRGRXOXjy?1|ZR`E3`!$HIcq{~Q$r!^m7 zkjL@uFzCa$0MB<&z#(8Tk;fuoy|vMAE6>WxAB_xiIXHZ1S(dp6)_CKProv12ITxy+E zI{UVJ|Ca@V9jBo{#fHDnJG)hu)|07R=j%wWTvvSn&DpPW0UI~hFL6x}0S2)}(5BhU zv^S9RbuoQs>rmxa;g`8RpybSn|M;seQg%Pt?looUFK`?cL?R$E3D;0}QO z=v-Hw4in#ZY%_rX55~S?gA;fl!%34W*dNp?@Ut%yY`ltj1p|oxBUn%Y0l@e|2aHJE z1q~RCV9d9DThA7f9Y$`6Ei{-b>G`H7gX*CfC2pXBPBB=N8W68&gN!#wYGRkRVt7=M zGFxYpQ)WnSc_&xy>XkQXw{jBRyylAkb>T@h1xHf~Q!i_rqm`UpZke6|;ELd%kb~zkN!J5{6wJuOVLYSjS=ejpl zX5W=mItV?!rKhC8_dYI=s!2X8Tw(TF9si#v zE%V?H-Qo2r^&iByg7{sF{b680rxOHVt>0zEJzXe^{6@emI^zyoZjBEY=z>)wTOtxZ zXSrQ5!Vx2O;&Rv~5})5gIp@m=Jh7P>!b1V!C{s|?sxA29{LoQ-d<^B?jZhc0zcFoP zj6i;)2hjA?PigmVIT1hFiU|;Et|2%)^g-?MNzhg{5ruu%Q zRk_0;Mg4~L+xohGBB^i>lmhSwZ_iwPsM9FdQ=_*h9!EK^oIZTTC(KgkMxRnhPoGw0 zabI=RC#JRaa zr(YbU9!M$tbfnZv%({}})0bmU3Sz^*ntYz;j5!T8mb z{%-1JMJwoTV4z~|ew{SUSBX$z%QKfnPnjJOC;@#R)#HLOusuG~A)G7cJ0T)>yiyh1p>~v*Ckg1 zo%O^wwLs0fE?6bhq&VxZXS8?^{5dVo-|{_^d^a$l#oe!Frdfyh;OKRPwcU}_Bpe*F z9O1e$h0_IU2rx6GAx(#RbK+lswKq1 z#Mc!aYFd11n!$S4_kg#3H<22(V88FCT|YD6Cu%gX)Q=Q9OIH2)#DsB#?kN#z5Nqkq2!NM}FB}$R3HB237 z^3a&|HZIT*w;v}J@m2JN zPOPGD9art{ATwmQj~*dnuB@(v z_XaTILFQ%{Y3p>|O|*V+c%_X&qOb$%)SaFGcTD(l^>CZm9TA_Q`Tg?hIi7#XbGaKB zAo}iCGtb42S~3|$Qs2_qLowkeQhS&CYpclCHcGhNwHy%UtW!W8c(KPFhY_M;y0Ak5 zcErsdGE$u4wb)BlIds}xv^CoIP5NcVL9I!@)U>ZX$O~_O)JCUmr?XtXR*|2QDF#Pg zKyBt)n4eSXmrQ0&o9oyYVqGsZGoD^2_op6&WG#wq^$pJ~-N}mB5dAa|cCK!ARyoKm z=5n4KI&+NbKx13e;(mr_sx?-L>8!n6O%@YhH6?2ih@#}}kE2(TarQx8TE3Se(ope! zTy8$4&!tBBr^@QrNOKvsqRQp(W&~NKOD$>d9MIr&e9V>Zq9uv$2A%fE(I5b2N*EXo zb{OomH?+{!sTtBo(8T0LYgykYbwc@(lf%(T@pE?|$lvfAK@XK~Yy%T&sV{+MD0G8~sb@5I*e}ZeO z)ABFlC7)RASAhg@A`uj*zd0FKv)kN|Uth_=-VBJbgRs&YNTLT&YiytF%TxY7>%He{ z=hqBGHDtxt)xXV*f`xX<92_`cSAiJsd}d&#lVgM&Spn?cAPP4f!ICwylxW7#MG@IP zG~JBnHeaBA4AZfRO;WVg;apIFS`RyWV+?`5d@m!-r|{r~CBIPX=Y{L_=|`XM%8j3` zaL?CE&>!JM=BhKvjfo%m|AA1K#Wkoy?1JrqXPO8B8}i@X5qTIEQ0xo<>{o%&zKA;) zHmxiO56VS}N3hMx0iAu7xv328{urfjx9#oFMQ>-jo#WuZ<|Yg0u}=|`qCX2eU42F% zN2r(1#|a5CFS{|bBSHD*S9YPI7^r-goR^?gC=P#gFfUVjABOnA+b8F=w%Lt+%qK$w zjNJixt4I9;YYefP?ZCk_ZAu#k#1hU9^fOwsaR;R>(9HX&suJgnVra|fhr}Er$-dn_ z5(8+DJKRe~zkK(NdB7fh-Js%u%j(1p^QcA8C57Vy z-eABL-}TKOhOP8MRR9NUx>ZW)TCw5jrW=!4RO{G57O0=WOiAouH9f{cnlUi4n)C`R z=?-T_>yS#u0mMrtwlP!3z1UxC?3P;WX;cH}nMzX@F%fs#qjaCoXteSb!PL(?#UN`S z0j@Ym)zBaxxM0tP>$+%d%r1}Pf_YcN*IU7NWn-RBdm|rbnL{7lP1sRT2JY|7KudYg z#}WdeMqSfptU{c_Nm_6jiXm;Mi#eSH*>?g9YeloLpMg>eke!Ze z*$Aj7`1!88T#czjnq{M5p?K6jD&ly{+Efc9sO`~XxgKT*Zb~lJ8mM(w+%-*7wG2=e z1P8Q>)PFc+enN@tq?&9-_5S~Lhw+12e-xd1;)o#^t*=UydM!rXqo4)I(!>6uVAzS7 zNdg;2XwT~}Y;V8cuv7aOPTD)u*>=`crb~VJ<&vxZMCg5j?L~83>!8*MuicX>`RdVz zo@eINOI@Pc_&34i>vJ@wk__l#Z>1gz6!Ca&9O^cauU1Rj#K(TQkim ztB{12u4H?}18F^;fvWLNk8E`f zh9yO1={TTMd^uVN2U(c5orxN6v0anX{NI#?m*~Cm@)Pue%*pS1?eF;ia+=`|zjx;w z-qk#NYP{y{T;f%JV75`X&F@rYqHGY0)OPSWD`RN8>ZWQ78yxv3^Lnh61HaK z!CKUfrCOL|z@a4LbZ9-q(mAWKUXvyr_Y7KjDbF!@)9xQoS7o`O-!1NQM%{VX3TNj( zL2;*QxG%VIGN230G3^L`T^Yl1OnY$^ofI3(sryUY=4ardvV=eWqQ6rdtOi9`G%1%`~VOy^v)}dN0V|( zKzhz&AY=6zPOAmWcVk6o_5veTxU5oP>ruYIVa6@;(->=gO!HYgDL|=|0vv z`gqc!mjpja=h2Q>`B5371Y6i0ACnIPog6w6v&4uMcj!$#86~#iP8h?h`3;9p3iO=5 z^DD$8{?oEAz`6caqY6f>5Ci@J-1T+JJwel?I3>4`uNTH~=inSN^vuC5ZpGBPC4i~B zh?sLAp&>4O(B*sff7pAo9@V*JLGbze7gzfgkeTG}TT-c1`gG1_NWv>(#flYkv}#+NNwapopd)upTKw3w&*`4ptusGX zh+4fhtwhb=X09Iyb?3dOg9-D^|JD9GF1kPkdR<?U$PT*I+-k6*0hUx_^HXQPlJrw zDP883i2C6`{y;M`fQ(?I<3EuM*&e?(S_>gr!UTeqFTlV@?!@o)i<3L+cZb`}lqJ0; zy;xGqV6(MB$S+inu_gmfRPkV(&T4k9nwy2CVrSm8l=({8TRE-Ptd_DkLZqX$ANs?g z6ZX_8xxag7e`c{8AwU&=DW4#U4?)M5UZkSv;+od~O9l4=7N~W31)>TplONkz5&CRB zm$f<9>*qe!aq-4%TGMhnI(Wok$#8jO_D0%}kTrhauAS3G)W)}zYtPA}D zua7E(@=4!q6ZAuQe&7?27te3~o$~S}W|ggcT12_It)KLpvz4}!Fi2qQYQsKH z^Q_MrTfyEWbZ6L$rtxt#Z&0U!p!>~k;7-^a-;H5t_c&KqgtJPPIvFj!R7qwq&bzx> zAOC*|k3!1aa*1E>5X563W%#BYeRYsFG0futb@`Rhfu6*-`j}rHq$^k;|MlfZ3GN5c z?ca?$AT5y=rtl`rdv(iQzt#_VbQUEnTj<-|1HuV2*&(kxD!{o)lh>SU< zZy`BTcTemN>tWr)Qs*3~4gZUi^n;}S9EEws%73XQRR9C+D(?`pf;RrW;MV-ne(bH+ zwcNwP4zE%hY)iX)0b5RM^xEpRgf7+F@8_=R8K=Pt^K_Hr{i(ej@N8Q;;z6(?>x*7M zi-~6nGbjx($^Kn%|EF+a~npq=&Xi|rW&yO+;6D44rQk& zhu9v^{75`A@hb=BrzPH!dY))ghQF=~#(M=mrAqta0gsd^AN$zM_oZzdx$Mb) zINGz6wU~_J=ncjE6BdbN zGw0xn&a|;ra+n1^6PwT)l=9U@e>HVRlGEID?H(4>%yGGgi3#hW-Jw5p~D^UYtSu_gu;C=|N-( zpQX9@XcPMu6&OvP<+^K~#T}Jlj&)%U1(`4irs-J2frif;T6cQ(MU!icwu)}*>P)PS zR5hBcr+H<}$DL4*UK)t@+JT8OC!ery!}hlR&aAmWMHDFE!)ZgnexQPCn4!$~wLNn- zRCUnZrK4c2Pm@VL;)E4b=eeGM@sY?zg5mRHqOP?>b+^o6m}$`6=6aCld%NZsn@z_g zYbr+{NA~v#%Xja`D~2$ubf-AQt4l+W@V{1B3uC+m5EUTXmThW?N$9P`}#_in#8wLipAJOAxV@}d1i@?_hS%lPvY2Jx@^b+re zN>ig*(u^wkZg=LnUTHm3z0f}&7dSuAYja3uBA)wo zojMP4VNR0$X2jb>KW6JwtV@%Jc$gkdnb%qkHi0JHvw1p(Sk}gOPYT=4v~=X}S#xaL zb7e27^<3@-MGuO{!&R*5T3`Q!bhWp@FS+Cn_=t(KV2tjAqL#dj_dt9~sHr#yKI)otr^Ivk?T zV$qM2+5J*`n_UnRpHAK9E()baRT!=%-#yfS74-b)PxVLTM-Ovr?$sf0Pg1zS1nS;i zKPn8+Vg~xCTlRJIZoJjd5P~VYr$)(GT_~AJ&JI%;UcVOTV^0W%i?Fd=)M9JmtgYRy z(U;EcDc9brG8XrbZF{Y%;~hUY$!M4vF@sy9_0Vw|QGKi56fk(`1AV_3OHee}hh7DU zz|hg)p3Vk;4|y88<3nj6q-2-f3sAlW%5^DCSNN0S;wpq=0RZY3QS%A38Q|qF{we;y z(gvlJq~P~Sl5+gx3x5CGxX~3VY{&KG<8YjpdtvQ^9d?i=tB~v;cgxOtK-pr4$l3zb z#f<6Z);QC=PIEh(p;K>gs`*+S>+wB(yxiEd%7|1e9BHP2M>3P7v!S4l$owI>qj2LD zM*b7R1Wcp(yJ-9YCAS@7Xz&0KemKs|P-`+o3%coc4+dl(P(9+Xnn%2>49?oNtJSb> zyB4(M{xY^=mF4^vIqY`k@l1%@sx0bjj)s&Dh2IddHeSfuZ@DVpBK;}|-a#RH*vVz#~GsnOp>gpzropdJ{i zuXnQsnJKBwkXhH?XuEuzDxPo8xzL^w@v-lFgra3NVZ99o{gE$i-XclWi3JDe1xZl5 zg1^(Ls<445)we*D0`3oF@%wvr$YB||wtJ?ykLa`kb&^;vD)r^ypws3#bacNUs-Uz^lBFu~SO+kG+8#?GWWW>1re3}wBf*k$y%h2Is6FZt=NNEF(_ zqns-Gx;!046lwW8+b%=GIg5)}%}=_PDEYX>8MZo>0^*={dPX{4lf#aDGL~s0pM$|N zBPPv`qB6NHFJ@AvG(u|Ef_v!bh-)Qn;SM?FC~}x2=Dx=*7E4LGX#;=W@4oW`jjn0K zPh={xi2shI3Yb8u;@^)F&<_%7-dP#lEUDvToj>(~Ay|28@mgcw3k}ZZNy;bN_;AN1 z3z%`ySvN!en06-XgWip6o^Tu~gu0ka6>`*?VgyWi5|;Bh{{{z@OZ?Ft|L|u|!~z5N z*6HDw8hsV?jb`P7K1#4Zkd90k&a-XN5-CN9{l;+|g?^K5rgF5POusjk=ixeVl2w~r zM3i#mM)v1JqHtB+j}s*BLVac$)}a|!*`)KO z5JIWH*WP1qQ{e?{AjADZaK$00KM-NoJ&Uzd&B0G%-8yd6LwcS`Z8y~q@{)_?$%Y8K zk|PV@G#}*kMiM0Qm}z&H!8F4<1MP^Lv!l+@ok7d$$>DOz=f_cYKW;zYaMfB%q%uEe z2~`ojm*qgWwe9~LVm>^hBf>I#D3N)|4o*A$xlh@6@JU#@H%;W%^>moH_p5&?d}X%CYuAt zeU|YPjuOw}engB`2Uij1`g**y*}N6Z z8{wk9*-hCK9oA%eL(8kiw5|5D-cXSeEzP&ht(1#4x54!zX~Goe8$Uc>_n(c@eI&O~*O8(vBo7 z!`Bx1xpwZJ(A8Gq3AC1P8cP3^d^J$Z9Vo#?{UZq2C{r$X2GdU4C_yBH$OPOhhhH zfv+BuU(xeM$A@fUfd9&)pb*21Xw39=XUC?)R>n5)&XB>vF{7_EaCR!6{5R0J%}+k`vPIz&x`@AjX(QYL zB6M%ii&mXK84J_3n2CnVkTqdehhA$o+0Z<@-7-(sdbrM=K{|nvlcRCZo$R9aZg?8! zHEgus>4q6k_X1GZ|IHt37P0t|3bvh)L_h{MkQMt7l$9_Hu*S{@@^!X$}ir+Oa z0KT}WKtHv&EZ_l+ihm(}0zllk;fs?{Kj#@odw zf}!2+F%7d(OX<%B3GL7cIH?Cra$YeK+^Ov`wa+bs9IR5KwF~^>UcLA|VeJnt3s{JU z^s+z2Wm8b;<^U~!RDS=0D&;Tkkl)G)@Q`ikK}jpR+kT`+JlxB9P1y;F*CT{wiwt@g zLoxK2>95z=3|k(op|tEDiB2-F?ez9>U!R_|kt#P})XGUsyzxwE=rzq;%;}>ZH)UF5 zTbDcKSu&Ju#hwlc%GLO#+XZzfL&pRDfyyoT`5n_I3E2D?(Bnldhq#t<&^p$PPGihi zhg>{7(br)m6+8HT9U|!WHhfR(MlAQ+!(9P+UH|0?1qWAl>$D%s* znl6nuC)#%h9Jy1WoAspwH3&1%>&m14nM_5GzUwttz2r~>)xX$W$XS3Q_A80X4uA!y zZ#Ehc=#cVI3^SiChGQ6&+np_zK}X5r6&44YzqJEmEY7?RMmNWlL3d&(T+Bk#nVwJ6 z?zz5R^MWg=$2NJ8B)uD&yell|QIQG!8QmDB;1tF1FPY-E7aU@W65HGf7X^!`KjT;18 zQ+AoK)oNu*Z_I72H9wir->FCCFnGw%236+LXsg&`pimLnDQh@1|8#9h_(UUgUVnXX zN^k{%%9r3#{3POD9vB>k=NgacQ`>Q+9EJG(zmaclYPc+DWB_v(xB#wj}3l(pc4p z;)pypG_4b@I!z*1cWW}@%^toqVYs})%tykZHa)7}QOAc);+hL3%8;9R=~7h5?E2>q zYH@xg4D{0i%3ZF`JA;KtkA(IJmW!^yC+eX<+iy9n0uoWM@)is=0Qb$QYJRZ0X^)sL zvv}6)a_yO9N$q8-s}0#*RgDK|2Ae?>MCegzeVi=B884Uq%RD0O0W4bn!$$=Q-z5?? zKZ0Z=?DO6sj87`h1l|c(L~KYha+bZg0ZM)T=_-f7scYG{E*O=4Ksw8-#^FHO|M(yO z<3AuaisCDeax=0E_uN;6`fZd4`Zg5s3JR4k3(7#V`|p+H0H1;$oQOkgHm)<$zTXpx z>3Qd9`}M4aPsb}JG9a$NA9T~~P-^7&YMbF1Cmj)&^#&0hso~MZ?MZ{eIv_G*cXE1cL-(cA$Hvv5r|nCVyCCWBYBaSf%z{dlX8@_te_vCo z`Qf?UaL){LJTuNCC^qWz+ITGmp<;5?bASfZmvQqa{;!15-_>%jVR*FO3uMrEP=(cZ zOU-d|y=iwEC#(|%`Uzqw=fQe!j%V$Cb*T`8FbWy|v{InO@10yFIJDC86{0CX`DUd> zzQb5Jb$ceojj2Uer{zhiXk>2~uap)wkVmS}kF+%L*Lw{=d-W!k)pychD^X`VS)H7m zKG${ofHll*Hs*#Zc&*cBYkBtqRW!S=&h>x$ZfpW#QJ7qDleu8h=T1;?E~G_(K6G;+ z86N5aTQW5&lD-IONSBCCF!|x~&FA4Bs5KC1S25ffpils_qoDz43|3@X#XrU4ixYCW zF~OcVB;~z}3SF-$7k?71>{?79KEB08FGCJU*oDVwZ&x&)_P&bM+iZ$xf_5JL3k-_r z^25HT34XM)y_0r!yCG#BLIJ~;`7Z76pu)d5vRK6nlno2X*d2?t^Zd}6={;p42FF3K z<0(!9-^&eJtNZoE*_eUbho5Z3yV!YS-!~A92r^JLO(%jn%5qPEdMMZBvo=!{@qeJE zU9Y5dwI|}c1iM27s@>nb*Iuigri=M*soRM(@Mg#QU@3L|^=5##xKqC+t>%oj98S;U z#y&jl&rzTq(tb3+YwlXqHuK}!^~J-QP4G}}2#wA`q1Jxv-;d1m&3Eab1$h)PN@psV zvWoS!S7;^S2f3zhEPJhAD%%&_N|Fj6+U@+5RQRzG*X7T^O8|o&E?aWxOnN_Y+pC)n zNy^*Dm3oT;1$2OJkAG}r^@;{|vYaHwAT~mqYjXO_$tPtd*=@_JLriYNHp`I7^jAej<86zJW`kC4xM`UlDGSA5d)nXJ-}~33FZk+s>>no&Zen z#Wx?tWA1G5g~Q7@XNxo5!lS*!KpUdXXhe9c4HtLM)QB6OqV*)-o!dQXyPGVx`j&}j zdeCImI>i|Az~AsIUhNUdb~?rD^Tn!lh;g-hFW!fTKFJFB>@xJQddzRt(_kcCzrRPz z(U8SkzH{*xSFC|WzSwnyFeKWb2|CZ6(NMnpZ4dtW6I{;9XSb4r`fHVSc~A}w5Wx*@(9S$n$W)y2#o1cszU z>4cdz>qkql&2uUnz9c{?4$;qY6};AUH>Wi`qJn|7$WokTi$wkc=ZB=rPm-tXNf`iD zzr5rwH2vKrcaa8n@Q{D5cxAiA!;J zkg%J##?2Rwzh8f!zb%sz3m~`NODMWjxtc!TkPu!+fud_KOEmWF<#kkEf<_ueC<;*| zb%T+RX!)xhL|Wu8U2zxw`0_FLo&54oN*naf_Ahr-Ajgx2o@+4AdlHDX;~Cd@IUYl{ z4(WF$_MGv8jyh`8F$_}YTe;g`Mk`~Hvyk(&AP*|OI%oC%&Kplht&~4&eUls?58wGU zFB^7Y&5~vxg@N^P>veR!x;pm@qo`%}9g#` z-C#iD4QY_h)7pvJg+edRj(FmRcSG(;!}#;{t@UUJ{3O2$x+A&xZ1A}nv_dpLuD;qQ zq8B##Z}t2t(1PIA4+=^7Qv|3T%&djfm3IOY60D`t63l@mQ7%#x8eoXpm+Wj z>kGUB;md2l6)CVcW$5Lt&>Mx?%4Pjdg3T0NV*96>j@L#b`#8mpQ9S4z^<$(v6F!W| z&1f*+@AiY}MC_pCWx?I4(<5hgY&X9(<-a}%Bfcl=`8N8 ze}mq0<=Uc=H`s_;hR%NR&C}UOGrFEohh*<7jJMTa7oqJ!EFMMUzvp#Aw&JjvH3syu zDdKp;si#AwK0l;}GRAsBJ+$XrW+v7rhi>dN>jS0>36XJ=$_E{#K3O!_z+xrBm`vxr zbmfob(V=N!_icU_qOT(s&=IaAF&IrRMx8zmwY_$ddquFyMAr8SRyH;*$X33DDBsV5 zLKrz?N2zhmUJvgQNjGc86TY+CJF^I{tw&Bn9YxT$!6(cn13}LnmT}(+e{qX zg851`zoGj=1S5ims!Xr&ohsLw+b z(Df8NhBR(UiSlieP5pG~|Bm9WHwQDsfx%;)+$OCS(VUyZ<(l&Y*)LFucI7N^vJ}c0 z{Ov6e{Ldfcg#WOj=%Q?*{@%BzK+x1bf|;Kb77>bn-19b};T+6@1*NkbhznVrHyQQM zpR#!ls)D=39l?6nvJXUUbpBB#*v*Ypx;3;m>S#%*XZFHSZ?~wbQ&TJ1E=(U_$HW~!A!qbk} z_J(6t!^d_QYUH@iZZbO?+iOBx#kHPIqzjKPS`gnk9nFP=ra>V}u6f-h5N+Ev#PBw@ zpTQ!uKYxO_9#P4H0EJyAGY2qQ9MB+@Mg#B zr&A%2R*Y-Xl-sbI9WvbnXE+5m^c-9QUYLMtMSM!NT6>7gvq*uTTqP_Y8I1laH_l(yK@P%b? z?csJG3dA5qA^NN7MNt zFcPUPQiBdN!C6z@HrGp;J%`OG(=>cHH)>O*Tdz%B)#-5~Z#R`EOfA=kLU*)xceuWu zFj_0Fw~N%_uhcd}^PM!dZnC~OZS6**(QI{YA{_ECj3ffV4^dTP3&T&Hw2VoisN=PN z`9FV9W}T~DT>YPJt-@0l0T{4#O4kO;#JOEJC`qSCb1J_pS@7Xhe|-~N;k?bR019o+ z{Z=8 zO{mZxEcQdMx7BA>y9?%^S$F1AZ)3aJch0hcT3{6sSaF`qEQUvNe0^2?GUErekS)jo z`-|>`?=pK({s4VcM8z7y-~l$zoX(igr z=IO{hZRlQnW=1u(9k^#I)i!kF6l@!Vrfnk4`Ft0TV zWcT+*Rd4Z>*Pl+U0PCE((WEVCi?h0Hj}({Eps%@bS~gm&sq7jfvfoxUs=Z6e zO7qrtOvQ@F16}VRDz2)kV_6o7mwaC+D34iO7eqH8gkD|o=r_N;;!DyYh<8Gwcg1P= z>9VJ5%SnHl&2&w3`df&5?1@2U8#O(zQ895$M?A~A_&&(%ls3}0&hmViNZAN8q*m)h zyTh<0^}SuDZ0Bv(%k7gq^!W`E4)@bgt`FR#Rvv6V!oWSD3;#9tzgKWxL%&nv@wvtA z{S#Fz|W8~b@$Uw4DWsH;0cO2OpS z9ep@!=Qiv2<^;@o3XUFK8y;pG@&`{+iAcP4iv0io61}DZ@=lQA2|wyEkiNFuNy1X% z^1YXAaiPB(K#THhI&zxdX2IY6C{HL<+$wM1bp;BA0$aWUe-Jt&UyF$5N4!_?j3gJ$ zL{g&^PrM-VyD$(pA>$YRpbDSHdVs9F7wZOF>tdt6zia7 z&y5XZk;g4|@CQ~R#@0+>gzLJW-7=Z8f7Rz`{r7bq_^U4cZe04Ltz4Qk% z0tyeG6e6~|tuJxe$a4m=s5lIxv#qddwPzHLsd~>guMWxrjps@rlo3(1AAvcvup?#a zYb8&?@gaNKDHGAak8#&X(K1T1qn~}+HgMDxb8-KBC1DV`H5(W1cuI44{OcFgEq>m< zUV?9v_wz!4x}QHlM;#oS4n_IR&p^qfCniJ$|;ov;ah$?p&x7v72dAlW6JLFv< zJ-RXO98V%G8cB{3`D8q4Yx9&Q$ugK&8a5Y@H2Hrv=_U?r6sy;y5^)8YW#A&m$+ssFq`wH9Zgf&vRRF_ z;*(|7R{5l+60_rUFj0s_WJ>1LnKtou#y{-qCsX$cU1WBamT&i$YIxO%E)c&zs8AHH zP=6pn6bK5gG+1$H^PNtNwJe%!#Bp*Ms&zYKd^3nwk+Wx$ZPx9Gcrx~-dCnY!@dO;| z&^}aUTpo-3nh@K|Xi5qLd4+v;tHV&qYb@poeUKKvjWu1tA)GIek0yikL*O9sS7>@%qqp}|Gs>M`w7__^;w6N{~OX6Lizhz16Rdsnzj%$2IO_Z87 zwMUG#?HurUoUT``T1Q=QXE#@sxm^o}*{X>hPHx^D>7z4ic4T6`+V|{6egf&)FOALGTmCJ=-i2J4vb@8t<0IP zoTaV|H{@&oS_mMtBWGT3A31y#DlAby1fDza`5+_a zlx4MKYBZz6ye+j`^iW>u>X4hpoI9L)aeL;GShk{@ybyGzzSO{2z1gZAn>@}H&GqkC z?&1$GFjJU&>{|J2rwb}+{4F~_fJJyed<3kGg3#X+z>pT*G+t+&y1C?*qa@Qhq0o?^ zt|I04xgbK@%Z3q)(}fkW8*743iA8(AU(}g|x42DPXf;|AyIHjs9mC*!YDm`e!2T3P zHC!ikUT^X(U-#{s9l=7VqJLq7k-Gdfe$5ZsUQvtoVXDu(#Q+z@fSidc6X4vu@e3(m zYP27jV_u3ok@&eP%7rE#eju5L)b#&EJa_vpgIwPGS7@~tIrp9QR*27{`uR$=&t?$V zptmQyt)}0B0{QN5ik1Ntt>~rclaT_ESXgVY(rw(?Wz!(?$AY`n(i zir~{d2hi_?EcX7s!8Zf!K@qrDi#_QAm2~sBkHZBVIuVzbj|t~5)!b%!m`fg$5EOS9 zxzV!L?$$LcThw`Fds?dlDEk=Kh%lZ9i!2Afx+?QdmOE?4QyNRt2vqMdjLFbi&-1y? zCq0AhY>VELC0kcmq5R;9bdTk9w*zy_9r(|yo&V=LYo?$us_eMh&R`vXI6+x@S450% zP~5=O;%)JR8yL?57t*QHy!ZwNyd01OTl_VWn77ZPazs7)?9v(QQ&9n0$}P1v4k1tB zIz;^j;aZ+|TSV%g9jL=D)gCl`_&U?-pFe5je(VAV)xG|?0m!zFQR0C_&MlXsX!}dMk+AS-9;}NLI`xc}LuR`;bs)qV!;lPZPu+)%16mc% zLkF+S?}N{;Z1qC^{O{9-rh@!;GV7<#G?nxAf?U-D_%^p(L4usRz65g|d9=P0)reyV zLiVsJ^yEB4JEQcFnybT>aYRb*b1B!|!|02#JYzX`$vURm5xGgCn0x5nY^^bOnWbBO zPS1~RdNCA4w%5yut&{rZE$sQ3W4(P;ciSB@MI_Qcg=H$us8qX;0QFi8H-a;O=>uG&c>b**AtsLMJl;W2uIHd;v znzaz_XBe*Z)#1Dshy9AO2;_yb=p`IWWV-%DS#T=|6773RZ1$}=uh0#(yB>f6?$e!Z zm-V!|BW2li5Sx?0lEYw$6ZH;7oZE6&5wkGlAFv#D|M)y9Y#p=PThTWX;?*;@t!JzevNg7d-e$?I`uX7l#l-DN9#%?rmNH zaKI+;{~&zO?|)%(^6)K8RXQPDPG4$G$- z4}E=Cw&8~_cUp>nKV8Hv=pXC6uvtRM@ z!g^jMhEj-#4Uk>2->Z*wcwGIid`vE?~jFpcS~z1DXPX2?nX-ciHlx>+Am(n{;~C(W$Z(9Vnf7t;0+#`(<(u0N*O_f=^>q*PS%I^(_8L&?h@#jdcBgXR||Uj5;R71GT5x!hx3j<9%zV$4%e~1-OVTng&e{q?`o==$Wj|0 z)YhCA^xGrV+ARqzs6kFvzEx-Q^X79n5d~3z2-m)R#p$ck0J)@oPlG$m68ro6BA8G) zg)i}*PU*fJ??@-D=Q<7p>tQezI}1Zb^y6I}Z%N90I?}PTj0gTQQ<(Ny@w|B;8q#Li zul1*ca5Jhe@D8>S>~?3(_BGla-K;j)%ZDrrm`#Pq;6of4X(9hEFPX=4S^1MEGL^sh z<@vk;2>LX$Dw< z_@_^bWAW3x1!f{*!gQ1J7P}!0N~Z*#S#C$O!J*dL_j(cKdQ<9X92pv?s3yA}Et473 zn+>+6d+wg4RhDl%?!feqQ1D^ZYq((sbdkJ!-M>fnfF6F@>C@ygV3C_Iz9LpU?~6SA zzmkmww30>$?vL^iaR#)j>vzPZD$%=bZ=kQO?gX0Tk9#6MX>a1WJV_{}wxN|B0n;t* zfh{_;LKACo!-i|=u$i=)tHpVvh>PV|qSuFXb)3lZ?FO%2USAQ*wT?yiJ=CZYsC3bd z3RUbvol=W?!|iwl^+G48!hTyPDBuA>i+_vIMdf;Vp%OJeveXK@ZH}K?gemrW2V!)V zrcgDhta>j^NF*~#!=-woLmvho)w@}q1KrwQhG~(__Up^@0dC1EpPvOxgMu1gU!sU< zre+&TtS3}0mYVbIu-?VSBub-@mbr}tjq+E}`W0GM*P}t(lhTAeE~0*K%cpuf>NZkQ zug&NgmC}vLDxkWJmATQ9c=~Y9R4SgHBnk3_{Q8o)0xYn;z5zY=`)jrN(SnFYvt3tr z8xxm&VW90&y9vW;rfqPlRL*h%5@JK;tiq=?m$91bA$ThZ@>2Fy!n`lLd|zCQKW&tt zrkj1$vPo*{9 z#N0$X8yv&0t)sEggGT;3CHacjqbU5Gx{gjVl7q!xBa`BuideL%y_!^TKRo7VmVT0} zjq?Z9QJUARQ`D;K*1o1($?G0l&tPAOiZaGgF7a(q@c){hHCqC)bFT@8rT9o3j zCvrTp=4UJr{k<{fYpyaI6UWeDtR+!5p*aKFIrmj^k;^S84BYN($N7+IVvu3Z?ATe` zwC47H6fBn~Z+SR*4rl&_^YhECfpwz*sBc$uL1A0rzq?tBnzDVs7C^^CXk}Y?Y6|`J zvvvEZFqK8VrW1!j?4W)ruas&cND){}(+ zcJ+dHWNIrH9apO&7i=+T#1o_uR1=rgu`f{XTm{ZA_~ij`Nq~nBfeZlp2X3iJ6LTkH zT^KFT)d`36IX>)lqMnPzN}V_5%>tTg#%<*wWkb$}@$>y-Dz>7O*a&6~bKP+R{BO<9 zV#O~v>-rp~A#4{#dgE6D_kmmfjT#$V*yTIP`1xlqq#}ZImA-FF#R^m)VdWi!@j~wk_RdSg9u*`0THipx3cf)vK(e5$#2daZ z&DeDoG5aB(FQ#pp3zmsgJAtmW5xvPyT1I&=hY8xegt63o!MW5qb`4&JkwEp)ymQ*)?aeav@n%|^ zTE4hCYG%Er7_9+!#)Iwx`ppea-sdq852YMW=%TIqHM;lekOJfT+hU7;LV7)+jxbl( z2zhKcIB5PZg<^De*Uo4O57&cPr%S2&-iVH7zK{7J$`*scTJx4&*JSo#SIb(iM-9gI zUef6vHc&;r%M{aj?;9KiP^%w@TK4k(M}_{s#rX~qp?rS_=K1zeBf849T&D zVpszC-Y#oC;M){*BE2s znDFN3MJqP*E}_)|X#;8W!rraRBfNQ>odTy*k0u>)@2`_Rh8=+gU2oglb^BaznAw&( zy0hZvNW;a8AIGnYj?snoTa^;QLP(>3iyQGLB{FP>#|0TRh12Pv&-XP|7kQYlyBoF? zZ_a5{vk`IK_V}#GkvHH+`}1f86Fu`&?>Jdb>*91k)S*4wQL~o!IT1dF zS`(PF^UBnyH2Hb^Ho1T+u`D3NDfro=(p!%SQq%W~GnXC>_OK_7M%S>;;ZQX4MZUne zz^OOzoZVxCi8bG=-f*=^IGQk$1<|9E+R(@RraPD=QnDkN(aDg>=Iso?>L2a$Vh<4i zLm3}friEcv>^MqZdo^S5`hype0ztTr2zXmHEZ|j`0YKaZ@fYf#-bjY5zOih5EAud} z6yhDg`Tf0P_YR5Bm71-lYZ1CGx%Nq^iKpSI?MM27)DrCjvLtV*QIBDcU%KCJ@Br!C>$ki(OWacDv!zt0crP@$QGc3_7WS-f z_r!*jxsEbwpX8CAaq6NuH#3}?YP;M$3yyi**6eH_bbFgg_ss3^R(NK*%}IL&2jrU5 z@`5=oLut#=K{uaF22GDM8#2Z`3t52|;dygIqT8qV1E5*)9WstCPTSk%{wXo?GeK{? zyWTx(1uR5NOHXYeBx=C*{Z+2_N!o?6(i-o}dJp=S(Lu609v~*xwhR}~9D>@w|M>aB z5Q8ivjAIPv@h-&a2a855^Z#3d~(r1ko4`V^;X?lwETlUlF3H8iW~6uOtt$ zjeg5s;A(-=LjYKi z)7S${gV-+CKGENH_a`P)$nJbNfT}@{JuD7OQ`4v9ggxZvXcf2&R)ely{B|+Kq{Y<6 zi_Fam!Z3LCWhA=+9Y}t?T?kl#Cwc+5A<{*^+a{i0n(0xGwv7Wh*dD|7X*|Oahu06cH_v3WNgmlfPXF@~@ z*s(h?Y>I>m=h3cCs0YDepr0;9tIa22{QZe+pQEj(oswF+N%s$t9fz1>M7)%5s{^pA1Ks|M)?E&WE0Vj-ee7J%XJRkg3oB!29|lUBqTB2z8{pC^^u^}fT%PZrqR=eR3r#@olZ*37JVLje zPIHDWGTv;-{!Hf^`CythQpHZR&kO_sm)A{Z5ZnJ+o)yrFMHa6L*7?p5Yks)cb~)|m zw8`Ur3OW;s_|&0R{NaeA+Lcq9pd=~Z0+rN%$uSjY#`^@V0xecu{h&zF`|gw?4w{e8 zwY+|$mtK8E%4Fs@Y3Lv^&R5}LfX!_oi1QV(=_&le=LJ0tSxWMa{G=|1T`8PvY?r16 zWXf>(cthKe17hIVAVzo49ra5?ohKHmG}w6?V+0E!ivESm20HY7b3&RQ>RRt@qxj6N zPSm)!AGeLZ(U{fZB)irZ!jm7(zlY!?($^8Y=GVw9a0bM&V@r$5dN6e7UB)MV=T5r! zk0~etW*o#!E*)M!ca(XT8vmye(En)!^twe9uxKR;4F~4)2S`l=8>Di(yl^TsKYrZ^ z$aFRvm>UAO7mRLr?HfQ->3*w>e1ck>{_11i8(FkEIFs`}ial09m>$zC#_43WMwN(#IXf3q%duOT3<1W9H(!sfIp6Y_Q$2QcW#Xpzf!#^_O_ztH z>a*?jbDQsCX^S?G14(Ig*;>0bPNs228;jUms3O@4706uk=d-ECDau)y*t5pB$$gon zJ0=WrDRN+uY%98K{byOI2sgr|2=og#+RI2o3)UNyUs>(f4>^# z6Wf~UEKZ+%Tk@tMsb(YxZ8FF7l%6LWJlL4saA?Ju>PSfd&26L(-q@WTc?uai)-d<+ z3FpiYq24Oy`ynDdI@!$tOxEKoo`O^Sd)>Z(R#IWpi-+0AA&wH0$zeR(Rex6 zIp|%}{%o_QVbPPL^$O3zto)@qeT9cGy}tg@K7~Gc`B+QYU9TBpHH)Vi#vAR%9j)6I zUUg~wD%0SF4pAg=J&su}S5{V|J}F3T)V%d?um*THtl>2%f)fWF%vMU<84*g6^^$KZSKP1FmNQ1oU&k1p5(<{$|NG@mT*1LcTwfMe&v!B#6xK<;1@F!XJI*s+F;0QvoYqmU##?BT za$oA}_S;Vk1P+~lwJrr$?<$qAT6-fLUOW=;LGXVN9r`>=_3o-p60{?F8_nUJZEf2- z5xGx_aTlLqqa)W6(~&5hJ9C;ILCe<^!}9dhkXJ%#?u72y+>NHQrVgDM7e{u!Nf)0I zVlSz{U$h#%O|f{J0%c|~Izm^-AU6Qa4~V9N&2h0)qRo)!w-!%r~CDZ(SQCia`z zPFl?7Qe2x`BqJTk-c}@!vu<7wxYKqlJ#JsJvPI{2xbifoxf-anMXG{exqTPYmV$~5+ znTGJh7?rZjw^{izTmd0^dHGnD`NYTw(R~Akl-Y~@c+-&@=MnGpw%&g3^X~k}iNhm# zvInB9TU@-X&mo(DU$f~JCY~*FJ=W;G=hEPX-fW}U+1qmNcItAi;nM$P38CdcChRux zzHCbV%Pge|#0$C?_{GuvE=#HT(Q|hPT$Cr^N)$1J35U>&oSHVwAw;(;S8BQD(oQZ# zEUH<4+Ng?N@tci;<$eNv$Kun+Z-u-U;n^7Xmw~%b4H2dbCyKzXKvmoIqFu~%`wdM5 z2l9Hg!cw)aqz%tG;j2JB>Pj0X^=hedGDNda7v5R)I8KjRjLa@1nhLwiM{Dzle7tt}l(KLvJII zsx9V+&A54Lb6o@5WG!cFCxSc~Q&VSB>5ld6{DUEI5yVytEfKX9xha`2p|d&@7-gDY zBomr*a-X!0804B7_UAI46y~=U01GYR=0>chW}{RS7ceD)f;oxnvX|qX9Cv}68YvDLqnX|bM9Tz#N1I^_fPNel^n^>Eo zyIIu9UU$>B7a7*2+QB3~X4C_^S7v#_74gomC1U}tK(u&O9INjnVsQs3v2j@LF{vLC zo!Po!?rnOcIM9^D*+FmO5v9)gL%RhX2v#V)2F6n~)zduJT(N0Qy&k^qE*ACivO6Fd zb>=DES#OmSpHZG%9y$+1tdP?A4R5mk?i$Qhzb$^$}cN-BeeZM z@%Jykg+6~DQR;u7eBNS36?yj0AE@xWOe6aPzQbFf5e#{hobN&ohf~_|=se$YuwW(7 z-4aF-!e872ZDpd?lhTz3D~m z_}va`vCw~DOLc|Opx)7#PP#o$s<}NdFA)N)ueP!nq5bO>B51`L(Tg&~@ZB4kTd@+EfhKyO z?v$gqAhhD_Q&^Gt;EKFLn&HN13ps|tM^N_Zzj#M*hg14}T zk?2sy(ucW(DZ{fCq2Vl44QJcT!X;aqt+)oqAHjR7E}OmCux9Ymo-QU}BHi!N^$%q{UiaedtF#1HGByH?QtJWA9qE@QW01Q!pBoc*l^tYtr0{%loH!Y42Qgb8 zN8_2?tFhQ34^PM0jM(*YjjiEA07FA+qaJ0?p_x@rPAx1W2v+Ot`ir1D8Gd(PX$A_U z6Od}*`HM94> zxts70}L$$u_3^|tn+s0SuV7GmNu#P$cNwKkJeb%mg} zCPvd#6F;9|(E0&J|4C~qZ0sSOK^&zl7WG!OS$$D&ac$ygj(ZDcwwv&^IpawK|FuN9 zHxJopaH*lDp=dXC7y^JaM&JG-`iANye`$Dr{Q#iV*I$CkhBo)lKBxK>3oP2X#M{Iwx?exB4!R(JSpfS8_DYJ%lM0*l`vO>b6&mZnCSbaa za2QT%+i7Q=9!%VtR?WKNS;Z0maceK9{@t7N1>`FtpPyH3=1&HoS{w03%k;RhD~Il& z&SImk+Z`J{wzrWJ8AgY9uv8f@Cj@;o&hUlZZm(MBCa37`oXE`;j>*fF!qUfDLk$ld zE+EePPhN&%y}9S!1>w_Pf*829pZygX?qIJZxPO99|EFHGFPRw&mzhU}ZrqoT9Y$I; z)v2~;x@2R%6NmoL-#`)R_^@+VM@WZm&Zg~?#GZ0tT3_{-p$s94P-JjBOU=VR;bcsS z)%}tB7*<1b#X=gFVz6 zPplQOA7x%DL{>s=Bd8fx0y83YCL65gOK!gzHtpR}47Hq^Pn5O{wXuXgZ5qvmjO}D; z3A4f%y3Y2*arZa{gZf5-XU_>53XN`cB%&YPv#87X)qr~DB?9$JxsdkF6!05BM42n_ zk7fbshwGt!V%Skb8}1m|9`HMQBsW5}4<}4!1%pzk`EVo%1_cE=~#gz^twJTmUQ@l2Ro(goyDp)ugajOx;tfaq1sUb!hd@OcvK z+r<|I=tmd2{PPDswP1?)&4evWhCh43ffDy=_D^(1uB_j(;0<6&=L__r;{7KEJU|f! zQ!|By*Kdst9iw#R=#Th(F7NtYZ8{At%pRn}=)5139<8`_bGMqMEyy-($y&S760zX0 zpV?g}B6iwXAQ7ft{jtydmfS{-k=LDUA^t~E4&Tp?V5fxL@G;^;TRdHg)`eLP`4wz$( zIr^rg_`l8TOU6TvsM{TYUm-R3wZ;N1eH5|TN)D@e$Zdn+dOsF?u@Q}zoHL@RM!?G* zXDJySTBrN?Toa8sW6$?%auYO0`$adM5mLBJ%`HVuqMlBiYNtqi<yY90~5^Oc~BY7HhM5p4Xs^}TodEXG+yomlgC6o1;tgCX>jlJgT z>Ao#BjP}^{2gzn(HZnz9aU8V~5A*R{Q3AZyb+cB_j>vVNmSb!iSD0BBG_+2XjQz1V zs4*~^jJIEL5!*veux@VPJ113c7lM}%#CXm*kdOEQYo2X;8JLdHWEwnm=!?&2AHNh~ zzfJs~;37nRx`Yk^!2RYFV22vtS*|9di1WjtLiVeHJ3sYi%J>lNyQ@yExvMTM?jS36 zKk@{aqoVZZjL%8nn)1|{T~8!(Iy817lhSogZ?!659NkXAQ=#pJ&Ic-^euj)Q5-&dC zw~~Z*7kD`m3fOt@@H=`U1=6y4%526pj@~Bb+Ur(1B30ajGUM20swO(`C*7k-@GHu! zD>lpem4i+i2`!EKl@q1A4Q#5yFjKM7+_gqW%aXEJ^pqQ-RuLUQZ5Xa12>OD^Pk--R0!Max)1O<}b=+uYQjA4^;v0yx22r2m#!=U7s2Za?y=3ry)5~NGPdeHpGfz`WRSadYZuiUgh7a)kv9t6nU)PslJ|BV;u2JwvA%jAT&{5;V4PG@GrK3`c7 zD|r(oRYk_$biq;dY8w|QHCO{k0|>WX#aK*yL~_z;;KK@R-!A!9A(#czz6}@ z%fmC|_;|w8tNqmP)@z(uKmp|==22+vBYo8mFxgri^|)5^ zy1bY5TBI8L%t(@0eHyp1I@^)t%3v_PX#+*R5lXv@!$i9=x2s|Hbhoe{uRc!~$QPf# z%C`yoZt-F|!8#3CK#dx)J4a#u%i1CE*;#BkagMRYOl6|6@l~xAN`vu_Nc)kIfS|p2H{dlM1)*^k2HJu@AXkWj=i*dqStsQ8n!ofv%TZ{;-nd+{49}7nLVtz$#CZM7+FaA zVU6BlQO+H&LyaT4^OZ2J-T82JDS6()0%?au2<%;zB!>m- z%>U-6`%L{ahLO%toa_JjyKm+ zV@S~l$Y$h?%|ASgMHcwG2QzNdZ0fGqm~$0J zi^#6#3xTayR;0XdolXHs_f~V`q)?lU77V?rU~f)@#+gIK$3{xj-!c`K()sr3&L56) zJrv{%4cfZC`;uaz zL=|M>J==Ov94{pL{+`F+y10QY)?dDqCpf)QV31be?@!4zhQ5x_xK1=r^X{a!3p=YI zj&4m5Y)9zvF=T^wEbMtFWIA}((>Qs!XpH39NKTFeqLU>@ z&Kf&Dsx7Cf9^PWsL=!rDv%4Kb;Mkb$>_rJX;bt08b>fwAw7cofIX5k--)M@!&Ng-9 zR`q!GyqC3|s|tive+R{Ta!5$`zka_|!&74Axr+|6KqVPGNlB@l{b!p2;ScgMA)9Gu z9-bY)v!QXZN#62H-N7vO=z0$bM838h(7}_kzUNN(Re!Xi<^$r;h#gv*DqNbaXU1N& z9M3t{#R}y~iP_$;`bJ;Fu!qdh8#}RI8Q8lZ;1W@9ce7wm34^)|z3;@EMyhJ4Y8z?d zmvw!%wE*A6rZq0S_aA>OF{dK+^g{qrySCAE^fWI*;yzl+Ags_cKLd5 z@4(Foz`j{=V2w?iU2c@QG4a(#!>v)hwa~+8n)N|vI*<_=)qEk0_*J4nm;cR4Y_2L? z8;X5RiM!Kp-!@ulxj+>Di${XZ?o-0{{tj6schOkH1+NOejp5 z+GCvE1YF)74mj-T8bV?)32DXaLoHB6almkOcU&!r&JU?hCjAF$nT|?(L&B z5vm+E-3y`;`@TNz>N}pP#nV-?UG5E?4zZRM2#G`6M0b}$>w4bSmaSmBJbCNEQ0R_? z0ffF7kE(7D%LbX+P^47$N}?ybsmc$Oj>ORq4WAOkVz~wUTvdA|x}gg_BUdDI&n_3t zc%}8JnrLb2p(G}sLHxSA595xJr^ z@<^JIg47UoeY+7w=(^t6-VVp3AS)U^Ul3Ga9a-4-&WQ7p^6F!hX!MlD7Yg9J%1jyL z6=~-?+Vt=@pd#IhX?4*{{l_{#7!;AB}A<0p&941QzAn`SgoE8 zS+kNFn6OJLIOn#crW?u1WXei>+8-F+-X(^l-ANNao7Pu-eh`x;83!SFYvR*p$fzfx zG3!}S`Pv$65~aTPV7BEYn+EGk15d z&wcJ5LI8+7NNeLXd&+c4nQC%4@iFw~_ARf%nsaeZ`VxNRtxhWRiEI#Y6R{JHc&V~9 zsQJWOZ2XpdB1SQ$NsF;WaMC1TnqhxfBRT{Dp`NfE`E{HaaRV9 zj#K#_IdA#S1nuF&;g$%hLVa%-R-{`pDKINt0U(7SXfj zt4i(I)wUts z9VtwC82-kIu7(N9A~X6kY?RH$bxbA$)!)Ogrdy`NgJAiC%5cJ>j2&s)pa|tm9~7a_ zwd|&*L1h{KOx;FO;)foU0vf{68Ezh4{Z64#m1AHG(lyq{346U&RzcsNR)#UX;8yCG zo)gu0o584(GUve$Nfrcx|!BHQ+3VEMrzVI&G2aGdMnNiq`UAjc=AyP zhA+pc{5VVJ1`w_F3jG}D{DvGRvk4ehy&Z#1m2O2yCqgA{>oQ5ejM#l0pB)GDp*|$% zHT$ILE}`@Zsp>c8> zHl+j@&q75#7G_Tm=xOy-lj_W=8-ejxy^IOVSv%x+{n>uoNnV{7 z-_k!IX*xGdk(2uxo`q)VTvlLw13dUSC|HVxJv=b7h<=#5djW@@ zwurLjC*f7vF80C8*q&B*+zk4Wr4w>Wjzj{I^)PvNb)i18wu||ZhkdU5l!cP-=i2;d zTdw2`dRS@6u6$b#6r;%Vm7b@P=YE7&o08jXFttWn<4{ciZj;lI?xzsmUvISWC=Hlt z>;^qGISJ4<(&x57&eoJRw)JU+bbBTbO+P8#8xJ+wUr!Gb4vmPmV=mCLJNNiGeD<(L z6dfz_y5C=;nJ>?TJ-i#Y_Vln$R@Gyouj&Z|a!h)`o7?Vj5OZq9J;Y0Qug&6`q|DW< z)3&CwFijS#W3OF{qXo&3tz$~9bSTT;5{vn|?~o&FIqgjk+PyS~q1BMK{oHMSZlidy zT;Gb7niqKaDht@KRunC{T18LSD(NK7?RxbYj3`aUeYe%?2419OIKO2(mO$2xgE<^G z_C3~FPj+fxN`@dW6PW)+d-FOK2eVH1U~EjUtE^Hzk}+tqUNQo1G1AgO&8JCQ&s$!@ z1OG6DZ@LA%eC@^SZ>1LYL6QN(!<6`1XFngV1Ew;ogtN6*t;(BM;SLjWm(=j9*Nz5bdvp{ zD7XWPR(*E?cn@k$`B zFufL~y?yu|9LQ&q6aD<>=z0eIjJIc>yg~Y)9UmB~J)qq7d^-rCUbM*_hC3MH96cfZ z3n%&<%ykn-2Av$X&&}(HpEurykHMR!g%UIy`Ph9?XAF4xF%gxap0QEB@|M}A2;&}p zWH+-a6=pS3;!j=vq!V)Q*wKT&w@XEcrdfi~-HZ>@$+llfRD02ND4DLUXPRr06FzDu zq&{M)WW;OOI$~!0y$FjwOz(?1fpEZozG?*Ryjt`M_8O7Y*M|lB5PIZ*!7$aH%R$so z)s_ND>0Ey>**)ucf8)}ytNH#uBV$yR`}0RX!#h8GK|4917mtth3>@p5J4+|Dws5q0 zUxkDOZMLF=l<$!%=+YFAQgSh9;aJ6Yx9#pct<`Ecy_n$*ZVL0TrX7WXVsT==6=95) zEmP~w;gB~IDX-N>V-sQ%@{5!tieW}CbVPTM6WE2(lFv|p(Ed|S4=%b_w>e|xdHAe>0oR z+Z=(9VuzhhFzB<|a8K-fIwYse()>)-_aWPI!1fmbLEsT*cxM!xU*}5bcWX6<9(0@+ zY@*@16)TEIR4>*tk)OKU%sbk7$B3A#Lp3%M$1>UM&O5HI8EP!H+qR^QsqmejE3 zbj7ZKMck5;6w={fv@bXqtIBDxX6GC~YbN#T6h^6GHznw0M#!!064Y-?t_-<#wkd=5 z1Nt}krJkJ=R6h0N-FyN&$JLYT;DG?o=K5v&H6M^0jO<4=YZU?m?$&0&lHjqSl508krh)MW6v`{WDH(_suEkJMUC)t#fwA+To(mXZwBM8B*TFI#nx)kvc7- z#SW*-&B15|Qpl+da?xm{BdS^rB(kl|>rK1X+5}tHAFY?rUB6>j7lWph*BXDNI{t?Y z!-?%GGA;lys7R=FOOXAK3rT^d6DfvP^y`Kbb`22zxqRg_)qU&65;okF@9$d`LFZf=Ub-v86a%X`30oVBahpaO1}tI%8icDlLUUZ zB91-q1TEVgzqy-g7Fl`q@Ej??+YpKuXQ9 z=MA)F294xLLP4hwp~^dCh8l8hJ|ow&r|`0+Z!P`_5)bVj;!tmz+CG<4u$Hxfa(KBxBH6F#|(M@J!iluuW`H(qPa$CP$T-jpyrV zCnr&7!Q2?$qi62!@k_kz6O}oVrCpt^B`iU1R^lUUA_Lbhy2PX8xzFkIclU{|o#X#H zQBz`moUie+?0RC5H9z8!VmsVJaym(n3Wpcwa7>79lh_X^U<80ZntR%XY9zIx*nBQ7M%qpy8**+ zwUs>I&4xNRSm|cV7-{Y_a#bp5RJ|J0Q$Zb!4VXLf>JXOm5A%amQqw=3#j7m2FwA?$ z8R{_oOwi;#rhizgh+qK<^QP73-+zO*L}=3HYTlUme%!!t%T)Uo-l8|-g=xdEm8xBL z4w;#pP6ukKO~z@rUG)djgz2uEQ!(9ly%yg;s)|^v;vyOA@{Beo)~z_`QJ9?jd0$nY z@*)9k_aVzOzAoud=YHLaeJ&;{e)x#W4+VMw>(B!Sm4H4a)BLADOgGIjdI$M}=DUmU zHBqm24sCj`S;=Y1dF*~Ll6&S_o|8Q(F+z4(SK^k_7IuA|=p3^cJ67kF<0hkwhTiwx zV97Tudm|2(RhysdX=P$~gSv&i3WL6GqMpxm$Z5Eghy`uyjL?%1WuC_+e2%}JF=B?` zDf%m^_e04+Ua_0MJEQfx5?f7}i&7_x(q6_MEg1a68-^zBWN49NDe7n|kua^%T!dVW z9Zn9`fURncWp$XIsAMW8bHIdx{YTsP`b+jQ^t$Du00RY%AX$WI+`+C2HVZ zT!Wl|%U7Yh(b@R=^Pe@aF|OCI0|h>Jy?=C9Uq(!v_5Sl&)TE+_@_sovW#ko>e@S2c z1U!?FL?b2u*2(7vCa3+i4j`I#(>w!TGEQRgVdk3WYF(O zc64ZRr;QU*$#O5TGlwPH`$JPw%)ATzc~Hb#)Rv!!RI;J*Sy4WGPi>GW z?i8Z{^17C*PJfg_9kEvkDxsF5Z&>a?5DAiyPZV_&X1MUBw{wegctB$L-@JQhDI?+w zvz<{EB+*uwXhpAmY?FGfUEQ55jydjUd{S-820PesaZRgLNx9x`2vfFR8%A|H@YpEq z@L9LnX@-k_x5Ck|DezP4>SrR{}g3RUHBk; zit|H_+t6l^vEqZe?O^3W1py# zA-`3rXirbXNb;NBVs08EBO$2PWW`iF`*Dw09<_8|ic_pFe8CeSh=Kf(T)vd_}&ZIZmg z1k_(&=e*#17v5$?jrVm+f~o=GkP-7}yZ3sB9iK&R?Wn*64o5))_v)C^Jh90Z^Xdj1MJ)Ci_*ZG9GPVW3GiMfpW<`mjViG66xnCa z`x)6stbGmT1Kg666lv0zuA6V;8G!>7qd$4+La8JlQ43@@eXeb(`MV+Hl4=8SGMbFL zjxbxW^+7h;tHWm0+IyWiImIe>=o;gBUrqT+!==XafK_X?u5SdBMYT3Fy7MJZR4ZV~ z$({Cw*%b-4w?loALQm+a5KBKKs2m_#DH3m}_xD}M;)}HoFegpp0acqdcX4%3iPp@g zu!>XDxC673dZ{ocXQ3qS>-CIZEot$vU8Wm-vQef6v8Sl9H5nQse7t2jV}T1(UuiqN ztBDUceRhH`;uJaOZ!<69%V}e51?coU1Fp(ob`c zu+?XCF@N`-mKs-hVKs@_xU%yDu1)o_cC$8*c}{i*OjccbKut4$%4Y z=M&e?r|0sGJU;U!fW(EAtgk-(!gBmhmv>AUM0x8kghbC3JwLTNpPW$@O3>knpP$g* zIJFSK%lSmF-*aIld!-|I$K`flbf!v>as$h%Lc!0DIPsE3>Yc9HJH&Ck7Mq<>wW|c= z#>W(M-Hj)HWxp0vD8lUSsu~;fkuGLr(+Pb1s^UMg;;)WJ{=}CPdA5}D6M0WbFDUKH zEqR7}Pm!UV0y$ltmC&E&-+kPu%0RaEr^evmTG@Wty)pKt>{Lp z-_{~%TCYt!s=}wrkm&D&J#J&IQ@0*q3Y{J56GrAuFOjVV)*4lmy)x3-N^2)XM9r5H z`>NJH*#}jN(Xhz!?9sET`UGEvf9N@`enYDW-~~_U^?S71Y^>_^{3zDjeIZPG4SOw( z<`%(P=6IN#RHon27mYr#Z*RzIx4#Qn_f(1OUM<2}U44lO@nL?NC8J|Hw`Y?|o7-ey zk-oywYk%Gsj6NrZ7lfLB{sm9^2@yYIVpmq`O8zO zyE?6RVY9!SI?e60P979#NY(;7s*5e`L{^DKT{s-VX(y|PM3i=igWg>RZhj=7C;_Ic zIMUOpGG+DrM~v(W^|JQsh4bRS3r2Yp2a}tDVX#rFJ+0&9fHHR?UsK81=HPlgb6`lZ zP#p?}-s>C>!P03C3EOP2X@#puKHYO1c79@d?zXi(h;$E|X#w_1L3)efJlX&y*Z5aV zNpg=jeHID(i~H_RX|mawO~Qv)&8yUn9#|Q;=&qdX@hM6^_lSM6bB8RV%$-ET>M zzux*Kt3)|vJbPWINJ-EXp)zT9$hCkclwnB+AZbq3S|*XmT@i`=xwY}R4~K4W3t z=~07VacXomy(z{~OS<|^o~VdLS|d#HKn}4>YU6`3{f>qk=3DKkBF znBL2r>sQuS;ahpCc>h&90`urm$BM#``wKUu1o*lirEBkP2SYD{#a!)>wSm=}ZT%rM zXYW!QW^EH&--Aw>6H(|c$jNlT45b=P_;If_BU-UvQKA#wvr=B4GR8dS{Q62(PL1t$ z>Q!G+`!xj~OoLr`t}@G~Wq>REs%E^U+B{3mxE`7>cKxLy@=6u>@(>o@#~-DSJW(SG z6Ywu253nh(WC5?=BL{XcU=!$7omf`AHVL^YjDMeEbt8y*OKLgdsK#;00kY6S)r82s zyV=ZmB9l)^bu_RK+r?>bHjnmfv7BkixSBd!D6`#sZ-*hLaLJc<)f*oa)F+tpT_0%! zsJREy3?DFvdf)s;o|NHU5Lvzk^=bh47KVN*OgwvqWAc=zopw)k6FSl|0pADqwq0p} z`(n{u@3+thWv_U=8}63wq93@lH|(rQ&4YszTWQjx zLj8c0vR?HgE9s`EUvP4}awf6w9GIfk_i2Cb29piVdCcCyTp^Bhd4aD-T?0s??u+*oO$O;(fhSW7%-HMrcOIw{n zaF!J-Njz=aZRIc)g-%y&jl0l;ZoTKb2DaQd`{iuAeaUDM8meENtl#j*9Isca_@=2` zZK?bVPYUTB9|OjF_}YH?ioRnA+@VJ2Gc& z7{n2d?fs;E97oB1P^Z=lHW;k?cu20MvZ6-EmRK7eyseCj4jHw6PgnUK-dMtoNUoAO z|HiW<&S!gaiP!ywXE+CW#e4qlJxo{4P=a|{0_d!mXbIASqZXoak$4YXaHdGQm5$^Y&QRt;-)9=3tdggQr$Vndg;Vn*}EgU*}4{Vzgg+#BMH_ zkD`t*UjQVWT$+i!m-&2qw!ifBq5w?k_@cM(o!|a=6J*JRTaUPyRja0|hX?$mPYAOw z6G?B+1=xb`Qe2qT`S#k}4IGcgn7BP(sO_5Pb)Cv~u8vkPCm|lwl-ezsmwHd1HC@a!Edap>05?rjK)vr4JiwQqGQDZ^^`55>#h|El=^N!a!b#o>Uc!TxCqV#b)kHdn0%DRUho|=gRF9cS}iwe2&Q9 zxV2nYh7-{gI;w_O7QQHoy&xKyo5PUmtU6xRt%>W1pnMUx zmoYx0~q5znWdnv0ff>+muo4K`xnmB#_ zMyV9z>Bn}Wo9+k9>yD*Eo)RA^P^@^a5_tB5PpK7;H@x|I%fj+f#qjUibvaJ{>%Trd zMJdm{2-M_JvSJ)lUfXi@Ae}2A;By%I1idE1FmE!6@&nIE$T4|u`aLg?_%i+CIhB_U zpkGFN-!%WwfZ+SmQIn0)9!>F{ zz*MD8)>@9 z>GEXI!MDRJhk%HFymxOE6lG_Q6v*a+6Xqq{#yEe41+lqbuBx`PSV9Z9Ev*8YX1>a07_^h!F`$;Uc zDVD1wX2)s{+Tn8I4NQ-A|H2S&abmx68GTh9_44@pFz4l#(TKvfpNFU9hrHwk`RjJ+ z0`#&|m-p}OmLYB;eyQy%!>GMA7^j&U;wj^2&PrmthsCi%hm}*4K55d(fsXV`f312e zniTOxn>aRg#*!;os;Sqd>xjtrP>|V2t<8S@Bi9PL9|Yxiq$x zYN(|4tdCwDe_yhzZ`o4$5ub1-^vstExwkpf6((%r^)<9KMCF^`)uG3$F&;Gc`{AnD zm(uRCJy=7_+Nv;7wn@B#Y?%NC-6PmxwRIGlrZre7 zE5&Xv_Qb4@&KttSKTy;^|6eKeot;GyAoZ`K;sWM{h>N%H(eQkd(yQaKr>%Db?F96@ zWctiz8!jD-@0(KW?|rA@4wt6d!kH~hjvyp@7H+!<3?PTmzN#Gfgd@M!#*6cuz0i)uXmWszW)5~D!7sgFq5nHs; z&hdxpuCHw5Nh8X0ONMXR$ipw6@DenF^|JYI^OAeOfcyIkA34x(xeDzs$$6de)OdM1 zq*Kmr)s^M2wcwhhIf|&1k5*L8lsZatA&b!K}v>u3oTn5yi>GV^Rgik~peZ-!nxhNgufn-YogST~_3p_-xm)Cj2&TlPo zb+X*q3fWMWr>RLpVOi8qYQ&IDI!kptVQR9rky&Fj$AR_u`UGamDqcSpIMnt7;HzAIimC)ABP(?ZTk?ENSEA|x3zH^)2yMb)H+`6d0Utr8 zmJ>*;$iZWIe&kzyQ(^eUF`>B4))11K(Z&O7yXC6mih43n{L3D$5?H`j{&X>o{z%Xl z@vQx{L6BUdy7}dga@4onz37h;MMc~V4K2L>3NAyLKiCOBMI#y$Fj^J zRZW3?vd@EkAh3!WM_hQ?A3&#eP&7X_z4KEd=6d}Uv}_!NAiL0ntxPo zZS&{cN7IF$-cMKugSiYmAAMb#r+lTP>+PRSnmu>MxIPB-+j%)xA_t1-_6pR^pgT~} za1t?JxHnB!UI`O^|F zguYY_<--W`GSlnRUA;@_!-HerJdycV?j&BO$)<|@0BAfE>fn9ebLjbdTg=x}+zU0Q z_<{qu6-ewBcPSB6@dY5M{IfQi&3!rg`KSQoMZj=`+cp?oEnR9!w^|K>Zc8TD~hxIL{M8HmBG-3rZ(MDrdbQChJ59-U$`73aFi*~ zS2{;HI`BFhDP-5@4{^9?t9;Lvs0?4PT?Y!TZP^>FuexqFYgv6BHex~6PBUVWkt8_5VSrJ* zb=R7=ji=C}jM&BPNISI_ftXC?0O z6OF&LUY4AO~r){b#rh8&*pl9KEiCt`|irh^mKuJ6>!ZqrcQhEE6Ut6~dJ|GB5@qvHs>@vX!)5gUcN z)7_aeYKeTGjnw^iSD z@sK(O$F=H&G_M|l(V;V5dv0~Owv)A~Ny9ENozxRw8Ffboj^%1Ijjl5LS!lpC-rY#c znC|ROzqL$P{qUalp+WMn$fJ6Djb~_Rk>^)H835#)RjLY)C3d9~JKCVr6e@>$yQ zUF|sJTx!gsbRfhhr;#3eB-2{3ew=m(l^Dmx)mmEah2BC5{h>Cr`)#owCd&ohB#c|8 z^OKQ{maQdEYf6yB`RSSwEVN?uHd8y2IjX%grVZi z@<&mU0Qh`hyB92hPWPgK2}Je9*_GFv@7Rj4Az+BbbOs(|pAGGft%UO?zL=;&Pw(v7lVHMnBfY6shxE*Kvy6)c zT!yk(kJ}$-gRD0*_{zy&do`)o&s>+%g%$O(j$HQC<3}lU3MxwHs^;8z*KU3nNE$~` z#q*Ydi41c_E?ZN4@{wy!A6giCMdOxo=EEODvq8(v#Uj{Jw_m?Q9@u9`ovoN?Yo45? zt5fRjvjm{f#=)OAMx)W=kPeA{n;&@iw#C=mq0MdV(IOcve=yqeI#V`B2NKqwW!=SH z|FA-Y(?TPCdxgmLkCur3A`b`L@3o){B2}u4+IvA-O7rTWnV!UYcmj{`BEy9)SH-9M z9!`w2X>&EIjO`UnuHS1_(%UY4bDfTZJ(OOwVeaoPU{5hMZmfDUDvyTTSfZ99bM|3* zNId;~dBy5nnD&iC#@CC(KA6nm1!#TPA7rG(HkR4!K#sNEXv^T24SdvHfb#7GV(4eX z{=eZ=+!zzm^}t;HK=HEH z7((^5scjWCnQ!*eY~URU7)wq097%~(yCwSc)Sd_JSJKS?I6q>3a*?a>;pBSi7jx}% zu37)-KIh#=Eot2vkXo|^N&P}%OM`JT7uaKCam4i*H6gYb(@06o z3ib7N9!6YcHWaAQ>af}?YZkh*%?x?FqBONTN!#l!7N`3rvsCoPWVY>1PBD z^7qFCoi7vtye<~KfdvDomq(gA^_NgXLhQzMb4HI@$&^WK+km ze7*=Y!RcrEz;zJ-^KKpR9+rYEvsc_{**+4zQH{b^dx6|7RA8sI=A@Ypohx^Gy%Z?c ze?DC;zxQt!lS92*PJZQ$1=SKZNvnfxtr@Nc*s(*w)X0>PTARhQQP4N)D&>7VFqx8% z_HAx?frl1xd7WEB-!YhpN2rq;-go$Ya&of?&o}&~COT?$RNL)S!6m`y+1bUK(>A4&#pU_FxVAMijhC^<4;IS`JLjd*#%Umi7s(lodS%=|(* zxPSx1TwcDVBIu2w2Ezqr^UUbZP-!>c~hR(M0soJ-< zF4I`a<3ycooI@nkhVu!nnZ0^tBJj4r3B0^)bI{IyCpD7rk7-_17i+CWU1+2 zwcNOd1KwqXWsvz(-|hgLiqyBS#S>C2wmjbR@vyq}w1BA0XA_^T)V3$5<}ccr5mW3A zTa$&)|j-MG=ic;sY(=Vx+$vuPGn` zK8ja4CQ4e%lUNP*VH##sojP8pr&b{Qs=XPQf|IQmt@wfq_}RVYQiSy3`XdT*!FInG zgp%UQeqRbE~ z&I^3O5``f1A@`vd`D^DS3U~&fHSoxlzWoH@`Oh2Io4?Co?m+{>?=Ju~!BaK9qo++W z9;D>3E>oFz+#N}}R}V)+nydKSQ-lMfDAssu&vVXL0?Co5{GWYN4;oW05`U%^Kfuj- zM+m*gO80uh0*|^uuo4@am|S^7t~II2w$QFxbW$%*um6;H^{{|aQ2O01DucW}`07*`(0iz`B&T1?d>~3&!wo7a_b&{-Y36+{V9;MT8st?1=+TJ+BMsxvQ@$ID2L8+Q(Ka1u?^d) zXS7#X&7zEMPo68ImDS8fFhAfXnjgJlawsW9Rz^8B;LrD2;3!D`d~?CJ`{8K>P&uw3 z><$4%z|(6i9cnAL9f8LPT2x>R!MAi*mN>o59t?awAIYsLKb||JI5k-kUrZU_PR+er znOn}raTYpDv>l~Y+t*216NZZ@j53MS?mQ!T2EbRLo+dDypDz$1N0&81lmqlM#I|0q zvw3WHp^dxVTCcc6-H}twPVmlrfvcXiaEAgL=)KxU4n@4@?Qc`ewm|!V;aj zm{H@XvtFwVgI6l^N-Nk0X)O#6hgCXhtVXO+<&}=J+A17d*;0lzHHB29xkXry<&iaE zs~fkqsky$~*!Cj)m7#vy=RfBi$wh5R{y-jp^09mB=0+>}IUVHS&Zx;>=7{-@5STz_ ztfohDT6fzP*WyvNlg?q5I0(NrL5OFIeuV8Ude94X%;u*>t#AU?YE@ z&U;g?(Q@U9zBy6Q>HiZUK*|Hkg@1OW5oh=@6D;86OD$gKq1^9i;5ZqrIMO%<>})CM zai`aAunVXzTfU-!oCSVB01PFp7rA>#xO{G5UCIi1I4MXJ5kKV#=OmL0g1}z{Tmis*b4Di7 z-nDQ!YiuUL<|M1fo;i^^VWG%7^^1ifaK%E=%iKHl-9p3o*tGntQ$4l$ zbw_m$vJJTynmUe`;6~7CZ8O*|!pt78=Jl4@){hY-pWI2d)b*^sst#AdkRPbxv4+>S zkjsr>gH1QMWw(?pnXl}+Z{2u+sFQ6z%?Lo;;iqnz0$hP81Ucspue2PbG|1gUv}pHM zyFF1Gi0cvANE$V7blTZC)v^qWPoP0!koszCKU|EQmO48y`=y1Eqi%mvH4d{)+c&65 zZDVXkTd%b@?G~rrl!iADRicN2-j_&U-Xh2Jm!Iax5i89Z zd7_zJ-%hQoS8Kg~Ei==O zX*A~>wugx>wj{?`byhjtPU53hT4J@Rf7N3G-Yv!CfkYaR(f-4HqXHU2$~kof_!BCq zeXX6bkyFtd)oipj_C3;yt;0GR(%V#RxSBJrg^e*Aku`Z)!K+o)P3Iz%{TN$?jAT~X zm|~!{*TH%+A$1(YT-aJj8PVF@a;zS)BA*k8QOe}Sr2ivBCL;0^0hXYI`7D9Z_&XQI z@DwoDyordcd{6)5@Xn8spx=WEy^eTFkKXXor z;4mwBRm-b*+YjmF8cg(ABm?AUrS=hJv4_fPPsdJ|px5=5*TsjuAvqiNw_BXY*MUYc z>wZeKW1+H_8>v-Y9Hptq)>vVB6k`|(OxNU!q%H+Al_QKLrBS_bu-x3PPj=wRauK$Q zg9lGrG)>6y_#!RtGiW%1pD%%cymPRBfr`bdzV++$rY>olX_Kn-s=ObyZLv8Ybx&lI z>)Y~>#hQEQT+_sMYd)8gQI`JM&#ROTrYl8x_&Lrx<+XK z@#g?ZfH~*PYtP?^?p<*Cge~KsVqVbkHe1f&0U73hfer!0jSjzHz}3?sYgSSN6Lx6@ z=iC;|myKj)GG!$`?GFrZ?-E1O?xYE%hSyhpeh`x;83$o|FpN)|A)}s%#;j)@G^I7z zBuahnxp!mcKht6^Wgf$3Wfdal-RG7J*N|43z@Fmkri;FhuM5#4oLyc6-jG#s)$hN+ z+wRn0_R73JauzIBrzhT)W_A0}cJMG9vhC1I!4s1T?O{}rJa_B$GfKy5Dj#vtj;)eJ z9nut8f#zwJAlk$(>2P)sUp0KV>6>^%d1v0Pd|XkxqKmSWKm0A;cz4S3jd%!7e{N@2 z#El}O(7HhVL}%;S7X44us4kJ-(r%nJi-KD|GM6XBS>`rx6Xz$$K%$?nfFXJp4*7ym zdn+xsGA zTT{|s?qtP-f(N;pS1Iwf8gm1A5%*_dglh5t+Kp{IRs8o-yW$L|kKUbod$#+5~#EY4zyrFdo} z8mvj3)=s*bKqZt)wd>KSI(6G*EMlubTy>jxce<+^O{>|H-Laev8wT+U=6vTYxoHad zQ-9*h7yk@=_UW7#$_H%OQ?7g2y{DM|TZy>i)_+T=YjPdXS;^_~w}g6jCa((k|2_#- zxYHhlQ^~#dzHCCkaDTXwP&WIk-lu>nYnMlwD0X{xLDR;M%F=XTH-_+ zILGCQv*rD0fAq9zQnOsSyE-wSiamd@=G0m>nO3K4pmN4RW~ELCH{8=+ zA?vGv^9PZ=Yc^Z;hB9TB48=S2rg3#l=c46n%j+w({vOLu&{M|y+vq7l1tgW;As_x5 z_7|nrm)qWCV6E*NO)r^h3{V~ERqEfhr3VpJqNj^zA{n(kBefG7S?a_iG$Vnu7mx);5$-lCfN3RyjhQF%7 z=YVIfX`!I!MH&0!$$K<52htKu{TxfXQ;|Iv9>g^x;~aSa^BO!)7uQi8fb z_U1MoTaAs9x>ekgCsq|pw#j6;OIXs4h?zvDeoA4xnjvUX+cxdcOO767YC-ofQB}xo z8+`hd!*>UE*uN6M7cA?nSHs-fqJ3AH2EGyG&y;HvHN7GahH^p0uX;_y{!esLiF?)i z-p+I-*Mk8|Ut}PIq4nd?<_#k3%IyvK%@M5Io;*F0HMaq1`mlQJgAXB!8>`FFF>^yU@>4lotjCz_ zvrzSXdwxy#VrZC}ch7owblB|+HN5@kSAgiLuWw+#?vBvI1EU-fW4l&b)4En+b#07k zgPvB!YTZ!9HA~)wVL-J>ztWyKJA5)8)aAL}nx}o1fxwTo8#Y_GKjg+OCvocCWiT+I z^--V*3_3u!hqfe&Ss6+z~=mwN?>mV12z(NEMe@X9fsE_b`9*&(@G9U!K6 ztRIJs=Ja%EM#GjhI31F~o;aB!d^nUDzuh`b2iy6feIyT)v0Q61AOh!h+=0oDV;Gse zuyJgqrpjEEpGUILDTPLGh7@Ny>e`pHcT@uP2Fr~@oVbWp08%oQ5IeXU2Jd1FfdgEj zKR^`U1xB$CeIs<{qk81dvyHf&oqT7U3}@~(sC)Uw7AFxc?^&O^Cjz3J!Tq*?cmxiM zc)SSOEx6)t8=te_dr^UXOosEmszG%ymAdJ8YmDe2bh};I{ODW`@&C5>WzDK`OM=f| z{fzTU?8~5nzLkm~;D90yJlqZhRFruXBD#Ki=fZjG9z0P|58WO2i@QaS>B?LybLE_O zDBbVa3sg>9c)Ia_kIEG&LgD)Gxe39`r919arTdz?N=MXmG_u!}*)9DfcO2qYt@5O* z0I2gRLR};74$T*vc8QKv$MzEaKo2)PwBj`gR?+p#*?c^i$VYT?$^9~re*<{o| z=4IKJXOKY;NAaZ$>V`!*qDy814YDl`KP1L*J}Y=A8$zL+gat+K&o28-uvENV<01Uj!|M;?<%Fy`R9xT<^@4vc~J7-J`8C1(8cqfLpRu zbG1WvX+c^~4l7Fb*0{^o7b}0?o#sY9ctkyLKcF?kmx!Z-_3n<}fkbHEJ%U5{=lxdd z%|)p}2W_U@jfBW!w#Ts}D5G|0x3n&vPB?FBt}UUz({|l9t%kv2JZsKKp6O&8b1T<- zQFF`HV|A@7gw4Qk;!SsP)lp&lJ{u`jlEc9|86u~h{=~?E>-Z>){-k{%+xLC)0I(Bb z;035j0ODKbmBtpf(pDn0W~K>~fSv~IVz%ULeXx3?v=!yVqdT?giE}l3po!l{4lOdl zzioXKr!f70-7DySwtBj)LOAd?uq%=l_cAU;&D5ZH5*muVtgS$>-lfnzOhl;rXQ0>j zM~M9BE|aZ9j=GW~Ku_?re_(lb6ioE?^l|~*hih-r@6rVKX_u?kmT!vc3K&{^^#TMP z5_MmT=t{Sw+InKZ@7 zw@`~P1pCcjILFYYCc1iU*YqrAEKuw1=+sLD<@kQ?q6V>C#Ai>qA;->}iUI;vA!VR4 zyq}bV1qhnt24iol0ar<6)uk)UQyv^F984 zn<{7(Hr1=o9>u3+W`o>MJ(tCJ zEp4udxv$c!+tBLSA|iw>PL8B>F_kvVzM<=@s^ijEMPKH9dVC?k!=c!D*WJqgSDrbX)= zxg2D&9ExtUrA`)crlefaTH<46Bzl~sj3u90Cq2SzjvNZ}dN7~o+xbXm{`k;Oy>*aO zKe=sg`tuo)FAe|Z#j^YLSvpY$0N%(151>B-s2>P~35!`sWXPczPF^uGg#n?Y4O* zo9z#bOEEtXyI0x+QUX4Yk@DlJ4cqH3%6}uiF7VJcU0(k}kO{JPv{K0;h^3!dAl7EY zw!3OKxzXVw$bOM@aqedMx-J45&H<;tOho;QJLn7z&^*8T@$NyqisQ|u%Pkb~*mREF zGB?}p&P*Io!(!1PDa;a9%#a;WN;q)a2TM|0;c=QRQl*&f-5RI50d&7gxs7pX3t>;6 z^D28>-|{719K`^7`k%C8bj&_Ww!0pDPj}Z{_Q-FU^aAcglv4x33d|1-I%Qg#h7)=F zDDi2{Uk#nIxi9d;dKZr(1&T#9Mn3ky{Vg^yj&c)jL2V?;7$=<_Y4lfzNxUw(IU`^_ ze=1q@Dj|G{`Hn%)TZXs-B>uB%e4*MCQT{@mtYB3Xft~o3GC8e#a(g~&tKckVYYm(~ z)KYPSGt1R_Vif*Pk<6@p6sF2(yW^a?#gMzX&wHKGq-+@reR&*H0!c`-E>_zQ%`Ee! zoHien$?I^4Cj?QV+nYN72^hjqk7BD)HG}(3Z$x}B-gtO-#+6fkHaq6Q2-2`+xmDXP zm0jPMg;b;AmD80XS~g2VZQp zn3FH^2}zL17n%I)qm6I_a2GV;B}lc0yx*7FOxG@~@sXS1qE?I=E&*-NH_N=PbUPxg z6x)(y1Bb}Ny|ZI`Jl~N?-iy_FZ$JceZRbN6$Jp04{lZ(?t+_ZH&;R@Kj54TH)A zhK%sI>U8sjE7Bm}R6*|`R_H<97GvpK~1GL@25wA=c#VBi&k(RZo3x(kn3V-~uU;3@fF*Q;{U9}%s1@wL`` zoxt>aMg&wVfEQ$|hiYej3W*F@v6Sb%UQeE4MZHZqavD*J<{6qwBHVzP-Z(8CTuf)KAMRS`a4Red4)1MKW|2X zs)Kn2dO`d82I#;5@|!D`{HRf#j@9mLRJ%E+31!kKrZkU-5bA=qTerQktOKn4l&St| z?MRlK!?(ZQu6vkh>G#i-Jh_W}zm%Y@%}_7t(m&>{A{djBRy3xpxK+}im!!l5+v4Le zjOYDjEt2?YGqiTo!K#e8_Ef8{=b4#p4xR+fv{QC{7*Lph%mlBRA=-j@kwrqZRF1ePCum~L`Ttcf5v9bV!Cw+&M+*PnU(n1a2IO?i?eX? zK{Zyd+1@Xhk=mHgXVav?AJ>-F2s^15Vf|vTf+m5V(fzW^$lqwfmsz!EWGmRe(uSQC zIl*OHguq5Q&hWC21X=7a10v`!znQlaoS;>BR&c8W{8Q$RCPZ_&kF^^V zn>XuIVo<|DZ5andT}~&I((}auy*|V{*Phu14$+Td0VAOqzu$0oqSld^k;@(_CR2vd zs<)Jvh7+*TqtrQUKcG9oYnDaY?Zx%+t5FQW2^zxk^a`*<#>3ZMHFWLwr);^_rF|D` zk70hvv8_V8`+9fGTSC^d))?JAu*$?A&64`ESongNrEm zcKwXlyHYwD;g&h}*2BFAWuz<U~scdG?=Z1T%hVi1m3ceKpaxx?kbEpT_5%wWWXl zRG(EN1y2PO_W^9Uv2@5VyX1+XiHpA|UVnsGZ3%>%@3It7#r(xj^XnM-9aPwpyC?9F zKCs%0C^=%bF4#;7rEF&9ELj?xu~YIr%W94>0~@;PmXAhu$5?vl0_uvyKDYoI{gMgu zU2ZkTTU}WR1n}Qs5H6NvTj4Q793OgBFKxs^r-=B?m-j_^%JcE8D0*Sn--((Rl`qvH zeJ+TB3*~#&8_}iar|LME>>$H&J=RG^WU%x&o&~~ewa|IU_igX|X$@;*IBB)wLsVK0 zZ{y~&?5&DyeN5Lqj$U|F0okiF$(BTp^GN-nlo^QO2CpqGG%V+B?yR7lP)2Y8OC)T+ z7A6SG(Q%aFhru@Owwa)|?=}4arT02x@tqEg=;k<+csNj0R+VS<`reFGd|YEf$Fnzf z!a^6jJaS#l@D-^TNLivCgJMp26uxHhQ9bFj+Zw(Vd#0u`(lF9}iNuzx_BHAI1>HcD z=XzwGa#m4F;YCpVf!1Dt!g+=%`LEVR6x}X^7-dmC@feB*ynCI;mD3_d{t7fo`unpr z70hv2_T4`uS(g<$#e$no#E|O3 zq)2k?PmUd48tY{eV!OTYsD7Sm$DdI9i#!cfhK`N_{P|T*#vs=UET}0Qbn++?6Nes8 zNj(p;daG}*x}n*cIz~gAn+IZ!HCJUu@28E9bEwUxt~?;2m0fFglnG&|@gla6IhE>g zyBuj^C!zNX2lcBWV&Iz-0O;j%iX$TbHFyC&g`tAfD^OG7SLXtSt={z+oWWHDJV6F7 zLdwkdCuBK|r+agQ?HjIx6*$dHeOX&a9NrA5)mA4&IWfbTu%eb$!{3QA+lqBo6bEt^ zw6KxV38HysW#&>V*4~~nvgQ~}@Q1{f@TI;^1DCwn^e#k20AUOsN%-myXw8J_p{|Fk z!N?cYwTW#hr)QRp!(bt#v*A?VwwFhTX-R#->9+4$(ug4u+nY*-N~p?zr{T+p6+NO12;% zza77EUxr-8xITxT;O2l<&z1M)Nn5yJxHL={Ub;}bh^Jk+kL3KJz{N0eCgFKTOk8%q1yq+=cj>%qZ?#IxNYi`&hu*|yb*qjW^Cv)g!BM?P-r zYlEiD=FI3U$VRSb>;@c$-K}95hn=CpB+O#6lB?|UU*9cN)EP?1FTGJvPW<&|f#MmY zq(LIsU0C_4`^)v8qdoxvOqhh+8q~kW@*djge8no%OSE+?16b z9duyu#5iIhY0XO2Mr@{?cmfX6I}`ol9KCe`dBPYu(B9N(KS4d=eLu?rSQ<5#`(AeS z);qr`)%U`>-#&Wj(PsQQHIB3`hikKu5o>$en@WZ19(DsRYeqJ09Wpp6wOgbxTmRQchjwlx=$+D~&@wt?RbenwRPh z20D`#%<=w?L$2stiG(a@B$X=(dXns~dwM*7wURWCNACabW&%$Vr{aN|RDsNmhgy$k z-v9SK@58sBxgY+;#SM7&dwuqPK_8r*|Jt`+6`fuE)4y_fouO5Sxq=J9yYDO4pa4Ya z4CbTMAI!~e-7gmAf+5D4Iv&<9BV3@SKLZX#gPu-j>WOrha2?VCDyn==*!xuf|8%XL z^sEc?U*dXeDNrGNdjyRNf@(ipXtT7f$NkAjcZ))#cIy@+q@A9w_SAf~A2^QY_lt{>eClwp!BJgdu^>do)GhqxOI&gH6Kgz)S*_qm~VrA z&~0^lEpnLE@w&PaRJU$G=W|`CHA#&PNl~>8&bH}#Uk}V`gzOW#5bT0#aTw|L>fZSa zU&saPE8IKeukZcn9U(vVypk+i!%=vIoC15)!?8{65bAD?5FWJ1iho|M9aM<7qs`|E zv}(x}U}UfS%wBnK)RB{Vp_JQtvF0WVYBnRw;UqO=snzH!JKO_z9yinGV?IqN7#Ni) z@isB_x=GQiXk|nM&E)&FTaNkWx?ttblCFK1bO(7fmCES)W?JQ&UUKiwdSR93a7h(8 zrEoq=sS|=mj?VGZdH)L+;+c3K0P&81@boK(BB8{12mNsepjGBK)s=U`JEp{I|@9Aq=RY4V^Cj8wSmfNEte(+Q<1~nwpA}_ zy?!k8wcI~2K_)elTElF2=QYX}_9Dw!3ys@o&X{WDw4%|>!J86EzZ8=Pr#gg=ceZzc znMSWsM`5LRM>gEUtPsEbMCD`paVP^LXFW%49Q*6MBvhK;aCFx$H=}qw5)zYO)A4fS zrH;~Ct*3|1LE|mR@ePG+Dh*5Jpw3~KJh6_}^Vu<}51YeqGA*;+) zPv=~Y+pX0=4-8dYdFfCx8CUfJ*V%qk3mQzM=_=Ex+kd zy@LpZxqGSt)jzpYBZ#&51S1)y>q=`r+v=m^L=huq&CeAWjHa}DA<1Duu%7x1fvqf^ zJs$D~Yc@yn2;*6Lz4ulwHHXpH-K86(tIX{#AI?2mQFI%X@FePxF7W0txCeR0`SJ^u z2Jn-WxzhZa)T9)anc9U-^vK>s_V(1MJo*r^S? zNv>oXE9qO7@5G&4@%<{;ezGzywNP-9zcXy&Q~KxHPHvrwkRI^N8^_mqVCedKn=1fT zMK1VT-G4uELSq1>3Nt5e8m;4&-{-YSG|YQ5cLqLm!soVG#3|Y0NK=k8rFKS7@FHoX zQM}gerfESrP}OESjs0#NSfSC_O;-{(HokK`99_rQLC$(5D_)g2T&I9P9iaxe8s8;| z19p7b^_neG`SPHU$}f}&Vh~*vw_CfL`ug;^KRR*db@oY zHvHqZU+7)6RjihoF^DsNuJ^?dj~mCOKtl*brjwGHwvO#_()W}xo-7ltwwTVGbNu}& z_bY~O{b-`L4vmR{a!;HChv@B?TjhmHAu6 z^IF5D1m*;q5oAq=qOS8>52ns*!eDa z`L|3^T}?OMxfUJ4nL7vR&XT8c2Vd>C7!^yqmI;lsUM71W27Pnj*geRK=C@y{?)vZA zmy#dSq+o=ip6lvhNn+u8TN{Q+eV%Q7^+oQ>JsuF!Nqm&a>A%#{5g)$kVgpR>fSz!< zdjqgRZsG5*o?c_XE}2CXG#irbG}b#UtJC}Der&Cwt5-uDx~pMrJLgTl-#l`VN4Hdm zP>JY_*=}_3kHeldvhk%RRaqb#DayMIa z7Av)MB7K#Uc%cRKDrHv;vr4k{h%jCDJDcUQ$Xn9x$x-v^)Spqg{HrH|{e^eu;g|2o zRsF`VJUk4BnH-dF9c#5lE$!%GlVzv%QF`oHNvG^G+GM z76y=Ot;2XD4}|tQb_Qj!uz0%{9$Oa7e9g5XA@%6qpvgOY4sPn!FmjF!JgC*yi&@%Q z@pNV=^9aNV2vYs8W z%A2`zsPF0-VukDVsbZ6#T>mla)Wabc*n5M|DN1eRbWL*EnxToCPRcp+(Rx0V_7-)p zd}#>HFDbQLtd06Ia(inw-x8yxXw(Xb2>3^4jfsnOgE>4}`uEAk&)W(Jzk4NK0ao~4 zQkj3e4w3D$9`L*~B_YezC_Ilc8!MMxLb2-Jfz%ypIPI|0QGXyd=K>9(rxvH$#f%$? zgpgTdMJCq9ayw_`sj=b1HWBRgPz^ToM;qVKD^2+c)4!2|2o^#T{r#2H+qNd;4s5WZ zMvoOG$=7u+>GC|UOR+vz_7l3f=^XuuktR-KqmWs;BAfkMt|YZRS8z#mIAT&s%t;7g zwd=#8ZL&jXv2&kEbDbjigdoyx-Zej~7UUI%Xf|QBh2NQ<&}Rx7JxV0e%a10*D>@c- zV-{mAn;}j;63?R9Pa|l<<5vAMo)(J4&bte}0z`|wK2$;A?-q>CoVwrYkmR>chOLbPKIl`9Grot~nI9s{gFiU(#$j+X&JTcstq_z$zr?G(aRxg^b^Tl{E zgodD8{c%j&-GbsYKyLI`Dt~3V{WabnXULEEpWg&JfLZtxA<|A?tqp2M84FQ~NDy_gEOyuSQNMJv~Y_|`#8dQAD4q{NwG^UqY&4yBM!R(*WPMd`^KNa)wdQI=W z0XO11%*17C^G4swXVbA<99g1EwT_{y3pA9{By((ci`U)xoGzIXpG#?;^Lp;Pkyc^{ zd1FxPb+9_^o68b;6F$!ntH}8OQcBQg0t4<(>{_`^{-?8qs>67m+w^p}kxBMuO6V2d z<$NR9ARYnGH%A;8I%v@i$Efk;_{a{nBVU!}?ZK1v5}L)H&g2~pZ9EO%1VK^qaoxm(a69HyK|l6mLITX08HtUptv!lH+;=wh+4*|PdAqfnKq(c- zfcj(%-8`I6hx6p{yojqR+Wk|G(8XbTqEqENg^fjVl&_^P`N8dut*B#Ciw(8vZ6-Bi z6Kdnmw7&8mHx|U4`*E3q_+q*5Ylq1VWVPhmKwzIXQD)XDW z@g+Z2OO7o)GLXCci3&i2x39}PkXI_4egWhP@|u0Od0QbhS!dl8ORDYC^Kv{s1P9I6 zz2m7(`h_cj(YOE0v{208i<%zr@VM8EN?CN!8sN25_=v+9GAs1-dSBN_q z@O*$!@b)CuE3@LHO;=L-G$JkdxYk{x^1)|`kC^5ox6Ri?yo2{^FIdHgCy+N9R=-e* z(eDLFZoNm+lIZ*r+(xy#bz-dL9ekBO&-P@BMh%|o*!sX-7t^XAflW_ z_3yE{0X-j)6O}7d^e1fe{ce*AYRgf`O_L+Wc8IBBy~fMNYiuqEJ~0n0_eRKS^KVMg z7g_$dbzkJ}eI*Oxu)nyqPPji3q5}29ZMCX3=d#j=!E{{I4LENCGr^Um8>VU2@RwsL z;H??0^HEguYrN5FJ9C{Dp}Chb?t1GZ&ubip6TUAnQY5D;j1^E#weg)Y`H5PmjF`_V zB;uHLH3sTQ9XYk%IkC<;L-l7J@(k}v9)Mkm;_tLbbQ{5}7S+oq7Y@vz((R^U&I~g6L4+L(8V!f?jA_thPS1Y6Tq(_K#tP zmt~+&`;RE`SN!o%V0xv*!@CtF?nK86FP6*=wMlvqa@T3H@dz&3++X*LZLkI9^t3-; zDA|dBsJ&)*NSJ+FO-0a7NT63xm5;J+zgJB8aZ@ljuEo0?n}ud7!~tZ9cFXQMEUj$; zGf-lsaE;;C)+DRDiAF8O&lA*E;ksyTS2og)F{ZSBpiar4=I^v@sE9qhx@6TJd^Qd~|KVfB$+l?_*) zABOA)@3lg8A;b&qqYe<>PNb^f!SSj7!e#Q%p7(_Yg{~94Jmw87gY3*rhSet? zqc^;GZHSVrD_NJ_`FoG%dJbH{K`v4AuEHigyO)GfljV|f#f{C9t_?beqh&DcDmAFR z?^P{OPgHsBpu8opov3uxO76Duvdb@s^H-|b_2dA7uCITgm?0uTGIB>s1`Bnbn~V}p zg{-R$ds%zv^J)N>3l>`wTeJ3iqB|~YQ|Jz{kn3?bt8KN#Vz3uy&=rW!jhJg#lE&LM z5#hV_mBA|Y@{_8MbhxC52S&fXwLmRSoJ22*1 zlLq`YlMH+i?fp&L>p0^i*);V1Gz;x%yE%azvNcE7Vj*-FA$9RgM7s1`(fg?>EV)M{C1t|aJ>Q7)wH@&UxpSxUUoCO znar^Lx|SXAX`xFCnUH5vu}Iv3G9=cRZmP3hwubIaJ-ttzb+(&D^DLoWZ0Y~6nZC)@ z|GsJKpRa%yghzM6*(VRD@oHAG0{z8F*o;Y9XPw(dMAe9NhyQoj-b)`N1l)FRh+T9gD5}V`x zbldDsg_)&|&GkNwn9(2|#f010&v#}39YuDKKwO&$>v1_4j~dgN3hnX=N@zuPDhM@9 zj;JnElu0BASK$sj{fSn8zEnnTYTucLNQ-|dX< zQ?>)DPX(YS0^a?~M+NeB>YhvxbVY_ix1CL$R-B~cer8Fr$MiizoMu^rAVWbnq;len zacqzujTT0PR6c-oCw7x1O#)|Sj|#$ZCl*cC_P0xZ+QP3!z9-u4T`=B|ZTP+RPRGk$Id5P>W8dt!VGGaHV8>5~_*5Lt zT1r=)ii3T=8E+fp&YC9M6j~CNhTd_u?NZuJbfPyO1#%DQn|5-osWcaQ_uF1nFDQ4B zUk?YNI)tc!(Gz70ckMecS;czk7(kf_?^=&Hh=`K6rz)-CCo8fw866r@&T?2MD>1nk zuMe)W+6#?CJXco<^agLM6cte;$=D1;V+ldx-GN=GH4HktjbYj%)}FK`yG^<2&Zsfg z9W7>!*@H_YsqC01UPH#&W%T=RnGHYzitzuHa3a4m?Gaz;9xiEhtX!#QK(NGzpBIculL#DTO~th@`xm zZguAvsLsF(aRq%kV8(TI7|>z9=!1VY@ds+46~N5;=MNt~c`(z^C#7SbsyOdm#(&%c z^cpxdv_>}X#r*kG=#B%)iq(&tTy2$1JgxV&WpxGh;vz<{FIL^JFX9tG*tpY+%Hw}` zEWgnEvUxbyCdH<<7#t~OXA+^)M zVWN|K|NPl)|MIFxJ%V%XsX7@&4Ot9})9wM<4wRjt66mPJ+`~+X&ojgwc~UY z;Ohh{T)Sw&OxAo^=q;%aJ^MtQUvh%29#;HKJ$Z40EC22(W8idDQH{;TxBusyd>4P* zf`0a=5!)WshSt!PRl`b83 z+idQ0mzhtCr8gWg_MCbI~e(d5wIhUPDvZB4MFZA&So)~tz<2PAPQJZ|! zkBlSR_;#e$e*!P+-a3WkdOQYw&pr8Kz(;oTx7_8k!w|Kz-3lhDXG3rIDyDx*`>KCZ zZ<1Z)zi$4HNb#nR^#lyjw1Qeu^Cxi&UEge85QnUj@3)NUK(9QBA4tt!yb7hQynv#_ zbv@sUrYVhbgBdYw;1NxBQ;*9Ck2P~Rx5nVUGFM6*mP@*`S{ohg@hSl)-78i^V(HDC zodiH3^x#h=kbcV2scndK+-pyAA>>n#Cc}9NDLI=tJ{friE(EDK;+r)l8l*~b zJOM_CKfU>5+yG|5aE)L;Ao>S)(KN7j&Gh*LbcM%Pi~3!H)n&TOM^!udYQO%XZu$}E z34v27&Z$DP0{H{G(+!!iOM2NTdJ)XfHMZI0xLyl6qaJG8anUdZGtuf1n^}W!7n!1r z4Q#xBq?1A-M!hvg@!i6+x9$%Jvhb_(ulabr6*X9JCTG1c^`Dd92b=OSzQKnnV zU=yVIUa~w#@sBt)#yc}dQ5R;RyKaz+6nDyDT(#K zc<``rr*4}0aN=`9(Hbq&kgApKJTW>%f)DrYEoNs{2Akjyj?xG`h>S z;}&Ev$7qsSbXp=^Q|YClm;F9RZ76ds+Q<5`3{;MoDm87rCpcahgU3OK>IUdF-5Ia+ zc6UPN7@?Qy;pY4Oq`pOU`qfE8YVg^v`SpbapwJ0}Kb6w^lbS|0gdG#?Hjp~mSi!{Y z4ra5-z}IJGePq_a`nTH|ahNo?k<>4jTXPZ0{tSkkvaIMX4QrCrq1O)W%;j0r@mNO= zcs8hNZZFE_XD`!>GxV7lIyy=(Sr0`-&n**vPmmM1iYTX-a0CF%Hy0ZDVJuTw*uwDP zTGDH@RW-Nc)Mk!3HF!1m77#dPTEe6dXqWanITTIpeOHk>gF|aSzl3WBzW9fQ*fg!AUv~G7rfO{$2_G`jZxUmp$pk`H{LXC z7|mNMRzs$8(t+%D?l3Lt0Va3T`9W0pLpke7^G976+>Re$9~mz#Z^RmJR{Wq~-U%SW z^!iY7*t_M7Q#$QrUSV@gCt+Z>NWFiFOJkLRfE2aUkZ@xh%dD9&=~}_{~<{v*mn+)(PST$ z7hwyi_(Dy|E(HCZ`F{a;K^FmsEk%%iIKl}Lm7TE3xV6pPFw;J(ayto{#V)ay<5QWKYM3#Du|SHKr~Gqz<*XszdP7F=!6)ac?&7D{ST-3VE9?vE?PIc!zB@G3<#+ zQA3({JL*-NYopFl=T{(P5tJYBoE@f8)QZ&^%)o9A%}v@>WM*!cVo^>^A1=tq$)J^m5WEs=lh1jrx3bR=r0m-Meyo zB38Y6Js-pB&}Rp@;>n8vdul=owEnU`D{|?)8QenTIsrV>?(_i11Qp?aE$E$EK`8BgGKLF&j49sX<@e+jV+{kNTRQ>OEgEG!m=tUac=cKO%AcMey~bGMcZ^ zL04{Rrp@JW)MKqclBO_$YP@XE z7WJ8$kS(Rfw1$ME4>rqYRw{u_B}K8HlmKZy;<>HIbx{7o!*dT3P`-cs(W`?F z#;&c!5)>O0Bnc)O+at#1VxKdfH_%*BTg_OgTj+6p%~W^uCU@vJhTV;?lFOlfT>4p1 zEE--2(Gxig35}IoTHz3N|Dk68I(6lRFudwSzun&xunJK$%cb&ad}l+DA92(g(;O#7 zF6SfySC>p-J;)TT17lKdtekqK9f0rc)vh27jeIjQcY#-}^aL8j4ubQ;A#6rm(qnpZ zBaX*8AB-q7At!Zj?+_z$r!GYXJTxWYSSq!fnjthOkMssp)>m@JnTKwj$iTHl`@W?0 z+Q)ixGn{3uV>ONBB(?7%A76>_wY~j7Ey!;r*>KrhwPDDg(yIpAfBx%1z^|PYn(sxY zCUG_3wX5xYu7iiUtJcxqKplotY;5P&{Ox*2m}%fxM=PR`xB%#PE^rtsh05=$50D%o zuU|qTF3Ynb!%wTEQlxRg=NI4kb8-)A@^%%+sHN7er_~kw`DQv%=yj;<4&N7E0Yrcc z$$sq>xPXK+b9o7}9RS^q%nNS-`Ozv!s*82ko7#G^Pxdsuihb87I4rsp$-D}ARmedo z?8Pk23lqTC?nag(y1tFmEAW8dtG6p&{s~uZQr{+|rgam!(G%rjacG9r057}rFK~T6 z3@^6s{&f6$>pnpS3_rb7IXmty>6aU+W#Pcs*46P~bkIA^kkD7n)oLmfX8UDf&S?wL zB0s5O0R7B$P!W5|8a-dX=dYkt$jGWHq0ggjE4I0CRkgZXF+6b0jiu0M@kL8JaogS3 zUTy4^tv(2d_$SX}H_oh${4v+`sPi#?g7;!)k=XcG?IId} zy|<5`VQU}X0I^aosgqq6XZ2-=&dr)+9XNbs=Uq) zp?d6L@sPG*McbEdzq=df*Ln=76Wx{RO5+#k(VE4hvl3b*~=Qf3A(htQJU;-jc=j(C{qQ8B3pj(^SGS<(g&H4Vh zxn;AHR{X?nC;#7xa=*-8MxfB?gFhe*kW2ZB=@Yw=A41^e1HP6FM~dU@;(=G2D#~t8 zjbIAjO&a7i<6{?nfUf(c1bb8V-a&-L-aY*&bt`{FQ*N*sJK9Su!~y#f6E>r!1Kn9> zw1e$^d}Y=8W5;5gmM3)Oma_qQM>RG@E9;wtI9^!!LEy@z(6hI-nJLW}anjg)7mr^@ zehw{!!Hs_!62F5qi;5Pn9TNy2Xoe2oupwv&b#Jd^%wL%6PjJt)d-$zi8SeF@WC@pR z+KN52M{$kl*n@Gc7i@UwUpAwL$`a=>pV5k(g}lMV1UiK$GYu*ux;5}(>7?4;)D3ai z?_gAC)1Z5iEv8kh{&H47>6Cw9i65R0)iD`R1Zv5uJnDxwR9EqwLwMyi$&dtn)3<#B zhUip5t&Z1EzRx7ao4qFV=w%KoB6Ai4D<2=&<t5X*L85hMIzFaC^C7&G@AM?!epJ1& zp<3}3TOsnj=`Q^Q6%pX^cdAo!XMa5jQY4ht4aasHb#W|@TK%NVq*k9>W*t|@BX7f5 zVQd@3P6_r2yPhAXHB*!Z1}1gtbDH1U{5W%%?h2PiyJmD${1z)sB2Voh?7w2Em&1yI zi|%y(Gakr)j&Ax_^tx+W|6BF*6Vw~MF27R+1AjU#!+J5yBie0ylairlYte0yb!;mK z9o*~YnYI>Hs%fY!ZBC&-pwfokV&k!*>K#&Kr{N&c$8$Wh38C9?dN2!T8}0e*F>Z8T z=cyU`)7{zxHQ-%lIUNfCc*7YPKNYBN?pbs^wrzhOu5q_DY3dDO-lBW8OA7h!_6E`1?oOPz*KxU)IuX(uu3K#(pj48Hl69ahMqV-r&0E;|$%_Bu z_~xmdD~eNJQT^u+%AP=S26VftwD{-GGs{>1<|I)*A1eE+Bmf8|T#xIobhLa2uqtB0 zUtlv7jrdw$L3HdNMRTB_xti_s_6Gj-veSbDmDVmX-h)sEoT&$cUt0Zb7sk^Z* zx;v7j@R{cJk4JTrilMwz#x9evg&q@QMfgrQ+cCHm&jfppLFC|>^z)AxZuwW-1={nw zL5Mquh%h(!$XD=f7=rx3#(daM7mge+aBd2-;g*w7Pt3sTuP$=rm3f`}k@=BFuUpO{ z74psa>J=VB-~tN?+?AxYlm0kb z$4!-SGFhRI8>S~pLykxnq$GA7qR$ZIwx;oEjJavAk)5^fQ+O4jdFf;HBoppf;@86P z0uSMOd0jc|z7v4t2PNk%saKoK8#8Pt8qFxKP0P9{*H*9Q8+>&KoV-cbo=Ycn^x~wd z{A5>TPs-LWrcOU}W_e+ZAtGIV;@5t#8&IIr?V%#n9m~Hk#{PfHA>^=p?WesF@{@qN zdN@CcZaAR9%K$l2o8GnIDq!bhA0TTJKzzgB!TSbL9t#?7`R?l>Fer=aU8(dLZngAJzg0CS_(@8&v%XPi4e0f=32U~m6#J-i z=(mbR-DTRvp^3MK1Gz7!Z9aEFG$h95MV@H_ADwwu!PaCOD;xg0& ze5dNUX$1d45n(mS2-3c;*9vl|zYdmHG6S6Dw`jFVew2(SyG_r1EI$ovG7O#Wb=g#i~3%d+-dqTddvVBk4 zyMQ~PTtNo;kNhCtD+QwFv69s65YsN3H|yNUWI-3!Buq@j9E+Jj*@QY{fl-81twEGq zj2$)E#Wn`iP*>wz=JExzVC3mwx>2Rz2w_gH`-mt+fnWN&Q8wM1V)2MzAr#TyDueDj zp@=qeAgxr=ZZE~9x@|ALmO9A{Lx13uqV4;B^FSN#FAsfh z#}P}*YRg+s+Q=EX-b(FNG0)u5fIK=wZFQ5CuhiLF?dsF1{fqL3Gc<(rsV4SUMGdvwgtY6>F}v&B^D7TP=Ns{tNC z$Iz>M_|L%x$4>3*g>`ZML;Rrn&dJ<5m2g~i(La9t;rNDrp7V`tr85;S5#z7)jswyy~=@f=S8Xx2ju=k-NI{6Hq!gvtX#N=xIQaTM-xLvjwBoidJv2+@)%#3$@|i a24k0m4(Uop(9RY4>TLWE!2W;#$NvE^T~iGJ diff --git a/cdn/package.json b/cdn/package.json deleted file mode 100644 index 22d6c8c25..000000000 --- a/cdn/package.json +++ /dev/null @@ -1,54 +0,0 @@ -{ - "name": "@fosscord/cdn", - "version": "1.0.0", - "description": "cdn for fosscord", - "main": "dist/index.js", - "types": "src/index.ts", - "scripts": { - "test": "npm run build && npx jest --coverage ./tests", - "build": "npx tsc -p .", - "start": "node dist/start.js" - }, - "repository": { - "type": "git", - "url": "git+https://github.com/fosscord/fosscord-server.git" - }, - "keywords": [], - "author": "Fosscord", - "license": "AGPL-3.0-only", - "bugs": { - "url": "https://github.com/fosscord/fosscord-server/issues" - }, - "homepage": "https://github.com/fosscord/fosscord-server#readme", - "devDependencies": { - "@types/body-parser": "^1.19.0", - "@types/dotenv": "^8.2.0", - "@types/express": "^4.17.12", - "@types/multer": "^1.4.7", - "@types/node": "^18.6.3" - }, - "dependencies": { - "@aws-sdk/client-s3": "^3.137.0", - "@fosscord/util": "file:../util", - "@types/node-fetch": "^2.6.2", - "body-parser": "^1.19.0", - "dotenv": "^16.0.1", - "exif-be-gone": "^1.3.0", - "express": "^4.17.1", - "file-type": "16.5", - "image-size": "^1.0.0", - "jest": "^28.1.3", - "lambert-server": "^1.2.12", - "multer": "^1.4.5-lts.1", - "node-fetch": "^2.6.7", - "picocolors": "^1.0.0", - "supertest": "^6.1.6", - "typescript": "^4.1.2" - }, - "jest": { - "setupFilesAfterEnv": [ - "/jest/setup.js" - ], - "verbose": true - } -} diff --git a/cdn/tsconfig.json b/cdn/tsconfig.json deleted file mode 100644 index 85b35f557..000000000 --- a/cdn/tsconfig.json +++ /dev/null @@ -1,81 +0,0 @@ -{ - "include": ["src/**/*.ts"], - "compilerOptions": { - /* Visit https://aka.ms/tsconfig.json to read more about this file */ - - /* Basic Options */ - "incremental": false /* Enable incremental compilation */, - "target": "ES6" /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */, - "module": "commonjs" /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */, - "lib": [ - "ES2021", - "dom" - ] /* Specify library files to be included in the compilation. */, - "allowJs": true /* Allow javascript files to be compiled. */, - "checkJs": true /* Report errors in .js files. */, - // "jsx": "preserve", /* Specify JSX code generation: 'preserve', 'react-native', or 'react'. */ - "declaration": true /* Generates corresponding '.d.ts' file. */, - "declarationMap": false /* Generates a sourcemap for each corresponding '.d.ts' file. */, - "inlineSourceMap": true /* Emit a single file with source maps instead of having a separate file. */, - "sourceMap": true /* Generates corresponding '.map' file. */, - // "outFile": "./", /* Concatenate and emit output to single file. */ - "outDir": "./dist/" /* Redirect output structure to the directory. */, - "rootDir": "./src/" /* Specify the root directory of input files. Use to control the output directory structure with --outDir. */, - // "composite": true, /* Enable project compilation */ - // "tsBuildInfoFile": "./", /* Specify file to store incremental compilation information */ - // "removeComments": true, /* Do not emit comments to output. */ - // "noEmit": true, /* Do not emit outputs. */ - // "importHelpers": true, /* Import emit helpers from 'tslib'. */ - // "downlevelIteration": true, /* Provide full support for iterables in 'for-of', spread, and destructuring when targeting 'ES5' or 'ES3'. */ - // "isolatedModules": true, /* Transpile each file as a separate module (similar to 'ts.transpileModule'). */ - - /* Strict Type-Checking Options */ - "strict": true /* Enable all strict type-checking options. */, - "noImplicitAny": true /* Raise error on expressions and declarations with an implied 'any' type. */, - // "strictNullChecks": true, /* Enable strict null checks. */ - // "strictFunctionTypes": true, /* Enable strict checking of function types. */ - // "strictBindCallApply": true, /* Enable strict 'bind', 'call', and 'apply' methods on functions. */ - "strictPropertyInitialization": false /* Enable strict checking of property initialization in classes. */, - // "noImplicitThis": true, /* Raise error on 'this' expressions with an implied 'any' type. */ - "alwaysStrict": true /* Parse in strict mode and emit "use strict" for each source file. */, - - /* Additional Checks */ - // "noUnusedLocals": true, /* Report errors on unused locals. */ - // "noUnusedParameters": true, /* Report errors on unused parameters. */ - // "noImplicitReturns": true, /* Report error when not all code paths in function return a value. */ - // "noFallthroughCasesInSwitch": true, /* Report errors for fallthrough cases in switch statement. */ - - /* Module Resolution Options */ - // "moduleResolution": "node", /* Specify module resolution strategy: 'node' (Node.js) or 'classic' (TypeScript pre-1.6). */ - // "baseUrl": "./", /* Base directory to resolve non-absolute module names. */ - // "paths": {}, /* A series of entries which re-map imports to lookup locations relative to the 'baseUrl'. */ - // "rootDirs": [], /* List of root folders whose combined content represents the structure of the project at runtime. */ - // "typeRoots": [], /* List of folders to include type definitions from. */ - "types": [ - "node" - ] /* Type declaration files to be included in compilation. */, - // "allowSyntheticDefaultImports": true, /* Allow default imports from modules with no default export. This does not affect code emit, just typechecking. */ - "esModuleInterop": true /* Enables emit interoperability between CommonJS and ES Modules via creation of namespace objects for all imports. Implies 'allowSyntheticDefaultImports'. */, - // "preserveSymlinks": true, /* Do not resolve the real path of symlinks. */ - // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ - - /* Source Map Options */ - // "sourceRoot": "", /* Specify the location where debugger should locate TypeScript files instead of source locations. */ - // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ - // "inlineSources": true, /* Emit the source alongside the sourcemaps within a single file; requires '--inlineSourceMap' or '--sourceMap' to be set. */ - - /* Experimental Options */ - "experimentalDecorators": true, /* Enables experimental support for ES7 decorators. */ - // "emitDecoratorMetadata": true, /* Enables experimental support for emitting type metadata for decorators. */ - - /* Advanced Options */ - "skipLibCheck": true /* Skip type checking of declaration files. */, - "forceConsistentCasingInFileNames": true /* Disallow inconsistently-cased references to the same file. */, - "baseUrl": ".", - "paths": { - "@fosscord/cdn": ["src/index"], - "@fosscord/cdn/*": ["src/*"] - }, - "plugins": [{ "transform": "@ovos-media/ts-transform-paths" }] - } -} diff --git a/dashboard/README.md b/dashboard/README.md deleted file mode 100644 index df1157a1e..000000000 --- a/dashboard/README.md +++ /dev/null @@ -1,12 +0,0 @@ -# Fosscord-dashboard - -A admin dashboard for fosscord-server - -## (planned) Features - -- [ ] Overview usage (registered users, concurrent connections, voice usage, reports) -- [ ] Reports -- [ ] Member managment (edit (disable, delete, premium, username, discriminator)) -- [ ] Configuration ([Config.ts](https://github.com/fosscord/fosscord-server-util/blob/master/src/util/Config.ts)) - -port = 3005 diff --git a/dashboard/package-lock.json b/dashboard/package-lock.json deleted file mode 100644 index 4d56041e1b70d383bdedc5e3a88ec0482a33819d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 88 zcmb>CQczIJOUzAGvQkh=Ni5Dt%1 diff --git a/dashboard/package.json b/dashboard/package.json deleted file mode 100644 index 87bc16991..000000000 --- a/dashboard/package.json +++ /dev/null @@ -1,23 +0,0 @@ -{ - "name": "@fosscord/dashboard", - "version": "1.0.0", - "description": "Dashboard for Fosscord", - "main": "dist/index.js", - "types": "src/index.ts", - "scripts": { - "test": "npm run build && npx jest --coverage ./tests", - "build": "npx tsc -p .", - "start": "node dist/start.js" - }, - "repository": { - "type": "git", - "url": "git+https://github.com/fosscord/fosscord-server.git" - }, - "keywords": [], - "author": "Fosscord", - "license": "AGPL-3.0-only", - "bugs": { - "url": "https://github.com/fosscord/fosscord-server/issues" - }, - "homepage": "https://github.com/fosscord/fosscord-server#readme" -} diff --git a/dashboard/src/index.ts b/dashboard/src/index.ts deleted file mode 100644 index e69de29bb..000000000 diff --git a/gateway/.env.example b/gateway/.env.example deleted file mode 100644 index 0224de64a..000000000 --- a/gateway/.env.example +++ /dev/null @@ -1,4 +0,0 @@ -MONGO_URL=mongodb://localhost/fosscord -PORT=3002 -PRODUCTION=TRUE -THREADS=# automatically use all available cores, only available if production = true \ No newline at end of file diff --git a/gateway/.gitignore b/gateway/.gitignore deleted file mode 100644 index daf8591a1..000000000 --- a/gateway/.gitignore +++ /dev/null @@ -1,107 +0,0 @@ -# Logs -logs -*.log -npm-debug.log* -yarn-debug.log* -yarn-error.log* -lerna-debug.log* - -# Diagnostic reports (https://nodejs.org/api/report.html) -report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json - -# Runtime data -pids -*.pid -*.seed -*.pid.lock - -# Directory for instrumented libs generated by jscoverage/JSCover -lib-cov - -# Coverage directory used by tools like istanbul -coverage -*.lcov - -# nyc test coverage -.nyc_output - -# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files) -.grunt - -# Bower dependency directory (https://bower.io/) -bower_components - -# node-waf configuration -.lock-wscript - -# Compiled binary addons (https://nodejs.org/api/addons.html) -build/Release - -# Dependency directories -node_modules/ -jspm_packages/ - -# TypeScript v1 declaration files -typings/ - -# TypeScript cache -*.tsbuildinfo - -# Optional npm cache directory -.npm - -# Optional eslint cache -.eslintcache - -# Microbundle cache -.rpt2_cache/ -.rts2_cache_cjs/ -.rts2_cache_es/ -.rts2_cache_umd/ - -# Optional REPL history -.node_repl_history - -# Output of 'npm pack' -*.tgz - -# Yarn Integrity file -.yarn-integrity - -# dotenv environment variables file -.env -.env.test - -# parcel-bundler cache (https://parceljs.org/) -.cache - -# Next.js build output -.next - -# Nuxt.js build / generate output -.nuxt -dist - -# Gatsby files -.cache/ -# Comment in the public line in if your project uses Gatsby and *not* Next.js -# https://nextjs.org/blog/next-9-1#public-directory-support -# public - -# vuepress build output -.vuepress/dist - -# Serverless directories -.serverless/ - -# FuseBox cache -.fusebox/ - -# DynamoDB Local files -.dynamodb/ - -# TernJS port file -.tern-port -.DS_Store - -data \ No newline at end of file diff --git a/gateway/.swcrc b/gateway/.swcrc deleted file mode 100644 index e8cbb8a13..000000000 --- a/gateway/.swcrc +++ /dev/null @@ -1,16 +0,0 @@ -{ - "module": { - "type": "commonjs" - }, - "jsc": { - "parser": { - "syntax": "typescript", - "decorators": true - }, - "target": "es5", - "baseUrl": ".", - "paths": { - "@fosscord/gateway": ["src/index"] - } - } -} diff --git a/gateway/.vscode/launch.json b/gateway/.vscode/launch.json deleted file mode 100644 index 29bdde138..000000000 --- a/gateway/.vscode/launch.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - // 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": [ - { - "sourceMaps": true, - "type": "node", - "request": "launch", - "name": "Launch Server", - "program": "${workspaceFolder}/dist/start.js", - "preLaunchTask": "tsc: build - tsconfig.json", - "outFiles": ["${workspaceFolder}/dist/**/*.js"] - } - ] -} diff --git a/gateway/Dockerfile b/gateway/Dockerfile deleted file mode 100644 index e07b7d8ff..000000000 --- a/gateway/Dockerfile +++ /dev/null @@ -1,14 +0,0 @@ -FROM node:lts-alpine -WORKDIR /usr/src/fosscord-gateway -COPY package.json . -COPY package-lock.json . -RUN apk --no-cache --virtual build-dependencies add \ - python \ - make \ - g++ -RUN npm install -RUN apk del build-dependencies -COPY . . -RUN npm run build -EXPOSE 3002 -CMD ["node", "dist/start.js"] diff --git a/gateway/README.md b/gateway/README.md deleted file mode 100644 index 959d0d5be..000000000 --- a/gateway/README.md +++ /dev/null @@ -1,42 +0,0 @@ -

- - - - - - - - -

D`dD)0P_v? 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 { missing: [], using: [], }; - x = JSON.parse(execIn("npx depcheck --json", partDir).stdout); + let dcproc = execIn("npx depcheck --json", partDir); + if(dcproc.stdout) x = JSON.parse(dcproc.stdout); + else x = JSON.parse(dcproc); fs.writeFileSync( path.join(__dirname, "..", `depclean.out.${part}.json`), diff --git a/cdn/package.json b/cdn/package.json index 4ee0be6a8..22d6c8c25 100644 --- a/cdn/package.json +++ b/cdn/package.json @@ -30,7 +30,6 @@ "dependencies": { "@aws-sdk/client-s3": "^3.137.0", "@fosscord/util": "file:../util", - "@ovos-media/ts-transform-paths": "^1.7.18-1", "@types/node-fetch": "^2.6.2", "body-parser": "^1.19.0", "dotenv": "^16.0.1", diff --git a/package-lock.json b/package-lock.json index 48f8206d6dd579df9a23e2383db6bebe965f0471..b76df0eed9b6b8a8dab66936d4a84602d7b6abbc 100644 GIT binary patch delta 1127 zcmX@M(_qzZgAM29r{9WX;@a-3%~8+T+^yK&t;o2&TaigeYkR6M(*|v(y!`2bGVEg0 z6&^CPOn1;?)t@d<&cw-CQlPJ^pO;@!Fum~@vudbUXmVJjpJhmHxq)L=zGGThR&h?S zNk&qcv1M9-Q&Ln)T8WdlagwP)x@ncZOKyfwaj98yib1Hqt5arRsc(6uky~a_afX|b zd$wh|V_8~wR&j>!^gw$i#pw+#Ol;E+WHND0x6fu$+AdnjG*h5mznck&nYZhAv+yot zHcCsJzHvW`#B`fkochxz=(4g30ENH~Oi9%RGIfonKL}$|4h;y*Nh$Kr$STc`s?4uU z@h$TWPA9%W*?E(;gHcN>&O=aYlLudIm~5T%16lgd%DT6D`TeEGntg zEh*0j=`aLpFq-TbDKdSV7`M=5gL>ZS_CSAZx6xtMJAONxrp zoSn5TEBqbP1B0U?ii`a+EzOLw3rxM8aw~zc8_%M`s!(R2XEwR9S*|_BoE3=Kwx^i0 zbAF!gwv$72@&U!R?bg~HiY43kE#UaBF`x;ik&j(=dcqnGM1tX)eqk#I`}VCTIkxh* z&%eb1#GKpb-{J~U8|YL6cPlkh4a@YY9ZYiD1sJ*AIEhI$VKhlKf$g4L+}l05cxr_J DFiC8P delta 1112 zcmZ3r+u+zvgAM29werjIi*<8TQ!*3vONw<%iW2jR)AEaQbqf+pGK!U~6qMo&_007Q zEp!d18~$b#-kzt;QP0>Mq1Yaw$hbX1kx55O2A>hr4Skr!S-}QOpUBNh6`zhsYew<4zqW5>x4vlZp4Qj79) za!Lz8F33pDDM&3s_WtyP){JV?cbc*Zuo?ry!)UUigY5PeZ>9~}+v6&jW(x2+AnTug zuaaGw4dU*}fhqcG$dXXQA%2B&AbyB0s3y#KI-9%rqsqEXmW=!o?`n zF`ytK!mFapyL@sZyTWwdY;Jx=qv;cmFlwNBMW+3G2NMu8Z~xxG!n<(#{dOkV>6R}! zji(0~v$9V2XXIWw{X;Di=QJZAFJBKx{9@#OH2HVG*!DVIRu#_no#w1S%(i`}IXlN^ z9lUXjlBSe&CKoC$+8(3Lp;$8X)6w+6jcl^=SmGMV&q~|#=5w%VZtp$Gv6X+Yr<&;# zKd{M6KUc%eKK;RJR*vb)lFUNwPB%G#m~*?+O|B5Nt-rXFIoqwcxwl(!^ArdH0F;P& A!vFvP From d52d9c62fc30e31e2c01bf6b63f9aedebdde216f Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Mon, 8 Aug 2022 04:27:28 +0200 Subject: [PATCH 171/238] Bunch of fixes and improvements, everything appears to work now --- api/src/middlewares/TestClient.ts | 19 +- api/src/routes/channels/#channel_id/index.ts | 4 +- .../routes/channels/#channel_id/invites.ts | 2 +- .../#channel_id/messages/#message_id/ack.ts | 2 +- .../routes/channels/#channel_id/recipients.ts | 2 +- api/src/routes/guilds/#guild_id/bans.ts | 4 +- api/src/routes/guilds/#guild_id/emojis.ts | 4 +- api/src/routes/guilds/#guild_id/index.ts | 2 +- .../#guild_id/members/#member_id/index.ts | 2 +- .../guilds/#guild_id/roles/#role_id/index.ts | 2 +- .../routes/guilds/#guild_id/roles/index.ts | 2 +- api/src/routes/guilds/#guild_id/stickers.ts | 4 +- api/src/routes/guilds/#guild_id/templates.ts | 6 +- api/src/routes/guilds/#guild_id/vanity-url.ts | 2 +- .../#guild_id/voice-states/#user_id/index.ts | 4 +- api/src/routes/guilds/templates/index.ts | 6 +- api/src/routes/users/@me/index.ts | 6 +- api/src/routes/users/@me/relationships.ts | 10 +- api/src/util/handlers/Message.ts | 8 +- bundle/package-lock.json | Bin 103377 -> 702083 bytes bundle/package.json | 53 +++- cdn/tsconfig.json | 2 +- gateway/src/events/Connection.ts | 15 ++ gateway/src/events/Message.ts | 26 +- gateway/src/opcodes/Heartbeat.ts | 2 +- gateway/src/opcodes/Identify.ts | 2 +- gateway/src/opcodes/LazyRequest.ts | 5 +- gateway/src/opcodes/VoiceStateUpdate.ts | 4 +- gateway/src/util/Send.ts | 2 + gateway/tsconfig.json | 2 +- util/src/entities/BaseClass.ts | 21 +- util/src/entities/Channel.ts | 11 +- util/src/entities/Config.ts | 2 + util/src/entities/Guild.ts | 10 +- util/src/entities/Member.ts | 10 +- util/src/entities/User.ts | 6 +- .../1659921859145-premium_since_as_date.ts | 26 ++ .../1659921826567-premium_since_as_date.ts | 26 ++ .../1659921722863-premium_since_as_date.ts | 252 ++++++++++++++++++ util/src/util/BitField.ts | 3 + 40 files changed, 490 insertions(+), 81 deletions(-) create mode 100644 util/src/migrations/mariadb/1659921859145-premium_since_as_date.ts create mode 100644 util/src/migrations/postgres/1659921826567-premium_since_as_date.ts create mode 100644 util/src/migrations/sqlite/1659921722863-premium_since_as_date.ts diff --git a/api/src/middlewares/TestClient.ts b/api/src/middlewares/TestClient.ts index 167b4c47c..4fe631cb5 100644 --- a/api/src/middlewares/TestClient.ts +++ b/api/src/middlewares/TestClient.ts @@ -5,6 +5,7 @@ import fetch, { Response as FetchResponse, Headers } from "node-fetch"; import ProxyAgent from 'proxy-agent'; import { Config } from "@fosscord/util"; import { AssetCacheItem } from "../util/entities/AssetCacheItem" +import { green } from "picocolors"; export default function TestClient(app: Application) { const agent = new ProxyAgent(); @@ -18,11 +19,16 @@ export default function TestClient(app: Application) { //load asset cache let newAssetCache: Map = new Map(); - if(!fs.existsSync(path.join(__dirname, "..", "..", "assets", "cache"))) { - fs.mkdirSync(path.join(__dirname, "..", "..", "assets", "cache")); + let assetCacheDir = path.join(__dirname, "..", "..", "assets", "cache"); + if(process.env.ASSET_CACHE_DIR) + assetCacheDir = process.env.ASSET_CACHE_DIR + + console.log(`[TestClient] ${green(`Using asset cache path: ${assetCacheDir}`)}`) + if(!fs.existsSync(assetCacheDir)) { + fs.mkdirSync(assetCacheDir); } - if(fs.existsSync(path.join(__dirname, "..", "..", "assets", "cache", "index.json"))) { - let rawdata = fs.readFileSync(path.join(__dirname, "..", "..", "assets", "cache", "index.json")); + if(fs.existsSync(path.join(assetCacheDir, "index.json"))) { + let rawdata = fs.readFileSync(path.join(assetCacheDir, "index.json")); newAssetCache = new Map(Object.entries(JSON.parse(rawdata.toString()))); } @@ -39,6 +45,7 @@ export default function TestClient(app: Application) { }); } else { + console.log(`[TestClient] Downloading file not yet cached! Asset file: ${req.params.file}`); response = await fetch(`https://discord.com/assets/${req.params.file}`, { agent, // @ts-ignore @@ -49,11 +56,11 @@ export default function TestClient(app: Application) { //set cache info assetCacheItem.Headers = Object.fromEntries(stripHeaders(response.headers)); - assetCacheItem.FilePath = path.join(__dirname, "..", "..", "assets", "cache", req.params.file); + assetCacheItem.FilePath = path.join(assetCacheDir, req.params.file); assetCacheItem.Key = req.params.file; //add to cache and save newAssetCache.set(req.params.file, assetCacheItem); - fs.writeFileSync(path.join(__dirname, "..", "..", "assets", "cache", "index.json"), JSON.stringify(Object.fromEntries(newAssetCache), null, 4)); + fs.writeFileSync(path.join(assetCacheDir, "index.json"), JSON.stringify(Object.fromEntries(newAssetCache), null, 4)); //download file fs.writeFileSync(assetCacheItem.FilePath, await response.buffer()); } diff --git a/api/src/routes/channels/#channel_id/index.ts b/api/src/routes/channels/#channel_id/index.ts index a49081efb..4001b8345 100644 --- a/api/src/routes/channels/#channel_id/index.ts +++ b/api/src/routes/channels/#channel_id/index.ts @@ -77,8 +77,8 @@ router.patch("/", route({ body: "ChannelModifySchema", permission: "MANAGE_CHANN const { channel_id } = req.params; if (payload.icon) payload.icon = await handleFile(`/channel-icons/${channel_id}`, payload.icon); - const channel = await Channel.findOneOrFail({ where: { id: channel_id } }); - channel.assign(payload); + let channel = await Channel.findOneOrFail({ where: { id: channel_id } }); + channel = Object.assign(channel, payload); await Promise.all([ channel.save(), diff --git a/api/src/routes/channels/#channel_id/invites.ts b/api/src/routes/channels/#channel_id/invites.ts index 6155ef7d7..4e97b275e 100644 --- a/api/src/routes/channels/#channel_id/invites.ts +++ b/api/src/routes/channels/#channel_id/invites.ts @@ -33,7 +33,7 @@ router.post("/", route({ body: "InviteCreateSchema", permission: "CREATE_INSTANT const expires_at = new Date(req.body.max_age * 1000 + Date.now()); - const invite = await new Invite({ + const invite = await Object.assign(new Invite(),{ code: random(), temporary: req.body.temporary, uses: 0, diff --git a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts index c14addbe9..fc2ec4880 100644 --- a/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts +++ b/api/src/routes/channels/#channel_id/messages/#message_id/ack.ts @@ -20,7 +20,7 @@ router.post("/", route({ body: "MessageAcknowledgeSchema" }), async (req: Reques permission.hasThrow("VIEW_CHANNEL"); let read_state = await ReadState.findOne({ where: { user_id: req.user_id, channel_id } }); - if (!read_state) read_state = new ReadState({ where: { user_id: req.user_id, channel_id } }); + if (!read_state) read_state = Object.assign(new ReadState(), { user_id: req.user_id, channel_id }); read_state.last_message_id = message_id; await read_state.save(); diff --git a/api/src/routes/channels/#channel_id/recipients.ts b/api/src/routes/channels/#channel_id/recipients.ts index 28d5607d4..d6e25599d 100644 --- a/api/src/routes/channels/#channel_id/recipients.ts +++ b/api/src/routes/channels/#channel_id/recipients.ts @@ -28,7 +28,7 @@ router.put("/:user_id", route({}), async (req: Request, res: Response) => { throw DiscordApiErrors.INVALID_RECIPIENT; //TODO is this the right error? } - channel.recipients!.push(new Recipient({ channel_id, user_id: user_id })); + channel.recipients!.push(Object.assign(new Recipient(), { channel_id, user_id: user_id })); await channel.save(); await emitEvent({ diff --git a/api/src/routes/guilds/#guild_id/bans.ts b/api/src/routes/guilds/#guild_id/bans.ts index 128ff2501..5ff639581 100644 --- a/api/src/routes/guilds/#guild_id/bans.ts +++ b/api/src/routes/guilds/#guild_id/bans.ts @@ -90,7 +90,7 @@ router.put("/:user_id", route({ body: "BanCreateSchema", permission: "BAN_MEMBER const banned_user = await User.getPublicUser(banned_user_id); - const ban = new Ban({ + const ban = Object.assign(new Ban(),{ user_id: banned_user_id, guild_id: guild_id, ip: getIpAdress(req), @@ -122,7 +122,7 @@ router.put("/@me", route({ body: "BanCreateSchema"}), async (req: Request, res: if (req.permission!.cache.guild?.owner_id === req.params.user_id) throw new HTTPError("You are the guild owner, hence can't ban yourself", 403); - const ban = new Ban({ + const ban = Object.assign(new Ban(), { user_id: req.params.user_id, guild_id: guild_id, ip: getIpAdress(req), diff --git a/api/src/routes/guilds/#guild_id/emojis.ts b/api/src/routes/guilds/#guild_id/emojis.ts index c4bcadf77..3e2ed4c20 100644 --- a/api/src/routes/guilds/#guild_id/emojis.ts +++ b/api/src/routes/guilds/#guild_id/emojis.ts @@ -50,7 +50,7 @@ router.post("/", route({ body: "EmojiCreateSchema", permission: "MANAGE_EMOJIS_A const user = await User.findOneOrFail({ where: { id: req.user_id } }); body.image = (await handleFile(`/emojis/${id}`, body.image)) as string; - const emoji = await new Emoji({ + const emoji = await Object.assign(new Emoji(), { id: id, guild_id: guild_id, ...body, @@ -80,7 +80,7 @@ router.patch( const { emoji_id, guild_id } = req.params; const body = req.body as EmojiModifySchema; - const emoji = await new Emoji({ ...body, id: emoji_id, guild_id: guild_id }).save(); + const emoji = await Object.assign(new Emoji(), { ...body, id: emoji_id, guild_id: guild_id }).save(); await emitEvent({ event: "GUILD_EMOJIS_UPDATE", diff --git a/api/src/routes/guilds/#guild_id/index.ts b/api/src/routes/guilds/#guild_id/index.ts index 263579e75..643db7ce2 100644 --- a/api/src/routes/guilds/#guild_id/index.ts +++ b/api/src/routes/guilds/#guild_id/index.ts @@ -59,7 +59,7 @@ router.patch("/", route({ body: "GuildUpdateSchema"}), async (req: Request, res: relations: ["emojis", "roles", "stickers"] }); // TODO: check if body ids are valid - guild.assign(body); + guild = Object.assign(guild, body); //TODO: check this, removed toJSON call const data = JSON.parse(JSON.stringify(guild)); diff --git a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts index 2717ec2ad..eb31ec1d5 100644 --- a/api/src/routes/guilds/#guild_id/members/#member_id/index.ts +++ b/api/src/routes/guilds/#guild_id/members/#member_id/index.ts @@ -31,7 +31,7 @@ router.patch("/", route({ body: "MemberChangeSchema" }), async (req: Request, re permission.hasThrow("MANAGE_ROLES"); if (body.roles.indexOf(everyone.id) === -1) body.roles.push(everyone.id); - member.roles = body.roles.map((x) => new Role({ id: x })); // foreign key constraint will fail if role doesn't exist + member.roles = body.roles.map((x) => Object.assign(new Role(), { id: x })); // foreign key constraint will fail if role doesn't exist } await member.save(); diff --git a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts index af04fd066..a4b91237e 100644 --- a/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/#role_id/index.ts @@ -43,7 +43,7 @@ router.patch("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" } if (body.icon) body.icon = await handleFile(`/role-icons/${role_id}`, body.icon as string); - const role = new Role({ + const role = Object.assign(new Role(), { ...body, id: role_id, guild_id, diff --git a/api/src/routes/guilds/#guild_id/roles/index.ts b/api/src/routes/guilds/#guild_id/roles/index.ts index d2d14122a..7e588d524 100644 --- a/api/src/routes/guilds/#guild_id/roles/index.ts +++ b/api/src/routes/guilds/#guild_id/roles/index.ts @@ -51,7 +51,7 @@ router.post("/", route({ body: "RoleModifySchema", permission: "MANAGE_ROLES" }) if (role_count > maxRoles) throw DiscordApiErrors.MAXIMUM_ROLES.withParams(maxRoles); - const role = new Role({ + let role: Role = Object.assign(new Role(),{ // values before ...body are default and can be overriden position: 0, hoist: false, diff --git a/api/src/routes/guilds/#guild_id/stickers.ts b/api/src/routes/guilds/#guild_id/stickers.ts index 7913539be..c6a5037f7 100644 --- a/api/src/routes/guilds/#guild_id/stickers.ts +++ b/api/src/routes/guilds/#guild_id/stickers.ts @@ -43,7 +43,7 @@ router.post( const id = Snowflake.generate(); const [sticker] = await Promise.all([ - new Sticker({ + Object.assign(new Sticker(), { ...body, guild_id, id, @@ -105,7 +105,7 @@ router.patch( const { guild_id, sticker_id } = req.params; const body = req.body as ModifyGuildStickerSchema; - const sticker = await new Sticker({ ...body, guild_id, id: sticker_id }).save(); + const sticker = await Object.assign(new Sticker(), { ...body, guild_id, id: sticker_id }).save(); await sendStickerUpdateEvent(guild_id); return res.json(sticker); diff --git a/api/src/routes/guilds/#guild_id/templates.ts b/api/src/routes/guilds/#guild_id/templates.ts index f2de46e46..edff67171 100644 --- a/api/src/routes/guilds/#guild_id/templates.ts +++ b/api/src/routes/guilds/#guild_id/templates.ts @@ -47,7 +47,7 @@ router.post("/", route({ body: "TemplateCreateSchema", permission: "MANAGE_GUILD const exists = await Template.findOneOrFail({ where: { id: guild_id } }).catch((e) => {}); if (exists) throw new HTTPError("Template already exists", 400); - const template = await new Template({ + const template = await Object.assign(new Template(), { ...req.body, code: generateCode(), creator_id: req.user_id, @@ -75,7 +75,7 @@ router.put("/:code", route({ permission: "MANAGE_GUILD" }), async (req: Request, const { code, guild_id } = req.params; const guild = await Guild.findOneOrFail({ where: { id: guild_id }, select: TemplateGuildProjection }); - const template = await new Template({ code, serialized_source_guild: guild }).save(); + const template = await Object.assign(new Template(), { code, serialized_source_guild: guild }).save(); res.json(template); }); @@ -84,7 +84,7 @@ router.patch("/:code", route({ body: "TemplateModifySchema", permission: "MANAGE const { code, guild_id } = req.params; const { name, description } = req.body; - const template = await new Template({ code, name: name, description: description, source_guild_id: guild_id }).save(); + const template = await Object.assign(new Template(), { code, name: name, description: description, source_guild_id: guild_id }).save(); res.json(template); }); diff --git a/api/src/routes/guilds/#guild_id/vanity-url.ts b/api/src/routes/guilds/#guild_id/vanity-url.ts index b4d9f6186..426559bdc 100644 --- a/api/src/routes/guilds/#guild_id/vanity-url.ts +++ b/api/src/routes/guilds/#guild_id/vanity-url.ts @@ -47,7 +47,7 @@ router.patch("/", route({ body: "VanityUrlSchema", permission: "MANAGE_GUILD" }) const { id } = await Channel.findOneOrFail({ where: { guild_id, type: ChannelType.GUILD_TEXT } }); - await new Invite({ + await Object.assign(new Invite(), { vanity_url: true, code: code, temporary: false, diff --git a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts index 37ea52b58..5900963e9 100644 --- a/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts +++ b/api/src/routes/guilds/#guild_id/voice-states/#user_id/index.ts @@ -33,7 +33,7 @@ router.patch("/", route({ body: "VoiceStateUpdateSchema" }), async (req: Request if (!body.suppress) body.request_to_speak_timestamp = new Date(); if (body.request_to_speak_timestamp) perms.hasThrow("REQUEST_TO_SPEAK"); - const voice_state = await VoiceState.findOne({ + let voice_state = await VoiceState.findOne({ where: { guild_id, channel_id: body.channel_id, @@ -42,7 +42,7 @@ router.patch("/", route({ body: "VoiceStateUpdateSchema" }), async (req: Request }); if (!voice_state) throw DiscordApiErrors.UNKNOWN_VOICE_STATE; - voice_state.assign(body); + voice_state = Object.assign(voice_state, body); const channel = await Channel.findOneOrFail({ where: { guild_id, id: body.channel_id } }); if (channel.type !== ChannelType.GUILD_STAGE_VOICE) { throw DiscordApiErrors.CANNOT_EXECUTE_ON_THIS_CHANNEL_TYPE; diff --git a/api/src/routes/guilds/templates/index.ts b/api/src/routes/guilds/templates/index.ts index e2242ebfd..bb8cc017c 100644 --- a/api/src/routes/guilds/templates/index.ts +++ b/api/src/routes/guilds/templates/index.ts @@ -57,13 +57,13 @@ router.post("/:code", route({ body: "GuildTemplateCreateSchema" }), async (req: const guild_id = Snowflake.generate(); const [guild, role] = await Promise.all([ - new Guild({ + Object.assign(new Guild(), { ...body, ...template.serialized_source_guild, id: guild_id, owner_id: req.user_id }).save(), - new Role({ + (Object.assign(new Role(), { id: guild_id, guild_id: guild_id, color: 0, @@ -74,7 +74,7 @@ router.post("/:code", route({ body: "GuildTemplateCreateSchema" }), async (req: permissions: BigInt("2251804225"), position: 0, tags: null - }).save() + }) as Role).save() ]); await Member.addToGuild(req.user_id, guild_id); diff --git a/api/src/routes/users/@me/index.ts b/api/src/routes/users/@me/index.ts index 924996890..6a2456d6b 100644 --- a/api/src/routes/users/@me/index.ts +++ b/api/src/routes/users/@me/index.ts @@ -32,9 +32,7 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: const body = req.body as UserModifySchema; if (body.avatar) body.avatar = await handleFile(`/avatars/${req.user_id}`, body.avatar as string); - if (body.banner) body.banner = await handleFile(`/banners/${req.user_id}`, body.banner as string); - - const user = await User.findOneOrFail({ where: { id: req.user_id }, select: [...PrivateUserProjection, "data"] }); + if (body.banner) body.banner = await handleFile(`/banners/${req.user_id}`, body.banner as string);let user = await User.findOneOrFail({ where: { id: req.user_id }, select: [...PrivateUserProjection, "data"] }); if (body.password) { if (user.data?.hash) { @@ -65,7 +63,7 @@ router.patch("/", route({ body: "UserModifySchema" }), async (req: Request, res: } } - user.assign(body); + user = Object.assign(user, body); await user.save(); // @ts-ignore diff --git a/api/src/routes/users/@me/relationships.ts b/api/src/routes/users/@me/relationships.ts index 0509b0acd..014a5bd20 100644 --- a/api/src/routes/users/@me/relationships.ts +++ b/api/src/routes/users/@me/relationships.ts @@ -140,7 +140,7 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ relationship.type = RelationshipType.blocked; await relationship.save(); } else { - relationship = await new Relationship({ to_id: id, type: RelationshipType.blocked, from_id: req.user_id }).save(); + relationship = await Object.assign(new Relationship(), { to_id: id, type: RelationshipType.blocked, from_id: req.user_id }).save(); } if (friendRequest && friendRequest.type !== RelationshipType.blocked) { @@ -166,8 +166,8 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ const { maxFriends } = Config.get().limits.user; if (user.relationships.length >= maxFriends) throw DiscordApiErrors.MAXIMUM_FRIENDS.withParams(maxFriends); - let incoming_relationship = new Relationship({ nickname: undefined, type: RelationshipType.incoming, to: user, from: friend }); - let outgoing_relationship = new Relationship({ + let incoming_relationship = Object.assign(new Relationship(), { nickname: undefined, type: RelationshipType.incoming, to: user, from: friend }); + let outgoing_relationship = Object.assign(new Relationship(), { nickname: undefined, type: RelationshipType.outgoing, to: friend, @@ -178,7 +178,7 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ if (friendRequest.type === RelationshipType.blocked) throw new HTTPError("The user blocked you"); if (friendRequest.type === RelationshipType.friends) throw new HTTPError("You are already friends with the user"); // accept friend request - incoming_relationship = friendRequest; + incoming_relationship = friendRequest as any; //TODO: checkme, any cast incoming_relationship.type = RelationshipType.friends; } @@ -186,7 +186,7 @@ async function updateRelationship(req: Request, res: Response, friend: User, typ if (relationship.type === RelationshipType.outgoing) throw new HTTPError("You already sent a friend request"); if (relationship.type === RelationshipType.blocked) throw new HTTPError("Unblock the user before sending a friend request"); if (relationship.type === RelationshipType.friends) throw new HTTPError("You are already friends with the user"); - outgoing_relationship = relationship; + outgoing_relationship = relationship as any; //TODO: checkme, any cast outgoing_relationship.type = RelationshipType.friends; } diff --git a/api/src/util/handlers/Message.ts b/api/src/util/handlers/Message.ts index 7035bc5cc..34fb3d05c 100644 --- a/api/src/util/handlers/Message.ts +++ b/api/src/util/handlers/Message.ts @@ -47,7 +47,7 @@ export async function handleMessage(opts: MessageOptions): Promise { const channel = await Channel.findOneOrFail({ where: { id: opts.channel_id }, relations: ["recipients"] }); if (!channel || !opts.channel_id) throw new HTTPError("Channel not found", 404); - const message = new Message({ + const message = Object.assign(new Message(), { ...opts, sticker_items: opts.sticker_ids?.map((x) => ({ id: x })), guild_id: channel.guild_id, @@ -132,9 +132,9 @@ export async function handleMessage(opts: MessageOptions): Promise { } } - message.mention_channels = mention_channel_ids.map((x) => new Channel({ id: x })); - message.mention_roles = mention_role_ids.map((x) => new Role({ id: x })); - message.mentions = mention_user_ids.map((x) => new User({ id: x })); + message.mention_channels = mention_channel_ids.map((x) => Object.assign(new Channel(), { id: x })); + message.mention_roles = mention_role_ids.map((x) => Object.assign(new Role(), { id: x })); + message.mentions = mention_user_ids.map((x) => Object.assign(new User(), { id: x })); message.mention_everyone = mention_everyone; // TODO: check and put it all in the body diff --git a/bundle/package-lock.json b/bundle/package-lock.json index 5c7aa2ba754b2a83f4b2d30f35889132f4f2eee2..f6cbc82b1d7754664104f7c1597333417a2ef25b 100644 GIT binary patch literal 702083 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%0A~ejJ>e<=Br=oI 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