From 4a3d8f33704098bfa443198f639f8dadc8241803 Mon Sep 17 00:00:00 2001 From: Fabio Buracchi <45599613+buracchi@users.noreply.github.com> Date: Wed, 11 Dec 2024 22:18:13 +0000 Subject: [PATCH] Fix Lichess sessions authentication logic Refactor session management and authentication logic for Chess.com and Lichess. Fixed typo in `isListening` ref variable. Exported `LichessSession` and `ChessComSession` types in `session.ts` for broader reuse. --- src/components/home/Accounts.tsx | 124 ++++++++++++++++++------------- src/utils/session.ts | 4 +- 2 files changed, 73 insertions(+), 55 deletions(-) diff --git a/src/components/home/Accounts.tsx b/src/components/home/Accounts.tsx index 2a10f56b..00429655 100644 --- a/src/components/home/Accounts.tsx +++ b/src/components/home/Accounts.tsx @@ -21,18 +21,79 @@ import { useEffect, useRef, useState } from "react"; import AccountCards from "../common/AccountCards"; import GenericCard from "../common/GenericCard"; import LichessLogo from "./LichessLogo"; +import type { ChessComSession, LichessSession } from "@/utils/session"; function Accounts() { const [, setSessions] = useAtom(sessionsAtom); - const isListesning = useRef(false); + const isListening = useRef(false); const [databases, setDatabases] = useState([]); useEffect(() => { getDatabases().then((dbs) => setDatabases(dbs)); }, []); const [open, setOpen] = useState(false); - async function login(username: string) { - await commands.authenticate(username); + function addChessComSession(alias: string, session: ChessComSession) { + setSessions((sessions) => { + const newSessions = sessions.filter( + (s) => s.chessCom?.username !== session.username, + ); + return [ + ...newSessions, + { + chessCom: session, + player: alias, + updatedAt: Date.now() + }, + ]; + }); + } + + function addLichessSession(alias: string, session: LichessSession) { + setSessions((sessions) => { + const newSessions = sessions.filter( + (s) => s.lichess?.username !== session.username, + ); + return [ + ...newSessions, + { + lichess: session, + player: alias, + updatedAt: Date.now() + }, + ]; + }); + } + + async function addChessCom( + player: string, + username: string + ) { + const p = player !== "" ? player : username; + const stats = await getChessComAccount(username); + if (!stats) { + return; + } + addChessComSession(p, { username, stats }); + }; + + async function addLichessNoLogin( + player: string, + username: string + ) { + const p = player !== "" ? player : username; + const account = await getLichessAccount({ username }); + if (!account) return; + addLichessSession(p, { username, account }); + } + + async function onLichessAuthentication(token: string) { + const player = sessionStorage.getItem("lichess_player_alias") || ""; + sessionStorage.removeItem("lichess_player_alias"); + const account = await getLichessAccount({ token }); + if (!account) return; + const username = account.username; + const p = player !== "" ? player : username; + addLichessSession(p, { accessToken: token, username: username, account }); } async function addLichess( @@ -40,45 +101,20 @@ function Accounts() { username: string, withLogin: boolean, ) { - const p = player !== "" ? player : username; if (withLogin) { - login(username); - } else { - const account = await getLichessAccount({ - username, - }); - if (!account) return; - setSessions((sessions) => { - const newSessions = sessions.filter( - (s) => s.lichess?.username !== username, - ); - return [ - ...newSessions, - { lichess: { username, account }, player: p, updatedAt: Date.now() }, - ]; - }); + sessionStorage.setItem("lichess_player_alias", player); + return await commands.authenticate(username); } + return await addLichessNoLogin(player, username); } useEffect(() => { async function listen_for_code() { - if (isListesning.current) return; - isListesning.current = true; + if (isListening.current) return; + isListening.current = true; await listen("access_token", async (event) => { const token = event.payload; - const account = await getLichessAccount({ token }); - if (!account) return; - setSessions((sessions) => [ - ...sessions, - { - lichess: { - accessToken: token, - account, - username: account.username, - }, - updatedAt: Date.now(), - }, - ]); + await onLichessAuthentication(token); }); } @@ -100,25 +136,7 @@ function Accounts() { open={open} setOpen={setOpen} addLichess={addLichess} - addChessCom={(player, username) => { - getChessComAccount(username).then((stats) => { - const p = player !== "" ? player : username; - if (!stats) return; - setSessions((sessions) => { - const newSessions = sessions.filter( - (s) => s.chessCom?.username !== username, - ); - return [ - ...newSessions, - { - chessCom: { username, stats }, - player: p, - updatedAt: Date.now(), - }, - ]; - }); - }); - }} + addChessCom={addChessCom} /> ); diff --git a/src/utils/session.ts b/src/utils/session.ts index 29f47fbe..57a7c40c 100644 --- a/src/utils/session.ts +++ b/src/utils/session.ts @@ -1,13 +1,13 @@ import type { ChessComStats } from "@/utils/chess.com/api"; import type { LichessAccount } from "@/utils/lichess/api"; -type LichessSession = { +export type LichessSession = { accessToken?: string; username: string; account: LichessAccount; }; -type ChessComSession = { +export type ChessComSession = { username: string; stats: ChessComStats; };