From be94dbbc6c7a26f5cf44408c25ce1072c3c4f675 Mon Sep 17 00:00:00 2001 From: Vendicated Date: Sat, 1 Oct 2022 17:04:57 +0200 Subject: [PATCH] Fix NitroBypass --- src/plugins/nitroBypass.ts | 36 +++++++++++++++++++++++++----------- 1 file changed, 25 insertions(+), 11 deletions(-) diff --git a/src/plugins/nitroBypass.ts b/src/plugins/nitroBypass.ts index ebed095b9..cd7770432 100644 --- a/src/plugins/nitroBypass.ts +++ b/src/plugins/nitroBypass.ts @@ -2,9 +2,10 @@ import { addPreSendListener, addPreEditListener, SendListener, removePreSendList import { findByProps } from "../webpack"; import definePlugin from "../utils/types"; import { Devs } from '../utils/constants'; +import { UserStore } from '../webpack/common'; export default definePlugin({ - name: "Nitro Bypass", + name: "NitroBypass", authors: [Devs.Arjix], description: "Allows you to stream in nitro quality and send fake emojis.", dependencies: ["MessageEventsAPI"], @@ -22,21 +23,33 @@ export default definePlugin({ }; }) }, + { + find: "STREAM_FPS_OPTION.format", + replacement: { + match: /(userPremiumType|guildPremiumTier):.{0,10}TIER_\d,?/g, + replace: "" + } + } ], + get guildId() { + return window.location.href.split("channels/")[1].split("/")[0]; + }, + + get canUseEmotes() { + return Boolean(UserStore.getCurrentUser().premiumType); + }, + start() { + if (this.canUseEmotes) { + console.info("[NitroBypass] Skipping start because you have nitro"); + return; + } + const { getCustomEmojiById } = findByProps("getCustomEmojiById"); - // Remove any nitro requirements for any of the streaming settings. - findByProps("ApplicationStreamPresets") - .ApplicationStreamSettingRequirements - .forEach(x => { - delete x.userPremiumType; - delete x.guildPremiumTier; - }); - this.preSend = addPreSendListener((_, messageObj) => { - const guildId = window.location.href.split("channels/")[1].split("/")[0]; + const guildId = this.guildId; for (const emoji of messageObj.validNonShortcutEmojis) { if (!emoji.require_colons) continue; if (emoji.guildId === guildId && !emoji.animated) continue; @@ -46,8 +59,9 @@ export default definePlugin({ messageObj.content = messageObj.content.replace(emojiString, ` ${url} `); } }); + this.preEdit = addPreEditListener((_, __, messageObj) => { - const guildId = window.location.href.split("channels/")[1].split("/")[0]; + const guildId = this.guildId; for (const [emojiStr, _, emojiId] of messageObj.content.matchAll(/(?/ig)) { const emoji = getCustomEmojiById(emojiId);