From 1c93819bc4d079cdd9bc5b96555b91504aae1c76 Mon Sep 17 00:00:00 2001 From: Demur Rumed Date: Thu, 23 Nov 2023 06:20:03 +0000 Subject: [PATCH] shuffle things around for logout button & home page being behind login page & redirects --- ui/app/api/login/route.ts | 3 ++- ui/app/api/logout/route.ts | 7 +++++++ ui/app/login/page.tsx | 3 +++ ui/app/page.tsx | 3 ++- ui/components/Logout.tsx | 10 ++++++++++ ui/components/Password.tsx | 18 ++++++++++++++---- ui/middleware.ts | 9 ++++++--- 7 files changed, 44 insertions(+), 9 deletions(-) create mode 100644 ui/app/api/logout/route.ts create mode 100644 ui/app/login/page.tsx create mode 100644 ui/components/Logout.tsx diff --git a/ui/app/api/login/route.ts b/ui/app/api/login/route.ts index 2b609ba66d..9ae9b961e0 100644 --- a/ui/app/api/login/route.ts +++ b/ui/app/api/login/route.ts @@ -5,8 +5,9 @@ export async function POST(request: Request) { if (process.env.PEERDB_PASSWORD !== password) { return new Response(JSON.stringify({ error: 'wrong password' })); } - cookies().set('password', password, { + cookies().set('auth', password, { expires: Date.now() + 24 * 60 * 60 * 1000, + secure: process.env.PEERDB_SECURE_COOKIES === 'true', }); return new Response('{}'); } diff --git a/ui/app/api/logout/route.ts b/ui/app/api/logout/route.ts new file mode 100644 index 0000000000..6ecd0f8971 --- /dev/null +++ b/ui/app/api/logout/route.ts @@ -0,0 +1,7 @@ +import {NextResponse} from 'next/server' +import { cookies } from 'next/headers'; + +export async function POST(req: Request) { + cookies().delete('auth'); + return NextResponse.redirect(new URL('/login', req.url)) +} diff --git a/ui/app/login/page.tsx b/ui/app/login/page.tsx new file mode 100644 index 0000000000..79f05c7423 --- /dev/null +++ b/ui/app/login/page.tsx @@ -0,0 +1,3 @@ +import Password from '@/components/Password'; + +export default function Login() { return } diff --git a/ui/app/page.tsx b/ui/app/page.tsx index 4821dbcae8..37b2718978 100644 --- a/ui/app/page.tsx +++ b/ui/app/page.tsx @@ -1,3 +1,4 @@ +import Logout from '@/components/Logout'; import Password from '@/components/Password'; import SidebarComponent from '@/components/SidebarComponent'; import { Header } from '@/lib/Header'; @@ -9,7 +10,7 @@ export default function Home() { }>
PeerDB Home Page
- <>PEERDB_PASSWORD + {cookies().get('auth') && }
); diff --git a/ui/components/Logout.tsx b/ui/components/Logout.tsx new file mode 100644 index 0000000000..72975b8fc3 --- /dev/null +++ b/ui/components/Logout.tsx @@ -0,0 +1,10 @@ +'use client'; +import { Button } from '@/lib/Button'; + +export default function Logout() { + return ( + + ); +} diff --git a/ui/components/Password.tsx b/ui/components/Password.tsx index f0b2103c5d..2f02a357bb 100644 --- a/ui/components/Password.tsx +++ b/ui/components/Password.tsx @@ -1,17 +1,27 @@ 'use client'; import { Button } from '@/lib/Button'; +import { TextField } from '@/lib/TextField'; +import { useState } from 'react'; export default function Password() { + const [pass, setPass] = useState(""); + const [error, setError] = useState(""); return ( <> - + {error &&
{error}
} + Password: ) => setPass(e.target.value)} />