diff options
author | Soopyboo32 <49228220+Soopyboo32@users.noreply.github.com> | 2022-09-17 19:39:05 +0800 |
---|---|---|
committer | Soopyboo32 <49228220+Soopyboo32@users.noreply.github.com> | 2022-09-17 19:39:05 +0800 |
commit | 431e4fc9d1657a50ebc34b8ac24f9bfaea06417f (patch) | |
tree | 5987bb14f38d2999c682970429f34b41eb3e5826 /src/features/spamHider/index.js | |
parent | e73f2efdf0f50aa775c540317394d46428e9704f (diff) | |
download | SoopyV2-431e4fc9d1657a50ebc34b8ac24f9bfaea06417f.tar.gz SoopyV2-431e4fc9d1657a50ebc34b8ac24f9bfaea06417f.tar.bz2 SoopyV2-431e4fc9d1657a50ebc34b8ac24f9bfaea06417f.zip |
Initial move to babel + change fetch to use async/await
Diffstat (limited to 'src/features/spamHider/index.js')
-rw-r--r-- | src/features/spamHider/index.js | 351 |
1 files changed, 351 insertions, 0 deletions
diff --git a/src/features/spamHider/index.js b/src/features/spamHider/index.js new file mode 100644 index 0000000..697e571 --- /dev/null +++ b/src/features/spamHider/index.js @@ -0,0 +1,351 @@ +/// <reference types="../../../../CTAutocomplete" /> +/// <reference lib="es2015" /> +import SoopyContentChangeEvent from "../../../guimanager/EventListener/SoopyContentChangeEvent"; +import Feature from "../../featureClass/class"; +import soopyV2Server from "../../socketConnection"; +import { fetch } from "../../utils/networkUtils"; +import ToggleSetting from "../settings/settingThings/toggle"; + +class SpamHider extends Feature { + constructor() { + super() + } + + onEnable() { + this.initVariables() + + this.hideMessages = [] + this.hideMessagesRexex = [] + this.moveMessages = [] + this.moveMessagesRexex = [] + + this.moveMessagesDict = { + all: [] + } + this.hideMessagesDict = { + all: [] + } + + this.hideMessagesSetting = new ToggleSetting("Hide some messages", "This will completely remove some spammy messages from chat", true, "completely_hide_spam", this) + this.moveMessagesSetting = new ToggleSetting("Move some messages to spam hider", "This will move some (potentially) usefull messages into a 'second chat'", true, "move_spam", this) + this.moveChatMessages = new ToggleSetting("Move spammed chat messages to spam hider", "This will move messages spammed in hubs to spam hider\n(eg the website advertisment bots)", true, "move_spam_chat", this) + this.textShadowSetting = new ToggleSetting("Spam Hider Text Shadow", "Whether to give the spam hider text shadow", true, "spam_text_shadow", this) + this.showFriendMessages = new ToggleSetting("Show friend message", "should it show friend join/leave message", false, "spam_text_friend", this) + this.showGuildMessages = new ToggleSetting("Show guild message", "should it show guild mate join/leave message", false, "spam_text_guild", this) + this.showPetLevelUpMessage = new ToggleSetting("Show pet level message", "should it show pet level up message", false, "spam_text_pet_level", this) + this.removeBlocksInTheWay = new ToggleSetting("Remove limited tp msg", "completely erases 'There are blocks in the way!' message from gui", false, "limited_tp_msg", this) + this.showAutoPetRule = new ToggleSetting("Show autopet rule", "Should it show autopet rule messages", false, "autopet_msg", this) + + this.SpamHiderMessagesRenderer = new SpamHiderMessagesRenderer() + this.textShadowSetting.toggleObject.addEvent(new SoopyContentChangeEvent().setHandler((newVal, oldVal, resetFun) => { + this.SpamHiderMessagesRenderer.textShadow = this.textShadowSetting.getValue() + })) + + this.loadSpamMessages() + + this.registerChat("${*}", this.onChat) + + this.registerEvent("renderOverlay", this.renderOverlay).registeredWhen(() => this.moveMessagesSetting.getValue()) + + // this.registerChat("&r${userandrank}&r&f: ${message}&r", this.chatPlayerMessage) + } + + // chatPlayerMessage(userandrank, message, e){ + // if(!this.FeatureManager.features["generalSettings"]) return + // if(userandrank.includes(">")) return + // if(message.length < 10) return //Short messages like 'LOL' are bound to get repeated + + // let msg = sha256(message + "This is a salt PogU") + + // if(soopyV2Server.spammedMessages.includes(msg)){ + // if(this.moveChatMessages.getValue()){ + // this.SpamHiderMessagesRenderer.addMessage(ChatLib.getChatMessage(e, true)) + // cancel(e) + // } + // return + // } + + // if(this.FeatureManager.features["generalSettings"].class.sendChatSetting && this.FeatureManager.features["generalSettings"].class.sendChatSetting.getValue()){ + // soopyV2Server.sendMessageToServer(msg, sha256(this.FeatureManager.features["dataLoader"].class.stats["Server"] + "This is a salt PogU")) + // } + // } + + onChat(e) { + let msg = ChatLib.getChatMessage(e, true).replace(/ยง/g, "&").replace(/(?:^&r)|(?:&r$)/g, "") + if (msg.length > 1000) return //performance + + //&r&aFriend > &r&6Soopyboo32 &r&ejoined.&r + if (this.showFriendMessages.getValue() && msg.includes("&aFriend")) return + + //&r&2Guild > &r&6Soopyboo32 &r&ejoined.&r + if (this.showGuildMessages.getValue() && msg.includes("&2Guild")) return + + //&r&aYour &r&6Golden Dragon &r&alevelled up to level &r&9200&r&a!&r + if (this.showPetLevelUpMessage.getValue() && msg.includes("&alevelled up")) return + + //&r&cThere are blocks in the way!&r + //completely erases this + if (this.removeBlocksInTheWay.getValue() && msg.includes("There are blocks in the way!")) { + cancel(e) + return + } + + //&cAutopet &eequipped your &7[Lvl 200] &6Golden Dragon&e! &a&lVIEW RULE&r + if (this.showAutoPetRule.getValue() && msg.includes("&cAutopet")) return + + if (this.hideMessagesSetting.getValue()) { + // console.log("testing " + (this.hideMessagesDict[msg.substring(0,5)]?.length || 0) + this.hideMessagesDict.all.length + " hide messages") + this.hideMessagesDict[msg.substring(0, 5)]?.forEach(regex => { + if (regex.test(msg)) { + cancel(e) + return + } + }) + this.hideMessagesDict.all.forEach(regex => { + if (regex.test(msg)) { + cancel(e) + return + } + }) + } + + if (this.moveMessagesSetting.getValue()) { + // console.log("testing " + (this.moveMessagesDict[msg.substring(0,5)]?.length || 0) + this.moveMessagesDict.all.length + " spam messages") + this.moveMessagesDict[msg.substring(0, 5)]?.forEach(regex => { + if (regex.test(msg)) { + this.SpamHiderMessagesRenderer.addMessage(msg) + cancel(e) + return + } + }) + this.moveMessagesDict.all.forEach(regex => { + if (regex.test(msg)) { + this.SpamHiderMessagesRenderer.addMessage(msg) + cancel(e) + return + } + }) + } + } + renderOverlay() { //TODO: move this to java + this.SpamHiderMessagesRenderer.render(100, 100, 1, 1) + } + + async loadSpamMessages() { + let messages = await fetch("http://soopy.dev/api/soopyv2/spamHiderMessages.json").json() + this.hideMessages = messages.hideMessages + this.moveMessages = messages.moveMessages + + this.hideMessagesDict = { + all: [] + } + + this.hideMessagesRexex = [] + this.hideMessages.forEach(message => { + let regex = new RegExp(message.replace(/[\\^$*+?.()|[\]{}]/g, '$&') + .replace(/\$\{\*\}/g, "(?:.+)")) + if (!message.substring(0, 5).includes("$")) { + if (!this.hideMessagesDict[message.substring(0, 5)]) this.hideMessagesDict[message.substring(0, 5)] = [] + this.hideMessagesDict[message.substring(0, 5)].push(regex) + } else { + this.hideMessagesDict.all.push(regex) + } + this.hideMessagesRexex.push(regex) + }) + + this.moveMessagesDict = { + all: [] + } + + this.moveMessagesRexex = [] + this.moveMessages.forEach(message => { + let regex = new RegExp(message.replace(/[\\^$*+?.()|[\]{}]/g, '$&') + .replace(/\$\{\*\}/g, "(?:.+)")) + + if (!message.substring(0, 5).includes("$")) { + if (!this.moveMessagesDict[message.substring(0, 5)]) this.moveMessagesDict[message.substring(0, 5)] = [] + this.moveMessagesDict[message.substring(0, 5)].push(regex) + } else { + this.moveMessagesDict.all.push(regex) + } + this.moveMessagesRexex.push(regex) + }) + } + + initVariables() { + this.hideMessages = undefined + this.hideMessagesRexex = undefined + this.moveMessages = undefined + this.moveMessagesRexex = undefined + this.SpamHiderMessagesRenderer = undefined + } + + onDisable() { + this.initVariables() + } +} + +class SpamHiderMessagesRenderer { + constructor() { + this.messages = [] + this.x = 0 //offset from corner, not absolute location + this.y = 0 //offset from corner, not absolute location + this.scale = 1 + this.corner = 2 + + this.lastRender = 0 + + this.textShadow = true + } + + addMessage(str) { + this.messages.push([str, Date.now(), this.y]) + } + + render() { + Renderer.drawString("", -100, -100)//Fixes skytils issue //idk if this is still needed, it was in old code and imma just leave it ig + + let now = Date.now() + let animDiv = (now - this.lastRender) / 1000 + this.lastRender = now + let swidth = Renderer.screen.getWidth() + let sheight = Renderer.screen.getHeight() + + //loop over all messages backwards + for (let i = this.messages.length - 1; i >= 0; i--) { + let message = this.messages[i] + + let [str, time, height] = message + + time = now - time + + let messageWidth = Renderer.getStringWidth(ChatLib.removeFormatting(str)) + + let x = 0; + let y = 0; + if (this.corner === 0) { //top left + x = 20 + this.messages[i][2] = height + (((this.messages.length - i) * -10) - height) * (animDiv * 5) + } + if (this.corner === 1) { //top right + x = swidth - 20 - messageWidth + this.messages[i][2] = height + (((this.messages.length - i) * -10) - height) * (animDiv * 5) + } + if (this.corner === 2) { //bottom right + x = swidth - 20 - messageWidth + this.messages[i][2] = height + (((this.messages.length - i) * 10) - height) * (animDiv * 5) + } + + let animOnOff = 0 + if (time < 500) { + animOnOff = 1 - (time / 500) + } + if (time > 3500) { + animOnOff = ((time - 3500) / 500) + } + + animOnOff *= 90 + animOnOff += 90 + + animOnOff = animOnOff * Math.PI / 180; + + animOnOff = Math.sin(animOnOff) + + animOnOff *= -1 + animOnOff += 1 + + if (this.corner === 0) { //top left + x += ((animOnOff * -1) * (messageWidth + 30)) + y = 30 - (height) + } + if (this.corner === 1) { //top right + x += (animOnOff * (messageWidth + 30)) + y = 30 - (height) + } + if (this.corner === 2) { //bottom right + x += (animOnOff * (messageWidth + 30)) + y = sheight - 30 - (height) + } + + if (this.textShadow) { + Renderer.drawStringWithShadow(str, x + this.x, y + this.y); + } else { + Renderer.drawString(str, x + this.x, y + this.y); + } + + if (time > 4000) { + this.messages.shift() + } + } + } +} + +module.exports = { + class: new SpamHider() +} + +var sha256 = function a(b) { + function c(a, b) { + return (a >>> b) | (a << (32 - b)); + } + for ( + var d, + e, + f = Math.pow, + g = f(2, 32), + h = "length", + i = "", + j = [], + k = 8 * b[h], + l = (a.h = a.h || []), + m = (a.k = a.k || []), + n = m[h], + o = {}, + p = 2; + 64 > n; + p++ + ) + if (!o[p]) { + for (d = 0; 313 > d; d += p) o[d] = p; + (l[n] = (f(p, 0.5) * g) | 0), (m[n++] = (f(p, 1 / 3) * g) | 0); + } + for (b += "\x80"; (b[h] % 64) - 56;) b += "\x00"; + for (d = 0; d < b[h]; d++) { + if (((e = b.charCodeAt(d)), e >> 8)) return; + j[d >> 2] |= e << (((3 - d) % 4) * 8); + } + for (j[j[h]] = (k / g) | 0, j[j[h]] = k, e = 0; e < j[h];) { + var q = j.slice(e, (e += 16)), + r = l; + for (l = l.slice(0, 8), d = 0; 64 > d; d++) { + var s = q[d - 15], + t = q[d - 2], + u = l[0], + v = l[4], + w = + l[7] + + (c(v, 6) ^ c(v, 11) ^ c(v, 25)) + + ((v & l[5]) ^ (~v & l[6])) + + m[d] + + (q[d] = + 16 > d + ? q[d] + : (q[d - 16] + + (c(s, 7) ^ c(s, 18) ^ (s >>> 3)) + + q[d - 7] + + (c(t, 17) ^ c(t, 19) ^ (t >>> 10))) | + 0), + x = + (c(u, 2) ^ c(u, 13) ^ c(u, 22)) + + ((u & l[1]) ^ (u & l[2]) ^ (l[1] & l[2])); + (l = [(w + x) | 0].concat(l)), (l[4] = (l[4] + w) | 0); + } + for (d = 0; 8 > d; d++) l[d] = (l[d] + r[d]) | 0; + } + for (d = 0; 8 > d; d++) + for (e = 3; e + 1; e--) { + var y = (l[d] >> (8 * e)) & 255; + i += (16 > y ? 0 : "") + y.toString(16); + } + return i; +}; |