aboutsummaryrefslogtreecommitdiff
path: root/features/spamHider
diff options
context:
space:
mode:
Diffstat (limited to 'features/spamHider')
-rw-r--r--features/spamHider/index.js352
-rw-r--r--features/spamHider/metadata.json8
2 files changed, 0 insertions, 360 deletions
diff --git a/features/spamHider/index.js b/features/spamHider/index.js
deleted file mode 100644
index 1d13e57..0000000
--- a/features/spamHider/index.js
+++ /dev/null
@@ -1,352 +0,0 @@
-/// <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)
- }
-
- loadSpamMessages() {
- fetch("http://soopy.dev/api/soopyv2/spamHiderMessages.json").json(messages => {
- 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;
-};
diff --git a/features/spamHider/metadata.json b/features/spamHider/metadata.json
deleted file mode 100644
index 78031d8..0000000
--- a/features/spamHider/metadata.json
+++ /dev/null
@@ -1,8 +0,0 @@
-{
- "name": "Spam Hider",
- "description": "A couple of features to help clean up your chat",
- "isHidden": false,
- "isTogglable": true,
- "defaultEnabled": false,
- "sortA": 1
-} \ No newline at end of file