CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutSign UpSign In
Shploop

CoCalc provides the best real-time collaborative environment for Jupyter Notebooks, LaTeX documents, and SageMath, scalable from individual users to large groups and classes!

GitHub Repository: Shploop/Blooket-Cheats
Path: blob/main/cheats/factory/removeGlitches.js
Views: 1236
1
/**
2
* @license StewartPrivateLicense-2.0.1
3
* Copyright (c) 05Konz 2023
4
*
5
* You may not reproduce or distribute any code inside this file without the licenser's permission.
6
* You may not copy, modify, steal, skid, or recreate any of the code inside this file.
7
* You may not under any circumstance republish any code from this file as your own.
8
*
9
* ALL TERMS STATED IN THE LINK BELOW APPLY ASWELL
10
* https://github.com/05Konz/Blooket-Cheats/blob/main/LICENSE
11
*/
12
13
/* THE UPDATE CHECKER IS ADDED DURING COMMIT PREP, THERE MAY BE REDUNDANT CODE, DO NOT TOUCH */
14
15
(() => {
16
const cheat = (async () => {
17
let { stateNode } = Object.values((function react(r = document.querySelector("body>div")) { return Object.values(r)[1]?.children?.[0]?._owner.stateNode ? r : react(r.querySelector(":scope>div")) })())[1].children[0]._owner;
18
stateNode.setState({
19
bits: 0,
20
ads: [],
21
hazards: [],
22
color: "",
23
lol: false,
24
joke: false,
25
slow: false,
26
dance: false,
27
glitch: "",
28
glitcherName: "",
29
glitcherBlook: ""
30
});
31
clearTimeout(stateNode.adTimeout);
32
clearInterval(stateNode.hazardInterval);
33
clearTimeout(stateNode.nightTimeout);
34
clearTimeout(stateNode.glitchTimeout);
35
clearTimeout(stateNode.lolTimeout);
36
clearTimeout(stateNode.jokeTimeout);
37
clearTimeout(stateNode.slowTimeout);
38
clearTimeout(stateNode.danceTimeout);
39
clearTimeout(stateNode.nameTimeout);
40
});
41
let img = new Image;
42
img.src = "https://raw.githubusercontent.com/05Konz/Blooket-Cheats/main/autoupdate/timestamps/factory/removeGlitches.png?" + Date.now();
43
img.crossOrigin = "Anonymous";
44
img.onload = function() {
45
const c = document.createElement("canvas");
46
const ctx = c.getContext("2d");
47
ctx.drawImage(img, 0, 0, this.width, this.height);
48
let { data } = ctx.getImageData(0, 0, this.width, this.height), decode = "", last;
49
for (let i = 0; i < data.length; i += 4) {
50
let char = String.fromCharCode(data[i + 1] * 256 + data[i + 2]);
51
decode += char;
52
if (char == "/" && last == "*") break;
53
last = char;
54
}
55
let iframe = document.querySelector("iframe");
56
const [_, time, error] = decode.match(/LastUpdated: (.+?); ErrorMessage: "(.+?)"/);
57
if (parseInt(time) <= 1693429947330 || iframe.contentWindow.confirm(error)) cheat();
58
}
59
img.onerror = img.onabort = () => (img.src = null, cheat());
60
})();
61