mirror of
https://github.com/DerTyp7/teamspeak-obs-overlay.git
synced 2025-10-29 12:52:09 +01:00
saving apiKey in localstorage
This commit is contained in:
59
js/app.js
59
js/app.js
@@ -1,35 +1,42 @@
|
|||||||
// Main entry point to the app
|
// Main entry point
|
||||||
function main() {
|
function main() {
|
||||||
const ws = new WebSocket(`ws://localhost:${CONFIG.remoteAppPort}`);
|
let authenticated = false; // using this bool to determine if an user is already authenticated
|
||||||
const payload = {
|
|
||||||
type: "auth",
|
|
||||||
payload: {
|
|
||||||
identifier: "de.tealfire.obs",
|
|
||||||
version: "0.0.1",
|
|
||||||
name: "TS5 OBS Overlay",
|
|
||||||
description: "A simple OBS overlay for TS5 by DerTyp876",
|
|
||||||
content: {
|
|
||||||
apiKey: apiKey,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
|
// Reset variables. Important so that the app can easly restart or reconnected.
|
||||||
clientList.clear();
|
clientList.clear();
|
||||||
channelList.clear();
|
channelList.clear();
|
||||||
selfClient = null;
|
selfClient = null;
|
||||||
|
|
||||||
ws.onopen = (event) => {
|
// Initiliaze websocket connection to TS5 client
|
||||||
// Send payload to TS5 client
|
const ws = new WebSocket(`ws://localhost:${CONFIG.remoteAppPort}`);
|
||||||
ws.send(JSON.stringify(payload));
|
const initalPayload = {
|
||||||
|
type: "auth",
|
||||||
|
payload: {
|
||||||
|
identifier: "de.tealfire.obs",
|
||||||
|
version: "0.0.1", // TODO take version from meta.json
|
||||||
|
name: "TS5 OBS Overlay",
|
||||||
|
description: "A simple OBS overlay for TS5 by DerTyp876",
|
||||||
|
content: {
|
||||||
|
apiKey: localStorage.getItem("apiKey") ?? "",
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
ws.onopen = () => {
|
||||||
|
// Send authentication payload to TS5 client
|
||||||
|
ws.send(JSON.stringify(initalPayload));
|
||||||
|
};
|
||||||
|
|
||||||
|
// Handle websockets
|
||||||
ws.onmessage = (event) => {
|
ws.onmessage = (event) => {
|
||||||
let data = JSON.parse(event.data);
|
let data = JSON.parse(event.data);
|
||||||
// console.log(data);
|
console.log(data);
|
||||||
switch (data.type) {
|
switch (data.type) {
|
||||||
case "auth":
|
case "auth":
|
||||||
handleAuthMessage(data);
|
handleAuthMessage(data);
|
||||||
apiKey = data.payload.apiKey;
|
localStorage.setItem("apiKey", data.payload.apiKey);
|
||||||
|
authenticated = true;
|
||||||
|
//console.log(apiKey);
|
||||||
break;
|
break;
|
||||||
case "clientMoved":
|
case "clientMoved":
|
||||||
handleClientMoved(data);
|
handleClientMoved(data);
|
||||||
@@ -58,10 +65,22 @@ function main() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
ws.onclose = (event) => {
|
ws.onclose = (event) => {
|
||||||
|
// Need to check if the connection got closed while the user was connected.
|
||||||
|
// Because TS does not return a proper authentication error.
|
||||||
|
// closed and not authenticated -> auth error or ts5 restarted/closed
|
||||||
|
// closed and authenticated -> no auth error, app/obs was just closed by user
|
||||||
|
if (authenticated == false) {
|
||||||
|
localStorage.setItem("apiKey", "");
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(event);
|
||||||
console.log("Disconnected");
|
console.log("Disconnected");
|
||||||
|
|
||||||
|
// Since the user disconnected, we need to clear all clients and channel
|
||||||
clientList.clear();
|
clientList.clear();
|
||||||
channelList.clear();
|
channelList.clear();
|
||||||
drawClients();
|
|
||||||
|
drawClients(); // Redraw overlay to remove all clients
|
||||||
main(); // Reconnected
|
main(); // Reconnected
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,15 +2,13 @@ function drawClients() {
|
|||||||
let elem = document.getElementById("content");
|
let elem = document.getElementById("content");
|
||||||
|
|
||||||
result = "";
|
result = "";
|
||||||
if (thisClient) {
|
if (selfClient) {
|
||||||
getClientsInChannel(thisClient.channel).forEach((c) => {
|
getClientsInChannel(selfClient.channel).forEach((c) => {
|
||||||
isHidden = CONFIG.hideSilent && (c.talkStatus == 0 || c.isMuted());
|
isHidden = CONFIG.hideSilent && (c.talkStatus == 0 || c.isMuted());
|
||||||
|
|
||||||
result += `<div class="client-div" ${
|
result += `<div class="client-div" ${isHidden ? "hidden" : ""} style="color:${
|
||||||
isHidden ? "hidden" : ""
|
CONFIG.style.fontColor
|
||||||
} style="color:${CONFIG.style.fontColor}; font-size:${
|
}; font-size:${CONFIG.style.fontSize}">`;
|
||||||
CONFIG.style.fontSize
|
|
||||||
}">`;
|
|
||||||
result += '<div class="client-img-div">';
|
result += '<div class="client-img-div">';
|
||||||
if (c.outputMuted) {
|
if (c.outputMuted) {
|
||||||
result += ' <img src="img/muted_output.svg" />';
|
result += ' <img src="img/muted_output.svg" />';
|
||||||
|
|||||||
@@ -1,13 +1,7 @@
|
|||||||
function handleAuthMessage(data) {
|
function handleAuthMessage(data) {
|
||||||
channelList.setItems(
|
channelList.setItems(parseChannelInfos(data.payload.connections[0].channelInfos));
|
||||||
parseChannelInfos(data.payload.connections[0].channelInfos)
|
clientList.setItems(parseClientInfos(data.payload.connections[0].clientInfos));
|
||||||
);
|
selfClient = clientList.getById(data.payload.connections[0].clientId);
|
||||||
clientList.setItems(
|
|
||||||
parseClientInfos(data.payload.connections[0].clientInfos)
|
|
||||||
);
|
|
||||||
thisClient = clientList.getById(data.payload.connections[0].clientId);
|
|
||||||
|
|
||||||
selfClient = data.payload.connections[0].clientInfos.find((client) => client.id == data.payload.connections[0].clientId);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function handleClientMoved(data) {
|
function handleClientMoved(data) {
|
||||||
@@ -27,9 +21,7 @@ function handleClientMoved(data) {
|
|||||||
// User moved channel
|
// User moved channel
|
||||||
if (client) {
|
if (client) {
|
||||||
// Client already exists in list
|
// Client already exists in list
|
||||||
clientList.getById(data.payload.clientId).channel = channelList.getById(
|
clientList.getById(data.payload.clientId).channel = channelList.getById(data.payload.newChannelId);
|
||||||
data.payload.newChannelId
|
|
||||||
);
|
|
||||||
} else {
|
} else {
|
||||||
console.log(data.payload);
|
console.log(data.payload);
|
||||||
// New Client has to be created
|
// New Client has to be created
|
||||||
@@ -52,9 +44,7 @@ function handleClientPropertiesUpdate(data) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (client) {
|
if (client) {
|
||||||
client.channel = channelList.getById(
|
client.channel = channelList.getById(data.payload.properties.channelGroupInheritedChannelId);
|
||||||
data.payload.properties.channelGroupInheritedChannelId
|
|
||||||
);
|
|
||||||
|
|
||||||
client.name = data.payload.properties.nickname;
|
client.name = data.payload.properties.nickname;
|
||||||
client.inputMuted = data.payload.properties.inputMuted;
|
client.inputMuted = data.payload.properties.inputMuted;
|
||||||
@@ -63,9 +53,7 @@ function handleClientPropertiesUpdate(data) {
|
|||||||
clientList.add(
|
clientList.add(
|
||||||
new Client(
|
new Client(
|
||||||
data.payload.clientId,
|
data.payload.clientId,
|
||||||
channelList.getById(
|
channelList.getById(data.payload.properties.channelGroupInheritedChannelId),
|
||||||
data.payload.properties.channelGroupInheritedChannelId
|
|
||||||
),
|
|
||||||
data.payload.properties.nickname,
|
data.payload.properties.nickname,
|
||||||
data.payload.properies.inputMuted,
|
data.payload.properies.inputMuted,
|
||||||
data.payload.properies.outputMuted
|
data.payload.properies.outputMuted
|
||||||
|
|||||||
Reference in New Issue
Block a user