send auth message to server

This commit is contained in:
Araozu 2024-05-25 14:57:33 -05:00
parent 85c0e27a32
commit 6b45296293
2 changed files with 31 additions and 3 deletions

View File

@ -4,8 +4,8 @@ import { backend, set_auth_token, UserInfo } from "../utils";
import { Card } from "../components/Card"; import { Card } from "../components/Card";
import { AxiosError } from "axios"; import { AxiosError } from "axios";
const userIdKey = "UserId"; export const userIdKey = "UserId";
const usernameKey = "Username"; export const usernameKey = "Username";
export function Index() { export function Index() {
const [userInfo, setUserInfo] = createSignal<UserInfo | null>(null); const [userInfo, setUserInfo] = createSignal<UserInfo | null>(null);

View File

@ -1,11 +1,14 @@
import { Show, createSignal, onMount } from "solid-js"; import { Show, createSignal, onCleanup, onMount } from "solid-js";
import LoadingIcon from "../assets/loading.svg"; import LoadingIcon from "../assets/loading.svg";
import ErrorIcon from "../assets/error.svg"; import ErrorIcon from "../assets/error.svg";
import { userIdKey } from "./Index";
import { useNavigate } from "@solidjs/router";
enum LobbyStatus { enum LobbyStatus {
Connecting, Connecting,
Connected, Connected,
Disconnected, Disconnected,
Authenticating,
Error, Error,
} }
@ -13,6 +16,8 @@ const connectionRetryInterval = 5000;
export function Lobby() { export function Lobby() {
const [status, setStatus] = createSignal(LobbyStatus.Disconnected); const [status, setStatus] = createSignal(LobbyStatus.Disconnected);
const navigate = useNavigate();
let ws: WebSocket|null = null; let ws: WebSocket|null = null;
const lobbyConnect = () => { const lobbyConnect = () => {
@ -30,6 +35,20 @@ export function Lobby() {
setStatus(LobbyStatus.Connected); setStatus(LobbyStatus.Connected);
// The first message must be authenticating with the server // The first message must be authenticating with the server
const userId = localStorage.getItem(userIdKey);
if (userId === null) {
// Redirect to home page
ws?.close();
navigate("/");
return;
}
// Send an auth message to the server
ws!.send(JSON.stringify({
action: "auth",
value: userId,
}));
}; };
const onWsMessage = (ev: MessageEvent) => { const onWsMessage = (ev: MessageEvent) => {
@ -65,6 +84,9 @@ export function Lobby() {
}; };
onMount(lobbyConnect); onMount(lobbyConnect);
onCleanup(() => {
ws?.close();
});
return ( return (
<div class="w-[40rem] mx-auto bg-c-bg-2 my-4 p-4 rounded shadow-md"> <div class="w-[40rem] mx-auto bg-c-bg-2 my-4 p-4 rounded shadow-md">
@ -78,6 +100,12 @@ export function Lobby() {
Connecting to the lobby Connecting to the lobby
</p> </p>
</Show> </Show>
<Show when={status() === LobbyStatus.Authenticating}>
<p>
<img class="inline-block h-6 animate-spin" src={LoadingIcon} alt="..." />
Logging in to the server
</p>
</Show>
<Show when={status() === LobbyStatus.Error}> <Show when={status() === LobbyStatus.Error}>
<p> <p>