Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- // ==UserScript==
- // @name SlashKickChelly..
- // @namespace http://tampermonkey.net/
- // @version 1.11
- // @description Automatic Moderation
- // @author MeKLiN
- // @match https://stumblechat.com/room/*
- // @icon https://www.google.com/s2/favicons?sz=64&domain=stumblechat.com
- // @grant none
- // @license MIT
- // ==/UserScript==
- let webSocket;
- (function() {
- 'use strict';
- let selfHandleSet = false; // Variable to track if the 'self' handle has been set
- let selfHandle; // Variable to store the 'self' handle
- const handleUserMap = {}; // Initialize handleUserMap as an empty object
- // Define yourHandle variable
- const yourHandle = "myHandle"; // Replace "myHandle" with the actual handle
- function parseWebSocketMessage(message) {
- const parsedMessage = JSON.parse(message);
- if (parsedMessage.stumble === "join") {
- const { handle, username } = parsedMessage;
- if (!selfHandleSet) {
- // If 'self' handle hasn't been set yet, set it now
- selfHandle = handle;
- handleUserMap[handle] = "self"; // Set the first entry as 'self'
- selfHandleSet = true;
- } else {
- handleUserMap[handle] = username;
- }
- addUserToUserList({ handle, username });
- const joinMessage = `${username} joined the chat.`;
- displayWebSocketMessage(joinMessage);
- } else if (parsedMessage.stumble === "quit") {
- const handle = parsedMessage.handle;
- const username = handleUserMap[handle];
- if (username) {
- delete handleUserMap[handle];
- removeUserFromUserList(handle);
- const quitMessage = `${username} left the chat.`;
- displayWebSocketMessage(quitMessage);
- }
- } else if (parsedMessage.stumble === "msg") {
- // Handle additional changes to the user list for specific "msg" messages
- }
- }
- let webSocketURL; // Global variable to store the WebSocket URL!
- // Function to set up WebSocket listener
- function setupWebSocketListener() {
- // Override WebSocket constructor to intercept WebSocket creation
- const originalWebSocket = window.WebSocket;
- window.WebSocket = function(url, protocols) {
- webSocket = new originalWebSocket(url, protocols); // Assign to global webSocket variable
- console.log('WebSocket URL:', webSocketURL);
- // Call original WebSocket constructor
- const ws = new originalWebSocket(url, protocols);
- // Event listener for receiving messages
- webSocket.addEventListener('message', event => {
- handleWebSocketMessage(event.data);
- });
- return webSocket;
- };
- }
- // WebSocket Listener: Override WebSocket constructor to intercept WebSocket creation
- const originalWebSocket = window.WebSocket;
- window.WebSocket = function(url, protocols) {
- // Call original WebSocket constructor
- const ws = new originalWebSocket(url, protocols);
- // Event listener for receiving messages
- ws.addEventListener('message', event => {
- const parsedMessage = JSON.parse(event.data);
- // Check if the message is a "joined" message
- if (parsedMessage.stumble === "joined") {
- // Extracting our own handle from the "self" object in the message
- const selfHandle = parsedMessage.self.handle;
- // Update handleUserMap and custom user list when a user joins
- const userList = parsedMessage.userlist;
- if (userList && userList.length > 0) {
- userList.forEach(user => {
- // Check if the user being added is ourselves
- const isSelf = user.handle === selfHandle;
- // If it's our own user, update handleUserMap and display our own handle in the user list
- if (isSelf) {
- // Update handleUserMap with our own handle and username
- handleUserMap[user.handle] = user.username || user.nick;
- // Add our own handle to the custom user list with purple icon
- addUserToUserList({
- username: user.username,
- handle: user.handle,
- active: true, // We just joined, so we're considered active
- icon: "⚪" // White icon for our own user entry
- }, "self");
- console.log('const originalWebSocket = window.WebSocket found self for white dot. Applying!')
- } else {
- // If it's not our own user, proceed as usual and add them to the user list
- updateUserListAndMapOnJoin(user);
- }
- });
- }
- } else if (parsedMessage.stumble === "join") {
- // Handle join messages
- const { handle, username } = parsedMessage;
- // Check if the user being added is not ourselves
- if (handle !== yourHandle) {
- handleUserMap[handle] = username;
- addUserToUserList({ handle, username }, "join");
- }
- } else if (parsedMessage.stumble === "quit") {
- // Handle quit messages
- const handle = parsedMessage.handle;
- const username = handleUserMap[handle];
- if (username) {
- // Remove the user from the handleUserMap
- delete handleUserMap[handle];
- // Remove the user from the user list
- removeUserFromUserList(handle);
- console.log('user departed')
- addUserToUserList({ handle, username }, "quit");
- }
- } else if (parsedMessage.stumble === "msg") {
- // Handle message messages
- const { handle, text } = parsedMessage;
- const username = handleUserMap[handle] || handle;
- displayWebSocketMessage(event.data);
- }
- // Check if the message is a system message
- if (parsedMessage.stumble === "system") {
- const systemMessage = parsedMessage.message;
- // Check if the system message contains the client version
- if (systemMessage.startsWith('"Client Version:')) {
- // Save the user list to a file
- console.log("sysmsgdetected");
- }
- }
- });
- return ws;
- };
- // Function to create user list div
- function createUserListDiv() {
- const userListDiv = document.createElement("div");
- userListDiv.id = "userList";
- userListDiv.style.position = "absolute"; // Change to absolute positioning
- userListDiv.style.top = "100px"; // Adjust top position as needed
- userListDiv.style.left = "10px"; // Adjust left position as needed
- userListDiv.style.height = "calc(100% - 100px)"; // Adjust height to fill remaining space
- userListDiv.style.overflowY = "auto";
- userListDiv.style.color = "#ffffff";
- userListDiv.style.padding = "10px";
- userListDiv.style.zIndex = "2"; // Set a higher z-index value
- userListDiv.style.display = "none"; // Hide the custom user list by default
- return userListDiv;
- }
- // Function to update handleUserMap with user data from the loaded file
- function updateHandleUserMap(fileContent) {
- // Split the file content into lines
- const lines = fileContent.split('\n');
- // Iterate over each line to parse user data
- lines.forEach(line => {
- const userData = line.trim().split(' '); // Splitting by space to separate username and handle
- if (userData.length === 2) {
- const username = userData[0].trim();
- const handle = userData[1].trim();
- // Check if the handle already exists in the handleUserMap
- if (!handleUserMap.hasOwnProperty(handle)) {
- // Update user map with the new username and handle
- handleUserMap[handle] = username;
- }
- }
- });
- }
- // Function to update the user list display
- function updateUserListDisplay() {
- // Get the user list element
- const userList = document.getElementById("userList");
- if (userList) {
- // Update the display with modified handleUserMap
- userList.innerHTML = ""; // Clear the user list
- for (const handle in handleUserMap) {
- const username = handleUserMap[handle];
- // Append the user to the user list with 'B' if present
- const listItem = document.createElement("li");
- listItem.textContent = `${username} (${handle})`;
- userList.appendChild(listItem);
- }
- }
- }
- // Function to get the user's own handle number (implement your own logic)
- function getOwnHandle() {
- // Implement your logic to retrieve the user's own handle number
- // For demonstration purposes, return a hardcoded value
- return "123456"; // Replace with your actual handle number
- }
- // WebSocket listener for handling messages
- function handleWebSocketMessage(message) {
- const parsedMessage = JSON.parse(message);
- const ownHandle = getOwnHandle(); // Function to get the user's own handle number
- if (parsedMessage.stumble === "msg" && ownHandle === parsedMessage.handle) {
- const text = parsedMessage.text;
- if (text.startsWith("#ban")) {
- // Extract the handle from the message
- const handleToBan = text.replace("#ban", "").trim();
- if (handleToBan !== "") {
- // Check if the handle exists in the handleUserMap
- if (handleUserMap.hasOwnProperty(handleToBan)) {
- // Add 'B' next to the handle number
- handleUserMap[handleToBan] += " B";
- // Update the user list display
- updateUserListDisplay();
- // Update the users.txt file
- saveUserListToFile();
- } else {
- alert("Handle not found!");
- }
- } else {
- alert("Invalid handle!");
- }
- }
- }
- }
- // Call functions to set up overlay, WebSocket listener, and initial user list display
- setupWebSocketListener();
- updateUserListDisplay();
- // Function to display WebSocket messages and update user list
- function displayWebSocketMessage(message) {
- const parsedMessage = JSON.parse(message);
- if (parsedMessage.stumble === "join") {
- // Handle join messages: Extract handle and username from the message
- const { handle, username } = parsedMessage;
- // Map handle to username in handleUserMap
- handleUserMap[handle] = username;
- // Add the user to the custom user list with the appropriate icon (join user)
- addUserToUserList({ handle, username }, "join");
- } else if (parsedMessage.stumble === "msg") {
- // Handle message messages: Extract handle and text from the message
- const { handle, text } = parsedMessage;
- // Retrieve username from handleUserMap or use handle if not found
- const username = handleUserMap[handle] || handle;
- // Display the message in the WebSocket messages div
- const webSocketMessagesDiv = document.getElementById("webSocketMessages");
- if (webSocketMessagesDiv) {
- // Append the message with a newline character
- webSocketMessagesDiv.textContent += `${username}: ${text}\n`;
- // Scroll to the bottom of the messages div
- webSocketMessagesDiv.scrollTop = webSocketMessagesDiv.scrollHeight;
- }
- // Additional logic for handling commands
- if (text === "#join") {
- console.log("join");
- // Add your logic here
- } else if (text === "#icon") {
- console.log("icon");
- // Add your logic here
- } else if (text === "#tokes") {
- console.log("tokes");
- // Call your tokes function here
- TokesSendEnter();
- } else if (text === ".afk meklin") {
- console.log("tokes");
- // Call your tokes function here
- MeklinSendEnter();
- } else if (text === ".afk kyskye") {
- console.log("tokes");
- // Call your tokes function here
- KyskyeSendEnter();
- } else if (text.startsWith("#ai ")) {
- console.log("ai");
- // Extract the word after "#ai"
- const word = text.substring(4);
- console.log("Word after '#ai':", word);
- // Call your AI function here with the extracted word
- DoAi(word); // Adjust parameters as needed
- }
- } else if (parsedMessage.stumble === "joined") {
- // Handle joined messages: Add users to handleUserMap and custom user list
- const userList = parsedMessage.userlist;
- if (userList && userList.length > 0) {
- userList.forEach(user => {
- // Extract username from either "username" or "nick"
- const username = user.username || user.nick;
- // Map handle to username in handleUserMap
- handleUserMap[user.handle] = username;
- // Add the user to the custom user list with the appropriate icon
- addUserToUserList({ handle: user.handle, username }, "joined");
- });
- }
- } else if (parsedMessage.stumble === "quit") {
- // Handle quit messages: Remove users from handleUserMap and custom user list
- const handle = parsedMessage.handle;
- const username = handleUserMap[handle];
- if (username) {
- // Remove the handle from handleUserMap
- delete handleUserMap[handle];
- // Remove the user from the custom user list
- removeUserFromUserList(handle);
- console.log('line 323 user departed')
- }
- }
- }
- // Function to add user to user list with appropriate icon based on user type
- function addUserToUserList(user, userType) {
- const userList = document.getElementById("userList");
- if (!userList) return;
- const userItem = document.createElement("div");
- userItem.textContent = `${user.username}`;
- // Define the default dot color and icon
- let dotColor; // Default dot color
- let icon; // Default icon
- // Set dot color and icon based on user type
- if (userType === "self") {
- console.log('[function addUserToList] found "self" for purple dot. Applying!')
- dotColor = "purple";
- icon = "🟣";
- } else if (userType === "join") {
- console.log('[function addUserToList] found "join" for green dot. Applying!')
- dotColor = "green";
- icon = "🟢";
- } else if (userType === "joined") {
- console.log('[function addUserToList] found "joined" for blue dot. Applying!')
- dotColor = "blue";
- icon = "🔵";
- } else {
- // For other user types, default to red dot
- console.log('[function addUserToList] found "userList" for green dot. Applying!')
- dotColor = "green";
- icon = "🟢";
- //dotColor = "red"; // FOR QUIT MSG
- //icon = "🔴";
- }
- // Add colored dot based on user status
- const dot = document.createElement("span");
- dot.textContent = icon;
- dot.style.color = dotColor;
- userItem.appendChild(dot);
- // Add custom icon for the user
- if (user.icon) {
- const customIcon = document.createElement("span");
- customIcon.textContent = user.icon;
- customIcon.style.marginLeft = "5px"; // Adjust margin as needed
- userItem.appendChild(customIcon);
- }
- userList.appendChild(userItem); // Append user item to the user list
- // If user is not active and not yourself, show popup for 5 seconds
- //if (!user.active && user.handle !== yourHandle) {
- //const popup = document.createElement("div");
- //popup.textContent = "WELCOME TO STUMBLECHAT YEOPARDY!";
- //popup.style.fontSize = "48px";
- //popup.style.position = "fixed";
- //popup.style.top = "50%";
- //popup.style.left = "50%";
- //popup.style.transform = "translate(-50%, -50%)";
- //popup.style.backgroundColor = "rgba(0, 0, 0, 0.5)";
- //popup.style.color = "white";
- //popup.style.padding = "10px";
- //popup.style.borderRadius = "5px";
- //document.body.appendChild(popup);
- }
- // Function to update handleUserMap and add users to custom user list
- function updateUserListAndMapOnJoin(user) {
- // Update handleUserMap with the new user
- handleUserMap[user.handle] = user.username || user.nick; // Derive username from handle or nick
- // Add the new user to the custom user list
- addUserToUserList(user);
- }
- // Call the function to update the user list
- function updateUserListOnMessage(userList) {
- return function(message) {
- const parsedMessage = JSON.parse(message);
- if (parsedMessage.stumble === "join" || parsedMessage.stumble === "msg" || parsedMessage.stumble === "joined") {
- // Add user to user list
- addUserToUserList(parsedMessage);
- }
- };
- }
- // Function to create WebSocket messages div
- function createWebSocketMessagesDiv() {
- const div = document.createElement("div");
- div.id = "webSocketMessages";
- div.style.position = "relative";
- div.style.height = "25%";
- div.style.paddingLeft = "2px";
- div.style.visibility = "visible"; // Ensure the div is visible
- div.style.willChange = "transform";
- div.style.boxSizing = "border-box";
- div.style.overflowX = "hidden";
- div.style.overflowY = "auto";
- div.style.color = "#ffffff"; // Set font color to white
- div.style.padding = "10px"; // Example padding
- div.style.zIndex = "2"; // Set a higher z-index value for the WebSocket messages div
- // Additional styles for specific scenarios
- div.style.display = "flex";
- div.style.flexDirection = "column";
- div.style.justifyContent = "flex-end";
- div.style.fontSize = "18px";
- div.style.whiteSpace = "pre-wrap"; // Allow text to wrap within the container
- div.style.wordWrap = "break-word"; // Allow long words to break and wrap
- // Locate the chat-position div
- const chatPositionDiv = document.getElementById("chat-position");
- if (chatPositionDiv) {
- // Append custom div to the chat-position div
- chatPositionDiv.appendChild(div);
- } else {
- // If chat-position div not found, append to document body as fallback
- document.body.appendChild(div);
- }
- }
- // Call the function to create the WebSocket messages div
- createWebSocketMessagesDiv();
- function toggleWebSocketMessagesDiv() {
- const webSocketMessagesDiv = document.getElementById("webSocketMessages");
- const chatContentDiv = document.getElementById("chat-content");
- if (webSocketMessagesDiv && chatContentDiv) {
- // Check the current display style of the WebSocket messages div
- const webSocketMessagesDisplayStyle = webSocketMessagesDiv.style.display;
- // Toggle the display of both divs based on the current display style of the WebSocket messages div
- if (webSocketMessagesDisplayStyle === "none") {
- // If WebSocket messages div is hidden, show it and hide chat content div
- webSocketMessagesDiv.style.display = "block";
- chatContentDiv.style.display = "none";
- } else {
- // If WebSocket messages div is visible, hide it and show chat content div
- webSocketMessagesDiv.style.display = "none";
- chatContentDiv.style.display = "block";
- }
- }
- }
- // This line keeps the default style and hides the socket log by default remove for default wss log
- toggleWebSocketMessagesDiv()
- // Add a button to toggle visibility of WebSocket messages div
- const toggleMessagesButton = document.createElement("button");
- toggleMessagesButton.textContent = "M";
- toggleMessagesButton.style.position = "fixed";
- toggleMessagesButton.style.right = "0px";
- toggleMessagesButton.style.bottom = "0px";
- toggleMessagesButton.addEventListener("click", toggleWebSocketMessagesDiv);
- document.body.appendChild(toggleMessagesButton);
- // Call the function to create the user list div
- const userListDiv = createUserListDiv();
- const chatContainer = document.getElementById("chat-container");
- if (chatContainer) {
- chatContainer.appendChild(userListDiv); // Append to chat container instead
- } else {
- document.body.appendChild(userListDiv);
- }
- // Function to remove user from custom user list
- function removeUserFromUserList(handle) {
- const userList = document.getElementById("userList");
- if (userList) {
- const userElements = userList.querySelectorAll("div");
- userElements.forEach(userElement => {
- if (userElement.textContent.includes(`(${handle})`)) {
- userElement.remove();
- console.log('line 490 user remove/depart')
- }
- });
- }
- }
- // Function to toggle visibility of custom user list
- function toggleCustomUserList() {
- const userListDiv = document.getElementById("userList");
- if (userListDiv) {
- userListDiv.style.display = userListDiv.style.display === "none" ? "block" : "none";
- }
- }
- // Add a button to toggle visibility of custom user list
- const toggleButton = document.createElement("button");
- toggleButton.textContent = "U";
- toggleButton.style.position = "fixed";
- toggleButton.style.top = "0px";
- toggleButton.style.left = "0px";
- toggleButton.addEventListener("click", toggleCustomUserList);
- document.body.appendChild(toggleButton);
- // Function to clear messages
- function clr() {
- const webSocketMessagesDiv = document.getElementById("webSocketMessages");
- if (webSocketMessagesDiv) {
- webSocketMessagesDiv.innerHTML = "";
- }
- }
- // Function to apply font size to WebSocket messages
- function applyFontSize(fontSize) {
- const webSocketMessagesDiv = document.getElementById("webSocketMessages");
- if (webSocketMessagesDiv) {
- webSocketMessagesDiv.style.fontSize = `${fontSize}px`;
- }
- }
- /* Additional compacting styles */
- /*@-moz-document url-prefix("https://stumblechat.com/room/") {*/
- // Compact message styles
- const compactStyles = `
- .message .nickname ~ .content {
- display: inline-block;
- top: -7px;
- position: relative;
- margin-left: 2px;
- margin-right: 1em;
- }
- .content + .content {
- display: inline-block!important;
- margin-right: 1em;
- }
- .message .nickname ~ .content span {
- line-height: 1.5em;
- }
- `;
- // Apply compact styles to the document
- const style = document.createElement('style');
- style.textContent = compactStyles;
- document.head.appendChild(style);
- /*}*/
- // Function to send the "Tokes in 20 seconds" message and simulate Enter key press
- function TokesSendEnter() {
- // Insert predefined text
- const textArea = document.getElementById("textarea");
- textArea.value += 'Tokes in 20 seconds\n';
- // Simulate Enter key press
- const event = new KeyboardEvent('keypress', {
- key: 'Enter',
- code: 'Enter',
- keyCode: 13,
- which: 13,
- bubbles: true
- });
- textArea.dispatchEvent(event);
- // Set a timeout to display "tokes started" message after 20 seconds
- setTimeout(function() {
- textArea.value += 'tokes started\n'; // Send message indicating tokes has started
- // Simulate Enter key press again
- textArea.dispatchEvent(event);
- }, 20000); // 20 seconds delay
- }
- // Function to send the "Tokes in 20 seconds" message and simulate Enter key press
- function KyskyeSendEnter() {
- // Insert predefined text
- const textArea = document.getElementById("textarea");
- textArea.value += 'Tokes in 20 seconds\n';
- // Simulate Enter key press
- const event = new KeyboardEvent('keypress', {
- key: 'Enter',
- code: 'Enter',
- keyCode: 13,
- which: 13,
- bubbles: true
- });
- textArea.dispatchEvent(event);
- // Set a timeout to display "tokes started" message after 20 seconds
- setTimeout(function() {
- textArea.value += 'tokes started\n'; // Send message indicating tokes has started
- // Simulate Enter key press again
- textArea.dispatchEvent(event);
- }, 20000); // 20 seconds delay
- }
- // Function to send the "Tokes in 20 seconds" message and simulate Enter key press
- function MeklinSendEnter() {
- // Insert predefined text
- const textArea = document.getElementById("textarea");
- textArea.value += 'Tokes in 20 seconds\n';
- // Simulate Enter key press
- const event = new KeyboardEvent('keypress', {
- key: 'Enter',
- code: 'Enter',
- keyCode: 13,
- which: 13,
- bubbles: true
- });
- textArea.dispatchEvent(event);
- // Set a timeout to display "tokes started" message after 20 seconds
- setTimeout(function() {
- textArea.value += 'tokes started\n'; // Send message indicating tokes has started
- // Simulate Enter key press again
- textArea.dispatchEvent(event);
- }, 20000); // 20 seconds delay
- }
- let input; // Declare input as a global variable
- // Function to create input element
- function createInputBox() {
- input = document.createElement('input'); // Assign to global variable
- input.type = 'text';
- input.placeholder = 'Type your message...';
- input.style.position = 'fixed';
- input.style.bottom = '50px';
- input.style.left = '10px';
- input.style.zIndex = '9999';
- const button = document.createElement('button');
- button.textContent = 'Send';
- button.style.position = 'fixed';
- button.style.bottom = '10px';
- button.style.left = '10px';
- button.style.zIndex = '9999';
- // Attach a single event listener for all behaviors
- button.addEventListener('click', function () {
- const msg = input.value.trim();
- if (msg.startsWith('/kick')) {
- const username = msg.substring(6).trim();
- const handle = Object.keys(handleUserMap).find(key => handleUserMap[key] === username);
- if (handle) {
- webSocket.send(JSON.stringify({
- "stumble": "kick",
- "handle": handle
- }));
- } else {
- console.error('Username not found');
- }
- } else if (msg.startsWith('/ban')) {
- const username = msg.substring(5).trim();
- const handle = Object.keys(handleUserMap).find(key => handleUserMap[key] === username);
- if (handle) {
- webSocket.send(JSON.stringify({
- "stumble": "ban",
- "handle": handle
- }));
- } else {
- console.error('Username not found');
- }
- } else if (webSocket && webSocket.readyState === WebSocket.OPEN && msg !== "") {
- webSocket.send(JSON.stringify({
- "stumble": "msg",
- "text": msg
- }));
- console.log('Sending regular message:', msg);
- } else {
- console.error('WebSocket is not defined or message is empty');
- }
- input.value = ""; // Clear the input field after handling
- });
- document.body.appendChild(input);
- document.body.appendChild(button);
- }
- // Function to send JSON data to WebSocket server
- function sendJSONData(data) {
- if (webSocket && webSocket.readyState === WebSocket.OPEN) {
- webSocket.send(JSON.stringify(data));
- console.log('JSON data sent:', data);
- } else {
- console.error('WebSocket connection is not open');
- }
- }
- // Example JSON data
- const jsonData = {
- stumble: "msg",
- text: "Hello, WebSocket server!"
- };
- // Initialize input box
- createInputBox();
- // Call sendJSONData function to send JSON data to WebSocket server
- sendJSONData(jsonData);
- })();
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement