implement protocol versioning and add site specific logos
This commit is contained in:
parent
ac5e24c5d7
commit
0787dfda47
8 changed files with 76 additions and 14 deletions
client
server
|
@ -1,7 +1,7 @@
|
|||
// ==UserScript==
|
||||
// @name MultiProbe
|
||||
// @namespace https://*.angusnicneven.com/*
|
||||
// @version 20241013.0
|
||||
// @version 20241013.1
|
||||
// @description Probe with friends!
|
||||
// @author tgpholly
|
||||
// @match https://*.angusnicneven.com/*
|
||||
|
@ -49,13 +49,22 @@ const SITE_DEFAULT_HOVER_CURSOR = {
|
|||
"heavenonline.xyz": "https://heavenonline.xyz/core/cursor_hover/frame1.png"
|
||||
};
|
||||
|
||||
const SITE_LOGOS = {
|
||||
"*.angusnicneven.com": "https://eusv.net/NLuGOZGZtS3BEr",
|
||||
"multiprobe.eusv.net": "https://eusv.net/NLuGOZGZtS3BEr",
|
||||
"*.heavenonline.xyz": "https://eusv.net/Iu8kZfgAC8NFdU",
|
||||
"*.eusv.net": "https://eusv.net/C89X3tb5mtkVI7"
|
||||
};
|
||||
|
||||
const PROTOCOL_VERSION = 2;
|
||||
|
||||
console.log("[MP] MultiProbe init");
|
||||
|
||||
(function() {
|
||||
'use strict';
|
||||
|
||||
// Make sure to change the userscript version too!!!!!!!!!!
|
||||
const USERSCRIPT_VERSION_RAW = "20241013.0";
|
||||
const USERSCRIPT_VERSION_RAW = "20241013.1";
|
||||
const USERSCRIPT_VERSION = parseInt(USERSCRIPT_VERSION_RAW.replace(".", ""));
|
||||
|
||||
if (!continueRunningScript) {
|
||||
|
@ -76,7 +85,8 @@ console.log("[MP] MultiProbe init");
|
|||
GroupData: 7,
|
||||
HonkShoe: 8,
|
||||
BadgeUnlock: 9,
|
||||
DEBUG_UnlockAllBadges: 10
|
||||
DEBUG_UnlockAllBadges: 10,
|
||||
TooOutOfDate: 11
|
||||
};
|
||||
|
||||
let cssCursor = "";
|
||||
|
@ -148,7 +158,7 @@ html {
|
|||
animation: ping 2s linear;
|
||||
animation-iteration-count: 1;
|
||||
image-rendering: pixelated;
|
||||
background: url("");
|
||||
background: url("https://eusv.net/MA7cm1BBelFHDP");
|
||||
width: 64px;
|
||||
height: 64px;
|
||||
z-index: -1!important;
|
||||
|
@ -161,7 +171,7 @@ html {
|
|||
width: 64px;
|
||||
height: 64px;
|
||||
image-rendering: pixelated;
|
||||
background: url("");
|
||||
background: url("https://eusv.net/9ZU5r29lg1yKIi");
|
||||
z-index: 1;
|
||||
transform: translate(60px, -60px);
|
||||
}
|
||||
|
@ -802,8 +812,13 @@ mp_button {
|
|||
}
|
||||
|
||||
let windowContainer = null;
|
||||
let preventReconnect = false;
|
||||
|
||||
function doConnect(apiKey) {
|
||||
if (preventReconnect) {
|
||||
return;
|
||||
}
|
||||
|
||||
const Buffer = getBufferClass();
|
||||
|
||||
console.log("[MP] Connecting to realtime server...");
|
||||
|
@ -820,11 +835,14 @@ mp_button {
|
|||
selfCursor.element.style.visibility = localStorage["t00mp_cursorStyle"] ?? "hidden";
|
||||
selfCursor.hasBeenMoved = true;
|
||||
const currentPage = windowLocation.split("/").slice(2).join("/");
|
||||
const key = window.ebfohezwACBL8DU8sqvedw ?? "";
|
||||
ws.send(keepAlivePacket);
|
||||
ws.send(createWriter(Endian.LE, 4 + apiKey.length + currentPage.length)
|
||||
ws.send(createWriter(Endian.LE, 8 + apiKey.length + currentPage.length + key.length)
|
||||
.writeUByte(MessageType.ClientDetails)
|
||||
.writeShortString(apiKey)
|
||||
.writeString(currentPage)
|
||||
.writeUShort(PROTOCOL_VERSION)
|
||||
.writeString(key)
|
||||
.toBuffer());
|
||||
pingStartTime = performance.now();
|
||||
keepAliveInterval = setInterval(() => {
|
||||
|
@ -954,6 +972,13 @@ mp_button {
|
|||
const badgeIconUrl = reader.readString16();
|
||||
|
||||
createBadgePopup(badgeTitle, badgeDescription, badgeIconUrl);
|
||||
break;
|
||||
}
|
||||
case MessageType.TooOutOfDate:
|
||||
{
|
||||
ws.close();
|
||||
preventReconnect = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -986,9 +1011,15 @@ mp_button {
|
|||
const dialog = document.createElement("mp_container");
|
||||
dialog.style = "position:absolute;top:50%;left:50%;min-width:15rem;background-color:#343434;padding:1rem;transform:translate(-50%,-50%);text-align:center;color:white";
|
||||
bg.appendChild(dialog);
|
||||
const title = document.createElement("h4");
|
||||
title.innerText = "MultiProbe";
|
||||
title.style.marginBottom = "0px";
|
||||
const title = document.createElement("img");
|
||||
for (const siteKey of Object.keys(SITE_LOGOS)) {
|
||||
const domain = window.location.href.split("://")[1].split("/")[0];
|
||||
if ((siteKey.startsWith("*.") && domain.includes(siteKey.replace("*.", ""))) || domain.startsWith(siteKey)) {
|
||||
title.src = SITE_LOGOS[siteKey];
|
||||
break;
|
||||
}
|
||||
}
|
||||
title.style = "background-color:black;padding:.25rem;margin-bottom:.5rem;border:1px solid white";
|
||||
dialog.appendChild(title);
|
||||
const subtitle = document.createElement("h5");
|
||||
subtitle.innerText = `Logged in as ${localStorage["t00mp_username"]}`;
|
||||
|
|
|
@ -7,7 +7,6 @@
|
|||
<title>UserScript test page</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<script src="./Terminal-00-Multiuser.user.js"></script>
|
||||
</body>
|
||||
</html>
|
|
@ -20,5 +20,8 @@
|
|||
"itterations": 10000,
|
||||
"keylength": 64
|
||||
}
|
||||
},
|
||||
"badge": {
|
||||
"key": "hidden :)"
|
||||
}
|
||||
}
|
|
@ -9,5 +9,6 @@ export enum MessageType {
|
|||
GroupData,
|
||||
HonkShoe,
|
||||
BadgeUnlock,
|
||||
DEBUG_UnlockAllBadges
|
||||
DEBUG_UnlockAllBadges,
|
||||
TooOutOfDate
|
||||
}
|
|
@ -196,6 +196,9 @@ async function updateConnectionMetrics() {
|
|||
}
|
||||
|
||||
const keepalivePacket = createWriter(Endian.LE, 1).writeByte(MessageType.KeepAlive).toBuffer();
|
||||
const outOfDatePacket = createWriter(Endian.LE, 1).writeByte(MessageType.TooOutOfDate).toBuffer();
|
||||
|
||||
const PROTOCOL_VERSION = 2;
|
||||
|
||||
websocketServer.on("connection", (socket: any) => {
|
||||
const myUUID = crypto.randomUUID();
|
||||
|
@ -270,6 +273,24 @@ websocketServer.on("connection", (socket: any) => {
|
|||
}
|
||||
const apiKey = reader.readShortString();
|
||||
const rawURL = reader.readString();
|
||||
let key = "";
|
||||
|
||||
// If there isn't enough bytes for the protocol version
|
||||
// then we're definitely out of date!
|
||||
if (reader.readOffset === reader.length) {
|
||||
socket.send(outOfDatePacket);
|
||||
return;
|
||||
} else {
|
||||
const protocolVersion = reader.readUShort();
|
||||
// Procol version is too old
|
||||
if (protocolVersion < PROTOCOL_VERSION) {
|
||||
socket.send(outOfDatePacket);
|
||||
return;
|
||||
}
|
||||
// We are the current version if we got here!
|
||||
key = reader.readString();
|
||||
}
|
||||
|
||||
const dbUser = await UserService.GetUserByAPIKey(apiKey);
|
||||
if (dbUser == null) {
|
||||
return;
|
||||
|
@ -319,7 +340,8 @@ websocketServer.on("connection", (socket: any) => {
|
|||
userParty: dbUserParty,
|
||||
party: dbParty,
|
||||
remoteUser: user,
|
||||
users: users
|
||||
users: users,
|
||||
key: key
|
||||
};
|
||||
for (const key of goalBadgeKeys) {
|
||||
scriptParams.badge = BadgeCache.GoalBadges.get(key)!;
|
||||
|
|
|
@ -11,5 +11,6 @@ export default interface ScriptParameters {
|
|||
userParty: UserParty | null,
|
||||
party: Party | null,
|
||||
remoteUser: RemoteUser,
|
||||
users: FunkyArray<string, RemoteUser>
|
||||
users: FunkyArray<string, RemoteUser>,
|
||||
key: string
|
||||
}
|
|
@ -7,6 +7,7 @@ export default abstract class Config {
|
|||
public static session:ConfigSession = config.session;
|
||||
public static githost:string = config.githost;
|
||||
public static database:ConfigDatabase = config.database;
|
||||
public static badge:ConfigBadge = config.badge;
|
||||
}
|
||||
|
||||
interface ConfigPorts {
|
||||
|
@ -34,3 +35,7 @@ interface DatabasePbkdf2 {
|
|||
itterations: number,
|
||||
keylength: number
|
||||
}
|
||||
|
||||
interface ConfigBadge {
|
||||
key: string
|
||||
}
|
|
@ -1 +1 @@
|
|||
Subproject commit 7accf5b1c9529490c5713f8dbb9a067cfb2c3d49
|
||||
Subproject commit 8b2408c67f98b1a51b35bbfecde1d65e5ea39daf
|
Loading…
Add table
Reference in a new issue