Professional Documents
Culture Documents
/* eslint-env es6 */
/* eslint-disable no-caller, no-undef, no-loop-func */
// Donations Accepted
// BTC: 3CsDVq96KgmyPjktUe1YgVSurJVe7LT53G
// ETH: 0x5dbF713F95F7777c84e6EFF5080e2f0e0724E8b1
// ETC: 0xF59BEbe25ECe2ac3373477B5067E07F2284C70f3
function Log() {
this.info = (str, args = []) => this.log('info', str, args);
this.warn = (str, args = []) => this.log('warn', str, args);
this.error = (str, args = []) => this.log('error', str, args);
this.log = (level, str, args) => {
let colour = [];
switch(level) {
case 'info':colour=["#07a1d5", "#6e07d5"];break;
case 'error':colour=["#d50707", "#d53a07"];break;
case 'warn':colour=["#d56e07", "#d5d507"];break;
}
console.log('%c '.concat('[ ', level.toUpperCase(), ' ] '), [
`background: linear-gradient(${colour[0]}, ${colour[1]})`
, 'border: 1px solid #3E0E02'
, 'color: white'
, 'display: block'
, 'text-shadow: 0 1px 0 rgba(0, 0, 0, 0.3)'
, 'box-shadow: 0 1px 0 rgba(255, 255, 255, 0.4) inset, 0 5px 3px
-5px rgba(0, 0, 0, 0.5), 0 -13px 5px -10px rgba(255, 255, 255, 0.4) inset'
, 'line-height: 12px'
, 'text-align: center'
, 'font-weight: bold'
].join(';'))
if (args.length) console.log(str, args);
else console.log(str);
}
} var log = new Log();
class Skid {
constructor() {
skid = this;
this.generated = false;
this.gameJS = null;
this.token = null;
this.downKeys = new Set();
this.settings = null;
this.vars = {};
this.playerMaps = [];
this.skinCache = {};
this.inputFrame = 0;
this.renderFrame = 0;
this.fps = 0;
this.lists = {
renderESP: {
off: "Off",
walls: "Walls",
twoD: "2d",
full: "Full"
},
renderChams: {
off: "Off",
"#FFFFFF": "White",
"#000000": "Black",
"#9400D3": "Purple",
"#FF1493": "Pink",
"#1E90FF": "Blue",
"#0000FF": "DarkBlue",
"#00FFFF": "Aqua",
"#008000": "Green",
"#7FFF00": "Lime",
"#FF8C00": "Orange",
"#FFFF00": "Yellow",
"#FF0000": "Red",
Rainbow: "Rainbow",
},
autoBhop: {
off: "Off",
autoJump: "Auto Jump",
keyJump: "Key Jump",
autoSlide: "Auto Slide",
keySlide: "Key Slide"
},
autoAim: {
off: "Off",
correction: "Aim Correction",
assist: "Legit Aim Assist",
easyassist: "Easy Aim Assist",
silent: "Silent Aim",
trigger: "Trigger Bot",
quickScope: "Quick Scope"
},
audioStreams: {
off: 'Off',
_2000s: 'General German/English',
_HipHopRNB: 'Hip Hop / RNB',
_Oldskool: 'Hip Hop Oldskool',
_Country: 'Country',
_Pop: 'Pop',
_Dance: 'Dance',
_Dubstep: 'DubStep',
_Lowfi: 'LoFi HipHop',
_Jazz: 'Jazz',
_Oldies: 'Golden Oldies',
_Club: 'Club',
_Folk: 'Folk',
_ClassicRock: 'Classic Rock',
_Metal: 'Heavy Metal',
_DeathMetal: 'Death Metal',
_Classical: 'Classical',
_Alternative: 'Alternative',
},
}
this.consts = {
twoPI: Math.PI * 2,
halfPI: Math.PI / 2,
playerHeight: 11,
cameraHeight: 1.5,
headScale: 2,
armScale: 1.3,
armInset: 0.1,
chestWidth: 2.6,
hitBoxPad: 1,
crouchDst: 3,
recoilMlt: 0.3,
nameOffset: 0.6,
nameOffsetHat: 0.8,
};
this.key = {
frame: 0,
delta: 1,
xdir: 2,
ydir: 3,
moveDir: 4,
shoot: 5,
scope: 6,
jump: 7,
reload: 8,
crouch: 9,
weaponScroll: 10,
weaponSwap: 11,
moveLock: 12
};
this.css = {
hideAdverts: `#aContainer, #aHolder, #endAContainer, #aMerger {
display: none !important; }`,
noTextShadows: `*, .button.small, .bigShadowT { text-shadow: none
!important; }`,
};
this.isProxy = Symbol("isProxy");
this.spinTimer = 1800;
try {
this.onLoad();
}
catch(e) {
log.error(e);
console.trace(e.stack);
}
}
canStore() {
return this.isDefined(Storage);
}
saveVal(name, val) {
if (this.canStore()) localStorage.setItem("kro_utilities_"+name, val);
}
deleteVal(name) {
if (this.canStore()) localStorage.removeItem("kro_utilities_"+name);
}
getSavedVal(name) {
if (this.canStore()) return
localStorage.getItem("kro_utilities_"+name);
return null;
}
isType(item, type) {
return typeof item === type;
}
isDefined(object) {
return !this.isType(object, "undefined") && object !== null;
}
isNative(fn) {
return (/^function\s*[a-z0-9_\$]*\s*\([^)]*\)\s*\{\s*\[native
code\]\s*\}/i).test('' + fn)
}
getStatic(s, d) {
return this.isDefined(s) ? s : d
}
crossDomain(url) {
return "https://crossorigin.me/" + url;
}
async fetchScript() {
// const data = await this.request("https://krunker.io/social.html",
"text");
// const buffer = await this.request("https://krunker.io/pkg/krunker." +
/\w.exports="(\w+)"/.exec(data)[1] + ".vries", "arrayBuffer");
// const array = Array.from(new Uint8Array(buffer));
// const xor = array[0] ^ '!'.charCodeAt(0);
// return array.map((code) => String.fromCharCode(code ^ xor)).join('');
return new Promise((erect, fostersFlop)=>erect(this.gameJS));
}
createSettings() {
this.displayStyle = (el, val) => {
this.waitFor(_=>window[el], 5e3).then(node => {
if (node) node.style.display = val ? "none" : "inherit";
else log.error(el, " was not found in the window object");
})
}
this.settings = {
//Rendering
showSkidBtn: {
pre: "<div class='setHed'>Rendering</div>",
name: "Show Skid Button",
val: true,
html: () => this.generateSetting("checkbox", "showSkidBtn",
this),
set: (value, init) => {
let button = document.getElementById("mainButton");
if (!this.isDefined(button)) this.createButton("5k1D",
"https://i.imgur.com/1tWAEJx.gif", this.toggleMenu, value)
else button.style.display = value ? "inherit" : "none";
}
},
hideAdverts: {
name: "Hide Advertisments",
val: true,
html: () => this.generateSetting("checkbox", "hideAdverts",
this),
set: (value, init) => {
if (value) this.mainCustomRule("insert",
this.css.hideAdverts);
else if (!init) this.mainCustomRule("delete",
this.css.hideAdverts);
}
},
hideStreams: {
name: "Hide Streams",
val: false,
html: () => this.generateSetting("checkbox", "hideStreams",
this),
set: (value) => { this.displayStyle("streamContainer", value) }
},
hideMerch: {
name: "Hide Merch",
val: false,
html: () => this.generateSetting("checkbox", "hideMerch",
this),
set: (value) => { this.displayStyle("merchHolder", value) }
},
hideNewsConsole: {
name: "Hide News Console",
val: false,
html: () => this.generateSetting("checkbox", "hideNewsConsole",
this),
set: (value) => { this.displayStyle("newsHolder", value) }
},
hideCookieButton: {
name: "Hide Security Manage Button",
val: false,
html: () => this.generateSetting("checkbox",
"hideCookieButton", this),
set: (value) => { this.displayStyle("onetrust-consent-sdk",
value) }
},
noTextShadows: {
name: "Remove Text Shadows",
val: false,
html: () => this.generateSetting("checkbox", "noTextShadows",
this),
set: (value, init) => {
if (value) this.mainCustomRule("insert",
this.css.noTextShadows);
else if (!init) this.mainCustomRule("delete",
this.css.noTextShadows);
}
},
customCSS: {
name: "Custom CSS",
val: "",
html: () => this.generateSetting("url", "customCSS", "URL to
CSS file"),
resources: { css: document.createElement("link") },
set: (value, init) => {
if (value.startsWith("http")&&value.endsWith(".css")) {
//let proxy = 'https://cors-anywhere.herokuapp.com/';
this.settings.customCSS.resources.css.href = value
}
if (init) {
this.settings.customCSS.resources.css.rel =
"stylesheet"
try {
document.getElementsByTagName('head')
[0].appendChild(this.settings.customCSS.resources.css)
} catch(e) {
alert(e)
this.settings.customCSS.resources.css = null
}
}
}
},
renderESP: {
name: "Player ESP Type",
val: "off",
html: () =>
this.generateSetting("select", "renderESP",
this.lists.renderESP),
},
renderTracers: {
name: "Player Tracers",
val: false,
html: () => this.generateSetting("checkbox", "renderTracers"),
},
rainbowColor: {
name: "Rainbow ESP",
val: false,
html: () => this.generateSetting("checkbox", "rainbowColor"),
},
renderChams: {
name: "Player Chams",
val: "off",
html: () =>
this.generateSetting(
"select",
"renderChams",
this.lists.renderChams
),
},
renderWireFrame: {
name: "Player Wireframe",
val: false,
html: () => this.generateSetting("checkbox",
"renderWireFrame"),
},
customBillboard: {
name: "Custom Billboard Text",
val: "",
html: () =>
this.generateSetting(
"text",
"customBillboard",
"Custom Billboard Text"
),
},
//Weapon
autoReload: {
pre: "<br><div class='setHed'>Weapon</div>",
name: "Auto Reload",
val: false,
html: () => this.generateSetting("checkbox", "autoReload"),
},
autoAim: {
name: "Auto Aim Type",
val: "off",
html: () =>
this.generateSetting("select", "autoAim", this.lists.autoAim),
},
frustrumCheck: {
name: "Line of Sight Check",
val: false,
html: () => this.generateSetting("checkbox", "frustrumCheck"),
},
wallPenetrate: {
name: "Aim through Penetratables",
val: false,
html: () => this.generateSetting("checkbox", "wallPenetrate"),
},
weaponZoom: {
name: "Weapon Zoom",
val: 1.0,
min: 0,
max: 50.0,
step: 0.01,
html: () => this.generateSetting("slider", "weaponZoom"),
set: (value) => { if (this.renderer) this.renderer.adsFovMlt =
value;}
},
weaponTrails: {
name: "Weapon Trails",
val: false,
html: () => this.generateSetting("checkbox", "weaponTrails"),
set: (value) => { if (this.me) this.me.weapon.trail = value;}
},
//Player
autoBhop: {
pre: "<br><div class='setHed'>Player</div>",
name: "Auto Bhop Type",
val: "off",
html: () => this.generateSetting("select", "autoBhop",
this.lists.autoBhop),
},
thirdPerson: {
name: "Third Person",
val: false,
html: () => this.generateSetting("checkbox", "thirdPerson"),
set: (value, init) => {
if (value) this.thirdPerson = 1;
else if (!init) this.thirdPerson = undefined;
}
},
skinUnlock: {
name: "Unlock Skins",
val: false,
html: () => this.generateSetting("checkbox", "skinUnlock",
this),
},
fakeDev: {
name: "Fake Developer",
val: false,
html: () => this.generateSetting("checkbox", "fakeDev", this),
},
//GamePlay
disableWpnSnd: {
pre: "<br><div class='setHed'>GamePlay</div>",
name: "Disable Players Weapon Sounds",
val: false,
html: () => this.generateSetting("checkbox", "disableWpnSnd",
this),
},
disableHckSnd: {
name: "Disable Hacker Fart Sounds",
val: false,
html: () => this.generateSetting("checkbox", "disableHckSnd",
this),
},
autoActivateNuke: {
name: "Auto Activate Nuke",
val: false,
html: () => this.generateSetting("checkbox",
"autoActivateNuke", this),
},
autoFindNew: {
name: "New Lobby Finder",
val: false,
html: () => this.generateSetting("checkbox", "autoFindNew",
this),
},
autoClick: {
name: "Auto Start Game",
val: false,
html: () => this.generateSetting("checkbox", "autoClick",
this),
},
inActivity: {
name: "No InActivity Kick",
val: true,
html: () => this.generateSetting("checkbox", "autoClick",
this),
},
//Radio Stream Player
playStream: {
pre: "<br><div class='setHed'>Radio Stream Player</div>",
name: "Stream Select",
val: "off",
html: () => this.generateSetting("select", "playStream",
this.lists.audioStreams),
set: (value) => {
if (value == "off") {
if ( this.settings.playStream.audio ) {
this.settings.playStream.audio.pause();
this.settings.playStream.audio.currentTime = 0;
this.settings.playStream.audio = null;
}
return;
}
let url = this.settings.playStream.urls[value];
if (!this.settings.playStream.audio) {
this.settings.playStream.audio = new Audio(url);
this.settings.playStream.audio.volume =
this.settings.audioVolume.val||0.5
} else {
this.settings.playStream.audio.src = url;
}
this.settings.playStream.audio.load();
this.settings.playStream.audio.play();
},
urls: {
_2000s: 'http://0n-2000s.radionetz.de/0n-2000s.aac',
_HipHopRNB: 'https://stream-mixtape-
geo.ntslive.net/mixtape2',
_Country: 'https://live.wostreaming.net/direct/wboc-
waaifmmp3-ibc2',
_Dance: 'http://streaming.radionomy.com/A-RADIO-TOP-40',
_Pop: 'http://bigrradio.cdnstream1.com/5106_128',
_Jazz: 'http://strm112.1.fm/ajazz_mobile_mp3',
_Oldies: 'http://strm112.1.fm/60s_70s_mobile_mp3',
_Club: 'http://strm112.1.fm/club_mobile_mp3',
_Folk: 'https://freshgrass.streamguys1.com/irish-128mp3',
_ClassicRock: 'http://1a-classicrock.radionetz.de/1a-
classicrock.mp3',
_Metal: 'http://streams.radiobob.de/metalcore/mp3-192',
_DeathMetal: 'http://stream.laut.fm/beatdownx',
_Classical: 'http://live-
radio01.mediahubaustralia.com/FM2W/aac/',
_Alternative: 'http://bigrradio.cdnstream1.com/5187_128',
_Dubstep: 'http://streaming.radionomy.com/R1Dubstep?
lang=en',
_Lowfi: 'http://streams.fluxfm.de/Chillhop/mp3-256',
_Oldskool: 'http://streams.90s90s.de/hiphop/mp3-128/',
},
audio: null,
},
audioVolume: {
name: "Radio Volume",
val: 0.5,
min: 0,
max: 1,
step: 0.01,
html: () => this.generateSetting("slider", "audioVolume"),
set: (value) => { if (this.settings.playStream.audio)
this.settings.playStream.audio.volume = value;}
},
};
if ('indexedDB' in window) {
resetSettings() {
if (confirm("Are you sure you want to reset all your settings? This
will also refresh the page")) {
// Object.keys(localStorage).filter(x =>
x.includes("kro_utilities_")).forEach(x => localStorage.removeItem(x));
if (this.isDefined(skid.db)) {
skid.db.deleteObjectStore('settings')
}
location.reload();
}
}
setSetting(t, e) {
this.settings[t].val = e;
//this.saveVal(t, e);
if (document.getElementById(`slid_utilities_${t}`))
document.getElementById(`slid_utilities_${t}`).innerHTML = e;
if (this.settings[t].set) this.settings[t].set(e);
if (this.isDefined(skid.db)) {
let transaction = skid.db.transaction("settings", "readwrite"); //
(1)
let objectStore = transaction.objectStore("settings"); // (2)
let tempSettings = {};
for (let key in skid.settings) {
tempSettings[key] = skid.settings[key].val;
}
let encoded = window.btoa(JSON.stringify(tempSettings));
let settings = { id: 'skidfest', data: encoded };
let storeRequest = objectStore.put(settings); // (3)
storeRequest.onerror = event => {
console.log("Error", event.target.error);
}
storeRequest.onsuccess = event => {
console.log("Set", t, ":", e, "to", event.target.result,
"store");
}
}
}
objectHas(obj, arr) {
return arr.some(prop => obj.hasOwnProperty(prop));
}
getVersion() {
// const elems = document.getElementsByClassName('terms');
//const version = elems[elems.length - 1].innerText;
return this.version//version;
}
isElectron() {
// Renderer process
if (typeof window !== 'undefined' && typeof window.process === 'object'
&& window.process.type === 'renderer') {
return true;
}
// Main process
if (typeof process !== 'undefined' && typeof process.versions ===
'object' && !!process.versions.electron) {
return true;
}
return false;
}
saveAs(name, data) {
let blob = new Blob([data], {type: 'text/plain'});
let el = window.document.createElement("a");
el.href = window.URL.createObjectURL(blob);
el.download = name;
window.document.body.appendChild(el);
el.click();
window.document.body.removeChild(el);
}
saveScript() {
this.fetchScript().then(script => {
this.saveAs("game_" + this.getVersion() + ".js", script)
})
}
saveStyleSheet() {
new Array(...document.styleSheets).map(css => {
if (css.href) {
let arr = /http.*?krunker.io\/css\/(\w+.css).+/.exec(css.href);
if (arr && arr[1]) {
let name = arr[1];
if (name && name.includes("main")) {
let cssText = Array.from(css.cssRules).reduce((prev,
cssRule) => {
return prev + '\n' + cssRule.cssText
}, '')
this.saveAs(name, cssText);
}
}
}
})
}
mainCustomRule(action, rule) {
const rules = this.mainCustom.cssRules;
if (action == "insert") this.mainCustom.insertRule(rule);
else if (action == "delete") {
for (let i = 0; i < rules.length; i++) {
if (rules[i].cssText == rule) {
this.mainCustom.deleteRule(i);
}
}
} else log.error(action + " not Implemented for mainCustomRule")
}
isKeyDown(key) {
return this.downKeys.has(key);
}
simulateKey(keyCode) {
var oEvent = document.createEvent('KeyboardEvent');
// Chromium Hack
Object.defineProperty(oEvent, 'keyCode', {
get : function() {
return this.keyCodeVal;
}
});
Object.defineProperty(oEvent, 'which', {
get : function() {
return this.keyCodeVal;
}
});
if (oEvent.initKeyboardEvent) {
oEvent.initKeyboardEvent("keypress", true, true,
document.defaultView, keyCode, keyCode, "", "", false, "");
} else {
oEvent.initKeyEvent("keypress", true, true, document.defaultView,
false, false, false, false, keyCode, 0);
}
oEvent.keyCodeVal = keyCode;
if (oEvent.keyCode !== keyCode) {
alert("keyCode mismatch " + oEvent.keyCode + "(" + oEvent.which +
")");
}
document.body.dispatchEvent(oEvent);
}
toggleMenu() {
let lock = document.pointerLockElement ||
document.mozPointerLockElement;
if (lock) document.exitPointerLock();
window.showWindow(12);
if (this.isDefined(window.SOUND)) window.SOUND.play(`tick_0`,0.1)
}
onLoad() {
this.waitFor(_=>document.documentElement instanceof
window.HTMLElement).then(_=>{
this.iframe();
})
this.createObservers();
this.defineProperties();
this.waitFor(_=>this.token).then(_ => {
//this.saveScript();
if (!this.token) location.reload();
this.version = /\['exports']\
['gameVersion']='(\d+\.\d+\.\d+)',/.exec(this.gameJS)[1];
if ( this.isElectron() || !this.isDefined(GM) ) {
const loader = new Function("WP_fetchMMToken", "Module",
this.gamePatch());
return loader(new Promise(res=>res(this.token)), { csv: async
() => 0 });
} else if (GM.info.script.version !== this.version) {
alert("This Script Needs Updating by Skidlamer, visit The
GamingGurus Discord");
return
window.location.assign("https://skidlamer.github.io/wp");
} else {
const loader = new Function("WP_fetchMMToken", "Module",
this.gamePatch());
return loader(new Promise(res=>res(this.token)), { csv: async
() => 0 });
}
})
this.waitFor(_=>this.exports, 3e4).then(exports => {
if (!exports) return alert("This Script needs updating");
else {
//console.dir(exports)
let toFind = {
overlay: ["render", "canvas"],
config: ["accAnnounce", "availableRegions", "assetCat"],
three: ["ACESFilmicToneMapping", "TextureLoader",
"ObjectLoader"],
//ws: ["socketReady", "ingressPacketCount",
"ingressPacketCount", "egressDataSize"],
//utility: ["VectorAdd", "VectorAngleSign"],
//colors: ["challLvl", "getChallCol"],
//ui: ["showEndScreen", "toggleControlUI",
"toggleEndScreen", "updatePlayInstructions"],
//events: ["actions", "events"],
}
for (let rootKey in this.exports) {
let exp = this.exports[rootKey].exports;
for (let name in toFind) {
if (this.objectHas(exp, toFind[name])) {
log.info("Found Export ", name);
delete toFind[name];
this[name] = exp;
}
}
}
if (!(Object.keys(toFind).length === 0 && toFind.constructor
=== Object)) {
for (let name in toFind) {
alert("Failed To Find Export " + name);
}
} else {
Object.defineProperty(this.config, "nameVisRate", {
value: 0,
writable: false,
configurable: true,
})
this.ctx = this.overlay.canvas.getContext('2d');
this.overlay.render = new Proxy(this.overlay.render, {
apply: function(target, that, args) {
return [target.apply(that, args),
render.apply(that, args)]
}
})
function render(scale, game, controls, renderer, me) {
let width = skid.overlay.canvas.width / scale;
let height = skid.overlay.canvas.height / scale;
const renderArgs = [scale, game, controls, renderer,
me];
if (renderArgs && void 0 !== skid) {
["scale", "game", "controls", "renderer",
"me"].forEach((item, index)=>{
skid[item] = renderArgs[index];
});
if (me) {
skid.ctx.save();
skid.ctx.scale(scale, scale);
//this.ctx.clearRect(0, 0, width, height);
skid.onRender();
//window.requestAnimationFrame.call(window,
renderArgs.callee.caller.bind(this));
skid.ctx.restore();
}
if(skid.settings && skid.settings.autoClick.val &&
window.endUI.style.display == "none" && window.windowHolder.style.display ==
"none") {
controls.toggle(true);
}
}
}
// Skins
const $skins = Symbol("skins");
Object.defineProperty(Object.prototype, "skins", {
set: function(fn) {
this[$skins] = fn;
if (void 0 == this.localSkins ||
!this.localSkins.length) {
this.localSkins = Array.apply(null,
Array(5e3)).map((x, i) => {
return {
ind: i,
cnt: 0x1,
}
})
}
return fn;
},
get: function() {
return skid.settings.skinUnlock.val && this.stats ?
this.localSkins : this[$skins];
}
})
this.waitFor(_=>this.ws, Infinity).then(_=> {
this.wsEvent = this.ws._dispatchEvent.bind(this.ws);
this.wsSend = this.ws.send.bind(this.ws);
this.ws.send = new Proxy(this.ws.send, {
apply: function(target, that, args) {
if (args[0] == "ah2") return;
try {
var original_fn =
Function.prototype.apply.apply(target, [that, args]);
} catch (e) {
e.stack = e.stack =
e.stack.replace(/\n.*Object\.apply.*/, '');
throw e;
}
return original_fn;
}
})
this.ws._dispatchEvent = new
Proxy(this.ws._dispatchEvent, {
apply: function(target, that, [type, event]) {
if (type =="init") {
//console.log(event)
if(event[10] && event[10].length &&
event[10].bill && skid.settings.customBillboard.val.length > 1) {
event[10].bill.txt =
skid.settings.customBillboard.val;
}
}
if (skid.settings.skinUnlock.val &&
skid.skinCache && type === "0") {
let skins = skid.skinCache;
let pInfo = event[0];
let pSize = 38;
while (pInfo.length % pSize !== 0) pSize++;
for(let i = 0; i < pInfo.length; i +=
pSize) {
if (pInfo[i] === skid.ws.socketId||0) {
pInfo[i + 12] = [skins.main,
skins.secondary];
pInfo[i + 13] = skins.hat;
pInfo[i + 14] = skins.body;
pInfo[i + 19] = skins.knife;
pInfo[i + 24] = skins.dye;
pInfo[i + 33] = skins.waist;
}
}
}
if (this.isDefined(window.SOUND)) {
window.SOUND.play = new Proxy(window.SOUND.play, {
apply: function(target, that, [src, vol, loop,
rate]) {
if ( src.startsWith("fart_") &&
skid.settings.disableHckSnd.val ) return;
return target.apply(that, [src, vol, loop,
rate]);
}
})
}
AudioParam.prototype.setValueAtTime = new
Proxy(AudioParam.prototype.setValueAtTime, {
apply: function(target, that, [value, startTime]) {
return target.apply(that, [value, 0]);
}
})
gamePatch() {
let entries = {
// Deobfu
inView: { regex: /(\w+\['(\w+)']\){if\(\(\w+=\w+\['\w+']\
['position']\['clone']\(\))/, index: 2 },
spectating: { regex: /\['team']:window\['(\w+)']/, index: 1 },
//inView: { regex: /\]\)continue;if\(!\w+\['(.+?)\']\)continue;/,
index: 1 },
//canSee: { regex: /\w+\['(\w+)']\(\w+,\w+\['x'],\w+\['y'],\w+\
['z']\)\)&&/, index: 1 },
//procInputs: { regex: /this\['(\w+)']=function\((\w+),
(\w+),\w+,\w+\){(this)\['recon']/, index: 1 },
aimVal: { regex: /this\['(\w+)']-=0x1\/\(this\['weapon']\
['\w+']\/\w+\)/, index: 1 },
pchObjc: { regex: /0x0,this\['(\w+)']=new \w+\['Object3D']\
(\),this/, index: 1 },
didShoot: { regex: /--,\w+\['(\w+)']=!0x0/, index: 1 },
nAuto: { regex: /'Single\\x20Fire','varN':'(\w+)'/, index: 1 },
crouchVal: { regex: /this\['(\w+)']\+=\w\['\w+']\*\w+,0x1<=this\
['\w+']/, index: 1 },
recoilAnimY: { regex: /\+\(-Math\['PI']\/0x4\*\w+\+\w+\
['(\w+)']\*\w+\['\w+']\)\+/, index: 1 },
//recoilAnimY: { regex: /this\['recoilAnim']=0x0,this\[(.*?\
(''\))]/, index: 1 },
ammos: { regex: /\['length'];for\(\w+=0x0;\w+<\w+\['(\w+)']\
['length']/, index: 1 },
weaponIndex: { regex: /\['weaponConfig']\[\w+]\['secondary']&&\
(\w+\['(\w+)']==\w+/, index: 1 },
isYou: { regex: /0x0,this\['(\w+)']=\w+,this\['\w+']=!0x0,this\
['inputs']/, index: 1 },
objInstances: { regex: /\w+\['\w+']\(0x0,0x0,0x0\);if\(\w+\
['(\w+)']=\w+\['\w+']/, index: 1 },
getWorldPosition: { regex: /{\w+=\w+\['camera']\['(\w+)']\(\);/,
index: 1 },
//mouseDownL: { regex: /this\['\w+'\]=function\(\){this\
['(\w+)'\]=\w*0,this\['(\w+)'\]=\w*0,this\['\w+'\]={}/, index: 1 },
mouseDownR: { regex: /this\['(\w+)']=0x0,this\['keys']=/, index: 1
},
//reloadTimer: { regex: /this\['(\w+)']&&\(\w+\['\w+']\
(this\),\w+\['\w+']\(this\)/, index: 1 },
maxHealth: { regex: /this\['health']\/this\['(\w+)']\?/, index: 1
},
xDire: { regex: /this\['(\w+)']=Math\['lerpAngle']\(this\
['xDir2']/, index: 1 },
yDire: { regex: /this\['(\w+)']=Math\['lerpAngle']\(this\
['yDir2']/, index: 1 },
//xVel: { regex: /this\['x']\+=this\['(\w+)']\*\w+\['map']\
['config']\['speedX']/, index: 1 },
yVel: { regex: /this\['(\w+)']=this\['\w+'],this\['visible']/,
index: 1 },
//zVel: { regex: /this\['z']\+=this\['(\w+)']\*\w+\['map']\
['config']\['speedZ']/, index: 1 },
//socket: { regex: /this\['(\w+)']\['onmessage']/, index: 1 },
// Patches
exports: {regex: /(this\['\w+']\['\w+']\(this\);};},function\
(\w+,\w+,(\w+)\){)/, patch: `$1 ${skidStr}.exports=$2.c;
${skidStr}.modules=$2.m;`},
inputs: {regex: /(\w+\['\w+']\[\w+\['\w+']\['\w+']\?'\w+':'push']\
()(\w+)\),/, patch: `$1${skidStr}.onInput($2)),`},
inView: {regex: /&&(\w+\['\w+'])\){(if\(\(\w+=\w+\['\w+']\['\w+']\
['\w+'])/, patch: `){if(!$1&&void 0 !== ${skidStr}.nameTags)continue;$2`},
socket: {regex: /this\['\w+']=new WebSocket\(\w+\)/, patch:
`${skidStr}.ws=this;$&`},
thirdPerson:{regex: /(\w+)\[\'config\'\]\[\'thirdPerson\'\]/g,
patch: `void 0 !== ${skidStr}.thirdPerson`},
isHacker:{regex: /(window\['\w+']=)!0x0\)/, patch: `$1!0x1)`},
fixHowler:{regex: /(Howler\['orientation'](.+?)\)\),)/, patch: ``},
respawnT:{regex: /'\w+':0x3e8\*/g, patch: `'respawnT':0x0*`},
anticheat1:{regex: /&&\w+\(\),window\['utilities']&&\(\w+\
(null,null,null,!0x0\),\w+\(\)\)/, patch: ""},
anticheat2:{regex: /(\[]instanceof Array;).*?(var)/, patch: "$1
$2"},
anticheat3:{regex: /windows\['length'\]>\d+.*?0x25/, patch:
`0x25`},
//anticheat4:{regex: /(\w+\=)\(!menuItemContainer\['innerHTML']\
['includes'].*?\);/, patch: `$1false;`},
//anticheat4:{regex: /kro_utilities_/g, patch:
`K_P_A_L__IS__A__G_A_Y__P_E_D_O`},
//kpal:{regex: /1tWAEJx/g, patch:
`K_P_A_L__IS__A__G_A_Y__P_E_D_O`},
//kpal2:{regex: /jjkFpnV/g, patch:
`K_P_A_L__IS__A__G_A_Y__P_E_D_O`},
commandline:{regex: /Object\['defineProperty']\(console.*?\),/,
patch: ""},
writeable:{regex: /'writeable':!0x1/g, patch: "writeable:true"},
configurable:{regex: /'configurable':!0x1/g, patch:
"configurable:true"},
typeError:{regex: /throw new TypeError/g, patch: "console.error"},
error:{regex: /throw new Error/g, patch: "console.error"},
};
let script = this.gameJS;
for(let name in entries) {
let object = entries[name];
let found = object.regex.exec(script);
if (object.hasOwnProperty('index')) {
if (!found) {
object.val = null;
alert("Failed to Find " + name);
} else {
object.val = found[object.index];
log.info ("Found ", name, ":", object.val);
}
Object.defineProperty(skid.vars, name, {
configurable: false,
value: object.val
});
} else if (found) {
script = script.replace(object.regex, object.patch);
log.info ("Patched ", name);
} else log.error("Failed to Patch " + name);
}
return script;
}
iframe() {
const iframe = document.createElement('iframe');
iframe.setAttribute('style', 'display:none');
iframe.setAttribute("id", skidStr);
iframe.src = location.origin;
document.documentElement.appendChild(iframe);
let skidneySplizy = 0;
ifrWin.TextDecoder.prototype.decode = new
Proxy(window.TextDecoder.prototype.decode, {
apply: function(target, that, args) {
let string = Reflect.apply(...arguments);
if (string.length > 5e4) {
log.warn("skidneySplizy = " + skidneySplizy);
if (skidneySplizy == 0) {
skid.gameJS = string;
} else {
skid.gameJS += string;
} skidneySplizy ++;
//console.log(string.length)
/*
if (!skid.gameJS) {
skid.gameJS = string;
console.log("1stSTR");
} else {
skid.gameJS += string;
console.log("2ndSTR");
}
*/
} //else //console.log(string.length)
if (string.includes("generate-token")) skid.generated = true;
else if (string.length == 40||skid.generated) {
skid.token = string;
log.info("Token ", string);
document.documentElement.removeChild(iframe);
}
return string;
},
});
}
defineProperties() {
let values = {updateItems:null}
Object.defineProperties(Object.prototype, {
isDev: {
get() { return skid.settings && skid.settings.fakeDev &&
skid.settings.fakeDev.val },
set(val) { return true }
},
});
}
createObservers() {
if (br) {
continue;
}
xmin = (xmin + 1) / 2;
ymin = (ymin + 1) / 2;
xmax = (xmax + 1) / 2;
ymax = (ymax + 1) / 2;
//Tracers
if (this.settings.renderTracers.val) {
CRC2d.save.apply(this.ctx, []);
let screenPos =
this.world2Screen(player[this.vars.objInstances].position);
this.ctx.lineWidth = 4.5;
this.ctx.beginPath();
this.ctx.moveTo(this.ctx.canvas.width/2, this.ctx.canvas.height
- (this.ctx.canvas.height - scaledHeight));
this.ctx.lineTo(screenPos.x, screenPos.y);
this.ctx.strokeStyle = "rgba(0, 0, 0, 0.25)";
this.ctx.stroke();
this.ctx.lineWidth = 2.5;
this.ctx.strokeStyle = this.settings.rainbowColor.val ?
this.overlay.rainbow.col : "#eb5656"
this.ctx.stroke();
CRC2d.restore.apply(this.ctx, []);
}
CRC2d.save.apply(this.ctx, []);
if (espVal == "twoD" || espVal == "full") {
// perfect box esp
this.ctx.lineWidth = 5;
this.ctx.strokeStyle = this.settings.rainbowColor.val ?
this.overlay.rainbow.col : "#eb5656"
let distanceScale = Math.max(.3, 1 -
this.getD3D(worldPosition.x, worldPosition.y, worldPosition.z, player.x, player.y,
player.z) / 600);
CRC2d.scale.apply(this.ctx, [distanceScale, distanceScale]);
let xScale = scaledWidth / distanceScale;
let yScale = scaledHeight / distanceScale;
CRC2d.beginPath.apply(this.ctx, []);
ymin = yScale * (1 - ymin);
ymax = yScale * (1 - ymax);
xmin = xScale * xmin;
xmax = xScale * xmax;
CRC2d.moveTo.apply(this.ctx, [xmin, ymin]);
CRC2d.lineTo.apply(this.ctx, [xmin, ymax]);
CRC2d.lineTo.apply(this.ctx, [xmax, ymax]);
CRC2d.lineTo.apply(this.ctx, [xmax, ymin]);
CRC2d.lineTo.apply(this.ctx, [xmin, ymin]);
CRC2d.stroke.apply(this.ctx, []);
if (espVal == "full") {
// health bar
this.ctx.fillStyle = "#000000";
let barMaxHeight = ymax - ymin;
CRC2d.fillRect.apply(this.ctx, [xmin - 7, ymin, -10,
barMaxHeight]);
this.ctx.fillStyle = player.health > 75 ? "green" :
player.health > 40 ? "orange" : "red";
CRC2d.fillRect.apply(this.ctx, [xmin - 7, ymin, -10,
barMaxHeight * (player.health / player[this.vars.maxHealth])]);
// info
this.ctx.font = "Bold 48px Tahoma";
this.ctx.fillStyle = "white";
this.ctx.strokeStyle='black';
this.ctx.lineWidth = 1;
let x = xmax + 7;
let y = ymax;
CRC2d.fillText.apply(this.ctx, [player.name||player.alias,
x, y]);
CRC2d.strokeText.apply(this.ctx,
[player.name||player.alias, x, y]);
this.ctx.font = "Bold 30px Tahoma";
this.ctx.fillStyle = "#cccccc";
y += 35;
CRC2d.fillText.apply(this.ctx, [player.weapon.name, x, y]);
CRC2d.strokeText.apply(this.ctx, [player.weapon.name, x,
y]);
y += 35;
this.ctx.fillStyle = player.health > 75 ? "green" :
player.health > 40 ? "orange" : "red";
CRC2d.fillText.apply(this.ctx, [player.health + ' HP', x,
y]);
CRC2d.strokeText.apply(this.ctx, [player.health + ' HP', x,
y]);
}
}
CRC2d.restore.apply(this.ctx, []);
this.ctx.strokeStyle = original_strokeStyle;
this.ctx.lineWidth = original_lineWidth;
this.ctx.font = original_font;
this.ctx.fillStyle = original_fillStyle;
// Chams
const obj = player[this.vars.objInstances];
if (this.isDefined(obj)) {
if (!obj.visible) {
Object.defineProperty(player[this.vars.objInstances],
'visible', {
value: true,
writable: false
});
} else {
let chamColor = this.settings.renderChams.val;
let chamsEnabled = chamColor !== "off";
//if (dog.gaybow >= 360) dog.gaybow = 0; else dog.gaybow++;
obj.traverse(child => {
if (child && child.type == "Mesh" &&
this.isDefined(child.material)) {
if (!child.hasOwnProperty(skidStr)) {
child[skidStr] = child.material;
} else if (child.hasOwnProperty(skidStr)) {
Object.defineProperty(child, 'material', {
get(){
return !chamsEnabled ? this[skidStr] :
new skid.three.MeshBasicMaterial({
color: new
skid.three.Color(chamColor == "Rainbow" ? skid.overlay.rainbow.col : chamColor),
depthTest: false,
transparent: true,
fog: false,
wireframe:
skid.settings.renderWireFrame.val
})
}
});
}
}
})
}
}
}
}
spinTick(input) {
//this.game.players.getSpin(this.self);
//this.game.players.saveSpin(this.self, angle);
const angle = this.getAngleDst(input[2], this.me[this.vars.xDire]);
this.spins = this.getStatic(this.spins, new Array());
this.spinTimer = this.getStatic(this.spinTimer, this.config.spinTimer);
this.serverTickRate = this.getStatic(this.serverTickRate,
this.config.serverTickRate);
(this.spins.unshift(angle), this.spins.length > this.spinTimer /
this.serverTickRate && (this.spins.length = Math.round(this.spinTimer /
this.serverTickRate)))
for (var e = 0, i = 0; i < this.spins.length; ++i) e += this.spins[i];
return Math.abs(e * (180 / Math.PI));
}
raidBot(input) {
let target = this.game.AI.ais.filter(enemy => {
return undefined !== enemy.mesh && enemy.mesh &&
enemy.mesh.children[0] && enemy.canBSeen && enemy.health > 0
}).sort((p1, p2) => this.getD3D(this.me.x, this.me.z, p1.x, p1.z) -
this.getD3D(this.me.x, this.me.z, p2.x, p2.z)).shift();
if (target) {
let canSee = this.containsPoint(target.mesh.position)
let yDire = (this.getDir(this.me.z, this.me.x, target.z, target.x)
|| 0)
let xDire = ((this.getXDire(this.me.x, this.me.y, this.me.z,
target.x, target.y + target.mesh.children[0].scale.y * 0.85, target.z) || 0) -
this.consts.recoilMlt * this.me[this.vars.recoilAnimY])
if (this.me.weapon[this.vars.nAuto] && this.me[this.vars.didShoot])
{ input[this.key.shoot] = 0; input[this.key.scope] = 0; this.me.inspecting = false;
this.me.inspectX = 0; }
else {
if (!this.me.aimDir && canSee) {
input[this.key.scope] = 1;
if (!this.me[this.vars.aimVal]||this.me.weapon.noAim) {
input[this.key.shoot] = 1;
input[this.key.ydir] = yDire * 1e3
input[this.key.xdir] = xDire * 1e3
this.lookDir(xDire, yDire);
}
}
}
} else {
this.resetLookAt();
}
return input;
}
onInput(input) {
if (this.isDefined(this.config) && this.config.aimAnimMlt)
this.config.aimAnimMlt = 1;
if (this.isDefined(this.controls) && this.isDefined(this.config) &&
this.settings.inActivity.val) {
this.controls.idleTimer = 0;
this.config.kickTimer = Infinity
}
if (this.me) {
this.inputFrame ++;
if (this.inputFrame >= 100000) this.inputFrame = 0;
if (!this.game.playerSound[this.isProxy]) {
this.game.playerSound = new Proxy(this.game.playerSound, {
apply: function(target, that, args) {
if (skid.settings.disableWpnSnd.val && args[0] &&
typeof args[0] == "string" && args[0].startsWith("weapon_")) return;
return target.apply(that, args);
},
get: function(target, key) {
return key === skid.isProxy ? true :
Reflect.get(target, key);
},
})
}
let isMelee =
this.isDefined(this.me.weapon.melee)&&this.me.weapon.melee||this.isDefined(this.me.
weapon.canThrow)&&this.me.weapon.canThrow;
let ammoLeft = this.me[this.vars.ammos]
[this.me[this.vars.weaponIndex]];
// autoReload
if (this.settings.autoReload.val) {
//let capacity = this.me.weapon.ammo;
//if (ammoLeft < capacity)
if (isMelee) {
if (!this.me.canThrow) {
//this.me.refillKnife();
}
} else if (!ammoLeft) {
this.game.players.reload(this.me);
input[this.key.reload] = 1;
// this.me[this.vars.reloadTimer] = 1;
//this.me.resetAmmo();
}
}
//Auto Bhop
let autoBhop = this.settings.autoBhop.val;
if (autoBhop !== "off") {
if (this.isKeyDown("Space") || autoBhop == "autoJump" ||
autoBhop == "autoSlide") {
this.controls.keys[this.controls.binds.jumpKey.val] ^= 1;
if (this.controls.keys[this.controls.binds.jumpKey.val]) {
this.controls.didPressed[this.controls.binds.jumpKey.val] = 1;
}
if (this.isKeyDown("Space") || autoBhop == "autoSlide") {
if (this.me[this.vars.yVel] < -0.03 &&
this.me.canSlide) {
setTimeout(() => {
this.controls.keys[this.controls.binds.crouchKey.val] = 0;
}, this.me.slideTimer||325);
this.controls.keys[this.controls.binds.crouchKey.val] = 1;
this.controls.didPressed[this.controls.binds.crouchKey.val] = 1;
}
}
}
}
//Autoaim
if (this.settings.autoAim.val !== "off") {
this.playerMaps.length = 0;
this.rayC.setFromCamera(this.vec2, this.renderer.fpsCamera);
let target = this.game.players.list.filter(enemy => {
let hostile = undefined !== enemy[this.vars.objInstances]
&& enemy[this.vars.objInstances] && !enemy[this.vars.isYou] &&
!this.getIsFriendly(enemy) && enemy.health > 0 && this.getInView(enemy);
if (hostile) this.playerMaps.push(
enemy[this.vars.objInstances] );
return hostile
}).sort((p1, p2) => this.getD3D(this.me.x, this.me.z, p1.x,
p1.z) - this.getD3D(this.me.x, this.me.z, p2.x, p2.z)).shift();
if (target) {
//let count = this.spinTick(input);
//if (count < 360) {
// input[2] = this.me[this.vars.xDire] + Math.PI;
//} else console.log("spins ", count);
//target.jumpBobY * this.config.jumpVel
let canSee =
this.containsPoint(target[this.vars.objInstances].position);
let inCast = this.rayC.intersectObjects(this.playerMaps,
true).length;
let yDire = (this.getDir(this.me.z, this.me.x, target.z,
target.x) || 0);
let xDire = ((this.getXDire(this.me.x, this.me.y,
this.me.z, target.x, target.y - target[this.vars.crouchVal] * this.consts.crouchDst
+ this.me[this.vars.crouchVal] * this.consts.crouchDst, target.z) || 0) -
this.consts.recoilMlt * this.me[this.vars.recoilAnimY])
if (this.me.weapon[this.vars.nAuto] &&
this.me[this.vars.didShoot]) {
input[this.key.shoot] = 0;
input[this.key.scope] = 0;
this.me.inspecting = false;
this.me.inspectX = 0;
}
else if (!canSee && this.settings.frustrumCheck.val)
this.resetLookAt();
else if (ammoLeft||isMelee) {
input[this.key.scope] = this.settings.autoAim.val ===
"assist"||this.settings.autoAim.val === "correction"||this.settings.autoAim.val ===
"trigger" ? this.controls[this.vars.mouseDownR] : 0;
switch (this.settings.autoAim.val) {
case "quickScope":
input[this.key.scope] = 1;
if
(!this.me[this.vars.aimVal]||this.me.weapon.noAim) {
if (!this.me.canThrow||!isMelee)
input[this.key.shoot] = 1;
input[this.key.ydir] = yDire * 1e3
input[this.key.xdir] = xDire * 1e3
this.lookDir(xDire, yDire);
}
break;
case "assist": case "easyassist":
if (input[this.key.scope] ||
this.settings.autoAim.val === "easyassist") {
if (!this.me.aimDir && canSee ||
this.settings.autoAim.val === "easyassist") {
input[this.key.ydir] = yDire * 1e3
input[this.key.xdir] = xDire * 1e3
this.lookDir(xDire, yDire);
}
}
break;
case "silent":
if
(!this.me[this.vars.aimVal]||this.me.weapon.noAim) {
if (!this.me.canThrow||!isMelee)
input[this.key.shoot] = 1;
} else input[this.key.scope] = 1;
input[this.key.ydir] = yDire * 1e3
input[this.key.xdir] = xDire * 1e3
break;
case "trigger":
if (input[this.key.scope] && canSee && inCast)
{
input[this.key.shoot] = 1;
input[this.key.ydir] = yDire * 1e3
input[this.key.xdir] = xDire * 1e3
}
break;
case "correction":
if (input[this.key.shoot] == 1) {
input[this.key.ydir] = yDire * 1e3
input[this.key.xdir] = xDire * 1e3
}
break;
default:
this.resetLookAt();
break;
}
}
} else {
this.resetLookAt();
//input = this.raidBot(input);
}
}
}
//this.game.config.deltaMlt = 1
return input;
}
getAngleDst(a, b) {
return Math.atan2(Math.sin(b - a), Math.cos(a - b));
}
containsPoint(point) {
let planes = this.renderer.frustum.planes;
for (let i = 0; i < 6; i ++) {
if (planes[i].distanceToPoint(point) < 0) {
return false;
}
}
return true;
}
lineInRect(lx1, lz1, ly1, dx, dz, dy, x1, z1, y1, x2, z2, y2) {
let t1 = (x1 - lx1) * dx;
let t2 = (x2 - lx1) * dx;
let t3 = (y1 - ly1) * dy;
let t4 = (y2 - ly1) * dy;
let t5 = (z1 - lz1) * dz;
let t6 = (z2 - lz1) * dz;
let tmin = Math.max(Math.max(Math.min(t1, t2), Math.min(t3, t4)),
Math.min(t5, t6));
let tmax = Math.min(Math.min(Math.max(t1, t2), Math.max(t3, t4)),
Math.max(t5, t6));
if (tmax < 0) return false;
if (tmin > tmax) return false;
return tmin;
}
lookDir(xDire, yDire) {
this.controls.object.rotation.y = yDire
this.controls[this.vars.pchObjc].rotation.x = xDire;
this.controls[this.vars.pchObjc].rotation.x = Math.max(-
this.consts.halfPI, Math.min(this.consts.halfPI,
this.controls[this.vars.pchObjc].rotation.x));
this.controls.yDr = (this.controls[this.vars.pchObjc].rotation.x %
Math.PI).round(3);
this.controls.xDr = (this.controls.object.rotation.y %
Math.PI).round(3);
this.renderer.camera.updateProjectionMatrix();
this.renderer.updateFrustum();
}
resetLookAt() {
this.controls.yDr = this.controls[this.vars.pchObjc].rotation.x;
this.controls.xDr = this.controls.object.rotation.y;
this.renderer.camera.updateProjectionMatrix();
this.renderer.updateFrustum();
}
world2Screen (position) {
let pos = position.clone();
let scaledWidth = this.ctx.canvas.width / this.scale;
let scaledHeight = this.ctx.canvas.height / this.scale;
pos.project(this.renderer.camera);
pos.x = (pos.x + 1) / 2;
pos.y = (-pos.y + 1) / 2;
pos.x *= scaledWidth;
pos.y *= scaledHeight;
return pos;
}
getInView(entity) {
return null == this.getCanSee(this.me, entity.x, entity.y, entity.z);
}
getIsFriendly(entity) {
return (this.me && this.me.team ? this.me.team : this.me.spectating ?
0x1 : 0x0) == entity.team
}
}
//window.instructionHolder.style.display = "block";
// window.instructions.innerHTML = `<div id="settHolder"><img
src="https://i.imgur.com/yzb2ZmS.gif" width="25%"></div><a
href='https://skidlamer.github.io/wp/' target='_blank.'><div class="imageButton
discordSocial"></div></a>`