From 1d31f2ec8921bb58d74458b057bbb31f4877c335 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Thu, 1 Jan 2026 21:28:33 +0900 Subject: fix(auth): redirect to login when session expires MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit When the refresh token fails (session expired), the ApiClient now notifies the AuthProvider via a callback. This triggers a logout and React state update, causing ProtectedRoute to redirect to /login. Closes #7 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 --- src/client/pages/DeckDetailPage.test.tsx | 1 + src/client/pages/HomePage.test.tsx | 1 + src/client/pages/LoginPage.test.tsx | 1 + src/client/pages/NoteTypesPage.test.tsx | 1 + src/client/pages/StudyPage.test.tsx | 1 + 5 files changed, 5 insertions(+) (limited to 'src/client/pages') diff --git a/src/client/pages/DeckDetailPage.test.tsx b/src/client/pages/DeckDetailPage.test.tsx index e02302f..1ef6ae7 100644 --- a/src/client/pages/DeckDetailPage.test.tsx +++ b/src/client/pages/DeckDetailPage.test.tsx @@ -17,6 +17,7 @@ vi.mock("../api/client", () => ({ isAuthenticated: vi.fn(), getTokens: vi.fn(), getAuthHeader: vi.fn(), + onSessionExpired: vi.fn(() => vi.fn()), rpc: { api: { decks: { diff --git a/src/client/pages/HomePage.test.tsx b/src/client/pages/HomePage.test.tsx index 5b8489a..944dd31 100644 --- a/src/client/pages/HomePage.test.tsx +++ b/src/client/pages/HomePage.test.tsx @@ -18,6 +18,7 @@ vi.mock("../api/client", () => ({ isAuthenticated: vi.fn(), getTokens: vi.fn(), getAuthHeader: vi.fn(), + onSessionExpired: vi.fn(() => vi.fn()), rpc: { api: { decks: { diff --git a/src/client/pages/LoginPage.test.tsx b/src/client/pages/LoginPage.test.tsx index e4dac95..a3efa8d 100644 --- a/src/client/pages/LoginPage.test.tsx +++ b/src/client/pages/LoginPage.test.tsx @@ -16,6 +16,7 @@ vi.mock("../api/client", () => ({ logout: vi.fn(), isAuthenticated: vi.fn(), getTokens: vi.fn(), + onSessionExpired: vi.fn(() => vi.fn()), }, ApiClientError: class ApiClientError extends Error { constructor( diff --git a/src/client/pages/NoteTypesPage.test.tsx b/src/client/pages/NoteTypesPage.test.tsx index c2df7f5..8364d17 100644 --- a/src/client/pages/NoteTypesPage.test.tsx +++ b/src/client/pages/NoteTypesPage.test.tsx @@ -18,6 +18,7 @@ vi.mock("../api/client", () => ({ isAuthenticated: vi.fn(), getTokens: vi.fn(), getAuthHeader: vi.fn(), + onSessionExpired: vi.fn(() => vi.fn()), }, ApiClientError: class ApiClientError extends Error { constructor( diff --git a/src/client/pages/StudyPage.test.tsx b/src/client/pages/StudyPage.test.tsx index 146322a..bc87b9d 100644 --- a/src/client/pages/StudyPage.test.tsx +++ b/src/client/pages/StudyPage.test.tsx @@ -17,6 +17,7 @@ vi.mock("../api/client", () => ({ isAuthenticated: vi.fn(), getTokens: vi.fn(), getAuthHeader: vi.fn(), + onSessionExpired: vi.fn(() => vi.fn()), rpc: { api: { decks: { -- cgit v1.2.3-70-g09d2