Kirka Hack Script
// ==UserScript==
// @name Better-Kirka-Script
// @author Anything tech
// @match *://kirka.io/*
// @icon https://raw.githubusercontent.com/42infi/better-kirka-client/master/src/icon.ico
// @connect raw.githubusercontent.com
// @grant GM_xmlhttpRequest
// @run-at document-start
// @noframes
// @description kirka extra features
// @license MIT
// @version 0.0.1.20221221013132
// @namespace https://greasyfork.org/users/997672
// ==/UserScript==
class Store {
constructor(config) {
this.config = JSON.parse(config);
}
get = (key) => this.config[key];
set = (key, value) => {
this.config[key] = value;
localStorage.saveSettings = JSON.stringify(this.config);
}
}
if (!localStorage.saveSettings) localStorage.saveSettings = JSON.stringify({
permCrosshair: true,
customCss: false,
hideWeaponsAds: false,
hideArms: false,
hideFlagAds: false,
playerHighLight: false,
fullBlack: false,
wireframeWeapons: false,
wireframeArms: false,
rainbow: false,
adspower: false,
autoJoin: false,
inspectKey: "j",
euLobbies: true,
naLobbies: false,
asiaLobbies: false,
ffaLobbies: true,
tdmLobbies: true,
parkourLobbies: false,
preferredFilter: 'Players',
minPlayers: 4,
maxPlayers: 8,
minTimeLeft: 3,
filterMaps: false,
maps: '',
cssLink: '',
menuOpen: true
})
const settings = new Store(localStorage.saveSettings);
let permCrosshair = !!settings.get('permCrosshair');
let noLoadingTimes = true;
let customCss = !!settings.get('customCss');
//let hpNumber = true;
let hideWeaponsAds = !!settings.get('hideWeaponsAds');
let hideArms = !!settings.get('hideArms');
let hideFlagAds = !!settings.get('hideFlagAds');
let playerHighLight = !!settings.get('playerHighLight');
let fullBlack = !!settings.get('fullBlack');
let wireframeWeapons = !!settings.get('wireframeWeapons');
let wireframeArms = !!settings.get('wireframeArms');
let rainbow = !!settings.get('rainbow');
let adspower = !!settings.get('adspower');
let autoJoin = !!settings.get('autoJoin');
let inspecting = false;
let prevInsp = false;
let prevInspectPos;
let prevInspectRot;
let prevWireframeWeapons = false;
let prevWireframeArms = false;
let gui = document.createElement("div");
let menuVisible = false;
let listening = false;
if (!settings.get('inspectKey')) settings.set('inspectKey', "j");
let euLobbies = !!settings.get('euLobbies');
let naLobbies = !!settings.get('naLobbies');
let asiaLobbies = !!settings.get('asiaLobbies');
let ffaLobbies = !!settings.get('ffaLobbies');
let tdmLobbies = !!settings.get('tdmLobbies');
let parkourLobbies = !!settings.get('parkourLobbies');
let preferredFilter = typeof settings.get('preferredFilter') == 'undefined' ? 'Players' : settings.get('preferredFilter');
let minPlayers = typeof settings.get('minPlayers') == 'undefined' ? 4 : settings.get('minPlayers');
let maxPlayers = typeof settings.get('maxPlayers') == 'undefined' ? 8 : settings.get('maxPlayers');
let minTimeLeft = typeof settings.get('minTimeLeft') == 'undefined' ? 3 : settings.get('minTimeLeft');
let filterMaps = !!settings.get('filterMaps');
let avoidSameLobby = true;
let currentURL = window.location.href;
let gameModes = [];
let bestLobby = '';
let allLobbyData = [];
let maps = settings.get('maps') ? settings.get('maps') : [];
let responseCount = 0;
let minPlayerSlider;
let maxPlayerSlider;
let minPlayersLab;
let maxPlayersLab;
let minTimeLeftSlider;
let minTimeLeftLab;
let settingsButtonsAdded = false;
let scene;
let flagMaterial;
WeakMap.prototype.set = new Proxy(WeakMap.prototype.set, {
apply(target, thisArg, argArray) {
if (argArray[0] && argArray[0].type === 'Scene' && argArray[0].children[0].type === 'AmbientLight') {
scene = argArray[0];
}
setTimeout(() => {
scene?.children?.forEach((e) => {
if (e.type === "Sprite" && !e.material.depthTest && e.material.map?.image?.width === 149) {
flagMaterial = e.material;
}
})
}, 1000)
return Reflect.apply(...arguments);
}
});
let crosshair;
new MutationObserver(mutationRecords => {
try {
mutationRecords.forEach(record => {
record.addedNodes.forEach(el => {
if (el.classList?.contains("loading-scene") && noLoadingTimes) el.parentNode.removeChild(el);
if (el.id === "qc-cmp2-container") el.parentNode.removeChild(el);
if (el.id === "cmpPersistentLink" || el.classList?.contains("home") || el.classList?.contains('moneys')) {
let btn = document.createElement("button");
btn.id = "clientJoinButton";
btn.style = "background-color: var(--primary-1);\n" +
" --hover-color: var(--primary-2);\n" +
" --top: var(--primary-2);\n" +
" --bottom: var(--primary-3);" +
" display: flex ;\n" +
" justify-content: center;\n" +
" align-items: center;\n" +
" border: none;\n" +
" position: absolute;\n" +
" color: var(--white);\n" +
" font-size: 1rem;\n" +
" transition: all .3s ease;\n" +
" font-family: Rowdies;\n" +
" padding: .9em 1.4em;\n" +
" transform: skew(-10deg);\n" +
" font-weight: 900;\n" +
" overflow: hidden;\n" +
" text-transform: uppercase;\n" +
" border-radius: .2em;\n" +
" outline: none;\n" +
" text-shadow: 0 0.1em 0 #000;\n" +
" -webkit-text-stroke: 1px var(--black);\n" +
" box-shadow: 0 0.15rem 0 rgba(0,0,0,.315);\n" +
" cursor: pointer;" +
" box-shadow: 0 5.47651px 0 rgba(0,0,0,.5)!important;\n" +
" text-shadow: -1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000,1px 1px 0 #000,0 1px 1px rgba(0,0,0,.486)!important;" +
" width: 150px;" +
" height: 50px;" +
" bottom: 20px;" +
" right: 100%;" +
" margin-right: 10px;" +
" font-size: 20px;";
btn.innerText = "Join Link";
btn.onclick = async () => {
window.location.href = await navigator.clipboard.readText();
}
document.getElementsByClassName('play-content')[0].append(btn);
document.getElementsByClassName('settings-and-socicons')[0].children[0].onclick = () => {
window.location.href = "https://discord.com/invite/cNwzjsFHpg";
};
document.getElementsByClassName('settings-and-socicons')[0].children[1].onclick = () => {
window.location.href = "https://github.com/42infi/better-kirka-client/releases";
};
if (!el.classList?.contains("home") && !el.classList?.contains('moneys')) el.parentNode.removeChild(el);
}
if (el.classList?.contains("game-interface")) {
crosshair = document.getElementById("crosshair-static");
//health number default ingame now
/*let hpElem = document.getElementsByClassName("hp-progress")[0];
document.getElementsByClassName('hp-title')[0].innerText = hpElem.style.width.slice(0, -1);
observer.observe(hpElem, {
attributeFilter: ["style"],
});*/
}
if (el.classList?.contains("settings") && !settingsButtonsAdded) {
let exportBtn = document.createElement('div');
exportBtn.id = "importBtn";
exportBtn.style = "line-height: 1.2;\n" +
"user-select: none;\n" +
"--white: #fff;\n" +
"--secondary-2: #37477c;\n" +
"-webkit-font-smoothing: antialiased;\n" +
"text-align: center;\n" +
"font-family: Exo\\ 2;\n" +
"box-sizing: border-box;\n" +
"text-shadow: -1px -1px 0 #0f0f0f,1px -1px 0 #0f0f0f,-1px 1px 0 #0f0f0f,1px 1px 0 #0f0f0f;\n" +
"font-weight: 100;\n" +
"height: 100%;\n" +
"padding: 0 .8rem;\n" +
"color: var(--white);\n" +
"font-size: 1.5rem;\n" +
"box-shadow: 0 .125rem .25rem rgba(24,28,40,.25);\n" +
"border-radius: 0 .313rem .313rem 0;\n" +
"background-color: var(--secondary-2);\n" +
"display: flex;\n" +
"justify-content: center;\n" +
"align-items: center;"
exportBtn.onmouseover = () => {
exportBtn.style.color = "#ffd500";
}
exportBtn.onmouseout = () => {
exportBtn.style.color = "#ffffff";
}
exportBtn.innerText = "Export to clipboard"
exportBtn.onclick = async () => {
let gameSettingsObj = {};
for (let key in localStorage) {
if (key.startsWith("m")) {
if (localStorage[key].startsWith('"') && localStorage[key].endsWith('"')) {
gameSettingsObj[key] = localStorage[key].slice(1, -1);
} else {
gameSettingsObj[key] = localStorage[key];
}
}
}
try {
navigator.clipboard.writeText(JSON.stringify(gameSettingsObj));
} catch {
throw new Error("Copying to clipboard failed")
}
//clipboard.writeText(JSON.stringify(gameSettingsObj));
}
let importBtn = document.createElement('div');
importBtn.id = "importBtn";
importBtn.style = "line-height: 1.2;\n" +
"user-select: none;\n" +
"--white: #fff;\n" +
"--secondary-2: #37477c;\n" +
"-webkit-font-smoothing: antialiased;\n" +
"text-align: center;\n" +
"font-family: Exo\\ 2;\n" +
"box-sizing: border-box;\n" +
"text-shadow: -1px -1px 0 #0f0f0f,1px -1px 0 #0f0f0f,-1px 1px 0 #0f0f0f,1px 1px 0 #0f0f0f;\n" +
"font-weight: 100;\n" +
"height: 100%;\n" +
"padding: 0 .8rem;\n" +
"color: var(--white);\n" +
"font-size: 1.5rem;\n" +
"box-shadow: 0 .125rem .25rem rgba(24,28,40,.25);\n" +
"border-radius: 0 .313rem .313rem 0;\n" +
"background-color: var(--secondary-2);\n" +
"display: flex;\n" +
"justify-content: center;\n" +
"align-items: center;"
importBtn.onmouseover = () => {
importBtn.style.color = "#ffd500";
}
importBtn.onmouseout = () => {
importBtn.style.color = "#ffffff";
}
importBtn.innerText = "Import from clipboard"
importBtn.onclick = () => {
//Object.assign(localStorage, JSON.parse(clipboard.readText()));
//window.location.reload();
}
document.getElementsByClassName('left')[0].appendChild(exportBtn);
document.getElementsByClassName('left')[0].appendChild(importBtn);
settingsButtonsAdded = true;
}
});
});
} catch {
}
}).observe(document, { childList: true, subtree: true });
let oldLog = console.log;
console.log = (...arguments) => {
if (typeof arguments[0] == "string" && arguments[0].startsWith("window.aiptag.cmd")) {
throw "ad's blocked by overengineered ad block " + Math.random().toString().split(".")[1];
}
oldLog(...arguments);
};
if (customCss) {
let cssLinkElem = document.createElement("link");
cssLinkElem.href = settings.get('cssLink');
cssLinkElem.rel = "stylesheet";
document.head.append(cssLinkElem);
}
gui.id = "gui";
gui.innerHTML += "<style>\n" +
" @import url('https://fonts.googleapis.com/css2?family=Titillium+Web:wght@300&display=swap');\n" +
"\n" +
" #gui {\n" +
" background-color: rgb(24, 25, 28);\n" +
" border: solid rgb(24, 25, 28) 5px;\n" +
" box-shadow: 0 0 8px 2px #000000;\n" +
" position: absolute;\n" +
" left: 200px;\n" +
" top: 100px;\n" +
" z-index: 300;\n" +
" color: rgb(255, 255, 255);\n" +
" padding: 6px;\n" +
" font-family: \"Titillium Web\", serif;\n" +
" line-height: 1.6;\n" +
" border-radius: 3px\n" +
" }\n" +
"\n" +
" input:disabled {\n" +
" background: rgb(255, 255, 255);\n" +
" border: solid rgb(0, 0, 0) 1px;\n" +
" width: 50px;\n" +
" }\n" +
"\n" +
" .heading {\n" +
" width: 300px;\n" +
" height: 40px;\n" +
" display: flex;\n" +
" justify-content: center;\n" +
" align-items: center;\n" +
" background-color: rgb(24, 25, 28);\n" +
" margin: -9px -6px 8px;\n" +
" font-family: \"Titillium Web\", serif;\n" +
" font-weight: bold;\n" +
" text-align: center;\n" +
" font-size: 24px;\n" +
" border-bottom: solid rgb(140, 140, 140) 2px;\n" +
" }\n" +
"\n" +
" .footer {\n" +
" width: 300px;\n" +
" height: 20px;\n" +
" display: flex;\n" +
" justify-content: center;\n" +
" align-items: center;\n" +
" background-color: rgb(24, 25, 28);\n" +
" margin: 6px -6px -10px;\n" +
" font-family: \"Titillium Web\", serif;\n" +
" font-weight: bold;\n" +
" text-align: center;\n" +
" font-size: 11px;\n" +
" position: relative;\n" +
" border-top: solid rgb(140, 140, 140) 2px;\n" +
" }\n" +
"\n" +
" .module:hover {\n" +
" background-color: rgb(0, 0, 0, 0.1)\n" +
" }\n" +
"\n" +
" .autojoin{\n" +
" display: none;\n" +
" }\n" +
"\n" +
" </style>\n" +
" <div id=\"infi\" class=\"heading\">Script Settings</div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"crosshair\" name=\"crosshair\">\n" +
" <label for=\"crosshair\">Perm. Crosshair</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"customCSS\" name=\"customCSS\">\n" +
" <label for=\"customCSS\">CSS Link: </label>\n" +
" <input type=\"text\" id=\"cssLink\" placeholder=\"Paste CSS Link Here\">\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"hideweap\" name=\"hideweap\">\n" +
" <label for=\"hideweap\">Hide Weapon ADS</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"arms\" name=\"arms\">\n" +
" <label for=\"arms\">Hide Arms</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"hideflag\" name=\"hideflag\">\n" +
" <label for=\"hideflag\">Hide Flag ADS</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"highlight\" name=\"highlight\">\n" +
" <label for=\"highlight\">Highlight Players</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"black\" name=\"black\">\n" +
" <label for=\"black\">Black Players</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"wireframeWeapons\" name=\"wireframeWeapons\">\n" +
" <label for=\"wireframeWeapons\">Wireframe Weapons</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"wireframeArms\" name=\"wireframeArms\">\n" +
" <label for=\"wireframeArms\">Wireframe Arms</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"rainbow\" name=\"rainbow\">\n" +
" <label for=\"rainbow\">Rainbow Colors</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" Inspect Key\n" +
" <button id=\"bindButton\" style=\"width: 100px\">click to bind</button>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"adspower\" name=\"adspower\">\n" +
" <label for=\"adspower\">0 ADS Power</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module\">\n" +
" <input type=\"checkbox\" id=\"autoJoin\" name=\"autoJoin\">\n" +
" <label for=\"autoJoin\">Auto-Joiner (Key F8)</label>\n" +
" </div>\n" +
"\n" +
" <hr class=\"autojoin\">\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"euLobbies\" name=\"euLobbies\">\n" +
" <label for=\"euLobbies\">EU Lobbies</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"naLobbies\" name=\"naLobbies\">\n" +
" <label for=\"naLobbies\">NA Lobbies</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"asiaLobbies\" name=\"asiaLobbies\">\n" +
" <label for=\"asiaLobbies\">ASIA Lobbies</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"ffaLobbies\" name=\"ffaLobbies\">\n" +
" <label for=\"ffaLobbies\">FFA Lobbies</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"tdmLobbies\" name=\"tdmLobbies\">\n" +
" <label for=\"tdmLobbies\">TDM Lobbies</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"parkourLobbies\" name=\"parkourLobbies\">\n" +
" <label for=\"parkourLobbies\">PARKOUR Lobbies</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <label for=\"preferredFilter\">Prefered Filter:</label>\n" +
" <select id=\"preferredFilter\" name=\"preferredFilter\">\n" +
" <option value=\"Time\">Time</option>\n" +
" <option value=\"Players\">Players</option>\n" +
" </select>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"range\" id=\"minPlayers\" name=\"minPlayers\" min=\"0\" max=\"8\" value=\"0\" step=\"1\">\n" +
" <label id=\"minPlayersLab\" for=\"minPlayers\">min. Players</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"range\" id=\"maxPlayers\" name=\"maxPlayers\" min=\"0\" max=\"8\" value=\"0\" step=\"1\">\n" +
" <label id=\"maxPlayersLab\" for=\"maxPlayers\">max. Players</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"range\" id=\"minTimeLeft\" name=\"minTimeLeft\" min=\"0\" max=\"8\" value=\"0\" step=\"1\">\n" +
" <label id=\"minTimeLeftLab\" for=\"minTimeLeft\">min. Time Left</label>\n" +
" </div>\n" +
"\n" +
" <div class=\"module autojoin\">\n" +
" <input type=\"checkbox\" id=\"filterMaps\" name=\"filterMaps\">\n" +
" <label for=\"filterMaps\">Map Filter: </label>\n" +
" <input type=\"text\" id=\"mapFilterField\" placeholder=\"Map1, Map2, Map3, etc.\">\n" +
" </div>\n" +
"\n" +
" <hr class=\"autojoin\">\n" +
"\n" +
" <div class=\"footer\">Toggle With \"PageUp\" Key</div>";
gui.onclick = (e) => {
if (e.target.id === "crosshair") {
permCrosshair = e.target.checked;
settings.set('permCrosshair', permCrosshair);
}
if (e.target.id === "customCSS") {
customCss = e.target.checked;
settings.set('customCss', customCss);
}
if (e.target.id === "hideweap") {
hideWeaponsAds = e.target.checked;
settings.set('hideWeaponsAds', hideWeaponsAds);
}
if (e.target.id === "arms") {
hideArms = e.target.checked;
settings.set('hideArms', hideArms);
}
if (e.target.id === "hideflag") {
hideFlagAds = e.target.checked;
settings.set('hideFlagAds', hideFlagAds);
}
if (e.target.id === "highlight") {
playerHighLight = e.target.checked;
settings.set('playerHighLight', playerHighLight);
}
if (e.target.id === "black") {
fullBlack = e.target.checked;
settings.set('fullBlack', fullBlack);
}
if (e.target.id === "wireframeWeapons") {
wireframeWeapons = e.target.checked;
settings.set('wireframeWeapons', wireframeWeapons);
}
if (e.target.id === "wireframeArms") {
wireframeArms = e.target.checked;
settings.set('wireframeArms', wireframeArms);
}
if (e.target.id === "rainbow") {
rainbow = e.target.checked;
settings.set('rainbow', rainbow);
}
if (e.target.id === "adspower") {
adspower = e.target.checked;
settings.set('adspower', adspower);
}
if (e.target.id === "autoJoin") {
autoJoin = e.target.checked;
settings.set('autoJoin', autoJoin);
for (let e of document.getElementsByClassName('autojoin')) {
e.style.display = autoJoin ? 'block' : 'none'
}
}
if (e.target.id === "euLobbies") {
euLobbies = e.target.checked;
settings.set('euLobbies', euLobbies);
}
if (e.target.id === "naLobbies") {
naLobbies = e.target.checked;
settings.set('naLobbies', naLobbies);
}
if (e.target.id === "asiaLobbies") {
asiaLobbies = e.target.checked;
settings.set('asiaLobbies', asiaLobbies);
}
if (e.target.id === "ffaLobbies") {
ffaLobbies = e.target.checked;
settings.set('ffaLobbies', ffaLobbies);
}
if (e.target.id === "tdmLobbies") {
tdmLobbies = e.target.checked;
settings.set('tdmLobbies', tdmLobbies);
}
if (e.target.id === "parkourLobbies") {
parkourLobbies = e.target.checked;
settings.set('parkourLobbies', parkourLobbies);
}
if (e.target.id === "filterMaps") {
filterMaps = e.target.checked;
settings.set('filterMaps', filterMaps);
}
};
gui.style.display = "none";
document.body.appendChild(gui);
if (settings.get('menuOpen') === undefined || settings.get('menuOpen')) {
toggleGui();
}
document.getElementById("crosshair").checked = permCrosshair;
document.getElementById("customCSS").checked = customCss;
document.getElementById("hideweap").checked = hideWeaponsAds;
document.getElementById("arms").checked = hideArms;
document.getElementById("hideflag").checked = hideFlagAds;
document.getElementById("highlight").checked = playerHighLight;
document.getElementById("black").checked = fullBlack;
document.getElementById("wireframeWeapons").checked = wireframeWeapons;
document.getElementById("wireframeArms").checked = wireframeArms;
document.getElementById("rainbow").checked = rainbow;
document.getElementById("adspower").checked = adspower;
maxPlayersLab = document.getElementById('maxPlayersLab');
minPlayersLab = document.getElementById('minPlayersLab');
minTimeLeftLab = document.getElementById('minTimeLeftLab');
maxPlayerSlider = document.getElementById("maxPlayers");
minPlayerSlider = document.getElementById("minPlayers");
minTimeLeftSlider = document.getElementById("minTimeLeft");
maxPlayerSlider.onchange = () => {
settings.set('maxPlayers', Number.parseInt(maxPlayerSlider.value));
}
minPlayerSlider.onchange = () => {
settings.set('minPlayers', Number.parseInt(minPlayerSlider.value));
}
minTimeLeftSlider.onchange = () => {
settings.set('minTimeLeft', Number.parseInt(minTimeLeftSlider.value));
}
minPlayerSlider.value = minPlayers;
maxPlayerSlider.value = maxPlayers;
minTimeLeftSlider.value = minTimeLeft;
if (autoJoin) {
for (let e of document.getElementsByClassName('autojoin')) {
e.style.display = autoJoin ? 'block' : 'none'
}
}
document.getElementById("autoJoin").checked = autoJoin;
document.getElementById("euLobbies").checked = euLobbies;
document.getElementById("naLobbies").checked = naLobbies;
document.getElementById("asiaLobbies").checked = asiaLobbies;
document.getElementById("ffaLobbies").checked = ffaLobbies;
document.getElementById("tdmLobbies").checked = tdmLobbies;
document.getElementById("parkourLobbies").checked = parkourLobbies;
let button = document.getElementById("bindButton");
button.style.fontWeight = "800";
button.onclick = () => {
listening = true;
button.innerText = "Press a Key"
}
button.innerText = settings.get('inspectKey').toUpperCase();
let cssField = document.getElementById('cssLink');
if (settings.get('cssLink') === undefined) settings.set('cssLink', '');
cssField.value = settings.get('cssLink');
cssField.oninput = () => {
settings.set('cssLink', cssField.value);
}
let filter = document.getElementById("preferredFilter");
filter.value = preferredFilter;
filter.onchange = () => {
preferredFilter = filter.value;
settings.set('preferredFilter', filter.value);
}
document.getElementById("filterMaps").checked = filterMaps;
let mapField = document.getElementById("mapFilterField");
let mapString = "";
for (let name of maps) {
mapString += name + ", "
}
mapField.value = mapString.slice(0, -2);
mapField.oninput = () => {
maps = mapField.value.replaceAll(' ', '').toLowerCase().split(',');
settings.set('maps', maps);
}
window.addEventListener("mouseup", (e) => {
if (e.button === 3 || e.button === 4)
e.preventDefault();
});
//hp numbers default ingame now
/*const observer = new MutationObserver(function (mutations) {
mutations.forEach(function (mutation) {
document.getElementsByClassName('hp-title')[0].innerText = hpNumber ? mutation.target.style.width.slice(0, -1) : "HP";
});
});*/
let scoped = false;
document.addEventListener('mousedown', (e) => {
if (e.button === 2) scoped = true;
});
document.addEventListener('mouseup', (e) => {
if (e.button === 2) scoped = false;
});
let inspectedWeapon;
document.addEventListener('keydown', (e) => {
if (listening) {
settings.set('inspectKey', e.key);
document.getElementById("bindButton").innerText = e.key.toUpperCase();
listening = false;
}
if (e.key === settings.get("inspectKey").toLowerCase()) {
inspecting = true;
setTimeout(() => {
inspecting = false
}, 3000);
}
if (e.code === "PageUp") {
toggleGui();
}
});
let r = 255;
let g = 0;
let b = 0;
function animate() {
window.requestAnimationFrame(animate);
if (rainbow) {
if (r > 0 && b === 0) {
r--;
g++;
}
if (g > 0 && r === 0) {
g--;
b++;
}
if (b > 0 && g === 0) {
r++;
b--;
}
} else {
let color = hexToRgb("#ff0000");
r = color.r;
g = color.g;
b = color.b;
}
if (menuVisible) {
if (minPlayerSlider) {
minPlayers = Number.parseInt(minPlayerSlider.value);
minPlayersLab.innerText = minPlayerSlider.value + " min. Players";
}
if (maxPlayerSlider) {
maxPlayers = Number.parseInt(maxPlayerSlider.value);
maxPlayersLab.innerText = maxPlayerSlider.value + " max. Players";
}
if (minTimeLeftSlider) {
minTimeLeft = Number.parseInt(minTimeLeftSlider.value);
minTimeLeftLab.innerText = minTimeLeftSlider.value + " min. Time Left";
}
}
if (flagMaterial) {
if (hideFlagAds) {
flagMaterial.visible = !scoped;
} else {
flagMaterial.visible = true;
}
}
if (crosshair && permCrosshair) crosshair.style = "visibility: visible !important; opacity: 1 !important; display: block !important;"
try {
let weap = document.getElementsByClassName('list-weapons')[0].children[0].children[0].innerText;
let num = 4;
if (weap === "Weatie" || weap === "MAC-10") num = 5;
if (weap === "AR-9") num = 3;
let arms = true;
if ((scoped && hideWeaponsAds) || hideArms) {
arms = false;
}
const weaponModel = scene["entity"]["_entityManager"]["mWnwM"]["systemManager"]["_systems"]["0"]["_queries"]["player"]["entities"]["0"]["_components"]["35"]["weapons"][weap]["model"];
const armsMaterial = weaponModel["parent"]["children"]["0"]["material"];
const weaponMaterial = weaponModel["children"][num]["material"];
armsMaterial.visible = arms;
if (hideWeaponsAds) weaponMaterial.visible = !scoped;
if (inspecting) {
if (!prevInsp) {
prevInspectPos = weaponModel.position.clone();
prevInspectRot = weaponModel.rotation.clone();
if (weaponModel) inspectedWeapon = weaponModel;
}
weaponModel.rotation.x = 0;
weaponModel.rotation.y = -0.3;
weaponModel.rotation.z = -0.4;
weaponModel.position.y = 0.05;
weaponModel.position.z = -0.08;
} else {
if (prevInsp) {
inspectedWeapon.rotation.x = prevInspectRot.x;
inspectedWeapon.rotation.y = prevInspectRot.y;
inspectedWeapon.rotation.z = prevInspectRot.z;
inspectedWeapon.position.y = prevInspectPos.y;
inspectedWeapon.position.z = prevInspectPos.z;
}
}
prevInsp = inspecting;
if (wireframeArms) {
armsMaterial.wireframe = true;
armsMaterial.color.r = r / 255;
armsMaterial.color.g = g / 255;
armsMaterial.color.b = b / 255;
armsMaterial.emissive.r = r / 255;
armsMaterial.emissive.g = g / 255;
armsMaterial.emissive.b = b / 255;
} else if (prevWireframeArms) {
armsMaterial.wireframe = false;
armsMaterial.color.r = 1;
armsMaterial.color.g = 1;
armsMaterial.color.b = 1;
armsMaterial.emissive.r = 0;
armsMaterial.emissive.g = 0;
armsMaterial.emissive.b = 0;
}
if (wireframeWeapons) {
weaponMaterial.wireframe = true;
weaponMaterial.color.r = r / 255;
weaponMaterial.color.g = g / 255;
weaponMaterial.color.b = b / 255;
weaponMaterial.emissive.r = r / 255;
weaponMaterial.emissive.g = g / 255;
weaponMaterial.emissive.b = b / 255;
} else if (prevWireframeWeapons) {
weaponMaterial.wireframe = false;
weaponMaterial.color.r = 1;
weaponMaterial.color.g = 1;
weaponMaterial.color.b = 1;
weaponMaterial.emissive.r = 0;
weaponMaterial.emissive.g = 0;
weaponMaterial.emissive.b = 0;
}
prevWireframeWeapons = wireframeWeapons;
prevWireframeArms = wireframeArms;
} catch {
}
try {
for (let i = 0; i < scene["entity"]["_entityManager"]["mWnwM"]["systemManager"]["_systems"]["2"]["_queries"]["animationEntities"]["entities"].length; i++) {
let localPlayerClass = scene["children"]["0"]["parent"]["entity"]["_entityManager"]["mWnwM"]["systemManager"]["_systems"]["0"]["_queries"]["player"]["entities"]["0"]["_components"]["38"].wnWmN;
let player = scene["entity"]["_entityManager"]["mWnwM"]["systemManager"]["_systems"]["2"]["_queries"]["animationEntities"]["entities"][i]["_components"];
let mat = scene["entity"]["_entityManager"]["mWnwM"]["systemManager"]["_systems"]["2"]["_queries"]["animationEntities"]["entities"][i]["_components"][0].value.children[0].children[0].children[1].material;
if ((mat.color.r === 1 && mat.color.g < 1 && mat.color.b < 1) || !playerHighLight) continue;
let color = hexToRgb("#0000ff");
if (!localPlayerClass.team || localPlayerClass.team !== player["50"].team) {
color = hexToRgb("#ff0000");
if (fullBlack) color = hexToRgb('#000000')
}
let r = color.r * Number.MAX_SAFE_INTEGER;
let g = color.g * Number.MAX_SAFE_INTEGER;
let b = color.b * Number.MAX_SAFE_INTEGER;
mat.map = null;
mat.color.r = r;
mat.color.g = g;
mat.color.b = b;
mat.needsUpdate = true;
}
} catch {
}
}
animate();
window.XMLHttpRequest = class extends window.XMLHttpRequest {
get responseText() {
if (this.invReq) {
this.invReq = false;
let entries = JSON.parse(this.responseText);
let sortedItems = { legendary: [], epic: [], rare: [], common: [] };
for (let entry of entries) {
sortedItems[entry.item.rarity.toLowerCase()].push(entry);
}
let editEntries = [];
for (let rarity in sortedItems) {
editEntries = [].concat(editEntries, sortedItems[rarity]);
}
return JSON.stringify(editEntries);
}
return super.responseText;
}
open(method, url) {
if (url === "https://api.kirka.io/api/inventory") this.invReq = true;
return super.open(...arguments);
}
}
function minutesLeft(e) {
return Math.ceil((480 - (Date.now() - Date.parse(e)) / 1000));
}
document.onkeydown = event => {
if (event.key === "F8" && autoJoin) {
responseCount = 0;
allLobbyData = [];
fetch('https://eu1.kirka.io/matchmake')
.then(response => response.json())
.then(dataEU => {
for (let i = 0; i < dataEU.length; i++) {
dataEU[i].region = "EU";
}
if (euLobbies) {
for (let i = 0; i < dataEU.length; i++) {
allLobbyData.push(dataEU[i]);
}
}
responseCount++;
checkSearchLobby();
});
fetch('https://na1.kirka.io/matchmake')
.then(response => response.json())
.then(dataNA => {
for (let i = 0; i < dataNA.length; i++) {
dataNA[i].region = "NA";
}
if (naLobbies) {
for (let i = 0; i < dataNA.length; i++) {
allLobbyData.push(dataNA[i]);
}
}
responseCount++;
checkSearchLobby();
});
fetch('https://asia1.kirka.io/matchmake')
.then(response => response.json())
.then(dataASIA => {
for (let i = 0; i < dataASIA.length; i++) {
dataASIA[i].region = "ASIA";
}
if (asiaLobbies) {
for (let i = 0; i < dataASIA.length; i++) {
allLobbyData.push(dataASIA[i]);
}
}
responseCount++;
checkSearchLobby();
});
}
}
function checkSearchLobby() {
if (responseCount < 3) return;
console.log(allLobbyData);
if (parkourLobbies) {
gameModes.push('ParkourRoom');
}
if (ffaLobbies) {
gameModes.push('DeathmatchRoom');
}
if (tdmLobbies) {
gameModes.push('TeamDeathmatchRoom');
}
let fittingLobbies = [];
for (let i = 0; i < allLobbyData.length; i++) {
if (allLobbyData[i].locked === false && allLobbyData[i].clients >= minPlayers && allLobbyData[i].clients <= maxPlayers && gameModes.includes(allLobbyData[i].name) && minutesLeft(allLobbyData[i].createdAt) >= minTimeLeft && (maps.includes(allLobbyData[i].metadata.mapName.toLowerCase()) || !filterMaps)) {
if (avoidSameLobby) {
if (!currentURL.includes(allLobbyData[i].roomId)) {
fittingLobbies.push(allLobbyData[i]);
}
} else {
fittingLobbies.push(allLobbyData[i]);
}
}
}
if (fittingLobbies.length !== 0) {
bestLobby = fittingLobbies[0];
if (fittingLobbies.length > 0) {
for (let i = 0; i < fittingLobbies.length; i++) {
if (bestLobby.clients < fittingLobbies[i].clients) {
bestLobby = fittingLobbies[i];
} else if (bestLobby.clients === fittingLobbies[i].clients) {
if (minutesLeft(bestLobby.createdAt) < minutesLeft(fittingLobbies[i].createdAt)) {
bestLobby = fittingLobbies[i];
}
}
}
}
} else if (preferredFilter === 'Time') {
bestLobby = fittingLobbies[0];
if (fittingLobbies.length > 0) {
for (let i = 0; i < fittingLobbies.length; i++) {
if (minutesLeft(bestLobby.createdAt) < minutesLeft(fittingLobbies[i].createdAt)) {
bestLobby = fittingLobbies[i];
}
}
}
}
if (fittingLobbies.length !== 0 && bestLobby !== '') {
let joinURL = 'https://kirka.io/games/' + bestLobby.region + '~' + bestLobby.roomId;
window.location.href = joinURL;
} else alert('No Lobby found - consider changing your settings'); //popup ohne alert?
}
function toggleGui() {
menuVisible = !menuVisible;
if (menuVisible) {
document.exitPointerLock();
gui.style.display = 'inline-block';
} else {
gui.style.display = 'none';
}
settings.set('menuOpen', menuVisible);
}
function hexToRgb(hex) {
let result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
return result ? {
r: parseInt(result[1], 16),
g: parseInt(result[2], 16),
b: parseInt(result[3], 16)
} : null;
}
let oldDefine = Object.defineProperty;
Object.defineProperty = (...args) => {
if (args[0] && args[1] && args[1] === 'renderer' && args[0].constructor.name.startsWith('_0x')) {
if (args[0].WnNMwm) {
Object.defineProperty(args[0].camera, "fov", {
get() {
return adspower ? args[0].WnNMwm.fov : this.vFov;
},
set(v) {
this.vFov = v;
}
});
}
}
return oldDefine(...args);
}
// ==UserScript==
// @name Kirka.IO Enhanced
// @namespace -
// @version 1.4.1
// @description Wallhack, adblock and more for Kirka.IO.
// @author Anything Tech
// @match *://kirka.io/*
// @run-at document-end
// @license GPL-3.0-or-later
// @grant none
// @icon 
// ==/UserScript==
(function() {
let wallhackEnabled = true
const KEYS = {
CHAT_VISIBILITY_TOGGLE: 'V',
WALLHACK_TOGGLE: 'f'
}
// Nerd Stuff
let players = []
let other = []
// No Logs
;(function() {
console._log = console.log
let props = ['log', 'info', 'warn', 'error']
props.forEach(e => {
let prop = props[e]
window.console[prop] = _
})
})()
// Styling
let css = `
.notification {
position: absolute;
background: var(--secondary-5);
border: 4px solid rgb(62, 77, 124);
border-bottom: 4px solid var(--secondary-6);
border-top: 4px solid rgb(77, 92, 139);
width: 250px;
height: 100px;
right: 15px;
bottom: 15px;
z-index: 100;
color: rgb(255, 255, 255);
transition: .3s;
opacity: 0.85;
pointer-events: none;
}
.notification-title {
font-size: x-large;
text-align: center;
margin: 2px;
}
.notification-body {
margin: 3px;
font-size: medium;
}
.highlight-disabled::after {
content: 'disabled';
color: rgb(210, 50, 50);
}
.highlight-enabled::after {
content: 'enabled';
color: rgb(50, 210, 50);
}
.bloody-screen {
pointer-events: none !important;
width: 100vw;
height: 100vh;
position: absolute;
left: 0;
top: 0;
box-shadow: rgba(255, 0, 0, .8) 0 0 150px inset;
transition: .3s opacity;
}`
// Visibility Change
let visibility = (function() {
function visible(el) {
el.style.opacity = '1'
el.style.pointerEvents = 'auto'
}
function invisible(el) {
el.style.opacity = '0'
el.style.pointerEvents = 'none'
}
return {
toggle(el) {
if(el.style.opacity === '0') {
visible(el)
} else {
invisible(el)
}
},
visible,
invisible,
}
})()
let wallhack = (function() {
function visible(e) {
e.alphaTest = .99
e.fog = false
e.depthTest = false
}
function invisible(e) {
e.alphaTest = 1
e.fog = true
e.depthTest = true
}
return {
visible,
invisible,
}
})()
// Ad Block
let adBlockCss
;(function() {
let ads = ['ad-left', 'ad-right', 'ad-bottom', 'ad-change-weapon']
let adsSelectors = ''
ads.forEach(e => {
let adSelector = ''
let prefixes = ['.', '#']
prefixes.forEach(r => {
adSelector += r + e + ','
})
adsSelectors += adSelector
})
adBlockCss = adsSelectors.slice(0, -1) + '{ display: none !important }'
window.show_rewarded = _
window.show_preroll = _
})()
let keybidings = [
{
// Toggle Chat Visibility
key: KEYS.CHAT_VISIBILITY_TOGGLE,
fn() {
let chat = document.querySelector('.chat')
if(chat) {
chat.style.transition = '.3s opacity'
visibility.toggle(chat)
}
}
},
// Toggle Wallhack
{
key: KEYS.WALLHACK_TOGGLE,
fn() {
wallhackEnabled = !wallhackEnabled
players.forEach(e => {
wallhack[(wallhackEnabled ? '' : 'in') + 'visible'](e)
})
notify('Wallhack', 'Wallhack is ', wallhackEnabled)
}
},
]
keybidings.forEach(e => {
window.addEventListener('keydown', r => {
let focused = document.querySelector(':focus') || document.activeElement
if(focused.matches('.chat .input')) {
return
}
if(r.code === 'Key' + e.key.toUpperCase()) {
r.preventDefault()
e.fn()
}
})
})
// Bloody Screen at low HP
;(function() {
let bloodyScreen = document.createElement('div')
bloodyScreen.className = 'bloody-screen'
visibility.invisible(bloodyScreen)
document.body.appendChild(bloodyScreen)
let obs = new MutationObserver(() => {
let progress = document.querySelector('.hp-progress')
if(progress) {
let hp = currentHealth()
if(hp < 35 && hp > 0) {
visibility.visible(bloodyScreen)
} else {
visibility.invisible(bloodyScreen)
}
}
})
obs.observe(document.body, {
subtree: true,
childList: true,
})
function currentHealth() {
return +document.querySelector('.hp-progress').style.width.slice(0, -1)
}
})()
// Wallhack (Actual)
;(function() {
Object.defineProperty(Object.prototype, 'material', {
set(value) {
this._material = value
if (this._material && this._material.name && this._material.name.indexOf('player') !== -1) {
players.push(value)
if(wallhackEnabled) {
wallhack.visible(value)
}
} else {
other.push(value)
}
},
get() {
return this._material
}
})
})()
// Actual Nerd Stuff
let styleNode = document.createElement('style')
styleNode.appendChild(document.createTextNode(css + adBlockCss))
document.querySelector('head').appendChild(styleNode)
function notify(title, body, highlight) {
let notifClass = 'notification'
let notif = document.createElement('div')
let notifTitle = document.createElement('h3')
let notifBody = document.createElement('p')
notifTitle.className = notifClass + '-title'
notifBody.className = notifClass + '-body'
notif.className = notifClass
notifTitle.textContent = title ?? 'Kirka.IO Enchanced'
notifBody.innerHTML = (body ?? '') + (`<span class="highlight-${highlight ? 'enabled' : highlight === false ? 'disabled' : ''}"></span>`)
notif.style.right = '100vw'
notif.appendChild(notifTitle)
notif.appendChild(notifBody)
document.body.appendChild(notif)
setTimeout(() => {
notif.style.right = ''
}, 300)
setTimeout(() => {
notif.style.right = '100vw'
setTimeout(() => {
notif.remove()
}, 300)
}, 1300)
}
// May be useful
function getUniqueId() {
return btoa(Math.random() * 1e3).replace(/=/g, '').toLowerCase()
}
function getWeapon(query) {
return Array.from(document.querySelectorAll('.gun-name')).find(e => e.textContent.toLowerCase() === query.toLowerCase())
}
function _() {}
})()