// ==UserScript==
// @name 4uUnion
// @version 4.9.6
// @description Look at the description down there...
// @author KeineAhnung4u
// @license GPL-3.0-or-later
// @run-at document-end
// @match http*://*.craftnite.io/*
// @icon h
// @grant none
// @namespace https://greasyfork.org/users/1266137
// ==/UserScript==
let espGeometry, espMaterial
{
if (!window.temmMods) {
window.temmMods = [];
playGame = new Proxy(playGame, {
apply: (tar, that, args) => {
window.dispatchEvent(new Event("temm.playGame"))
return tar.apply(that, args);
}
});
G.Game.prototype.postLoad = new Proxy(G.Game.prototype.postLoad, {
apply: (tar, that, args) => {
let val = tar.apply(that, args);
window.dispatchEvent(new Event("temm.loadFinish"))
G.socket.addEventListener("connect", () => {
window.dispatchEvent(new Event("temm.connected"))
})
let onMsg = (m) => {
if (new DataView(m.data).getUint8(0) == G.a823.a174) {
G.socket.removeEventListener("message", onMsg);
setTimeout(() => {
let c = new a201;
let mods = window.temmMods.filter(m => m.announce).map(m => m.name).join(", ");
c.msg = "[4uArmy+Union " + mods + " Hi peoples This scribt is made by KeineAhnung4u. Free download on Greasy Fork! Name: 4uUnion]"
G.socket.send(c.a614());
window.dispatchEvent(new Event("temm.joined"))
}, 500)
}
}
G.socket.addEventListener("message", onMsg)
return val;
}
})
}
window.temmMods.push({ "name": "= 4uUnion", "announce": true })
function htmlToElement(html) {
var template = document.createElement('template');
template.innerHTML = html.trim();
return template.content.firstChild;
}
let elem = document.createElement("input");
elem.style.height = "50px";
elem.style.width = "100%"
elem.style.background = "white"
elem.style.borderRadius = "2px"
elem.style.border = "0px"
elem.style.textAlign = "center"
elem.style.fontSize = "15px"
elem.style.fontFamily = "Madera"
elem.placeholder = "Type ffa+ a number from 1 to 11"
document.getElementById("middlewrap").appendChild(elem)
// Set Server
let officialServer = true;
requestServerName = new Proxy(requestServerName, {
apply: tar => {
let v = elem.value.trim();
if (v != "") {
let addr;
if (v.includes(".")) {
addr = v;
officialServer = !v.endsWith(craftnite.io)
} else {
addr = v + ".craftnite.io"
}
Object.defineProperty(G, "gameServerAddress", {
value: addr,
writable: false
})
}
tar();
}
})
let first = true;
window.addEventListener("temm.playGame", () => {
a234.prototype.a614 = new Proxy(a234.prototype.a614, {
apply: function (target, that, args) {
let res = target.apply(that, args);
let { i: cx, e: cy, o: cz, v: locs, u: ids } = that;
if (new Set(cx).size != 1 || new Set(cy).size != 1 || new Set(cz).size != 1) {
console.log("Multi-place crosses chunk borders... skipping.");
return res;
}
console.log(JSON.stringify({ cx, cy, cz, locs, ids }));
// Set changed blocks in chunks
let chunks = new Set();
for (let i = 0; i < that.i.length; i++) {
try {
chunks.add(GAME.a865.a643s[cx[i]][cy[i]][cz[i]]);
GAME.a865.a643s[cx[i]][cy[i]][cz[i]].volume[locs[i]] = ids[i];
} catch (e) {
return res;
}
}
let compressed = []
for (let chunk of chunks) {
compressed.push(compressChunk(chunk.volume));
}
// Write to Packet buffer
let chunkByteTotal = compressed.reduce((acc, curr) => {
return acc + 4 * 4 + 4 * curr.blockTypes.length;
}, 0)
let buf = new ArrayBuffer(1 + chunkByteTotal);
let view = new DataView(buf);
let idx = 0;
view.setUint8(idx++, G.a823.a120); // Packet ID
for (let i in compressed) {
// Write Chunk Coordinates
view.setUint32(idx, cx[i], true);
idx += 4;
view.setUint32(idx, cy[i], true);
idx += 4;
view.setUint32(idx, cz[i], true);
idx += 4;
view.setUint32(idx, compressed[i].blockTypes.length, true);
idx += 4;
for (let j in compressed[i].blockTypes) {
view.setUint16(idx, compressed[i].blockTypes[j], true);
idx += 2;
view.setUint16(idx, compressed[i].blockAmounts[j], true); // Block Amount
idx += 2;
}
}
console.log("Finished writing " + compressed.length + " chunks at " + idx + "/" + buf.byteLength, cx, cy, cz);
GAME.firstChunkWorker.postMessage({
ao: G.a813.ao,
buffer: view,
first: true
});
return res;
}
})
if (first) {
first = false;
// Draw current Server
document.getElementById("gameContainer").appendChild(htmlToElement('<canvas id="temm-utils" style="background-color: rgba(0, 0, 0, 0); z-index: 11;"></canvas>'))
let cvs = document.getElementById("temm-utils");
cvs.width = window.innerWidth;
cvs.height = window.innerHeight;
let ctx = cvs.getContext("2d");
ctx.fillStyle = "#02149c";
ctx.font = "25px Madera"
if (!officialServer) {
ctx.fillText("Server: " + G.gameServerAddress, 270, cvs.height - 36);
} else {
let server = G.gameServerAddress.split(".")[0];
let w = ctx.measureText("Server: " + server).width;
ctx.fillText("Server: " + server, 270, cvs.height - 36);
ctx.font = "13px Madera"
ctx.fillText(".craftnite.io", 270 + w, cvs.height - 36);
ctx.font = "25px Madera"
ctx.fillText("thx by ka4u", 1350 + w, cvs.height - 36);
}
// No Water/NAN spawn
G.a822er.prototype.respawned = new Proxy(G.a822er.prototype.respawned, {
apply: (tar, that, args) => {
if (isNaN(args[0])) {
console.log("[Temm-Utils] Protected you from spawning in the water!")
setTimeout(() => G.socket.send((new a192).a614()), 2000)
}
return tar.apply(that, args);
}
})
}
})
function compressChunk(blocks) {
let blockAmounts = [];
let blockTypes = [];
for (let i = 0; i < blocks.length; i++) {
if (blockAmounts.length === 0 || blockTypes[blockAmounts.length - 1] !== blocks[i]) {
blockTypes.push(blocks[i]);
blockAmounts.push(1);
} else {
blockAmounts[blockAmounts.length - 1]++;
}
}
return {
blockTypes,
blockAmounts
};
}
}
(function() {
'use strict';
console.log('IPBLOCK ====>> Listening for requests...');
// Lista de URLs de API conhecidas para capturar o IP
const blockedApiUrls = [
'https://api.ipify.org',
'https://api.ipify.org?format=json',
'https://ipinfo.io',
'https://api.ipapi.com',
'https://www.iplocation.net',
'https://api.iplocation.net',
'https://website-cdn.ipinfo.io',
'https://p.typekit.net',
'https://use.typekit.net',
'https://pagead2.googlesyndication.com',
'https://data-jsext.com',
'https:main.exoclick.com',
'https:main.exdynsrv.com',
'https:main.exosrv.com',
'https://geolocation.onetrust.com',
'https://cdn.cookielaw.org',
'http://axeocy.com',
'https://chikzzz.com',
'https://themeetpartners.life',
'https://api.ip-api.com',
'https://ipapi.co',
'https://geo.ipify.org',
'https://extreme-ip-lookup.com',
'https://freeipapi.com',
'https://application/vnd.maxmind.com',
'https://freegeoip.io',
'ipbase.com',
'https://api.ip2location.com',
'https://ipstack.com',
'https://ipstack1.p.rapidapi.com',
'https://app.fusebox.fm',
'https://api.usercentrics.eu',
'https://maps.googleapis.com',
'https://www.expressvpn.com',
'https://graphql.usercentrics.eu',
'https://ipaddress',
'https://tls.browserleaks.com',
'https://rf.revolvermaps.com',
'whoisxmlapi.com',
'maxmind.com',
'ip-api',
'/cookie',
'/location',
'/ip',
'/ips',
'/api/hostname',
'/api/whois',
'https://[',
'geoip',
'geoip2',
'ipaddress'
// Adicione mais URLs de API que deseja bloquear, se necessário
];
let listBlock1 = "list of blocked ==> ";
let listBlock2 = "list of blocked --> ";
var verifyc1 = false;
// Intercepta as solicitações AJAX feitas pelo website
const open = XMLHttpRequest.prototype.open;
XMLHttpRequest.prototype.open = function(method, url) {
// Verifica se a URL da solicitação corresponde a uma URL de API bloqueada
console.log('====>>', url);
if (blockedApiUrls.some(apiUrl => url.startsWith(apiUrl))) {
verifyc1 = true;
listBlock1 += url+" ~ ";
console.log(`Solicitação de API bloqueada: ${url}`);
return; // Interrompe a execução da solicitação
}
for (var i = 0; i < blockedApiUrls.length; i++) {
var palavra = blockedApiUrls[i];
if (url.includes(palavra)) {
console.log(`~ Block: ${palavra}`);
listBlock1 += palavra+" ~ ";
verifyc1 = true;
return;
}
}
// Continua com a execução normal da solicitação
open.apply(this, arguments);
};
let bloquearFetch = true;
let verifyc2 = false;
function interceptarFetch(url, options) {
console.log('---->>', url);
for (var i = 0; i < blockedApiUrls.length; i++) {
var palavra = blockedApiUrls[i];
if (url.includes(palavra)) {
console.log(`~ Block: ${palavra}`);
listBlock2 += palavra+" ~ ";
verifyc2 = true;
return Promise.resolve({ status: 200, body: 'A solicitação foi bloqueada.' });
}
}
if (bloquearFetch && correspondeAUrlBloqueada(url)) {
console.log('Solicitação fetch bloqueada:', url);
verifyc2 = true;
listBlock2 += url+" ~ ";
return Promise.resolve({ status: 200, body: 'A solicitação foi bloqueada.' });
} else {
return window.originalFetch.call(this, url, options);
}
}
function correspondeAUrlBloqueada(url) {
for (const urlBloqueada of blockedApiUrls) {
if (url.startsWith(urlBloqueada)) {
return true;
}
for (var i = 0; i < blockedApiUrls.length; i++) {
var palavra = blockedApiUrls[i];
if (url.includes(palavra)) {
console.log(`~ Block: ${palavra}`);
return true;
}
}
}
return false;
}
// Substituir a função fetch globalmente
window.originalFetch = window.fetch;
window.fetch = interceptarFetch;
// Aguarde o evento de carregamento total da página
window.addEventListener('load', function() {
// Após o carregamento total da página, permitir todas as solicitações fetch
bloquearFetch = false;
});
function notificaAlert() {
setTimeout(function(){
if(verifyc1 == true){
alert("~~ 4uBlocked ~~\n\n"+listBlock1);
listBlock1 = "list of 4uBlocked ==> ";
verifyc1 = false;
}
else if(verifyc2 == true){
alert("~~ 4uBlocked Fetch ~~\n\n"+listBlock2);
listBlock2 = "list of 4uBlocked --> ";
verifyc2 = false;
}
else{
console.log('IPBLOCK ====>> No API requests for IP identified.');
}
},1000);
}
window.addEventListener('load', notificaAlert);
})();