// ==UserScript==
// @name owopfuck.cc
// @namespace http://tampermonkey.net/
// @version 1.4
// @license MIT
// @description cool bot
// @author ukrainian nigger i censored
// @match *://augustberchelmann.com/owop/*
// @match *://ourworldofpixels.com/*
// @match *://ywop.scar17off.repl.co/*
// @match *://owop.scar17off.repl.co/*
// @icon https://www.google.com/s2/favicons?domain=ourworldofpixels.com
// @grant none
// @require https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.7.1/socket.io.js
// @namespace none
// ==/UserScript==
const SCRIPT_VERSION = "1.4";
(function () {
"use strict";
var I = 6666666;
if (location.host == "ourworldofpixels.com") I = 0; // OWOP is using different event IDs
const events = {
"loaded": I + 1,
"init": I + 2,
"tick": I + 3,
"misc": {
"toolsRendered": I + 4,
"toolsInitialized": I + 5,
"logoMakeRoom": I + 6,
"worldInitialized": I + 7,
"windowAdded": I + 8,
"captchaToken": I + 9,
"loadingCaptcha": I + 10
},
"renderer": {
"addChunk": I + 11,
"rmChunk": I + 12,
"updateChunk": I + 13
},
"camera": {
"moved": I + 14,
"zoom": I + 15
},
"net": {
"connecting": I + 16,
"connected": I + 17,
"disconnected": I + 18,
"playerCount": I + 19,
"chat": I + 20,
"devChat": I + 21,
"world": {
"leave": I + 22,
"join": I + 23,
"joining": I + 24,
"setId": I + 25,
"playersMoved": I + 26,
"playersLeft": I + 27,
"tilesUpdated": I + 28,
"teleported": I + 29
},
"chunk": {
"load": I + 30,
"unload": I + 31,
"set": I + 32,
"lock": I + 33,
"allLoaded": I + 34
},
"sec": {
"rank": I + 35
},
"maxCount": I + 36,
"donUntil": I + 37
}
};
window.onload = () => OWOP.on(events.net.world.join, () => {
if (!OWOP.cursors.paste && OWOP.cursors.stamp) OWOP.cursors.paste = OWOP.cursors.stamp;
if (!OWOP.tools) OWOP.tools = OWOP.tool;
if (!OWOP.tool) OWOP.tool = OWOP.tools;
if (typeof localStorage == 'undefined') localStorage = sessionStorage;
!function (e) { "use strict"; function t() { } function n(e, t) { for (var n = e.length; n--;)if (e[n].listener === t) return n; return -1 } function r(e) { return function () { return this[e].apply(this, arguments) } } var i = t.prototype, s = e.EventEmitter; i.getListeners = function (e) { var t, n, r = this._getEvents(); if (e instanceof RegExp) for (n in t = {}, r) r.hasOwnProperty(n) && e.test(n) && (t[n] = r[n]); else t = r[e] || (r[e] = []); return t }, i.flattenListeners = function (e) { var t, n = []; for (t = 0; t < e.length; t += 1)n.push(e[t].listener); return n }, i.getListenersAsObject = function (e) { var t, n = this.getListeners(e); return n instanceof Array && ((t = {})[e] = n), t || n }, i.addListener = function (e, t) { if (!function e(t) { return "function" == typeof t || t instanceof RegExp || !(!t || "object" != typeof t) && e(t.listener) }(t)) throw TypeError("listener must be a function"); var r, i = this.getListenersAsObject(e), s = "object" == typeof t; for (r in i) i.hasOwnProperty(r) && -1 === n(i[r], t) && i[r].push(s ? t : { listener: t, once: !1 }); return this }, i.on = r("addListener"), i.addOnceListener = function (e, t) { return this.addListener(e, { listener: t, once: !0 }) }, i.once = r("addOnceListener"), i.defineEvent = function (e) { return this.getListeners(e), this }, i.defineEvents = function (e) { for (var t = 0; t < e.length; t += 1)this.defineEvent(e[t]); return this }, i.removeListener = function (e, t) { var r, i, s = this.getListenersAsObject(e); for (i in s) s.hasOwnProperty(i) && -1 !== (r = n(s[i], t)) && s[i].splice(r, 1); return this }, i.off = r("removeListener"), i.addListeners = function (e, t) { return this.manipulateListeners(!1, e, t) }, i.removeListeners = function (e, t) { return this.manipulateListeners(!0, e, t) }, i.manipulateListeners = function (e, t, n) { var r, i, s = e ? this.removeListener : this.addListener, o = e ? this.removeListeners : this.addListeners; if ("object" != typeof t || t instanceof RegExp) for (r = n.length; r--;)s.call(this, t, n[r]); else for (r in t) t.hasOwnProperty(r) && (i = t[r]) && ("function" == typeof i ? s.call(this, r, i) : o.call(this, r, i)); return this }, i.removeEvent = function (e) { var t, n = this._getEvents(); if ("string" == typeof e) delete n[e]; else if (e instanceof RegExp) for (t in n) n.hasOwnProperty(t) && e.test(t) && delete n[t]; else delete this._events; return this }, i.removeAllListeners = r("removeEvent"), i.emitEvent = function (e, t) { var n, r, i, s, o = this.getListenersAsObject(e); for (s in o) if (o.hasOwnProperty(s)) for (n = o[s].slice(0), i = 0; i < n.length; i++)!0 === (r = n[i]).once && this.removeListener(e, r.listener), r.listener.apply(this, t || []) === this._getOnceReturnValue() && this.removeListener(e, r.listener); return this }, i.trigger = r("emitEvent"), i.emit = function (e) { var t = Array.prototype.slice.call(arguments, 1); return this.emitEvent(e, t) }, i.setOnceReturnValue = function (e) { return this._onceReturnValue = e, this }, i._getOnceReturnValue = function () { return !this.hasOwnProperty("_onceReturnValue") || this._onceReturnValue }, i._getEvents = function () { return this._events || (this._events = {}) }, t.noConflict = function () { return e.EventEmitter = s, t }, "function" == typeof define && define.amd ? define(function () { return t }) : "object" == typeof module && module.exports ? module.exports = t : e.EventEmitter = t }("undefined" != typeof window ? window : this || {});
// Pray to god this method of font drawing will work.
function getTextImageData(text, font) {
var tempCanvas = document.createElement('canvas');
var tempCtx = tempCanvas.getContext('2d');
tempCtx.font = font;
var textMetrics = tempCtx.measureText(text);
tempCanvas.width = textMetrics.width;
tempCanvas.height = parseInt(font, 10);
tempCtx.font = font;
tempCtx.fillText(text, 0, parseInt(font, 10));
var imageData = tempCtx.getImageData(0, 0, tempCanvas.width, tempCanvas.height);
tempCanvas.remove();
return imageData;
};
// this nigger took me 2.5 hours to finish
function addResizeableProperty(elementId, elementId2, element) {
const resizableDiv = document.getElementById(elementId);
const eventHandlerDiv = document.getElementById(elementId2);
let isResizing = false;
let startX;
let startY;
let startWidth;
let startHeight;
eventHandlerDiv.addEventListener('mousedown', (e) => {
if (e.target === eventHandlerDiv) {
isResizing = true;
startX = e.clientX;
startY = e.clientY;
startWidth = parseInt(getComputedStyle(resizableDiv).width, 10);
startHeight = parseInt(getComputedStyle(resizableDiv).height, 10);
document.addEventListener('mousemove', resize);
document.addEventListener('mouseup', stopResize);
}
});
function resize(e) {
if (!isResizing) return;
const newWidth = startWidth + e.clientX - startX;
const newHeight = startHeight + e.clientY - startY;
// this is useless
// const widthChange = newWidth - startWidth;
const heightChange = newHeight - startHeight;
resizableDiv.style.width = `${newWidth}px`;
resizableDiv.style.height = `${newHeight}px`;
resizableDiv.style.maxWidth = `${newWidth}px`;
resizableDiv.style.maxHeight = `${newHeight}px`;
// this code is shit
if (resizableDiv.id == "window-owopfuck") {
document.getElementById("owopfuck-title").childNodes.forEach(node => {
if (node.style) {
node.style.fontSize = newWidth <= 750 ? "0px" : "20px";
};
});
document.getElementById("owopfuck-tablist").style.textAlign = newWidth <= 750 ? "unset" : "right";
};
const sections = document.querySelectorAll(".owopfuck-section");
const windowSize = parseInt(document.getElementById("window-owopfuck").style.height.replace("px", ''));
// set section height
sections.forEach(section => {
section.style.height = windowSize - 60 + "px";
});
// set full tab heights
document.querySelectorAll(".owopfuck-full-tab").forEach(node => {
node.style.height = windowSize - 60 + "px";
});
window.animbuilderCenter.y = (windowSize - 60) / 2;
};
function stopResize() {
isResizing = false;
document.removeEventListener('mousemove', resize);
document.removeEventListener('mouseup', stopResize);
};
};
function shuffleArray(array) {
for (let i = array.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[array[i], array[j]] = [array[j], array[i]];
};
return array;
};
const createExpressionFunction = (expression) => {
return new Function('pos', 'length', 'i', 'f', `return ${expression};`);
};
function gameToSize(gameX, gameY) {
var sc = 16 / 16;
var pixelSize = 32 * sc;
var screenWidth = Math.ceil(gameX * pixelSize);
var screenHeight = Math.ceil(gameY * pixelSize);
return {
width: screenWidth / 2 + 'px',
height: screenHeight / 2 + 'px'
};
};
function lerpColor(color1, color2, alpha) {
const r = Math.round(lerp(color1[0], color2[0], alpha));
const g = Math.round(lerp(color1[1], color2[1], alpha));
const b = Math.round(lerp(color1[2], color2[2], alpha));
return [r, g, b];
};
function lerp(color1, color2, factor) {
if (arguments.length < 3) {
factor = 0.5;
};
var result = color1.slice();
for (var i = 0; i < 3; i++) {
result[i] = Math.round(result[i] + factor * (color2[i] - color1[i]));
}
return result;
};
const getIbyXY = (x, y, w) => (y * w + x) * 4;
function pixColor(img, X, Y) {
var data = img.getImageData(X, Y, 1, 1).data;
return [data[0], data[1], data[2]];
};
function getRandomItemFromArray(array) {
let randomIndex = Math.floor(Math.random() * array.length);
return array[randomIndex];
};
const upload = (accept = "*") => new Promise(resolve => {
let file = document.createElement('input');
file.type = "file";
file.accept = accept;
file.onchange = () => {
let reader = new FileReader();
reader.onloadend = () => {
resolve(reader.result);
};
reader.readAsDataURL(file.files[0]);
};
file.click();
});
function rgb2int(rgb) {
return ((rgb[0] & 0x0ff) << 16) | ((rgb[1] & 0x0ff) << 8) | (rgb[2] & 0x0ff)
};
const eq = (a, b) => a[0] === b[0] && a[1] === b[1] && a[2] === b[2];
var OJS = [];
const error = m => console.error("%c " + m, "color: #ff0000");
/*
Events:
name - description [arguments].
open - Opened WebSocket connection.
close - Closed WebSocket connection.
join - Joined to world [world name].
id - Got id [id].
rawMessage - Any message from WebSocket server. (It can be object or string) [data].
update - Player in world updates [player object].
pixel - New pixel in world [x, y, [r, g, b]].
disconnect - Someone in world disconnected [player object].
teleport - got 'teleport' opcode. Very rare. [x, y].
rank - Got new rank. [rank].
captcha - Captcha state. [gcaptcha id].
chunkProtect - Chunk (un)protected. [x, y, newState].
pquota - New PQuota. [rate, per].
destroy - Socket was destroyed and won't reconnect anymore.
chunk - New chunk. [x, y, chunk, protected].
message - New message in chat. [msg].
*/
class ChunkSystem {
constructor() {
this.chunks = [];
this.chunkProtected = [];
};
setChunk(x, y, data) {
if (!data || typeof x !== "number" || typeof y !== "number") return error("ChunkSystem.setChunk: failed to set chunk (no data or invalid coords).");
if (data.constructor.name !== "Array") data = Array.from(data);
if (!this.chunks[x]) this.chunks[x] = [];
return this.chunks[x][y] = data;
};
getChunk(x, y, raw) {
if (!raw) {
x = Math.floor(x / Client.options.chunkSize);
y = Math.floor(y / Client.options.chunkSize);
};
if (!this.chunks[x]) return;
return this.chunks[x][y];
};
removeChunk(x, y) {
if (!this.chunks[x]) return;
if (!this.chunks[x][y]) return;
return this.chunks[x].splice(y, 1);
};
setPixel(x, y, rgb) {
if (!rgb || typeof rgb !== "object" || typeof x !== "number" || typeof y !== "number") return error("ChunkSystem.setPixel: failed to set pixel (no/wrong rgb or invalid coords).");
const chunkX = Math.floor(x / Client.options.chunkSize);
const chunkY = Math.floor(y / Client.options.chunkSize);
if (!this.chunks[chunkX]) return;
const chunk = this.chunks[chunkX][chunkY];
if (!chunk) return false;
const i = getIbyXY(x & Client.options.chunkSize - 1, y & Client.options.chunkSize - 1, Client.options.chunkSize);
chunk[i] = rgb[0];
chunk[i + 1] = rgb[1];
chunk[i + 2] = rgb[2];
return true;
};
getPixel(x, y) {
if (typeof x !== "number" || typeof y !== "number") return error("ChunkSystem.getPixel: failed to get pixel (invalid coords).");
const chunkX = Math.floor(x / Client.options.chunkSize);
const chunkY = Math.floor(y / Client.options.chunkSize);
if (!this.chunks[chunkX]) return;
const chunk = this.chunks[chunkX][chunkY];
const i = getIbyXY(x & Client.options.chunkSize - 1, y & Client.options.chunkSize - 1, Client.options.chunkSize);
return [chunk[i], chunk[i + 1], chunk[i + 2]];
};
protectChunk(x, y) {
if (typeof x !== "number" || typeof y !== "number") return error("ChunkSystem.protectChunk: failed to protect chunk (invalid coords).");
if (!this.chunkProtected[x]) this.chunkProtected[x] = [];
return this.chunkProtected[x][y] = true;
}
unProtectChunk(x, y) {
if (typeof x !== "number" || typeof y !== "number") return error("ChunkSystem.unprotectChunk: failed to unprotect chunk (invalid coords).");
if (!this.chunkProtected[x]) return false;
this.chunkProtected[x][y] = false;
return true;
}
isProtected(x, y) {
if (typeof x !== "number" || typeof y !== "number") return error("ChunkSystem.isProtected: failed to check (invalid coords).");
if (!this.chunkProtected[x]) return false;
return Boolean(this.chunkProtected[x][y]);
}
};
const Chunks = new ChunkSystem();
class Client {
/**
* @param {Object} options Options for connection
* @param {?number} options.id ID for logging. If not set, OWOP ID will be used. ✔️
* @param {string} [options.world=main] World name. ✔️
* @param {?boolean} options.noLog No logging. ✔️
* @param {?boolean} options.reconnect Reconnect if disconnected. ✔️
* @param {?string} options.adminlogin Admin login. ✔️
* @param {?string} options.modlogin Mod login. ✔️
* @param {?string} options.pass Pass for world. ✔️
* @param {?string} options.captchapass Captcha pass. ✔️
* @param {?string} options.teleport Teleport on 'teleport' opcode. ✔️
* @param {number} [options.reconnectTime=5000] Reconnect time (ms) after disconnect. ✔️
* @param {?boolean} options.unsafe Use methods that are supposed to be only for admin or moderator. ✔️
* @param {?boolean} options.simpleChunks Use original OWOP chunks instead of OJS. ✔️
*/
constructor(options = {}) {
if (!options.world) options.world = "main";
if (!options.reconnectTime) options.reconnectTime = 2500;
if (!options.captchaSiteKey) options.captchaSiteKey = "6LcgvScUAAAAAARUXtwrM8MP0A0N70z4DHNJh-KI";
let types = {
"glitch": ".glitch.me/?ws=",
"replit": ".repl.co/?ws="
};
if (options.proxy && !options.proxyType) {
if (options.proxy.includes(".")) options.proxyType = "replit";
else options.proxyType = "glitch";
};
if (options.proxy && !options.zombie) options.ws = new WebSocket(`wss://${options.proxy}${types[options.proxyType]}${options.ws.url}`, null, options.ws.options);
if (options.zombie) options.ws = new BotNetReplicator(options.zombie);
const OJS = this;
this.clientOptions = options;
this.RANK = {
ADMIN: 3,
MODERATOR: 2,
USER: 1,
NONE: 0
};
this.options = {
chunkSize: 16,
maxChatBuffer: 256,
maxMessageLength: {
0: 128,
1: 128,
2: 512,
3: 16384
},
maxWorldNameLength: 24,
worldBorder: 0xFFFFFF,
opcode: {
setId: 0,
worldUpdate: 1,
chunkLoad: 2,
teleport: 3,
setRank: 4,
captcha: 5,
setPQuota: 6,
chunkProtected: 7
},
captchaState: {
CA_WAITING: 0,
CA_VERIFYING: 1,
CA_VERIFIED: 2,
CA_OK: 3,
CA_INVALID: 4
},
captchaStateNames: {
0: "WAITING",
1: "VERIFYING",
2: "VERIFIED",
3: "OK",
4: "INVALID"
}
};
if (window.document === undefined) {
this.options.misc = {
chatVerification: String.fromCharCode(10),
tokenVerification: "CaptchA",
worldVerification: 25565
};
} else this.options.misc = {
chatVerification: OWOP.options.serverAddress[0].proto.misc.chatVerification,
tokenVerification: OWOP.options.serverAddress[0].proto.misc.tokenVerification,
worldVerification: OWOP.options.serverAddress[0].proto.misc.worldVerification
};
OJS.chat = {
send(msg) {
if (typeof OJS.player.rank !== "number") return false;
msg = OJS.chat.sendModifier(msg);
OJS.net.ws.send(msg.substr(0, OJS.options.maxMessageLength[OJS.player.rank]) + OJS.options.misc.chatVerification);
return true;
},
local(msg) {
OJS.util.log(msg)
},
sendModifier(msg) {
return msg
},
recvModifier(msg) {
return msg
},
messages: []
};
OJS.world = {
join(world = "main") {
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected) return false;
let ints = [];
world = world.toLowerCase();
for (let i = 0; i < world.length && i < 24; i++) {
let charCode = world.charCodeAt(i);
if ((charCode < 123 && charCode > 96) || (charCode < 58 && charCode > 47) || charCode === 95 || charCode === 46)
ints.push(charCode);
}
let array = new ArrayBuffer(ints.length + 2);
let dv = new DataView(array);
for (let i = ints.length; i--;) dv.setUint8(i, ints[i]);
dv.setUint16(ints.length, OJS.options.misc.worldVerification, true);
OJS.net.ws.send(array);
OJS.util.log(`Joining world: ${world}`);
OJS.world.name = world;
return true;
},
leave() {
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
OJS.net.ws.close();
},
destroy() {
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
OJS.net.destroyed = true;
OJS.net.ws.close();
OJS.emit("destroy");
},
move(x = 0, y = 0) {
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected) return false;
if (!x || !y) return false;
OJS.player.x = x;
OJS.player.y = y;
if (document.getElementById(`owopfuck-${OJS.player.id}-x`)) document.getElementById(`owopfuck-${OJS.player.id}-x`).innerText = Math.floor(x);
if (document.getElementById(`owopfuck-${OJS.player.id}-y`)) document.getElementById(`owopfuck-${OJS.player.id}-y`).innerText = Math.floor(y);
x *= 16;
y *= 16;
const dv = new DataView(new ArrayBuffer(12));
OJS.player.worldX = x;
OJS.player.worldY = y;
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
dv.setUint8(8, OJS.player.color[0]);
dv.setUint8(9, OJS.player.color[1]);
dv.setUint8(10, OJS.player.color[2]);
dv.setUint8(11, OJS.player.tool);
OJS.net.ws.send(dv.buffer);
OJS.highlight.move();
return true;
},
setPixel(x = OJS.player.x, y = OJS.player.y, color = OJS.player.color, move = true) {
if (!OJS.net.bucket.canSpend(1) && location.origin == "ourworldofpixels.com") return false;
let pixel = OWOP.world.getPixel(x, y);
if (eq(pixel, color)) return;
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected || OJS.player.rank === OJS.RANK.NONE) return false;
const oldX = OJS.player.x,
oldY = OJS.player.y;
if (getValue("smartsneaky")) {
let distx = Math.trunc(x / Client.options.chunkSize) - Math.trunc(oldX / Client.options.chunkSize);
distx *= distx;
let disty = Math.trunc(y / Client.options.chunkSize) - Math.trunc(oldY / Client.options.chunkSize);
disty *= disty;
let dist = Math.sqrt(distx + disty);
if (dist >= 3) OJS.world.move(x, y);
} else {
if (move) OJS.world.move(x, y);
};
const dv = new DataView(new ArrayBuffer(11));
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
dv.setUint8(8, color[0]);
dv.setUint8(9, color[1]);
dv.setUint8(10, color[2]);
OJS.player.color = color;
OJS.net.ws.send(dv.buffer);
if (getValue("wolfmove")) OJS.world.move(oldX, oldY);
document.getElementById(`owopfuck-${OJS.player.id}-color`).childNodes[0].style.backgroundColor = "rgb(" + OJS.player.color + ")";
return true;
},
setTool(id = 0) {
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected) return false;
OJS.player.tool = id;
const dv = new DataView(new ArrayBuffer(12));
dv.setInt32(0, OJS.player.worldX, true);
dv.setInt32(4, OJS.player.worldY, true);
dv.setUint8(8, OJS.player.color[0]);
dv.setUint8(9, OJS.player.color[1]);
dv.setUint8(10, OJS.player.color[2]);
dv.setUint8(11, id);
OJS.net.ws.send(dv.buffer);
return true;
},
setColor(color = [0, 0, 0]) {
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected) return false;
OJS.player.color = color;
const dv = new DataView(new ArrayBuffer(12));
dv.setInt32(0, OJS.player.worldX, true);
dv.setInt32(4, OJS.player.worldY, true);
dv.setUint8(8, OJS.player.color[0]);
dv.setUint8(9, OJS.player.color[1]);
dv.setUint8(10, OJS.player.color[2]);
dv.setUint8(11, OJS.player.tool);
OJS.net.ws.send(dv.buffer);
return true;
},
protectChunk(x = OJS.player.x, y = OJS.player.y, newState = 1) {
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected) return false;
if (OJS.player.rank < OJS.RANK.ADMIN && !options.unsafe) return false;
const dv = new DataView(new ArrayBuffer(10));
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
dv.setUint8(8, newState);
OJS.net.ws.send(dv.buffer);
return true;
},
clearChunk(x = OJS.player.x, y = OJS.player.y, rgb = OJS.player.color) {
if (OJS.player.rank === OJS.RANK.ADMIN || options.unsafe) {
const dv = new DataView(new ArrayBuffer(13));
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
dv.setUint8(8, rgb[0]);
dv.setUint8(9, rgb[1]);
dv.setUint8(10, rgb[2]);
OJS.net.ws.send(dv.buffer);
return true;
}
return false;
},
requestChunk(x, y, inaccurate) {
if (options.simpleChunks) return true;
if (OJS.net.ws.readyState !== 1 || !OJS.net.isWebsocketConnected) return false;
if (typeof x !== "number" && typeof y !== "number") {
x = OJS.player.x;
y = OJS.player.y;
inaccurate = true;
};
if (inaccurate) {
x = Math.floor(x / OJS.options.chunkSize);
y = Math.floor(y / OJS.options.chunkSize);
};
let wb = OJS.options.worldBorder;
if (x > wb || y > wb || x < ~wb || y < ~wb) return;
let dv = new DataView(new ArrayBuffer(8));
dv.setInt32(0, x, true);
dv.setInt32(4, y, true);
OJS.net.ws.send(dv.buffer);
return true;
},
getPixel(x = OJS.player.x, y = OJS.player.y) {
if (options.simpleChunks) return OWOP.world.getPixel(x, y);
// It'll return undefined on unknown chunk but it'll request it, so you'll need to getPixel(x, y) again. I suggest you requesting chunks manually and getting them from ChunkSystem.
if (!Chunks.getChunk(x, y)) OJS.world.requestChunk(x, y, true);
return Chunks.getPixel(x, y);
}
};
OJS.captcha = {
usedKeys: [],
login(key) {
if (!OJS.net.ws ||
OJS.net.ws.readyState !== 1) return false;
if (OJS.captcha.usedKeys.includes(key)) {
return false
} else if (!key.startsWith(Client.options.misc.tokenVerification)) {
OJS.captcha.usedKeys.push(key);
}
OJS.net.ws.send(Client.options.misc.tokenVerification + key);
OJS.captcha.usedKeys.push(key);
return true;
},
renderCaptcha(uniqueName = true) {
return new Promise(resolve => {
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window(`Verification Needed ` + (uniqueName ? String.fromCharCode(Math.random() * 100) : ''), {
closeable: true,
moveable: true,
centered: true
}, win => {
win.container.parentNode.style["z-index"] = "101";
grecaptcha.render(win.addObj(OWOP.util.mkHTML('div', {})), {
theme: 'dark',
sitekey: OJS.clientOptions.captchaSiteKey,
callback: token => {
win.close();
resolve(token);
}
});
}));
});
},
async renderAndLogin(unique = true) {
OJS.captcha.login(await OJS.captcha.renderCaptcha(unique));
}
};
OJS.world.originalSetPixel = OJS.world.setPixel;
OJS.player = {
x: 0,
y: 0,
worldX: 0,
worldY: 0,
tool: 0,
rank: null,
id: null,
color: [0, 0, 0]
};
let highlight_element = document.createElement("div");
highlight_element.style.position = 'fixed';
highlight_element.style.transformOrigin = 'left top 0px';
highlight_element.style.overflow = 'hidden';
highlight_element.style.width = '40px';
highlight_element.style.height = '40px';
highlight_element.style.backgroundColor = 'rgba(0, 255, 0, 0.7)';
OJS.highlight = {
shown: false,
ismag: false,
element: highlight_element
};
OJS.highlight.move = () => {
let tools = {
0: 'cursor',
1: 'move',
2: 'pipette',
3: 'eraser',
4: 'zoom',
5: 'fill',
6: 'paste',
7: 'export',
8: 'line',
9: 'protect',
10: 'copy'
};
var sc = OWOP.camera.zoom / 16;
var pixelSize = 32 * sc;
var gameX = OJS.player.x / 2;
var gameY = OJS.player.y / 2;
var screenX = (-OWOP.camera.x) * OWOP.camera.zoom + gameX * pixelSize - OWOP.tools.allTools[tools[OJS.player.tool]].offset[0];
var screenY = (-OWOP.camera.y) * OWOP.camera.zoom + gameY * pixelSize
if (screenX > -512 && screenY > -512 && screenX < window.innerWidth && screenY < window.innerHeight) {
if (sc > 1.0 && !OJS.highlight.ismag) {
OJS.highlight.ismag = true;
OJS.highlight.element.style.imageRendering = 'pixelated';
} else if (sc <= 1.0 && OJS.highlight.ismag) {
OJS.highlight.ismag = false;
OJS.highlight.element.style.imageRendering = 'auto';
};
OJS.highlight.element.style.transform = `matrix(${sc}, 0, 0, ${sc}, ${Math.round(screenX)}, ${Math.round(screenY)})`;
if (!OJS.highlight.shown) {
OWOP.elements.viewport.appendChild(OJS.highlight.element);
OJS.highlight.shown = true;
};
} else {
if (OJS.highlight.shown) {
OJS.highlight.element.remove();
OJS.highlight.shown = false;
};
};
if (!getValue("bothighlight")) {
OJS.highlight.shown = false;
OWOP.removeListener(OWOP.events.tick, OJS.highlight.move);
OJS.highlight.element.remove();
};
};
OJS.players = {};
OJS.net = {
isWebsocketConnected: false,
isWorldConnected: false,
destroyed: false,
bucket: new Bucket(32, 4, OJS),
async dataHandler(data) {
if (typeof data !== "object") return error("Client.net.dataHandler: data is not object.");
const realData = data;
data = new DataView(data);
const opcode = data.getUint8(0);
switch (opcode) {
case OJS.options.opcode.setId:
{
OJS.emit("id", data.getUint32(1, true));
OJS.player.id = data.getUint32(1, true);
OJS.net.isWorldConnected = true;
if (typeof OJS.player.rank !== "number") OJS.player.rank = OJS.RANK.NONE;
OJS.util.log(`Joined world '${OJS.world.name}' and got id '${data.getUint32(1, true)}'`, "color: #00ff00");
if (options.adminlogin) OJS.chat.send("/adminlogin " + options.adminlogin);
if (options.modlogin) OJS.chat.send("/modlogin " + options.modlogin);
if (options.pass) OJS.chat.send("/pass " + options.pass);
OJS.emit("join", OJS.world.name);
/*
Bypass antibot
if(location.origin == "ourworldofpixels.com") {
fetch('https://opm.dimden.dev/client/img/polybius.png?' + Date.now(), {
'credentials': 'include',
'headers': {
'x-caching': protect('p+' + Math.floor(Date.now() / 60000) * 60000, randomIP())
}
});
};
*/
let table = document.createElement("tr");
let connection = "🖥️";
if (options.proxy) connection = "📡";
if (options.zombie) connection = "🧟";
table.innerHTML = `
${connection} |
${OJS.player.id} |
0 |
0 |
|
${OJS.net.bucket.allowance} |
| `;
table.id = `owopfuck-bot-${OJS.player.id}`;
document.getElementById("owopfuck-bots").appendChild(table);
document.getElementById(`owopfuck-${OJS.player.id}-disconnect`).addEventListener("click", () => {
OJS.net.ws.close();
document.getElementById(`owopfuck-bot-${OJS.player.id}`).remove();
});
break;
}
case OJS.options.opcode.worldUpdate:
{
// Players
let updated = false;
let updates = {};
for (let i = data.getUint8(1); i--;) {
updated = true;
let pid = data.getUint32(2 + i * 16, true);
if (pid === OJS.player.id) continue;
let pmx = data.getUint32(2 + i * 16 + 4, true);
let pmy = data.getUint32(2 + i * 16 + 8, true);
let pr = data.getUint8(2 + i * 16 + 12);
let pg = data.getUint8(2 + i * 16 + 13);
let pb = data.getUint8(2 + i * 16 + 14);
let ptool = data.getUint8(2 + i * 16 + 15);
updates[pid] = {
x: pmx,
y: pmy,
rgb: [pr, pg, pb],
tool: ptool
};
}
if (updated) {
for (let i in updates) {
if (!OJS.players[i]) OJS.emit("connect", i);
OJS.players[i] = {
id: i,
x: updates[i].x >> 4,
y: updates[i].y >> 4,
rgb: updates[i].rgb,
tool: updates[i].tool
};
OJS.emit("update", OJS.players[i]);
}
};
// Pixels
let off = 2 + data.getUint8(1) * 16;
for (let i = data.getUint16(off, true), j = 0; j < i; j++) {
let
x = data.getInt32(2 + off + j * 15 + 4, true),
y = data.getInt32(2 + off + j * 15 + 8, true);
let r = data.getUint8(2 + off + j * 15 + 12),
g = data.getUint8(2 + off + j * 15 + 13),
b = data.getUint8(2 + off + j * 15 + 14);
OJS.emit('pixel', x, y, [r, g, b]);
Chunks.setPixel(x, y, [r, g, b]);
}
// Disconnects
off += data.getUint16(off, true) * 15 + 2;
for (let k = data.getUint8(off); k--;) {
let dpid = data.getUint32(1 + off + k * 4, true);
if (OJS.players[dpid]) {
OJS.emit("disconnect", OJS.players[dpid]);
delete OJS.players[dpid];
}
}
break;
}
case OJS.options.opcode.chunkLoad:
{
let chunkX = data.getInt32(1, true);
let chunkY = data.getInt32(5, true);
let locked = !!data.getUint8(9);
let u8data = new Uint8Array(realData, 10, realData.byteLength - 10);
let decompressed = OJS.util.decompress(u8data)
Chunks.setChunk(chunkX, chunkY, decompressed);
if (locked) Chunks.protectChunk(chunkX, chunkY);
OJS.emit('chunk', chunkX, chunkY, decompressed, locked);
break;
}
case OJS.options.opcode.teleport:
{
if (!options.teleport) break;
const x = data.getInt32(1, true);
const y = data.getInt32(5, true);
OJS.world.move(x, y);
OJS.emit("teleport", x, y);
break;
}
case OJS.options.opcode.setRank:
{
OJS.player.rank = data.getUint8(1);
OJS.emit("rank", data.getUint8(1));
break;
}
case OJS.options.opcode.captcha:
{
switch (data.getUint8(1)) {
case OJS.options.captchaState.CA_WAITING:
OJS.util.log("CaptchaState: WAITING (0)", "color: #ffff00");
if (options.captchapass) {
OJS.net.ws.send(OJS.options.misc.tokenVerification + "LETMEINPLZ" + options.captchapass);
OJS.util.log("Used captchapass.", "color: #00ff00");
};
break;
case OJS.options.captchaState.CA_VERIFYING:
OJS.util.log("CaptchaState: VERIFYING (1)", "color: #ffff00");
break;
case OJS.options.captchaState.CA_VERIFIED:
OJS.util.log("CaptchaState: VERIFIED (2)", "color: #00ff00");
break;
case OJS.options.captchaState.CA_OK:
OJS.util.log("CaptchaState: OK (3)", "color: #00ff00");
OJS.world.join(options.world);
break;
case OJS.options.captchaState.CA_INVALID:
OJS.util.log("CaptchaState: INVALID (4)", "color: #ff0000");
OJS.util.log("Captcha failed. Websocket is invalid now.", "color: #ff0000");
OJS.net.destroyed = true;
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
OJS.emit("destroy");
break;
}
const id = data.getUint8(1);
OJS.emit("captcha", id);
(async () => {
if (id === 0) await OJS.captcha.renderAndLogin(true);
})();
break;
}
case OJS.options.opcode.setPQuota:
{
let rate = data.getUint16(1, true);
let per = data.getUint16(3, true);
if (rate == 0 && per == 0) return;
OJS.net.bucket = new Bucket(rate, per, OJS);
OJS.emit("pquota", rate, per);
if (document.getElementById(`owopfuck-${OJS.player.id}-pb`)) document.getElementById(`owopfuck-${OJS.player.id}-pb`).innerText = Math.floor(rate).toString();
let totalQuota = 0;
for (let i in bots) totalQuota += bots[i].net.bucket.rate;
let cps = (totalQuota / (16 * 16)).toFixed(3);
owopfuck.infowindow.container.childNodes[0].childNodes[15].innerText = "CPS: " + cps;
OJS.util.log(`New PQuota: ${rate}x${per}`);
break;
}
case OJS.options.opcode.chunkProtected:
{
let cx = data.getInt32(1, true);
let cy = data.getInt32(5, true);
let newState = data.getUint8(9);
if (newState) Chunks.protectChunk(cx, cy);
else Chunks.unProtectChunk(cx, cy);
OJS.emit("chunkProtect", cx, cy, newState);
break;
}
}
},
messageHandler(data) {
if (typeof data !== "string") return error("Client.net.messageHandler: data is not string.");
if (data.startsWith("You are banned")) {
OJS.util.log("Got ban message.", "color: #ff0000");
OJS.emit("banMessage");
OJS.emit("destroy");
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
return OJS.net.destroyed = true;
};
if (data.startsWith("DEV")) OJS.util.log("[DEV] " + data.slice(3));
if (data.startsWith("<")) return;
data = OJS.chat.recvModifier(data);
const nick = data.split(":")[0];
OJS.emit("message", data);
OJS.chat.messages.push(data);
if (OJS.chat.messages.length > OJS.options.maxChatBuffer) OJS.chat.messages.shift();
}
};
void
function makeSocket() {
let ws = options.ws;
if (!options.zombie) {
ws.binaryType = "arraybuffer";
ws.onopen = () => {
OJS.util.log("WebSocket connected!", "color: #00ff00");
OJS.net.isWebsocketConnected = true;
owopfuck.infowindow.container.childNodes[0].childNodes[0].innerText = `Bots: ${bots.filter(bot => bot.net.ws.readyState === 1).length}`;
OWOP.on(OWOP.events.tick, OJS.highlight.move);
OJS.emit("open");
};
ws.onmessage = msg => {
OJS.emit("rawMessage", msg.data);
if (typeof msg.data === "string") OJS.net.messageHandler(msg.data);
else if (typeof msg.data === "object") OJS.net.dataHandler(msg.data);
};
ws.onclose = () => {
OJS.emit("close");
OJS.util.log("WebSocket disconnected!", "color: #ff0000");
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
owopfuck.infowindow.container.childNodes[0].childNodes[0].innerText = `Bots: ${bots.filter(bot => bot.net.ws.readyState === 1).length}`;
if (options.reconnect && !OJS.net.destroyed) setTimeout(makeSocket, options.reconnectTime);
};
ws.onerror = () => {
OJS.util.log("WebSocket error!", "color: #ff0000");
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
};
OJS.net.ws = ws;
} else {
ws.on("open", () => {
OJS.util.log("WebSocket connected!", "color: #00ff00");
OJS.net.isWebsocketConnected = true;
owopfuck.infowindow.container.childNodes[0].childNodes[0].innerText = `Bots: ${bots.filter(bot => bot.net.ws.readyState === 1).length}`;
OWOP.on(OWOP.events.tick, OJS.highlight.move);
OJS.emit("open");
});
ws.on("message", msg => {
OJS.emit("rawMessage", msg);
if (typeof msg === "string") OJS.net.messageHandler(msg);
else if (typeof msg === "object") OJS.net.dataHandler(msg);
});
ws.on("close", () => {
OJS.emit("close");
OJS.util.log("WebSocket disconnected!", "color: #ff0000");
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
owopfuck.infowindow.container.childNodes[0].childNodes[0].innerText = `Bots: ${bots.filter(bot => bot.net.ws.readyState === 1).length}`;
if (options.reconnect && !OJS.net.destroyed) setTimeout(makeSocket, options.reconnectTime);
});
ws.on("error", () => {
OJS.util.log("WebSocket error!", "color: #ff0000");
OJS.net.isWorldConnected = false;
OJS.net.isWebsocketConnected = false;
});
OJS.net.ws = ws;
};
}();
OJS.util = {
log(...msg) {
if (options.noLog) return;
if (options.id) console.log(`[${options.id}] ${msg}`);
else if (OJS.player.id) console.log(`%c [${OJS.player.id}] ` + msg[0], msg[1]);
else console.log(`%c [?] ` + msg[0], msg[1]);
},
decompress(u8arr) {
// I'm not touching this shit anymore.
var originalLength = u8arr[1] << 8 | u8arr[0];
var u8decompressedarr = new Uint8Array(originalLength);
var numOfRepeats = u8arr[3] << 8 | u8arr[2];
var offset = numOfRepeats * 2 + 4;
var uptr = 0;
var cptr = offset;
for (var i = 0; i < numOfRepeats; i++) {
var currentRepeatLoc = (u8arr[4 + i * 2 + 1] << 8 | u8arr[4 + i * 2]) + offset;
while (cptr < currentRepeatLoc) {
u8decompressedarr[uptr++] = u8arr[cptr++];
}
var repeatedNum = u8arr[cptr + 1] << 8 | u8arr[cptr];
var repeatedColorR = u8arr[cptr + 2];
var repeatedColorG = u8arr[cptr + 3];
var repeatedColorB = u8arr[cptr + 4];
cptr += 5;
while (repeatedNum--) {
u8decompressedarr[uptr] = repeatedColorR;
u8decompressedarr[uptr + 1] = repeatedColorG;
u8decompressedarr[uptr + 2] = repeatedColorB;
uptr += 3;
}
}
while (cptr < u8arr.length) {
u8decompressedarr[uptr++] = u8arr[cptr++];
}
return u8decompressedarr;
}
};
if (options.unsafe) OJS.util.log("Using 'unsafe' option.", "color: #ffff00");
this._events = {};
};
on(event, fn) {
if (!this._events[event]) this._events[event] = [];
this._events[event].push(fn);
};
once(event, fn) {
if (!this._events[event]) this._events[event] = [];
this._events[event].push([fn]);
};
emit(event, ...args) {
if (!this._events[event]) return;
for (let i in this._events[event])
if (typeof this._events[event][i] === "function") this._events[event][i](...args);
else {
this._events[event][i][0](...args);
this._events[event].splice(i, 1);
}
};
off(event, fn) {
if (!this._events[event]) return;
for (let i in this._events[event])
if (String(this._events[event][i]) === String(fn)) this._events[event].splice(i, 1);
}
};
Client.RANK = {
ADMIN: 3,
MODERATOR: 2,
USER: 1,
NONE: 0
};
Client.options = {
chunkSize: 16,
maxChatBuffer: 256,
maxMessageLength: {
0: 128,
1: 128,
2: 512,
3: 16384
},
maxWorldNameLength: 24,
worldBorder: 0xFFFFFF,
opcode: {
setId: 0,
worldUpdate: 1,
chunkLoad: 2,
teleport: 3,
setRank: 4,
captcha: 5,
setPQuota: 6,
chunkProtected: 7
},
captchaState: {
CA_WAITING: 0,
CA_VERIFYING: 1,
CA_VERIFIED: 2,
CA_OK: 3,
CA_INVALID: 4
},
captchaStateNames: {
0: "WAITING",
1: "VERIFYING",
2: "VERIFIED",
3: "OK",
4: "INVALID"
}
};
if (window.document === undefined) {
Client.options.misc = {
chatVerification: String.fromCharCode(10),
tokenVerification: "CaptchA",
worldVerification: 25565
};
} else Client.options.misc = {
chatVerification: OWOP.options.serverAddress[0].proto.misc.chatVerification,
tokenVerification: OWOP.options.serverAddress[0].proto.misc.tokenVerification,
worldVerification: OWOP.options.serverAddress[0].proto.misc.worldVerification
};
class Bucket {
constructor(rate, time, bot, infinite = false) {
this.lastCheck = Date.now();
this.allowance = rate;
this.rate = rate;
this.time = time;
this.OJS = bot;
this.infinite = infinite;
};
update() {
this.allowance += (Date.now() - this.lastCheck) / 1000 * (this.rate / this.time);
this.lastCheck = Date.now();
if (this.allowance > this.rate) {
this.allowance = this.rate;
};
// if(document.getElementById(`owopfuck-${this.OJS.player.id}-pb`)) document.getElementById(`owopfuck-${this.OJS.player.id}-pb`).innerText = Math.floor(this.OJS.net.bucket.allowance).toString();
};
canSpend(count) {
if (this.infinite) return true;
this.update();
if (this.allowance < count) return false;
this.allowance -= count;
return true;
};
getTimeToRestore() {
if (this.allowance >= this.rate) return 0;
return (this.rate - this.allowance) / (this.rate / this.time);
};
async waitUntilRestore() {
const restoreTime = this.getTimeToRestore() * 1000;
return new Promise(resolve => setTimeout(resolve, restoreTime));
};
};
OJS = {
Client: Client,
ChunkSystem: ChunkSystem,
Chunks: Chunks,
Bucket: Bucket
};
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window("owopfuck", {
closeable: false
}, function (win) {
let styles = document.createElement("style");
let tabsys = document.createElement("script");
let div = document.createElement("div");
let container = win.container;
container.id = "window-owopfuck";
container.style.overflow = "hidden";
container.parentNode.firstChild.remove();
container.style = `overflow-y: auto;
margin: 0 -5px -5px -5px;
-o-border-image: url(/img/window_in.png) 5 repeat;`;
container.classList = '';
container.parentNode.style["position"] = "absolute";
container.parentNode.style["pointer-events"] = "initial";
container.parentNode.style["background-color"] = "rgb(17, 19, 20)";
container.parentNode.style["border"] = "5px rgb(17, 19, 20) solid";
container.parentNode.style["-o-border-image"] = "none";
container.parentNode.style["border-image"] = "none";
container.parentNode.style["border-image-outset"] = "0px";
container.parentNode.style["box-shadow"] = "transparent 0px 0px 0px 0px";
container.parentNode.style["z-index"] = "100";
div.innerHTML = `
<
Connection |
ID |
X |
Y |
Color |
PB |
Actions |
`;
tabsys.innerHTML = `let owopfuck_tabs = [
document.getElementById("owopfuck-tab-main"),
document.getElementById("owopfuck-tab-bots"),
document.getElementById("owopfuck-tab-animbuilder"),
document.getElementById("owopfuck-tab-botnet"),
document.getElementById("owopfuck-tab-proxy"),
document.getElementById("owopfuck-tab-botlist")
];
const altTabs = ["botnet", "proxy", "botlist"]; // those pages require block display, not flex (css)
function settab(Tab) {
for(let i in owopfuck_tabs) {
let tab = owopfuck_tabs[i];
tab.hidden = true;
tab.style.display = "none";
document.getElementById("owopfuck-tabbtn-" + tab.id.slice(13)).classList = "owopfuck-tabbtn";
};
document.getElementById("owopfuck-tab-"+Tab).hidden = false;
document.getElementById("owopfuck-tab-"+Tab).style.display = "flex";
if(altTabs.includes(Tab))
document.getElementById("owopfuck-tab-"+Tab).style.display = "block";
document.getElementById("owopfuck-tabbtn-" + Tab).classList = "owopfuck-tabbtn-active";
};
settab("main")`;
styles.innerHTML = `
.animbuilder-canvas-container {
background-color: rgba(255, 255, 255, 0.03);
position: relative;
display: inline-block;
width: 300px;
height: 100%;
box-shadow: inset 0 0 8px 3px;
}
.input-group {
display: grid;
grid-auto-flow: dense;
}
.animbuilder-sets-container {
display: inline-block;
vertical-align: top;
margin-left: 5px;
cursor: pointer;
width: 48%;
height: 53vh;
}
#window-owopfuck > * {
font-family: arial;
}
.owopfuck-dropdown > option {
background-color: rgb(24, 26, 28);
border: 2px solid #222324;
border-radius: 3px;
}
.owopfuck-dropdown {
background-color: transparent;
border: 2px solid #222324;
border-radius: 3px;
margin-left: 10px;
color: rgb(230, 230, 230);
width: 93%;
margin-top: 1px;
}
.owopfuck-keyinput {
height: 18px;
width: 50px;
background: transparent;
border: 1px solid #222324;
border-radius: 3px;
margin-left: 10px;
color: white;
text-align: center;
}
input.owopfuck-range[type="range"] {
-webkit-appearance: none;
appearance: none;
background: transparent;
cursor: pointer;
width: 215px;
margin-left: 10px;
}
input.owopfuck-range[type="range"]:focus {
outline: none;
}
input.owopfuck-range[type="range"]::-webkit-slider-runnable-track {
background-color: #383839;
border-radius: 3px;
height: 5px;
}
input.owopfuck-range[type="range"]::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
margin-top: -5.5px;
background-color: #5666f2;
border-radius: 15px;
height: 16px;
width: 16px;
}
input.owopfuck-range[type="range"]::-moz-range-track {
background-color: #383839;
border-radius: 3px;
height: 5px;
}
input.owopfuck-range[type="range"]::-moz-range-thumb {
background-color: #5666f2;
border: none;
border-radius: 15px;
height: 16px;
width: 16px;
}
input.owopfuck-range2[type="range"] {
-webkit-appearance: none;
appearance: none;
background: transparent;
cursor: pointer;
width: 190px;
margin-left: 10px;
}
input.owopfuck-range2[type="range"]:focus {
outline: none;
}
input.owopfuck-range2[type="range"]::-webkit-slider-runnable-track {
background-color: #383839;
border-radius: 3px;
height: 5px;
}
input.owopfuck-range2[type="range"]::-webkit-slider-thumb {
-webkit-appearance: none;
appearance: none;
margin-top: -5.5px;
background-color: #5666f2;
border-radius: 15px;
height: 16px;
width: 16px;
}
input.owopfuck-range2[type="range"]::-moz-range-track {
background-color: #383839;
border-radius: 3px;
height: 5px;
}
input.owopfuck-range2[type="range"]::-moz-range-thumb {
background-color: #5666f2;
border: none;
border-radius: 15px;
height: 16px;
width: 16px;
}
.owopfuck-text {
background-color: transparent;
border: 2px solid #222324;
margin-left: 10px;
border-radius: 3px;
color: rgb(230, 230, 230);
}
.owopfuck-rangetext {
/* -moz-appearance: textfield; */
background-color: transparent;
border: 2px solid #222324;
margin-left: 10px;
border-radius: 3px;
color: rgb(230, 230, 230);
width: 35px;
text-align: center;
}
/*
.owopfuck-rangetext::-webkit-inner-spin-button,
.owopfuck-rangetext::-webkit-outer-spin-button {
-webkit-appearance: none;
margin: 0;
}
*/
.owopfuck-label {
margin-left: 15px;
color: rgb(230, 230, 230);
font-size: 14px;
}
.owopfuck-cbtext {
position: absolute;
margin-top: 4px;
margin-left: 6px;
color: rgb(230, 230, 230);
font-size: 13px;
}
hr.owopfuck-hr {
border: solid 1px rgb(74, 86, 198);
box-shadow: rgb(74, 86, 198) 0px 0px 11px 2px;
margin-bottom: 5px;
margin-top: 3px;
}
label.owopfuck-section {
color: rgb(230, 230, 230);
}
div.owopfuck-section {
border-radius: 5px;
height: 530px;
background-color: rgb(22, 24, 26);
margin-right: 10px;
flex: 1;
}
div[id^="owopfuck-tab-"] {
display: flex;
margin-left: 10px;
margin-top: 8px;
overflow-y: auto;
}
#owopfuck-tablist {
text-align: right;
margin-top: -40px;
}
::-webkit-scrollbar-thumb {
background-color: rgb(65, 65, 65);
}
::-webkit-scrollbar-button {
display: none;
}
::-webkit-scrollbar {
width: 6px;
height: 1px;
}
html, body {
background-color: rgb(11, 11, 11);
}
.owopfuck-tabbtn {
border: none;
background: transparent;
width: 95px;
height: 40px;
color: rgb(150, 150, 150);
font-size: 11.5px;
padding: 0;
margin: 0;
}
.owopfuck-tabbtn:active, .owopfuck-tabbtn-active:active {
border: none;
-o-border-image: none;
border-image: none;
transition: -webkit-filter 0.125s;
transition: filter 0.125s;
transition: filter 0.125s, -webkit-filter 0.125s;
}
.owopfuck-tabbtn-active {
border: none;
background: linear-gradient(0deg, rgb(74 88 200 / 55%) 0%, rgba(0, 0, 0, 0) 100%);
border-bottom: solid 2px rgb(74 88 200);
width: 95px;
height: 40px;
color: rgb(150, 150, 150);
font-size: 11.5px;
padding: 0;
margin: 0;
}
.owopfuck-tabbtn:hover {
border: none;
background: linear-gradient(0deg, rgb(54 68 180 / 55%) 0%, rgba(0, 0, 0, 0) 100%);
border-bottom: solid 2px rgb(44 58 170);
width: 95px;
height: 40px;
color: rgb(150, 150, 150);
font-size: 11.5px;
padding: 0;
margin: 0;
}
.owopfuck-btn {
border: 2px solid #222324;
border-radius: 3px;
background: rgba(200, 200, 200, 0.01);
width: 93%;
height: 25px;
color: rgb(150, 150, 150);
font-size: 11.5px;
margin-bottom: 1px;
margin-top: 2px;
margin-left: 10px;
}
.owopfuck-smallbtn {
border: 2px solid #222324;
border-radius: 3px;
background: rgba(200, 200, 200, 0.01);
width: 72%;
height: 25px;
color: rgb(150, 150, 150);
font-size: 11.5px;
margin-bottom: 1px;
margin-top: 2px;
margin-left: 10px;
}
.owopfuck-smallbtn2 {
border: 2px solid #222324;
border-radius: 3px;
background: rgba(200, 200, 200, 0.01);
width: 40%;
height: 25px;
color: rgb(150, 150, 150);
font-size: 11.5px;
margin-bottom: 1px;
margin-top: 2px;
margin-left: 10px;
}
#owopfuck-topbar {
background-color: rgb(13, 15, 17);
height: 40px;
}
#window-owopfuck {
background-color: rgb(17, 19, 20);
width: 800px;
height: 590px;
}
.control {
display: block;
position: relative;
padding-left: 25px;
margin-bottom: 1px;
padding-top: 1px;
cursor: pointer;
font-size: 16px;
margin-left: 10px;
padding-bottom: 20px;
}
.control input {
position: absolute;
z-index: -1;
opacity: 0;
}
.control_indicator {
position: absolute;
top: 2px;
left: 0;
height: 18px;
width: 18px;
background: transparent;
border: 1px solid #222324;
border-radius: 3px;
}
.control:hover input ~ .control_indicator,
.control input:focus ~ .control_indicator {
background: rgba(255, 255, 255, 0.025);
}
.control input:checked ~ .control_indicator {
background: #4a59c8;
}
.control:hover input:not([disabled]):checked ~ .control_indicator,
.control input:checked:focus ~ .control_indicator {
background: #0e6647d;
}
.control input:disabled ~ .control_indicator {
background: #333f9e;
opacity: 1;
pointer-events: none;
}
.control_indicator:after {
box-sizing: unset;
content: '';
position: absolute;
display: none;
}
.control input:checked ~ .control_indicator:after {
display: block;
}
.control-checkbox .control_indicator:after {
left: 7px;
top: 3px;
width: 3px;
height: 8px;
border: solid #111314;
border-width: 0 2px 2px 0;
transform: rotate(45deg);
}
.control-checkbox input:disabled ~ .control_indicator:after {
border-color: #111314;
}
table[id^="owopfuck-"] {
border-collapse: collapse;
color: rgb(75 88 213);
text-align: center;
width: -webkit-fill-available;
border: solid 1px rgb(55, 55, 55);
font-family: 'pixel-op';
}
th[id^="owopfuck-bots"], td[id^="owopfuck-bots"] {
font-family: Verdana;
font-size: 12.5px;
padding: 2px;
text-align: center;
border-color: rgb(200, 200, 200);
border-width: 1px;
border-style: double;
border-right-style: none;
width: 110px;
border: solid 1px rgb(55, 55, 55);
}
tr[id^="owopfuck-"]:first-child {
text-align: center;
border: solid 1px rgb(55, 55, 55);
}`;
win.addObj(div);
win.addObj(styles);
win.addObj(tabsys);
}).move(165, 115));
addResizeableProperty("window-owopfuck", "window-owopfuck");
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window("owopfuck info", {
closeable: false
}, function (win) {
const div = document.createElement("div");
let container = win.container;
container.id = 'window-owopfuck-info';
container.parentNode.firstChild.remove();
container.style = `overflow: hidden;
margin: 0 -5px -5px -5px;
-o-border-image: url(/img/window_in.png) 5 repeat;`;
container.classList = '';
container.parentNode.style["position"] = "absolute";
container.parentNode.style["pointer-events"] = "initial";
container.parentNode.style["background-color"] = "rgb(17, 19, 20)";
container.parentNode.style["border"] = "4px rgb(17, 19, 20) solid";
container.parentNode.style["width"] = "200px";
// container.parentNode.style["height"] = "80px";
// commented to make the height automatically set
div.innerHTML = `
`;
win.addObj(div);
}).move(105, window.innerHeight - 120));
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window("owopfuck assets", {
closeable: false
}, function (win) {
const div = document.createElement("div");
let container = win.container;
container.parentNode.style.width = "260px";
container.parentNode.style.height = "500px";
container.id = 'window-owopfuck-assets';
container.parentNode.firstChild.remove();
container.style = `margin: 0 -5px -5px -5px;
-o-border-image: url(/img/window_in.png) 5 repeat;`;
container.classList = '';
container.parentNode.style["position"] = "absolute";
container.parentNode.style["pointer-events"] = "initial";
container.parentNode.style["background-color"] = "rgb(17, 19, 20)";
container.parentNode.style["border"] = "4px rgb(17, 19, 20) solid";
div.innerHTML = `
`;
win.addObj(div);
}).move(130, 200));
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window("owopfuck jobs", {
closeable: false
}, function (win) {
const div = document.createElement("div");
let container = win.container;
container.parentNode.style.width = "260px";
container.parentNode.style.height = "500px";
container.id = 'window-owopfuck-assets';
container.parentNode.firstChild.remove();
container.style = `margin: 0 -5px -5px -5px;
-o-border-image: url(/img/window_in.png) 5 repeat;`;
container.classList = '';
container.parentNode.style["position"] = "absolute";
container.parentNode.style["pointer-events"] = "initial";
container.parentNode.style["background-color"] = "rgb(17, 19, 20)";
container.parentNode.style["border"] = "4px rgb(17, 19, 20) solid";
div.innerHTML = `
`;
win.addObj(div);
}).move(130, 200));
function createconfig() {
if (localStorage.OWOPFUCK) return;
let structure = {
vanish: false,
instaplace: false,
mppchat: false,
nohelp: false,
streamer: false,
diagfill: false,
assets: [],
wsproxy: [],
animations: {},
freebucket: 2,
animbuildmovement: false,
animbuildintms: 45,
animbuildbots: 10,
animbuildlwidth: 2,
animation: "Circle",
reconnectTime: 250,
eraserdiameter: 16,
livepredtime: true,
fakerank: false,
fakerank_prefix: "(A)",
animationtool: "Selected",
irc: true,
chatmentions: false,
guibind: "Insert",
ircbind: "RShift",
infogui: true,
language: "English",
botautoreconnect: false,
followid: "Disabled",
followbyid: false,
autoreconnect: false,
automalogin: false,
botcount: 2,
eraserpattern: "Horizontal",
areapattern: "Horizontal",
pastepattern: "Horizontal",
wolfmove: false,
smartsneaky: false,
follow: false,
bothighlight: false,
areahighlight: false,
areahighlightblink: false
};
localStorage.OWOPFUCK = JSON.stringify(structure);
};
createconfig();
const getStorage = () => JSON.parse(localStorage.OWOPFUCK || '{}');
function getValue(variable) {
let value = getStorage()[variable.toLowerCase()];
return typeof value === 'string' && value.includes('[') ? JSON.parse(value) : value;
};
function setValue(variable, value) {
let storage = getStorage();
storage[variable] = value;
localStorage.OWOPFUCK = JSON.stringify(storage);
return true;
};
let selectedAsset = null;
const refreshAssets = () => {
let assets = getValue("assets");
const assetsDiv = document.getElementById("owopfuck-assets-container");
assetsDiv.innerHTML = '';
for (let i in assets) {
const image = new Image();
image.onload = () => {
image.style.width = "96px";
image.style.height = "96px";
image.style.border = "solid 1px";
image.onclick = e => {
for (let j in document.getElementById("owopfuck-assets-container").children) {
if (typeof (document.getElementById("owopfuck-assets-container").children[j]) !== "object") break;
document.getElementById("owopfuck-assets-container").children[j].style.border = "solid 1px";
};
selectedAsset = assets[i];
image.style.border = "solid 1px red";
};
image.oncontextmenu = e => {
e.preventDefault();
assets.splice(i, 1);
setValue("assets", JSON.stringify(assets));
refreshAssets();
};
assetsDiv.append(image);
};
image.src = assets[i];
};
};
refreshAssets();
let last = 0;
const sleep = ms => new Promise(resolve => setTimeout(resolve, ms));
const getFree = () => {
let b = bots.filter(i => i.net.ws.readyState === 1 && i.net.isWorldConnected);
if (b.length === 0) return -1;
if (last >= b.length) last = 0;
return last++;
};
function getRandomInt(min, max) {
min = Math.ceil(min);
max = Math.floor(max);
return Math.floor(Math.random() * (max - min)) + min;
};
function squareX(angle) {
let x = Math.sin(angle), y = Math.cos(angle);
return x / Math.max(Math.abs(x), Math.abs(y));
};
function squareY(angle) {
let x = Math.sin(angle), y = Math.cos(angle);
return y / Math.max(Math.abs(x), Math.abs(y));
};
function infinityX(t) {
let x = (Math.cos(t * 2) - 1) / 2;
if (Math.abs(t * 2) % (4 * Math.PI) > 2 * Math.PI) return -x;
else return x;
};
function infinityY(t) {
return Math.sin(t * 2) / 2;
};
function load(url, onload) {
let script = document.createElement('script');
script.src = url;
script.onload = onload;
document.head.appendChild(script);
};
function dist(x, y) {
return Math.sqrt(x * x + y * y);
};
OWOP.chat.recvModifier = (msg) => {
if (msg == 'Stop playing around with mod tools! :)') return;
return msg;
};
load("https://www.google.com/recaptcha/api.js");
// (auto) manual updater
fetch("https://scar17.scar17off.repl.co/owopfuck/version")
.then(data => {
return data.text();
}).then(data => {
if (data !== SCRIPT_VERSION) {
location.href = "https://scar17.scar17off.repl.co/owopfuck/script.js"; // i will force everyone to update owopfuck
};
});
document.getElementById("owopfuck-fakerank").addEventListener("input", () => {
const checked = document.getElementById("owopfuck-fakerank").checked;
if (checked) {
OWOP.chat.recvModifier = (msg) => {
if (msg == 'Stop playing around with mod tools! :)') return;
let temp = msg.split(':');
if ((temp[0].includes(OWOP.player.id.toString()) || temp[0].includes(localStorage.nick.toString())) && getValue("fakerank")) {
if (msg.startsWith("(M)") || msg.startsWith("(A)")) msg = msg.replace("(M) ", '').replace("(A) ", '');
msg = (document.getElementById("owopfuck-fakerank-prefix").value !== "User") ? `${document.getElementById("owopfuck-fakerank-prefix").value} ${msg.replace("[" + OWOP.player.id + "] ")}` : `[${OWOP.player.id}] ${localStorage.nick}: ${msg.replace("[" + OWOP.player.id.toString() + "] ", '').replace(localStorage.nick + ": ", '')}`;
// msg = `${document.getElementById("owopfuck-fakerank-prefix").value} ${msg.replace("["+OWOP.player.id+"] ")}`;
};
return msg;
};
for (var k in OWOP.tool.allTools) {
OWOP.tool.allTools[k].rankRequiredB = OWOP.tool.allTools[k].rankRequired;
// if(OWOP.tool.allTools[k].rankRequiredB === 3) console.log("admin " + k);
// if(OWOP.tool.allTools[k].rankRequiredB === 2) console.log("mod " + k);
OWOP.tool.allTools[k].rankRequired = 1;
OWOP.tool.updateToolbar();
};
} else {
OWOP.chat.recvModifier = (msg) => {
if (msg == 'Stop playing around with mod tools! :)') return;
return msg;
};
for (var k in OWOP.tool.allTools) {
OWOP.tool.allTools[k].rankRequired = OWOP.tool.allTools[k].rankRequiredB;
OWOP.tool.updateToolbar();
};
};
});
document.getElementById("owopfuck-asset-add").addEventListener("click", async () => {
let assets = getValue("assets");
assets.push(await upload("image/*"));
setValue("assets", JSON.stringify(assets));
refreshAssets();
});
var socket;
WebSocket.prototype.oldSend = WebSocket.prototype.send;
WebSocket.prototype.send = function (data) {
if (!socket && this.url !== "wss://botnet.scar17off.repl.co") socket = this;
if (getValue("vanish") && this === socket && this.url !== "wss://botnet.scar17off.repl.co") {
if (typeof data == "object") {
if (data.byteLength == 12) {
let dv = new DataView(data);
dv.setInt32(0, 0, true);
dv.setInt32(4, 0, true);
dv.setUint8(8, 0);
dv.setUint8(9, 0);
dv.setUint8(10, 0);
dv.setUint8(11, 0);
socket.oldSend(data);
} else {
this.oldSend(data);
};
};
} else {
this.oldSend(data);
};
};
document.getElementById("owopfuck-bothighlight").addEventListener("input", () => {
const checked = document.getElementById("owopfuck-bothighlight").checked;
if (checked) {
bots.forEach(bot => {
bot.highlight.move();
});
} else {
bots.forEach(bot => {
bot.highlight.shown = false;
bot.highlight.element.remove();
OWOP.removeListener(OWOP.events.tick, bot.highlight.move);
bot.highlight.move();
});
};
});
let ircServer;
function reconnectIRC() {
ircServer = io("wss://owopfuck-cc.scar17off.repl.co/");
try {
ircServer.on("message", (id, author, message) => displayIRCmessage(id, author, message));
ircServer.on("self", (id) => ircServer.id = id);
ircServer.on("users", (n) => owopfuck.infowindow.container.childNodes[0].childNodes[12].innerText = 'IRC users: ' + n);
} catch (error) {
};
};
function displayIRCmessage(id, author, message) {
if (id == ircServer.id) return;
OWOP.chat.local(`IRC [${id}] ${author}: ${message}`);
};
if (getValue("irc")) reconnectIRC();
document.getElementById("owopfuck-irc").addEventListener("input", () => {
if (!document.getElementById("owopfuck-irc").checked && ircServer) {
ircServer.close();
} else if (document.getElementById("owopfuck-irc").checked) {
reconnectIRC();
};
});
let chatInput = document.getElementById("chat-input");
chatInput.addEventListener("keydown", function (event) {
let key = event.key;
if (event.location === KeyboardEvent.DOM_KEY_LOCATION_RIGHT) key = "R" + key;
if (key == getValue("ircbind") && getValue("irc")) {
if (chatInput.value.startsWith("/nick ")) {
let nick = chatInput.value.replace("/nick ", '');
localStorage.ircnick = nick;
chatInput.value = '';
chatInput.style.height = "16px";
event.stopPropagation();
return;
};
if (chatInput.value.trimLeft().trimRight() == '') return;
OWOP.chat.local(`IRC [${ircServer.id}] ${localStorage.ircnick}: ${chatInput.value.replaceAll('<', '').replaceAll('>', '')}`);
ircServer.emit("send", chatInput.value, localStorage.ircnick);
chatInput.value = '';
chatInput.style.height = "16px";
event.stopPropagation();
};
});
const switchVisiblity = (window) => OWOP.windowSys.windows[window].container.parentNode.hidden = !OWOP.windowSys.windows[window].container.parentNode.hidden;
switchVisiblity("owopfuck assets");
switchVisiblity("owopfuck jobs");
switchVisiblity("owopfuck");
document.addEventListener("keydown", (E) => {
let key = E.key;
switch (key) {
case getValue("guibind"):
switchVisiblity("owopfuck");
break;
};
});
// needed to generate random proxy IP to bypass
function randomIP() {
return `${getRandomInt(1, 255)}.${getRandomInt(1, 255)}.${getRandomInt(1, 255)}.${getRandomInt(1, 255)}`;
};
// stolen from polybius
function protect(r, Q) {
let c = e => e.split('').map(h => h.charCodeAt(0));
let N = e => ('0' + Number(e).toString(16)).substr(-2);
let J = e => c(r).reduce((h, T) => h ^ T, e);
return Q.split('').map(c).map(J).map(N).join('');
};
// botnet
class BotNetReplicator {
constructor(zombie) {
this._events = {};
this.on = (event, fn) => {
if (!this._events[event]) this._events[event] = [];
this._events[event].push(fn);
};
this.once = (event, fn) => {
if (!this._events[event]) this._events[event] = [];
this._events[event].push([fn]);
};
this.emit = (event, ...args) => {
if (!this._events[event]) return;
for (let i in this._events[event])
if (typeof this._events[event][i] === "function") this._events[event][i](...args);
else {
this._events[event][i][0](...args);
this._events[event].splice(i, 1);
}
};
this.off = (event, fn) => {
if (!this._events[event]) return;
for (let i in this._events[event])
if (String(this._events[event][i]) === String(fn)) this._events[event].splice(i, 1);
}
this.readyState = 0;
botnet.on("message", (id, message) => {
if (id !== zombie) return;
this.emit("message", message);
});
botnet.on("status", (id, status) => {
if (id !== zombie) return;
if (status == "open") this.readyState = 1;
if (status == "close") this.readyState = 3;
this.emit(status);
});
this.send = (data) => {
botnet.emit("send", zombie, data);
};
this.close = () => {
botnet.emit("close", zombie);
};
};
};
const botnet = io("wss://botnet.scar17off.repl.co");
botnet.on("connect", () => {
botnet.emit("controller"); // mark current websocket as controller to not your ip
});
botnet.on("id", id => {
botnet.id = id;
});
const defaultBotnetHTML = document.getElementById("owopfuck-botsnet").innerHTML;
botnet.on("list", (list) => {
document.getElementById("owopfuck-botsnet").innerHTML = defaultBotnetHTML;
for (let i in list) {
let zombie = list[i];
let zombieTable = document.createElement("tr");
zombieTable.innerHTML = `${zombie.id.toString()} |
${zombie.ip} |
${(zombie.controller == botnet.id) ? "✅" : "❌"} |
| `;
zombieTable.id = `owopfuck-botnet-${zombie.sid}`;
document.getElementById("owopfuck-botsnet").appendChild(zombieTable);
if (zombie.controller == botnet.id) {
document.getElementById(`botnet-${zombie.sid}-control`).remove();
document.getElementById(`botnet-${zombie.sid}-connect`).addEventListener("click", () => {
botnet.emit("con", zombie.id, OWOP.options.serverAddress[0].url, "arraybuffer");
let options = {
index: bots.length + 1,
world: OWOP.world.name || undefined,
reconnect: getValue("botautoreconnect"),
reconnectTime: 250,
noLog: true,
adminlogin: getValue("automalogin") ? localStorage.adminlogin : undefined,
modlogin: getValue("automalogin") ? localStorage.modlogin : undefined,
captchapass: localStorage.owopcaptcha,
pass: localStorage.worldPasswords ? JSON.parse(localStorage.worldPasswords)[OWOP.world.name] : undefined,
zombie: zombie.id
};
var bot = new OJS.Client(options);
bot.on("close", () => {
bots.splice(bots.indexOf(bot), 1);
});
bot.on("connect", (id) => {
if (OWOP.player.id.toString() === id) return;
let playerOption = document.createElement("option");
playerOption.innerText = id.toString();
if (!Array.from(document.querySelector("*[name^=\"followid\"]").options).some(option => option.value === id))
document.querySelector("*[name^=\"followid\"]").options.add(playerOption);
});
bot.on("disconnect", (player) => {
for (let i in document.querySelector("*[name^=\"followid\"]").options) {
if (document.querySelector("*[name^=\"followid\"]").options[i].innerText === player.id.toString())
document.querySelector("*[name^=\"followid\"]").options.remove(i);
};
});
bots.push(bot);
});
} else {
document.getElementById(`botnet-${zombie.sid}-connect`).remove();
document.getElementById(`botnet-${zombie.sid}-control`).addEventListener("click", () => {
botnet.emit("control", zombie.id);
});
};
};
});
document.getElementById("botnet-controlall").addEventListener("click", () => {
document.getElementById("owopfuck-botsnet").childNodes.forEach((bot) => {
if (bot.id) bot.childNodes[6].childNodes[1].click();
});
});
// wsproxy
let onlineproxy = 0;
let ProxyPasswords = getValue('wsproxy');
let proxylist = {};
const defaultServersHTML = document.getElementById("owopfuck-wsproxy").innerHTML;
const updateServers = () => {
proxylist = {};
ProxyPasswords = getValue('wsproxy');
const servers = document.getElementById("owopfuck-wsproxy");
document.getElementById("owopfuck-wsproxy").innerHTML = defaultServersHTML;
for (let i in ProxyPasswords) {
const Proxy = ProxyPasswords[i].replace('\n', '');
let soc = `wss://${Proxy}.glitch.me/?ws=WS-STATUS`;
let site = `https://glitch.com/edit/#!/${Proxy}`;
let ico = '';
if (Proxy.includes(".")) {
let data = Proxy.split(".");
soc = `wss://${Proxy}.repl.co/?ws=WS-STATUS`;
site = `https://replit.com/@${data[1]}/${data[0]}`;
ico = '';
};
let displayname = getValue("streamer") ? 'STREAMER MODE' : Proxy;
let proxytable = document.createElement("tr");
proxytable.id = `owopfuck-wsproxy-${Proxy}`;
proxytable.innerHTML = `
${displayname} |
❓ |
❓ |
❓ |
| `;
servers.appendChild(proxytable);
document.getElementById(`owopfuck-wsproxy-${Proxy}-delete`).onclick = () => {
ProxyPasswords = ProxyPasswords.filter(e => e !== Proxy);
delete proxylist[Proxy];
setValue('wsproxy', JSON.stringify(ProxyPasswords));
document.getElementById(`owopfuck-wsproxy-${Proxy}`).remove();
};
const WSCheck = new WebSocket(soc);
WSCheck.onopen = () => {
proxylist[Proxy] = {
connections: 0
};
onlineproxy++;
document.getElementById(`owopfuck-proxy-reconnect`).innerText = `Reconnect [ ${onlineproxy} / ${ProxyPasswords.length} ]`;
document.getElementById(`owopfuck-wsproxy-${Proxy}-status`).innerText = "✔️";
document.getElementById(`owopfuck-wsproxy-${Proxy}-connect`).onclick = () => {
proxyJoin(Proxy);
//document.getElementById(`owopfuck-proxy-reconnect-${Proxy}`).innerText = parseInt(document.getElementById(`owopfuck-proxy-reconnect-${Proxy}`).innerText) + 1;
};
document.getElementById(`owopfuck-wsproxy-${Proxy}-disconnect`).onclick = () => {
for (let i in bots) {
if (bots[i].clientOptions.proxy == Proxy) {
bots[i].ws.close();
bots = bots.filter(b => b.clientOptions.proxy == Proxy);
document.getElementById(`owopfuck-wsproxy-${Proxy}-online`).innerText = '0';
};
};
};
WSCheck.send("WS-STATUS");
};
WSCheck.onmessage = msg => {
document.getElementById(`owopfuck-wsproxy-${Proxy}-ip`).innerText = msg.data.split(",")[0];
if (WSCheck.url.includes(".glitch.me")) {
let connections = parseInt(msg.data.split(",")[1]) - 1
document.getElementById(`owopfuck-wsproxy-${Proxy}-online`).innerText = connections;
proxylist[Proxy].connections = connections;
};
WSCheck.close();
};
WSCheck.onerror = () => {
delete proxylist[Proxy];
if (onlineproxy > 0) onlineproxy -= 1;
document.getElementById(`owopfuck-wsproxy-${Proxy}-online`).innerText = '❌';
document.getElementById("owopfuck-proxy-reconnect").innerText = `Reconnect [ ${onlineproxy} / ${ProxyPasswords.length} ]`;
document.getElementById(`owopfuck-wsproxy-${Proxy}-status`).innerText = "❌";
};
};
};
if (ProxyPasswords.length !== 0) updateServers();
document.getElementById("owopfuck-nohelp").addEventListener("change", () => {
const val = document.getElementById("owopfuck-nohelp").checked;
var button = OWOP.elements.helpButton;
if (!button) button = OWOP.elements.hubButton
if (val) {
button.hidden = true;
} else {
button.hidden = false;
};
});
// totally not stolen from the masterbot client
document.getElementById("owopfuck-mppchat").addEventListener("change", () => {
const val = document.getElementById("owopfuck-mppchat").checked;
if (val) {
document.getElementById("chat").style.width = "inherit";
} else {
document.getElementById("chat").style.width = "";
};
});
window.bots = []; // allow to access the bots variable from console or third-party scripts
var bots = window.bots;
// SHIT CODE (PLEASE DONT READ IT)
let ranges = document.querySelectorAll(".owopfuck-range");
let ranges2 = document.querySelectorAll(".owopfuck-range2");
let checkboxes = document.querySelectorAll(".control, .control-checkbox");
let dropdowns = document.querySelectorAll(".owopfuck-dropdown");
let keybinds = document.querySelectorAll(".owopfuck-keyinput");
for (let i in ranges) {
if (Object.prototype.hasOwnProperty.call(ranges, i)) {
let range = ranges[i];
range.value = getValue(range.name);
document.getElementById("owopfuck-" + range.name + "-label").innerText = getValue(range.name);
range.addEventListener("input", () => {
setValue(range.name, parseInt(range.value));
document.getElementById("owopfuck-" + range.name + "-label").innerText = range.value.toString();
});
};
};
for (let i in ranges2) {
if (Object.prototype.hasOwnProperty.call(ranges2, i)) {
let range = ranges2[i];
range.value = getValue(range.name);
document.getElementById("owopfuck-" + range.name + "-input").value = getValue(range.name);
range.addEventListener("input", () => {
setValue(range.name, parseInt(range.value));
document.getElementById("owopfuck-" + range.name + "-input").value = range.value;
});
document.getElementById("owopfuck-" + range.name + "-input").addEventListener("input", () => {
setValue(range.name, parseInt(document.getElementById("owopfuck-" + range.name + "-input").value));
range.value = document.getElementById("owopfuck-" + range.name + "-input").value;
});
};
};
for (let i in checkboxes) {
if (Object.prototype.hasOwnProperty.call(checkboxes, i)) {
let checkbox = checkboxes[i].querySelector("input");
checkbox.checked = getValue(checkbox.name);
checkbox.addEventListener("change", () => {
setValue(checkbox.name, checkbox.checked);
});
var event = new Event('change', {
bubbles: true,
cancelable: true,
});
checkbox.dispatchEvent(event);
};
};
for (let i in dropdowns) {
if (Object.prototype.hasOwnProperty.call(dropdowns, i)) {
let dropdown = dropdowns[i];
// dropdown.value = getValue(dropdown.name);
dropdown.addEventListener("input", () => {
setValue(dropdown.name, dropdown.value);
});
};
};
for (let i in keybinds) {
if (Object.prototype.hasOwnProperty.call(keybinds, i)) {
let keybind = keybinds[i];
keybind.value = getValue(keybind.name);
keybind.addEventListener("keydown", (event) => {
let key = event.key;
if (event.location === KeyboardEvent.DOM_KEY_LOCATION_RIGHT) key = "R" + key;
document.getElementById(keybind.id).value = key;
setTimeout(() => setValue(keybind.name, key), 300);
});
};
};
// patterns
load("https://scar17.scar17off.repl.co/helpers/patterns.js", () => {
for (const key in constants) {
if (constants.hasOwnProperty(key)) document.querySelector("*[name^='eraserpattern']").add(new Option(key, window.constants[key]));
if (constants.hasOwnProperty(key)) document.querySelector("*[name^='areapattern']").add(new Option(key, window.constants[key]));
if (constants.hasOwnProperty(key)) document.querySelector("*[name^='pastepattern']").add(new Option(key, window.constants[key]));
};
for (let i in dropdowns) {
if (Object.prototype.hasOwnProperty.call(dropdowns, i)) {
let dropdown = dropdowns[i];
dropdown.value = getValue(dropdown.name);
};
};
});
const proxyJoin = server => {
if (typeof server !== 'string') return;
proxylist[server].connections++;
let bot = new OJS.Client({
index: bots.length + 1,
proxy: server,
world: OWOP.world.name || undefined,
reconnect: getValue("botautoreconnect"),
reconnectTime: 250,
noLog: true,
adminlogin: getValue("automalogin") ? localStorage.adminlogin : undefined,
modlogin: getValue("automalogin") ? localStorage.modlogin : undefined,
captchapass: localStorage.owopcaptcha,
pass: localStorage.worldPasswords ? JSON.parse(localStorage.worldPasswords)[OWOP.world.name] : undefined,
ws: new WebSocket(OWOP.options.serverAddress[0].url, null, {
headers: {
'Origin': (location.host !== "ourworldofpixels.com") ? location.origin : "https://ourworldofpixels.com",
'Referer': (location.host !== "ourworldofpixels.com") ? document.referrer : "https://ourworldofpixels.com/"
},
origin: (location.host !== "ourworldofpixels.com") ? location.origin : "https://ourworldofpixels.com"
})
});
bot.on("close", () => {
bots.splice(bots.indexOf(bot), 1);
});
bot.on("connect", (id) => {
if (OWOP.player.id.toString() === id) return;
let playerOption = document.createElement("option");
playerOption.innerText = id.toString();
if (!Array.from(document.querySelector("*[name^=\"followid\"]").options).some(option => option.value === id))
document.querySelector("*[name^=\"followid\"]").options.add(playerOption);
});
bot.on("disconnect", (player) => {
for (let i in document.querySelector("*[name^=\"followid\"]").options) {
if (document.querySelector("*[name^=\"followid\"]").options[i].innerText === player.id.toString())
document.querySelector("*[name^=\"followid\"]").options.remove(i);
};
});
bots.push(bot);
};
document.getElementById("owopfuck-proxy-input").addEventListener("keydown", (event) => {
if (event.key == "Enter") {
let proxyname = document.getElementById("owopfuck-proxy-input").value;
let old = getValue("wsproxy");
if (old.indexOf(proxyname) == -1) old.push(proxyname);
setValue("wsproxy", old);
updateServers();
document.getElementById("owopfuck-proxy-input").value = '';
};
});
document.getElementById("owopfuck-proxy-reconnect").addEventListener("click", () => {
updateServers();
});
document.getElementById("owopfuck-connect").addEventListener("click", async () => {
for (let i = 0; i < getValue("botcount"); i++) {
let options = {
index: bots.length + 1,
world: OWOP.world.name || undefined,
reconnect: getValue("botautoreconnect"),
reconnectTime: 250,
noLog: true,
adminlogin: getValue("automalogin") ? localStorage.adminlogin : undefined,
modlogin: getValue("automalogin") ? localStorage.modlogin : undefined,
captchapass: localStorage.owopcaptcha,
pass: localStorage.worldPasswords ? JSON.parse(localStorage.worldPasswords)[OWOP.world.name] : undefined,
ws: new WebSocket(OWOP.options.serverAddress[0].url, null, {
headers: {
'Origin': (location.host !== "ourworldofpixels.com") ? location.origin : "https://ourworldofpixels.com",
'Referer': (location.host !== "ourworldofpixels.com") ? document.referrer : "https://ourworldofpixels.com/"
},
origin: (location.host !== "ourworldofpixels.com") ? location.origin : "https://ourworldofpixels.com"
})
};
var bot = new OJS.Client(options);
bot.on("close", () => {
bots.splice(bots.indexOf(bot), 1);
});
bot.on("connect", (id) => {
if (OWOP.player.id.toString() === id) return;
let playerOption = document.createElement("option");
playerOption.innerText = id.toString();
if (!Array.from(document.querySelector("*[name^=\"followid\"]").options).some(option => option.value === id))
document.querySelector("*[name^=\"followid\"]").options.add(playerOption);
});
bot.on("disconnect", (player) => {
for (let i in document.querySelector("*[name^=\"followid\"]").options) {
if (document.querySelector("*[name^=\"followid\"]").options[i].innerText === player.id.toString())
document.querySelector("*[name^=\"followid\"]").options.remove(i);
};
});
bots.push(bot);
};
});
document.getElementById("owopfuck-clear-jobs").addEventListener("click", () => {
const buttons = document.querySelectorAll("[id$='-stopbtn']");
buttons.forEach(button => {
button.click();
});
owopfuck.infowindow.container.childNodes[0].childNodes[3].innerText = "Time remaining: no job";
});
document.getElementById("animbuilder-add").addEventListener("click", () => {
let name = document.getElementById("animbuilder-name").value;
if (name == '') return;
let animations = getValue("animations");
animations[name] = [document.getElementById("animbuilder-x-expression").value, document.getElementById("animbuilder-y-expression").value];
setValue("animations", animations);
document.getElementById("animbuilder-name").value = '';
const optionElement_1 = document.createElement("option");
optionElement_1.text = name;
const optionElement_2 = document.createElement("option");
optionElement_2.text = name;
document.querySelector('select[name="animation"]').options.add(optionElement_1);
document.getElementById("animbuilder-animations").options.add(optionElement_2);
});
document.getElementById("animbuilder-remove").addEventListener("click", () => {
let name = document.getElementById("animbuilder-animations").value;
let animations = getValue("animations");
delete animations[name];
setValue("animations", animations);
for (let i in document.querySelector('select[name="animation"]').options) {
if (document.querySelector('select[name="animation"]').options[i].innerText === name)
document.querySelector('select[name="animation"]').options.remove(i);
};
for (let i in document.getElementById("animbuilder-animations").options) {
if (document.getElementById("animbuilder-animations").options[i].innerText === name)
document.getElementById("animbuilder-animations").options.remove(i);
};
});
document.getElementById("owopfuck-disconnect").addEventListener("click", () => {
bots.forEach(bot => {
bot.highlight.element.remove();
bot.world.destroy();
});
document.getElementById("owopfuck-bots").innerHTML = defaultBotnetHTML;
});
document.getElementById("owopfuck-chat-send").addEventListener("click", () => {
const value = document.getElementById("owopfuck-chat-msg").value;
for (let i in bots) bots[i].chat.send(value);
});
OWOP.on(events.net.disconnected, () => {
if (getValue("autoreconnect")) {
setTimeout(function () {
document.getElementById("reconnect-btn").click();
}, 100);
};
});
let PI2 = 3 * Math.PI,
FOLLOWADD = PI2 / 45,
f = 0,
x, y,
folint,
x1, y1,
f1 = 0,
pos = {};
let spiral = {
step: 0,
PI2: 2 * Math.PI,
speed: () => ((2 * Math.PI) / 30 / bots.length),
radius: (i) => i * 3
};
document.getElementById("owopfuck-follow").addEventListener("change", () => {
if (!getValue("follow")) {
clearInterval(folint);
return;
};
folint = setInterval(() => {
if (typeof pos !== "object") return;
if (getFree() === -1) return;
if (getValue("followid") == "Disabled") {
pos = {
x: OWOP.mouse.tileX,
y: OWOP.mouse.tileY
};
} else {
let playerID = document.querySelector("*[name^=\"followid\"]").selectedOptions[0].innerText;
if (bots[0].players[playerID]) pos = {
x: bots[0]?.players[playerID].x,
y: bots[0]?.players[playerID].y
}
else pos = {
x: OWOP.mouse.tileX,
y: OWOP.mouse.tileY
};
};
let length = bots.length;
let radius = bots.length;
let i = bots.length;
let animation = getValue("animation");
let animations = getValue("animations");
while (i--) {
if (getFree() === -1) return;
// animation builder
if (animations[animation]) {
let xfunc = createExpressionFunction(animations[animation][0]);
let yfunc = createExpressionFunction(animations[animation][1]);
x = xfunc(pos, length, i, f);
y = yfunc(pos, length, i, f);
};
if (animation == "Circle") {
x = pos.x + (Math.cos(2 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Circle 2") {
x = pos.x + (Math.cos(2 / Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(2 / Math.PI * 2 / length * i + f) * length);
};
if (animation == "Expanding circle") {
x = pos.x + Math.cos(2 * Math.PI * 2 / length * i + f) * length * (1 + Math.sin(f));
y = pos.y + Math.sin(2 * Math.PI * 2 / length * i + f) * length * (1 + Math.sin(f));
};
if (animation == "Spinning circle") {
x = pos.x + Math.cos(2 * Math.PI * 2 / length * i + f) * length * (Math.sin(f));
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Wave 2") {
x = pos.x + (Math.cos(2 * Math.PI * 0 / length * i + f + 4) * i);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f - 2) * length);
};
if (animation == "Wave 3") {
x = pos.x + (Math.cos(2 * Math.PI * 2 / length * (i + f)) - i);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Wave 4") {
x = pos.x + (Math.cos(1 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(3 * Math.PI * i - f) * i);
};
if (animation == "Wave 5") {
x = pos.x + (Math.cos(.5 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(1 * Math.PI * i - f) * i);
};
if (animation == "Wave 6") {
x = pos.x + (Math.cos(0.1 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(1 * Math.PI * i - f) * i);
};
if (animation == "Wave 7") {
x = pos.x + Math.cos(f + 2 * Math.PI * i / 4) * length;
y = pos.y + Math.cos(f) * Math.sin(2 * Math.PI * i / 5) * length;
};
if (animation == "Spinning line") {
x = pos.x + (Math.cos(2 * Math.PI * 2 * i + f) * i);
y = pos.y + (Math.sin(2 * Math.PI * 2 * i - f) * i);
};
if (animation == "Paralelpipedum") {
x = pos.x + (Math.cos(2 * Math.PI * 3 / length * i + f) * length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f - 2) * length);
};
if (animation == "Rhombus") {
x = pos.x + Math.sin(f) * Math.pow(Math.sin(f), 2) * length;
y = pos.y + Math.cos(f) * Math.pow(Math.cos(f), 2) * length;
};
if (animation == "Vertical Sector Circle") {
x = pos.x + Math.sin(f) * Math.cos(2 * Math.PI * i / 4) * length;
y = pos.y + Math.cos(f) * Math.pow(Math.abs(Math.cos(f)), 0) * length;
};
if (animation == "Horizontal Sector Circle") {
x = pos.x + Math.cos(f + 2 * Math.PI * i / 4) * length;
y = pos.y + Math.cos(f) * Math.sin(2 * Math.PI * i / 4) * length;
};
if (animation == "Cross") {
x = pos.x + Math.sin(f) * Math.cos(2 * Math.PI * i / 4) * length;
y = pos.y + Math.cos(f) * Math.sin(2 * Math.PI * i / 4) * length;
};
if (animation == "Rect Random") {
x = pos.x + Math.sin(f) * Math.random() * length;
y = pos.y + Math.cos(f) * Math.random() * length;
};
if (animation == "Cobra") {
x = pos.x + (Math.cos(1 * Math.PI * 1 / length * i + f) * i);
y = pos.y + (Math.sin(2 * Math.PI * 4 / length * i + f) * f * i / 8);
};
if (animation == "Piramid") {
x = pos.x + (Math.sin(5 + Math.PI * Math.PI / i * length + f + Math.PI / 2) * i);
y = pos.y + (Math.sin(5 + Math.PI * Math.PI / i * i + length) * i);
};
if (animation == "Xray") {
x = pos.x + (Math.sin(1 + Math.PI * i + f) * length);
y = pos.y + (Math.sin(2 * Math.PI * 3 / length * i + f) * length);
};
if (animation == "Disk") {
x = pos.x + (Math.cos(2 * Math.PI * 2 / length * i + f * 2) * length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Atom") {
if (i >= bots.length / 2) {
x = pos.x + (Math.cos(2 * Math.PI * 2 / bots.length * i + f) * bots.length / 2);
y = pos.y + (Math.sin(2 * Math.PI * 2 / bots.length * i + f + 2) * bots.length / 2);
} else {
x = pos.x + (Math.cos(2 * Math.PI * 2 / bots.length * i + f + 2) * bots.length / 2);
y = pos.y + (Math.sin(2 * Math.PI * 2 / bots.length * i + f) * bots.length / 2);
};
};
if (animation == "Random") {
x = pos.x - (length / 2) + Math.floor(Math.random() * length);
y = pos.y - (length / 2) + Math.floor(Math.random() * length);
};
if (animation == "Random 2") {
x = pos.x + (Math.cos(0.1 * Math.PI * Math.random() ^ 50 / length * i + f) * length);
y = pos.y + (Math.sin(0.1 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Random TB") {
x = pos.x + (Math.cos(2 - length * i - f) * length);
y = pos.y + (Math.sin(2 / length * i + f) * length);
};
if (animation == "Wave") {
x = pos.x + (Math.cos(2 * Math.PI / length * i + f) * length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Right - Left") {
x = pos.x + (Math.cos(2 * Math.PI * 2 ** length * i + f) * length);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "Bot Line") {
x = pos.x + i;
y = pos.y;
};
if (animation === "Bot Line 2") {
x = pos.x + (Math.cos(2 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(5 * Math.PI * 0.1 ^ 5 / length * i + f) * length);
};
if (animation === "Snake") {
x = pos.x + (Math.ceil(2 * Math.PI * 2 / length * i + f) * length) / 5; // 5 is snake length
y = pos.y + (Math.cos(1 * Math.PI * 2 / length * i + f) * length / 2) / 2;
};
if (animation === "Snake 2") {
x = pos.x + (Math.floor(2 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.cos(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation === "Random lines") {
x = pos.x + (Math.cos(5 * Math.PI * 2 / length * i + f ^ 2 * 1) * i);
y = pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
};
if (animation === "Multiple Top - Bottom") {
x = pos.x + (Math.cos(5 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.sin(5 / 45 * Math.PI * 2 / length * i + f) * length);
};
if (animation == "X") {
let r = 2 * Math.PI * 2 / length * i + f;
if (i % 2 == 0) {
let s = Math.sin(r);
y = pos.y + (Math.cos(r) * 3 + 15 * s);
x = pos.x + (s * 15 + 3 * s);
} else {
let c = Math.cos(r)
x = pos.x + (c * 8 + 9 * c);
y = pos.y + (Math.sin(r) * 3 + -15 * c);
};
};
if (animation == "Spiral") {
let speed = spiral.speed();
let radius = spiral.radius(i);
x = Math.cos(Math.PI / length * i + spiral.step) * radius;
y = Math.sin(Math.PI / length * i + spiral.step) * radius;
x += pos.x;
y += pos.y;
spiral.step += speed;
spiral.step %= spiral.PI2;
};
if (animation == "Top - Bottom") {
x = pos.x + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);
y = pos.y + (Math.cos(2 * Math.PI * 2 ** length * i + f) * length);
};
if (animation == "Eight") {
x = pos.x + (Math.sin(10 * Math.PI / length * i * f) * length / 1.768);
y = pos.y + (Math.cos(5 * Math.PI / length * i * f) * length / 1.768);
};
if (animation == "3D") {
if (i >= length / 2) {
y = pos.y + Math.cos(2 * Math.PI / bots * i + f) * 40;
x = pos.x + Math.sin(2 * Math.PI * 2 / bots * i + f) * 40;
} else {
x = pos.x + (Math.cos(2 * Math.PI * 4 / 4.09 * i + f * 2.5) * 9);
y = pos.y + (Math.sin(2 * Math.PI * 2 / 4.09 * i + f) * 9);
};
};
if (animation == "Infinity") {
a = spiral.PI2 / bots[i].length * i + f;
x = pos.x + infinityX(f / 20 * i + f) * 40;
y = pos.y + infinityY(f / 20 * i + f) * 40;
};
if (animation == "Infinity 2") {
a = spiral.PI2 / bots[i].length * i + f;
x = pos.x + infinityX(f / 20 * i + f) * 40;
y = pos.y + infinityY(f / 20 * i + f) * 40;
};
if (animation == "Square") {
a = spiral.PI2 / bots[i].length * i + f;
x = pos.x + squareX(f / 40 * i + f) * length / 1.285;
y = pos.y + squareY(f / 40 * i + f) * length / 1.285;
};
if (animation == "Triagle") {
let t = Math.PI * 2 / length * i + f;
x = pos.x + (2 * Math.sin(t) + Math.sin(2 * (t))) * length / 2;
y = pos.y + (2 * Math.cos(t) - Math.cos(2 * (t))) * length / 2;
};
if (animation == "Storm") {
let t = Math.PI * 2 / length * i - f;
let t1 = Math.PI * 3 / length * i + f;
x1 = pos.x + (Math.cos(2 * t) * length);
y1 = pos.y + (Math.sin(2 * t) * length);
x = x1 + (Math.cos(3 * t) * length);
y = y1 + (Math.sin(3 * t) * length);
};
if (animation == "Copy Disk") {
let t = Math.PI * 2 / length * i + f;
let t1 = Math.PI / length * i + f;
x = pos.x + (2 * Math.sin(t) + Math.sin(2 * t1)) * length / 2;
y = pos.y + (2 * Math.cos(t) - Math.cos(2 * t1)) * length / 2;
};
if (animation == "Disk X") {
let t = Math.PI * 2 / length * i + f;
let t1 = Math.PI * 2 / length * i - f;
if (i % 2 == 0) {
x = pos.x + (Math.cos(t) * (length * 1.5));
y = pos.y + (Math.sin(t1) * (length * 1.5));
} else {
x = pos.x + (Math.cos(t1) * (length));
y = pos.y + (Math.sin(t) * (length));
};
};
if (animation == "Asshole") {
let t = Math.PI * 2 / length * i - f;
let t1 = Math.PI * 2 / length * i + (f * 2);
x1 = pos.x + (Math.cos(t1) * length);
y1 = pos.y + (Math.sin(t1) * length);
x = x1 + (Math.cos(t) * length);
y = y1 + (Math.sin(t) * length);
};
if (animation == "Smooth Disk") {
let t = Math.PI * 2 / length * i - f;
let t1 = Math.PI * 2 / length * i + f;
x1 = pos.x + (Math.cos(t1) * length);
y1 = pos.y + (Math.sin(t) * length);
x = x1 + (Math.cos(t) * length);
y = y1 + (Math.sin(t) * length);
};
if (animation == "50% Disk") {
let t = Math.PI * 2 / length * i - f;
let t1 = Math.PI * 2 / length * i + f;
x1 = pos.x + (Math.cos(t1) * length);
y1 = pos.y + (Math.sin(t) * length);
x = x1 + (Math.cos(t1) * length);
y = y1 + (Math.sin(t) * length);
};
if (animation == "Lasso") {
let t = Math.PI * 2 / length * i - f;
let t1 = Math.PI * 2 / length * i + f;
let t2 = Math.PI * 3 / length * i * (f / length);
x1 = pos.x + (Math.cos(t1) * length);
y1 = pos.y + (Math.sin(t) * length);
x = x1 + (Math.cos(t) * length);
y = y1 + (Math.sin(t2) * length);
};
if (animation == "Smooth Disk 2") {
let t = Math.PI * 2 / length * i - f;
let t1 = Math.PI * 2 / length * i + f;
let t2 = Math.PI * 3 / length * 10 * (f / length);
x1 = pos.x + (Math.cos(t2) * length);
y1 = pos.y + (Math.sin(t1) * length);
x = x1 + (Math.cos(t) * length);
y = y1 + (Math.sin(t) * length);
};
if (animation == "卐") {
let t = Math.PI * 2 / length * i + f;
if (i == 1) {
x = pos.x + 5;
y = pos.y + 1;
} else if (i == 2) {
x = pos.x + 4;
y = pos.y + 1;
} else if (i == 3) {
x = pos.x + 3;
y = pos.y + 1;
} else if (i == 4) {
x = pos.x + 3;
y = pos.y + 2;
} else if (i == 5) {
x = pos.x + 3;
y = pos.y + 3;
} else if (i == 6) {
x = pos.x + 3;
y = pos.y + 4;
} else if (i == 7) {
x = pos.x + 3;
y = pos.y + 5;
} else if (i == 8) {
x = pos.x + 1;
y = pos.y + 1;
} else if (i == 9) {
x = pos.x + 1;
y = pos.y + 2;
} else if (i == 10) {
x = pos.x + 1;
y = pos.y + 3;
} else if (i == 11) {
x = pos.x + 2;
y = pos.y + 3;
} else if (i == 12) {
x = pos.x + 4;
y = pos.y + 3;
} else if (i == 13) {
x = pos.x + 5;
y = pos.y + 3;
} else if (i == 14) {
x = pos.x + 5;
y = pos.y + 4;
} else if (i == 15) {
x = pos.x + 5;
y = pos.y + 5;
} else if (i == 16) {
x = pos.x + 1;
y = pos.y + 5;
} else if (i == 17) {
x = pos.x + 2;
y = pos.y + 5;
} else if (i == 18) {
x = pos.x + 3;
y = pos.y + 5;
} else {
let t = Math.PI * 2 / (length - 18) * (i - 18) + f;
x = pos.x + 3 + (Math.cos(t) * ((length - 18) * 1));
y = pos.y + 3 + (Math.sin(t) * ((length - 18) * 1));
};
};
bots[i].world.move(x, y);
if (getValue("paintfollow")) bots[i].world.setPixel(x, y, OWOP.player.selectedColor);
let tools = {
id: {
'cursor': 0,
'move': 1,
'pipette': 2,
'eraser': 3,
'zoom': 4,
'fill': 5,
'paste': 6,
'export': 7,
'line': 8,
'protect': 9,
'copy': 10
},
0: 'cursor',
1: 'move',
2: 'pipette',
3: 'eraser',
4: 'zoom',
5: 'fill',
6: 'paste',
7: 'export',
8: 'line',
9: 'protect',
10: 'copy'
};
let tool;
if (getValue("animationtool") == 'Selected') tool = tools.id[OWOP.player.tool.id];
if (getValue("animationtool") == 'Random') {
let rank = bots[i].player.rank;
if (rank == 1) {
let toolList = [0, 1, 2, 4, 5, 7, 8];
tool = getRandomItemFromArray(toolList);
} else if (rank > 1) {
let toolList = [0, 1, 2, 4, 5, 7, 8, 3, 6, 9, 10];
tool = getRandomItemFromArray(toolList);
};
} else if (getValue("animationtool") !== 'Selected' && getValue("animationtool") !== 'Random') tool = tools.id[getValue("animationtool").toLowerCase()];
bots[i].world.setTool(tool);
};
if (animation == "Infinity") {
FOLLOWADD = PI2 / 100;
f = (f + FOLLOWADD);
} else if (animation == "Infinity 2") {
FOLLOWADD = PI2 / 95;
f = (f + FOLLOWADD);
} else if (animation == "Eight") {
FOLLOWADD = PI2 / 500;
f = (f + FOLLOWADD) % PI2;
} else {
f = (f + FOLLOWADD - .5) % PI2;
};
}, 90);
});
{
let animationOptions = getValue("animations");
for (let i in animationOptions) {
const optionElement_1 = document.createElement("option");
optionElement_1.text = i;
const optionElement_2 = document.createElement("option");
optionElement_2.text = i;
document.querySelector('select[name="animation"]').options.add(optionElement_1);
document.getElementById("animbuilder-animations").options.add(optionElement_2);
};
const cvs_2 = document.getElementById("animbuilder-canvas");
const ctx_2 = cvs_2.getContext("2d");
const xexpr = document.getElementById("animbuilder-x-expression");
const yexpr = document.getElementById("animbuilder-y-expression");
const movement_toggle = document.getElementById("owopfuck-animbuilder-movement");
let animationInterval = null;
const bot_poses = [];
const defaultExpression = `pos.x + (Math.cos(2 * Math.PI * 2 / length * i + f) * length);
pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);`;
let mathexpressions = defaultExpression;
xexpr.value = defaultExpression.split("\n")[0];
yexpr.value = defaultExpression.split("\n")[1];
function updateExpression() {
mathexpressions = xexpr.value + "\n" + yexpr.value;
xfunc = createExpressionFunction(mathexpressions.split("\n")[0]);
yfunc = createExpressionFunction(mathexpressions.split("\n")[1]);
clearCanvas();
};
xexpr.addEventListener("input", updateExpression);
yexpr.addEventListener("input", updateExpression);
cvs_2.addEventListener('mousedown', mouse => {
if (mouse.button === 1) {
const imageDataUrl = cvs.toDataURL();
const image = new Image();
image.src = imageDataUrl;
image.onload = function () {
const canvasElement = document.createElement('canvas');
canvasElement.width = image.width;
canvasElement.height = image.height;
const context = canvasElement.getContext('2d');
context.drawImage(image, 0, 0);
canvasElement.toBlob(blob => {
navigator.clipboard.write([
new ClipboardItem({
[blob.type]: blob
})
]);
});
};
};
});
document.getElementById("owopfuck-animbuildintms").addEventListener("input", () => {
clearInterval(animationInterval);
clearCanvas();
createInterval();
});
document.getElementById("animbuilder-animations").addEventListener("change", () => {
const name = document.getElementById("animbuilder-animations").value;
let animations = getValue("animations");
const animation = animations[name];
document.getElementById("animbuilder-x-expression").value = animation[0];
document.getElementById("animbuilder-y-expression").value = animation[1];
// redraw after loading
updateExpression();
});
document.querySelectorAll('input[name^="animbuild"][type="range"]').forEach(input => {
input.addEventListener("input", () => {
input.parentNode.children[0].innerText = input.parentNode.children[0].innerText.replace(/\d+/g, input.value);
clearCanvas();
});
});
movement_toggle.addEventListener("change", () => {
clearCanvas();
});
document.getElementById("owopfuck-animationbuilder-bots").addEventListener("input", () => {
xfunc = createExpressionFunction(mathexpressions.split("\n")[0]);
yfunc = createExpressionFunction(mathexpressions.split("\n")[1]);
});
document.getElementById("animbuilder-redraw").addEventListener("click", () => {
clearCanvas();
});
document.getElementById("animbuilder-reset").addEventListener("click", () => {
xexpr.value = "pos.x + (Math.cos(2 * Math.PI * 2 / length * i + f) * length);";
yexpr.value = "pos.y + (Math.sin(2 * Math.PI * 2 / length * i + f) * length);";
mathexpressions = xexpr.value + "\n" + yexpr.value;
xfunc = createExpressionFunction(mathexpressions.split("\n")[0]);
yfunc = createExpressionFunction(mathexpressions.split("\n")[1]);
clearCanvas();
});
async function copyContent(text) {
try {
await navigator.clipboard.writeText(text);
} catch (err) {
console.error('Failed to copy: ', err);
};
};
document.getElementById("animbuilder-copy").addEventListener("click", () => {
copyContent(mathexpressions);
});
function clearCanvas() {
ctx_2.clearRect(0, 0, cvs_2.width, cvs_2.height);
};
let PI2_2 = 3 * Math.PI,
FOLLOWADD_2 = PI2_2 / 45,
f_2 = 0;
window.animbuilderCenter = {
x: cvs_2.width / 2,
y: cvs_2.height / 2
};
let xfunc = createExpressionFunction(mathexpressions.split("\n")[0]);
let yfunc = createExpressionFunction(mathexpressions.split("\n")[1]);
function createInterval() {
animationInterval = setInterval(() => {
if (movement_toggle.checked) clearCanvas();
let bots = getValue("animbuildbots") * 8 - 1;
let length = bots;
for (let i = bots; i >= 0; i--) {
const x = xfunc(animbuilderCenter, length, i, f_2);
const y = yfunc(animbuilderCenter, length, i, f_2);
if (movement_toggle.checked) bot_poses[i] = [x, y];
ctx_2.fillStyle = "#5666f2";
let width = getValue("animbuildlwidth");
ctx_2.fillRect(x, y, width, width);
};
f_2 = (f_2 + FOLLOWADD_2 - 0.5) % PI2_2;
}, getValue("animbuildintms"));
};
createInterval();
};
OWOP.world.protection = {
intervals: {},
pixels: {},
chunks: []
};
let protection_queue = [];
let pixbusu = false;
async function placePixel(x, y, color, item, abc) {
await pixbusu == true;
if (abc === -1 || typeof abc == "undefined") {
abc = getFree();
};
if (abc == -1) {
pixbusu = false;
return;
};
let setpixel = bots[abc].world.setPixel;
if (item) setpixel = bots[abc].world[item];
if (!setpixel) return;
if (!eq(OWOP.world.getPixel(x, y), color)) {
bots[abc].net.bucket.canSpend(0);
if (bots[abc].net.bucket.allowance >= getValue("freebucket")) {
setpixel(x, y, color);
pixbusu = false;
} else {
pixbusu = false;
await placePixel(x, y, color, item, abc);
return;
};
};
pixbusu = false;
};
// area table summizer
function updateIndicator() {
const elements = document.querySelectorAll('td[id^="owopfuck-fill-"][id$="-time"]');
const regex = /\d+/;
let sum = 0;
Array.from(elements).forEach(element => {
if (regex.test(element.id)) {
const innerText = element.innerText;
const number = parseFloat(innerText.replace('s', ''));
sum += number;
}
});
sum = sum.toFixed(2) + "s";
if (sum == "0.00s") sum = "no job";
owopfuck.infowindow.container.childNodes[0].childNodes[3].innerText = "Time remaining: " + sum;
};
function updateAreaPoses() {
const elements = document.querySelectorAll('td[id^="owopfuck-fill-"][id$="-pos"]');
owopfuck.area_poses = [];
Array.from(elements).forEach(element => {
element = element.children[0].title.split(";");
let start = element[0].split(",");
let end = element[1].split(",");
start = start.map(Number);
end = end.map(Number);
let complete = [start, end];
if (owopfuck.area_poses.indexOf(complete) == -1) owopfuck.area_poses.push(complete);
});
};
// filling functions
let jobs = 0;
function updateJobsIndicator() {
if (jobs > 0)
owopfuck.infowindow.container.childNodes[0].childNodes[6].innerText = "Jobs: " + jobs;
else if (jobs === 0)
owopfuck.infowindow.container.childNodes[0].childNodes[6].innerText = "Jobs: no jobs";
};
async function fill(x1, y1, x2, y2, color, item, tool) {
x2--; y2--;
jobs++;
updateJobsIndicator();
if (bots.length === 0) return;
for ([x, y] of patterns[document.querySelector(`select[name^='${tool}']`).selectedIndex](x1, y1, x2, y2)) {
const abc = getFree();
const pixel = OWOP.world.getPixel(x, y);
if (!eq(pixel, color)) {
await placePixel(x, y, color, item, abc);
bots[abc].net.bucket.canSpend(0);
if (bots[abc].net.bucket.allowance < getValue("freebucket"))
if (getValue("instaplace"))
await bots[abc].net.bucket.waitUntilRestore();
else
await sleep(Math.ceil(bots[abc].net.bucket.time * 1000 / bots[abc].net.bucket.rate) * jobs);
else {
if (!getValue("instaplace")) await sleep(0);
};
};
};
jobs--;
updateJobsIndicator();
};
async function unfill(x1, y1, x2, y2, color, uncolor, item, tool) {
x2--; y2--;
jobs++;
updateJobsIndicator();
for ([x, y] of patterns[document.querySelector(`select[name^='${tool}']`).selectedIndex](x1, y1, x2, y2)) {
const abc = getFree();
const pixel = OWOP.world.getPixel(x, y);
if (eq(pixel, uncolor) && !eq(pixel, color)) {
bots[abc].net.bucket.canSpend(0);
await placePixel(x, y, color, item, abc);
if (bots[abc].net.bucket.allowance < getValue("freebucket"))
if (getValue("instaplace"))
await bots[abc].net.bucket.waitUntilRestore();
else
await sleep(Math.ceil(bots[abc].net.bucket.time * 1000 / bots[abc].net.bucket.rate) * jobs);
else {
if (!getValue("instaplace")) await sleep(0);
};
};
};
jobs--;
updateJobsIndicator();
};
async function paste(x1, y1, imageData, assetContext) {
jobs++;
updateJobsIndicator();
for ([x, y] of patterns[document.querySelector("select[name^='pastepattern']").selectedIndex](x1, y1, x1 + imageData.width - 1, y1 + imageData.height - 1)) {
// TODO: Make color blending.
const pixel = await OWOP.world.getPixel(x, y);
const color = pixColor(assetContext, x - x1, y - y1);
const i = getIbyXY(x - x1, y - y1, imageData.width);
const transparency = Math.floor(Math.floor(imageData.data[i + 3] * 2) / 255); // 2 because the original value is devided by 2 by some reason
const blendedColor = lerp(pixel, color, transparency);
const abc = getFree();
if (!eq(pixel, blendedColor)) {
bots[abc].net.bucket.canSpend(0);
await placePixel(x, y, blendedColor, null, abc);
if (bots[abc].net.bucket.allowance < getValue("freebucket"))
if (getValue("instaplace"))
await bots[abc].net.bucket.waitUntilRestore();
else
await sleep(Math.ceil(bots[abc].net.bucket.time * 1000 / bots[abc].net.bucket.rate) * jobs);
else {
if (!getValue("instaplace")) await sleep(0);
};
};
};
jobs--;
updateJobsIndicator();
};
// tools
// let LastChunkTime = Date.now();
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Erase', OWOP.cursors.erase, OWOP.fx.player.RECT_SELECT_ALIGNED(16), OWOP.RANK.USER, function (tool) {
tool.setFxRenderer((fx, ctx) => {
var x = (fx.extra.player.x);
var y = (fx.extra.player.y);
var diameter = parseInt(getValue("eraserdiameter"));
var pxc = tool.diam * 16;
var fxx = (tool.diam * Math.floor(x / pxc) - OWOP.camera.x) * OWOP.camera.zoom;
var fxy = (tool.diam * Math.floor(y / pxc) - OWOP.camera.y) * OWOP.camera.zoom;
ctx.globalAlpha = 0.5;
ctx.fillStyle = fx.extra.player.htmlRgb;
ctx.fillRect(fxx, fxy, OWOP.camera.zoom * diameter, OWOP.camera.zoom * diameter);
return 1;
});
tool.setEvent('mousedown mousemove', async function (mouse) {
if (mouse.buttons === 0 || mouse.buttons === 4) return;
if (bots.length === 0) return;
// if(Date.now() - LastChunkTime < 100) return;
// LastChunkTime = Date.now();
let pix = parseInt(getValue("eraserdiameter"));
tool.diam = pix;
let color = mouse.buttons === 1 ? OWOP.player.selectedColor : [255, 255, 255];
let chunkx = x1 = Math.floor(OWOP.mouse.tileX / pix) * pix;
let chunky = y1 = Math.floor(OWOP.mouse.tileY / pix) * pix;
const str = JSON.stringify([chunkx, chunky]);
if (owopfuck.erase_poses.indexOf(str) === -1) {
owopfuck.erase_poses.push(str);
await fill(chunkx, chunky, chunkx + pix, chunky + pix, color, null, "eraserpattern");
owopfuck.erase_poses = owopfuck.erase_poses.filter(pos => pos !== str);
};
});
}));
OWOP.on(events.tick, () => {
if (OWOP.player.tool.name === "Bot Paste") {
owopfuck.assetswindow.container.parentNode.hidden = false;
} else {
owopfuck.assetswindow.container.parentNode.hidden = true;
};
if (OWOP.player.tool.name.toLowerCase().includes("area")) {
owopfuck.jobswindow.container.parentNode.hidden = false;
} else {
owopfuck.jobswindow.container.parentNode.hidden = true;
};
});
let assetContext;
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Paste", OWOP.cursors.paste, OWOP.fx.player.RECT_SELECT_ALIGNED(1), OWOP.RANK.USER, tool => {
let cvs = document.createElement("canvas");
tool.setFxRenderer(function (fx, ctx) {
let fxx = Math.floor(OWOP.mouse.tileX << 4 / 16) - OWOP.camera.x;
let fxy = Math.floor(OWOP.mouse.tileY << 4 / 16) - OWOP.camera.y;
if (fx.extra.isLocalPlayer && cvs.width && cvs.height) {
ctx.strokeStyle = "#000000";
ctx.scale(OWOP.camera.zoom, OWOP.camera.zoom);
ctx.drawImage(cvs, fxx, fxy);
ctx.scale(1 / OWOP.camera.zoom, 1 / OWOP.camera.zoom);
ctx.globalAlpha = 0.5;
ctx.strokeRect(fxx * OWOP.camera.zoom, fxy * OWOP.camera.zoom, cvs.width * OWOP.camera.zoom, cvs.height * OWOP.camera.zoom);
return 0;
};
});
tool.setEvent("mousedown mousemove", async function (mouse) {
if (mouse.buttons === 1) {
if (!selectedAsset) OWOP.chat.local("No asset selected!");
if (typeof selectedAsset === "string") {
// convert
let ctx = cvs.getContext('2d');
assetContext = ctx;
let img = new Image();
img.onload = () => {
cvs.width = img.width;
cvs.height = img.height;
ctx.globalAlpha = 0.5;
ctx.drawImage(img, 0, 0);
// asset
selectedAsset = ctx.getImageData(0, 0, img.naturalWidth, img.naturalHeight);
};
img.src = selectedAsset;
return OWOP.chat.local("Image is ready.");
};
let Pixelization = getValue("pixelization");
let x = !Pixelization ? OWOP.mouse.tileX : Math.floor(OWOP.mouse.tileX / 16) * 16,
y = !Pixelization ? OWOP.mouse.tileY : Math.floor(OWOP.mouse.tileY / 16) * 16;
paste(x, y, selectedAsset);
};
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Cursor', OWOP.cursors.cursor, OWOP.fx.player.RECT_SELECT_ALIGNED(1), OWOP.RANK.USER, function (tool) {
var lastX, lastY;
tool.setEvent('mousedown mousemove', async function (mouse) {
if (getFree() === -1 || mouse.buttons === 4 || mouse.buttons === 0) return;
if (!lastX || !lastY) {
lastX = OWOP.mouse.tileX;
lastY = OWOP.mouse.tileY;
};
(0, OWOP.util.line)(lastX, lastY, OWOP.mouse.tileX, OWOP.mouse.tileY, 1, async function (x, y) {
var color = mouse.buttons === 2 ? [255, 255, 255] : OWOP.player.selectedColor;
await placePixel(x, y, color);
});
lastX = OWOP.mouse.tileX;
lastY = OWOP.mouse.tileY;
});
tool.setEvent('mouseup', function (mouse) {
lastX = null;
lastY = null;
});
}));
let textContext;
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Text", OWOP.cursors.write, OWOP.fx.player.RECT_SELECT_ALIGNED(1), OWOP.RANK.USER, tool => {
let cvs = document.createElement("canvas");
let imageData;
tool.setEvent("mousedown", async function (mouse) {
if (mouse.buttons === 1) {
var text = prompt("Text to draw:");
var font = prompt("Text font:\n \n30px Arial");
imageData = getTextImageData(text, font);
// convert
let ctx = cvs.getContext("2d");
textContext = ctx;
let Pixelization = getValue("pixelization");
let x = !Pixelization ? OWOP.mouse.tileX : Math.floor(OWOP.mouse.tileX / 16) * 16,
y = !Pixelization ? OWOP.mouse.tileY : Math.floor(OWOP.mouse.tileY / 16) * 16;
for (let i = 0; i < imageData.data.length; i += 4) {
if (
imageData.data[i + 3] == 255
) {
imageData.data[i] = 0;
imageData.data[i + 1] = 0;
imageData.data[i + 2] = 0;
imageData.data[i + 3] = 255;
};
};
paste(x, y, imageData, textContext);
};
});
}));
let brDiameter = 2;
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Brush', OWOP.cursors.brush, OWOP.fx.player.RECT_SELECT_ALIGNED(brDiameter), false, function (tool) {
tool.brDiameter = 2; //Declaring variable for brush diameter.
var lastX, lastY;
tool.setEvent('mousedown mousemove', async function (mouse) {
const usedButtons = 3; /* Left and right mouse buttons are always used... */
const color = mouse.buttons === 2 ? [255, 255, 255] : OWOP.player.selectedColor; /* White color if right clicking */
if (mouse.buttons === 2 || mouse.buttons === 1) {
if (!lastX || !lastY) {
lastX = OWOP.mouse.tileX;
lastY = OWOP.mouse.tileY;
};
(0, OWOP.util.line)(lastX, lastY, OWOP.mouse.tileX, OWOP.mouse.tileY, 1, async function (x, y) {
const R = Math.floor(tool.brDiameter / 2);
if (getFree() === -1) return;
for (var ix = 0; ix < tool.brDiameter; ix++) {
for (var iy = 0; iy < tool.brDiameter; iy++) {
if (!eq(OWOP.world.getPixel(x + ix - R, y + iy - R), color)) {
await placePixel(x + ix - R, y + iy - R, color);
};
};
};
});
lastX = OWOP.mouse.tileX;
lastY = OWOP.mouse.tileY;
};
return usedButtons;
});
tool.setEvent('mouseup', function (mouse) {
lastX = null;
lastY = null;
});
tool.setFxRenderer(function (fx, ctx, time) {
var x = fx.extra.player.x;
var y = fx.extra.player.y;
var diameter = tool.brDiameter
var fxx = (Math.floor(x / 16) - Math.floor(diameter / 2) - OWOP.camera.x) * OWOP.camera.zoom;
var fxy = (Math.floor(y / 16) - Math.floor(diameter / 2) - OWOP.camera.y) * OWOP.camera.zoom;
ctx.globalAlpha = 0.8;
ctx.strokeStyle = fx.extra.player.htmlRgb;
ctx.strokeRect(fxx, fxy, OWOP.camera.zoom * diameter, OWOP.camera.zoom * diameter);
return 1; /* Rendering finished (won't change on next frame) */
});
}));
OWOP.windowSys.addWindow(new OWOP.windowSys.class.window('Bot Brush diameter', {}, function (win) {
win.container.title = 'Bot Brush Diameter';
win.container.style.height = '16px';
win.container.style.overflow = 'hidden';
var brDiamElmm = OWOP.util.mkHTML('span', {
innerHTML: OWOP.tools.allTools['bot brush'].brDiameter
});
win.addObj(brDiamElmm);
var Rbarr = OWOP.util.mkHTML('input', {
type: 'range',
style: '-moz-appearance:none;-webkit-appearance:none;appearance:none;height:6px;outline:none;float:right;',
min: 2,
max: 16,
value: OWOP.tools.allTools['bot brush'].brDiameter,
oninput: function () {
OWOP.tools.allTools['bot brush'].brDiameter = this.value;
brDiamElmm.innerHTML = this.value;
},
ondblclick: function () {
this.value = 1;
this.onchange();
}
});
win.addObj(Rbarr);
}).move(800, 32));
OWOP.tools.addToolObject(new OWOP.tools.class("Bot Protection", OWOP.cursors.shield, OWOP.fx.player.RECT_SELECT_ALIGNED(16), OWOP.RANK.USER, tool => {
tool.setFxRenderer((fx, ctx) => {
if (!OWOP.world.protection) OWOP.world.protection = {
intervals: {},
pixels: {},
chunks: []
};
try {
const X = fx.extra.player.x,
Y = fx.extra.player.y,
cX = (16 * Math.floor(X / 256) - OWOP.camera.x) * OWOP.camera.zoom,
cY = (16 * Math.floor(Y / 256) - OWOP.camera.y) * OWOP.camera.zoom,
tX = fx.extra.player.tileX,
tY = fx.extra.player.tileY,
chunk = OWOP.world.protection.pixels[`${tX},${tY}`];
ctx.globalAlpha = .5;
ctx.fillStyle = chunk ? "#00FF00" : "#FF0000";
ctx.fillRect(cX, cY, 16 * OWOP.camera.zoom, 16 * OWOP.camera.zoom);
} catch (error) {
const X = fx.extra.player.x,
Y = fx.extra.player.y,
cX = (16 * Math.floor(X / 256) - OWOP.camera.x) * OWOP.camera.zoom,
cY = (16 * Math.floor(Y / 256) - OWOP.camera.y) * OWOP.camera.zoom,
tX = fx.extra.player.tileX,
tY = fx.extra.player.tileY;
ctx.globalAlpha = .5;
ctx.fillStyle = "#FF0000";
ctx.fillRect(cX, cY, 16 * OWOP.camera.zoom, 16 * OWOP.camera.zoom);
};
return true;
});
tool.setEvent("mousedown mousemove", fx => {
if (!OWOP.world.protection) return;
const X = Math.floor(OWOP.mouse.tileX / OWOP.options.serverAddress[0].proto.chunkSize) * 16,
Y = Math.floor(OWOP.mouse.tileY / OWOP.options.serverAddress[0].proto.chunkSize) * 16,
chunk = OWOP.world.protection.pixels[`${X},${Y}`];
let chunkX = Math.floor(OWOP.mouse.tileX / 16).toString();
let chunkY = Math.floor(OWOP.mouse.tileY / 16).toString();
switch (fx.buttons) {
case 1:
if (chunk) return false;
for (let y = 0; y < 16; y++)
for (let x = 0; x < 16; x++) {
OWOP.world.protection.pixels[`${X + x},${Y + y}`] = OWOP.world.getPixel(X + x, Y + y);
OWOP.world.protection.intervals[`${X + x},${Y + y}`] = setInterval(() => {
if (!eq(OWOP.world.getPixel(X + x, Y + y), OWOP.world.protection.pixels[`${X + x},${Y + y}`])) {
protection_queue.unshift({
pos: [X + x, Y + y],
color: OWOP.world.protection.pixels[`${X + x},${Y + y}`]
});
let abc = getFree();
bots[abc].world.setPixel(X + x, Y + y, OWOP.world.protection.pixels[`${X + x},${Y + y}`]);
}
}, 2000);
};
if (OWOP.world.protection.chunks.indexOf(`${chunkX},${chunkY}`) == -1) OWOP.world.protection.chunks.push(`${chunkX},${chunkY}`);
return true;
break;
case 2:
if (!chunk) return false;
for (let y = 0; y < 16; y++)
for (let x = 0; x < 16; x++) {
clearInterval(OWOP.world.protection.intervals[`${X + x},${Y + y}`]);
delete OWOP.world.protection.intervals[`${X + x},${Y + y}`];
delete OWOP.world.protection.pixels[`${X + x},${Y + y}`];
OWOP.world.protection.chunks = OWOP.world.protection.chunks.filter(pos => pos !== `${chunkX},${chunkY}`);
};
break;
};
owopfuck.infowindow.container.childNodes[0].childNodes[9].innerText = "Protected chunks: " + OWOP.world.protection.chunks.length;
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Fill', OWOP.cursors.fill, OWOP.fx.player.NONE, OWOP.RANK.USER, function (tool) {
let stopFlag = false;
async function flooFill(x, y, targetColor, fillColor) {
if (!targetColor || eq(targetColor, fillColor)) return;
const pixelQueue = [[x, y]];
const visited = new Set();
while (pixelQueue.length > 0) {
if (stopFlag) return;
const [x, y] = pixelQueue.shift();
if (visited.has(`${x},${y}`)) continue;
visited.add(`${x},${y}`);
const currentColor = await OWOP.world.getPixel(x, y);
if (!currentColor) return;
if (currentColor[0] !== targetColor[0] || currentColor[1] !== targetColor[1] || currentColor[2] !== targetColor[2]) continue;
await placePixel(x, y, fillColor);
pixelQueue.push([x + 1, y]);
pixelQueue.push([x - 1, y]);
pixelQueue.push([x, y + 1]);
pixelQueue.push([x, y - 1]);
// add diagonals to the queue to fill in a circular pattern
if (!getValue("diagfill")) {
pixelQueue.push([x + 1, y + 1]);
pixelQueue.push([x + 1, y - 1]);
pixelQueue.push([x - 1, y + 1]);
pixelQueue.push([x - 1, y - 1]);
};
await sleep(1);
};
};
function stopFill() {
stopFlag = true;
busy = false;
};
let busy = false;
async function startFill(newX, newY, targetColor, fillColor) {
if (busy) return;
busy = true;
stopFlag = false;
await flooFill(newX, newY, targetColor, fillColor);
};
tool.setEvent("mousedown", async function (mouse) {
if (mouse.buttons == 0 || mouse.buttons == 4) return;
if (bots.length === 0) return;
startFill(mouse.tileX, mouse.tileY, OWOP.world.getPixel(mouse.tileX, mouse.tileY), OWOP.player.selectedColor);
});
tool.setEvent("mouseup deselect", () => {
stopFill();
return;
});
}));
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Area', OWOP.cursors.select, OWOP.fx.player.NONE, OWOP.RANK.USER, function (tool) {
let step = 1;
try {
tool.setFxRenderer(function (fx, ctx, time) {
if (!fx.extra.isLocalPlayer) return 1;
let x = fx.extra.player.x;
let y = fx.extra.player.y;
let fxx = (Math.floor(x / step) - OWOP.camera.x) * OWOP.camera.zoom;
let fxy = (Math.floor(y / step) - OWOP.camera.y) * OWOP.camera.zoom;
let oldlinew = ctx.lineWidth;
ctx.lineWidth = 1;
if (tool.extra.end) {
let s = tool.extra.start;
let e = tool.extra.end;
let x = (s[0] - OWOP.camera.x) * OWOP.camera.zoom + 0.5;
let y = (s[1] - OWOP.camera.y) * OWOP.camera.zoom + 0.5;
let w = e[0] - s[0];
let h = e[1] - s[1];
ctx.beginPath();
ctx.rect(x, y, w * OWOP.camera.zoom, h * OWOP.camera.zoom);
ctx.globalAlpha = 0.25;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3, 4]);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.globalAlpha = 0.25 + Math.sin(time / 320) / 4;
ctx.fillStyle = OWOP.renderer.patterns.unloaded;
ctx.fill();
ctx.setLineDash([]);
let oldfont = ctx.font;
ctx.font = "16px sans-serif";
let txt = (!tool.extra.clicking ? "M2 Inside to void. " : '') + `(${Math.abs(w)}x${Math.abs(h)}, ${(Math.abs(w) / 16 * Math.abs(h) / 16).toFixed(4)} chunks)`
let txtx = window.innerWidth >> 1;
let txty = window.innerHeight >> 1;
txtx = Math.max(x, Math.min(txtx, x + w * OWOP.camera.zoom));
txty = Math.max(y, Math.min(txty, y + h * OWOP.camera.zoom));
OWOP.drawText = (ctx, str, x, y, centered) => {
ctx.strokeStyle = "#000000", ctx.fillStyle = "#FFFFFF", ctx.lineWidth = 2.5, ctx.globalAlpha = 1;
if (centered) {
x -= ctx.measureText(str).width >> 1;
}
ctx.strokeText(str, x, y);
ctx.globalAlpha = 1;
ctx.fillText(str, x, y);
};
OWOP.drawText(ctx, txt, txtx, txty, true);
ctx.font = oldfont;
ctx.lineWidth = oldlinew;
return 0;
} else {
ctx.beginPath();
ctx.moveTo(0, fxy + 0.5);
ctx.moveTo(fxx + 0.5, 0);
//ctx.lineWidth = 1;
ctx.globalAlpha = 0.8;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3]);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.setLineDash([]);
ctx.lineWidth = oldlinew;
return 1;
}
});
tool.extra.start = null;
tool.extra.end = null;
tool.extra.clicking = false;
tool.setEvent('mousedown', function (mouse) {
let s = tool.extra.start;
let e = tool.extra.end;
let isInside = function isInside() {
return mouse.tileX >= s[0] && mouse.tileX < e[0] && mouse.tileY >= s[1] && mouse.tileY < e[1];
};
if (mouse.buttons === 1 && !tool.extra.end) {
tool.extra.start = [Math.floor(mouse.tileX / step) * step, Math.floor(mouse.tileY / step) * step];
tool.extra.clicking = true;
tool.setEvent('mousemove', function (mouse) {
if (tool.extra.start && mouse.buttons === 1) {
tool.extra.end = [Math.floor(mouse.tileX / step) * step, Math.floor(mouse.tileY / step) * step];
return 1;
}
});
let finish = function finish() {
tool.setEvent('mousemove mouseup deselect', null);
tool.extra.clicking = false;
let s = tool.extra.start;
let e = tool.extra.end;
if (e) {
if (s[0] === e[0] || s[1] === e[1]) {
tool.extra.start = null;
tool.extra.end = null;
}
if (s[0] > e[0]) {
let tmp = e[0];
e[0] = s[0];
s[0] = tmp;
}
if (s[1] > e[1]) {
let tmp = e[1];
e[1] = s[1];
s[1] = tmp;
}
}
OWOP.renderer.render(OWOP.renderer.rendertype.FX);
};
tool.setEvent('deselect', finish);
tool.setEvent('mouseup', function (mouse) {
if (!(mouse.buttons & 1)) {
finish();
};
});
} else if (mouse.buttons === 1 && tool.extra.end) {
if (isInside()) {
let offx = mouse.tileX;
let offy = mouse.tileY;
tool.setEvent('mousemove', function (mouse) {
let dx = mouse.tileX - offx;
let dy = mouse.tileY - offy;
tool.extra.start = [s[0] + dx, s[1] + dy];
tool.extra.end = [e[0] + dx, e[1] + dy];
});
let end = function end() {
tool.setEvent('mouseup deselect mousemove', null);
};
tool.setEvent('deselect', end);
tool.setEvent('mouseup', function (mouse) {
if (!(mouse.buttons & 1)) {
end();
};
});
}
} else if (mouse.buttons === 2 && tool.extra.end && isInside()) {
let w = tool.extra.end[0] - tool.extra.start[0];
let h = tool.extra.end[1] - tool.extra.start[1];
let color = OWOP.player.selectedColor;
let chunkx = tool.extra.start[0];
let chunky = tool.extra.start[1];
let element = document.createElement("div");
element.style.position = "fixed";
element.style.transformOrigin = "left top 0px";
element.style.overflow = "hidden";
element.style.width = gameToSize(w, h).width;
element.style.height = gameToSize(w, h).height;
element.style.backgroundColor = `rgba(${[color[0], color[1], color[2]].join(", ")}, 0.5)`;
if (getValue("areahighlightblink")) {
var style = document.createElement("style");
style.innerHTML = `
@keyframes blink {
0% { opacity: 1; }
50% { opacity: 0; }
100% { opacity: 1; }
}`;
element.style.animation = "blink 1s infinite";
document.head.appendChild(style);
};
var shown = false;
var ismag = false;
var finished = false;
function move() {
var sc = OWOP.camera.zoom / 16;
var pixelSize = 32 * sc;
var gameX = chunkx / 2;
var gameY = chunky / 2;
var screenX = (-OWOP.camera.x) * OWOP.camera.zoom + gameX * pixelSize;
var screenY = (-OWOP.camera.y) * OWOP.camera.zoom + gameY * pixelSize;
if (screenX > -512 && screenY > -512 && screenX < window.innerWidth && screenY < window.innerHeight) {
if (sc > 1.0 && !ismag) {
ismag = true;
element.style.imageRendering = 'pixelated';
} else if (sc <= 1.0 && ismag) {
ismag = false;
element.style.imageRendering = 'auto';
};
element.style.transform = `matrix(${sc}, 0, 0, ${sc}, ${Math.round(screenX)}, ${Math.round(screenY)})`;
if (!shown) {
OWOP.elements.viewport.appendChild(element);
shown = true;
};
} else {
if (shown) {
element.remove();
shown = false;
};
};
if (!getValue("areahighlight") || finished) {
shown = false;
OWOP.removeListener(OWOP.events.camMoved || OWOP.events.camera.moved, move);
element.remove();
};
};
// if(getValue("areahighlight")) {
// move();
OWOP.on(OWOP.events.tick, move);
// };
const totalPixels = w * h; // TODO: make this more accurate by counting every different pixel
let filledPixels = 0;
let job_id = `${tool.extra.start.toString()}-${tool.extra.end.toString()}`;
let id = `owopfuck-fill-${job_id}`;
let fillTable = document.createElement("tr");
fillTable.innerHTML = ` |
? |
| `;
fillTable.id = `owopfuck-job-${job_id}`;
document.getElementById("owopfuck-jobs").appendChild(fillTable);
document.getElementById(id + "-tp").addEventListener("click", () => {
OWOP.emit(6666695, chunkx, chunky);
});
let item = `setPixel_${chunkx.toString().replace("-", "_")}_${chunky.toString().replace("-", "_")}_${(chunkx + w).toString().replace("-", "_")}_${(chunky + h).toString().replace("-", "_")}`;
document.getElementById(id + "-stopbtn").addEventListener("click", () => {
bots.forEach(bot => delete bot.world[item]);
fillTable.remove();
shown = false;
finished = true;
move();
OWOP.removeListener(OWOP.events.camMoved || OWOP.events.camera.moved, move);
updateIndicator();
updateAreaPoses();
});
(async function () {
bots.forEach(bot => {
bot.world[item] = (...args) => {
if (bot.net.bucket.allowance >= getValue("freebucket")) filledPixels++;
bot.world.originalSetPixel(...args);
if ((!getValue("livepredtime") && filledPixels % 100 === 0) || getValue("livepredtime")) {
const elapsedTime = Date.now() - startTime;
let remainingTime = (elapsedTime / filledPixels) * (totalPixels - filledPixels);
if (remainingTime < 0) remainingTime = 0;
if (document.getElementById(id + "-time")) document.getElementById(id + "-time").innerText = `${(remainingTime / 1000).toFixed(2)}s`;
updateIndicator();
};
updateAreaPoses();
};
});
let startTime = Date.now();
await fill(chunkx, chunky, chunkx + w, chunky + h, color, item, "areapattern");
await (async () => {
bots.forEach(bot => delete bot.world[item]);
fillTable.remove();
shown = false;
finished = true;
move();
OWOP.removeListener(OWOP.events.camMoved || OWOP.events.camera.moved, move);
updateIndicator();
updateAreaPoses();
})();
})();
} else {
tool.extra.start = null;
tool.extra.end = null;
};
});
} catch (e) {
console.log(e);
};
}));
OWOP.tools.addToolObject(new OWOP.tools.class('Bot Unpixel area', OWOP.cursors.select, OWOP.fx.player.NONE, OWOP.RANK.USER, function (tool) {
let step = 1;
let toreplace = [0, 0, 0];
try {
tool.setFxRenderer(function (fx, ctx, time) {
if (!fx.extra.isLocalPlayer) return 1;
let x = fx.extra.player.x;
let y = fx.extra.player.y;
let fxx = (Math.floor(x / step) - OWOP.camera.x) * OWOP.camera.zoom;
let fxy = (Math.floor(y / step) - OWOP.camera.y) * OWOP.camera.zoom;
let oldlinew = ctx.lineWidth;
ctx.lineWidth = 1;
if (tool.extra.end) {
let s = tool.extra.start;
let e = tool.extra.end;
let x = (s[0] - OWOP.camera.x) * OWOP.camera.zoom + 0.5;
let y = (s[1] - OWOP.camera.y) * OWOP.camera.zoom + 0.5;
let w = e[0] - s[0];
let h = e[1] - s[1];
ctx.beginPath();
ctx.rect(x, y, w * OWOP.camera.zoom, h * OWOP.camera.zoom);
ctx.globalAlpha = 0.25;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3, 4]);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.globalAlpha = 0.25 + Math.sin(time / 320) / 4;
ctx.fillStyle = OWOP.renderer.patterns.unloaded;
ctx.fill();
ctx.setLineDash([]);
let oldfont = ctx.font;
ctx.font = "16px sans-serif";
let txt = (!tool.extra.clicking ? "M2 Inside to void. " : '') + `(${Math.abs(w)}x${Math.abs(h)}, ${(Math.abs(w) / 16 * Math.abs(h) / 16).toFixed(4)} chunks)`
let txtx = window.innerWidth >> 1;
let txty = window.innerHeight >> 1;
txtx = Math.max(x, Math.min(txtx, x + w * OWOP.camera.zoom));
txty = Math.max(y, Math.min(txty, y + h * OWOP.camera.zoom));
OWOP.drawText = (ctx, str, x, y, centered) => {
ctx.strokeStyle = "#000000", ctx.fillStyle = "#FFFFFF", ctx.lineWidth = 2.5, ctx.globalAlpha = 1;
if (centered) {
x -= ctx.measureText(str).width >> 1;
}
ctx.strokeText(str, x, y);
ctx.globalAlpha = 1;
ctx.fillText(str, x, y);
};
OWOP.drawText(ctx, txt, txtx, txty, true);
ctx.font = oldfont;
ctx.lineWidth = oldlinew;
return 0;
} else {
ctx.beginPath();
ctx.moveTo(0, fxy + 0.5);
ctx.moveTo(fxx + 0.5, 0);
//ctx.lineWidth = 1;
ctx.globalAlpha = 0.8;
ctx.strokeStyle = "#FFFFFF";
ctx.stroke();
ctx.setLineDash([3]);
ctx.strokeStyle = "#000000";
ctx.stroke();
ctx.setLineDash([]);
ctx.lineWidth = oldlinew;
return 1;
}
});
tool.extra.start = null;
tool.extra.end = null;
tool.extra.clicking = false;
tool.setEvent('keydown', function (key) {
if (key["17"]) {
toreplace = OWOP.world.getPixel(OWOP.mouse.tileX, OWOP.mouse.tileY);
OWOP.chat.local(`Unpixel [${toreplace.join(", ")}] to selected color.`);
};
});
tool.setEvent('mousedown', function (mouse) {
let s = tool.extra.start;
let e = tool.extra.end;
let isInside = function isInside() {
return mouse.tileX >= s[0] && mouse.tileX < e[0] && mouse.tileY >= s[1] && mouse.tileY < e[1];
};
if (mouse.buttons === 1 && !tool.extra.end) {
tool.extra.start = [Math.floor(mouse.tileX / step) * step, Math.floor(mouse.tileY / step) * step];
tool.extra.clicking = true;
tool.setEvent('mousemove', function (mouse) {
if (tool.extra.start && mouse.buttons === 1) {
tool.extra.end = [Math.floor(mouse.tileX / step) * step, Math.floor(mouse.tileY / step) * step];
return 1;
}
});
let finish = function finish() {
tool.setEvent('mousemove mouseup deselect', null);
tool.extra.clicking = false;
let s = tool.extra.start;
let e = tool.extra.end;
if (e) {
if (s[0] === e[0] || s[1] === e[1]) {
tool.extra.start = null;
tool.extra.end = null;
}
if (s[0] > e[0]) {
let tmp = e[0];
e[0] = s[0];
s[0] = tmp;
}
if (s[1] > e[1]) {
let tmp = e[1];
e[1] = s[1];
s[1] = tmp;
}
}
OWOP.renderer.render(OWOP.renderer.rendertype.FX);
};
tool.setEvent('deselect', finish);
tool.setEvent('mouseup', function (mouse) {
if (!(mouse.buttons & 1)) {
finish();
};
});
} else if (mouse.buttons === 1 && tool.extra.end) {
if (isInside()) {
let offx = mouse.tileX;
let offy = mouse.tileY;
tool.setEvent('mousemove', function (mouse) {
let dx = mouse.tileX - offx;
let dy = mouse.tileY - offy;
tool.extra.start = [s[0] + dx, s[1] + dy];
tool.extra.end = [e[0] + dx, e[1] + dy];
});
let end = function end() {
tool.setEvent('mouseup deselect mousemove', null);
};
tool.setEvent('deselect', end);
tool.setEvent('mouseup', function (mouse) {
if (!(mouse.buttons & 1)) {
end();
};
});
}
} else if (mouse.buttons === 2 && tool.extra.end && isInside()) {
let w = tool.extra.end[0] - tool.extra.start[0];
let h = tool.extra.end[1] - tool.extra.start[1];
let color = OWOP.player.selectedColor;
let chunkx = tool.extra.start[0];
let chunky = tool.extra.start[1];
let element = document.createElement("div");
element.style.position = "fixed";
element.style.transformOrigin = "left top 0px";
element.style.overflow = "hidden";
element.style.width = gameToSize(w, h).width;
element.style.height = gameToSize(w, h).height;
element.style.backgroundColor = `rgba(${[color[0], color[1], color[2]].join(", ")}, 0.5)`;
if (getValue("areahighlightblink")) {
var style = document.createElement("style");
style.innerHTML = `
@keyframes blink {
0% { opacity: 1; }
50% { opacity: 0; }
100% { opacity: 1; }
}`;
element.style.animation = "blink 1s infinite";
document.head.appendChild(style);
};
var shown = false;
var ismag = false;
var finished = false;
function move() {
var sc = OWOP.camera.zoom / 16;
var pixelSize = 32 * sc;
var gameX = chunkx / 2;
var gameY = chunky / 2;
var screenX = (-OWOP.camera.x) * OWOP.camera.zoom + gameX * pixelSize;
var screenY = (-OWOP.camera.y) * OWOP.camera.zoom + gameY * pixelSize;
if (screenX > -512 && screenY > -512 && screenX < window.innerWidth && screenY < window.innerHeight) {
if (sc > 1.0 && !ismag) {
ismag = true;
element.style.imageRendering = 'pixelated';
} else if (sc <= 1.0 && ismag) {
ismag = false;
element.style.imageRendering = 'auto';
};
element.style.transform = `matrix(${sc}, 0, 0, ${sc}, ${Math.round(screenX)}, ${Math.round(screenY)})`;
if (!shown) {
OWOP.elements.viewport.appendChild(element);
shown = true;
};
} else {
if (shown) {
element.remove();
shown = false;
};
};
if (!getValue("areahighlight") || finished) {
shown = false;
OWOP.removeListener(OWOP.events.camMoved || OWOP.events.camera.moved, move);
element.remove();
};
};
// if(getValue("areahighlight")) {
// move();
OWOP.on(OWOP.events.tick, move);
// };
const totalPixels = w * h;
let filledPixels = 0;
let job_id = `${tool.extra.start.toString()}-${tool.extra.end.toString()}`;
let id = `owopfuck-fill-${job_id}`;
let fillTable = document.createElement("tr");
fillTable.innerHTML = ` |
? |
| `;
fillTable.id = `owopfuck-job-${job_id}`;
document.getElementById("owopfuck-jobs").appendChild(fillTable);
document.getElementById(id + "-tp").addEventListener("click", () => {
OWOP.emit(6666695, chunkx, chunky);
});
document.getElementById(id + "-stopbtn").addEventListener("click", () => {
w = 0;
h = 0;
});
(async function () {
let item = `setPixel_${chunkx.toString().replace("-", "_")}_${chunky.toString().replace("-", "_")}_${(chunkx + w).toString().replace("-", "_")}_${(chunky + h).toString().replace("-", "_")}`;
bots.forEach(bot => {
bot.world[item] = (...args) => {
if (bot.net.bucket.allowance >= getValue("freebucket")) filledPixels++;
bot.world.originalSetPixel(...args);
if ((!getValue("livepredtime") && filledPixels % 100 === 0) || getValue("livepredtime")) {
const elapsedTime = Date.now() - startTime;
let remainingTime = (elapsedTime / filledPixels) * (totalPixels - filledPixels);
if (remainingTime < 0) remainingTime = 0;
if (document.getElementById(id + "-time")) document.getElementById(id + "-time").innerText = `${(remainingTime / 1000).toFixed(2)}s`;
updateIndicator();
};
updateAreaPoses();
};
});
let startTime = Date.now();
await unfill(chunkx, chunky, chunkx + w, chunky + h, color, toreplace, item, "areapattern");
await (async () => {
bots.forEach(bot => delete bot.world[item]);
fillTable.remove();
shown = false;
finished = true;
move();
OWOP.removeListener(OWOP.events.camMoved || OWOP.events.camera.moved, move);
updateIndicator();
updateAreaPoses();
})();
})();
} else {
tool.extra.start = null;
tool.extra.end = null;
};
});
} catch (e) {
console.log(e);
};
}));
window.owopfuck = {
assetswindow: OWOP.windowSys.windows["owopfuck assets"],
infowindow: OWOP.windowSys.windows["owopfuck info"],
jobswindow: OWOP.windowSys.windows["owopfuck jobs"],
mainwindow: OWOP.windowSys.windows["owopfuck"],
config: { getValue, setValue },
irc: ircServer,
area_poses: [],
erase_poses: []
};
});
})();