152 lines
5.7 KiB
TypeScript
152 lines
5.7 KiB
TypeScript
import { useAuth } from '@/hooks'
|
|
|
|
export default function HomePage() {
|
|
const { isAuthenticated, login, isLoading } = useAuth()
|
|
|
|
if (isLoading) {
|
|
return (
|
|
<div className="flex min-h-[60vh] items-center justify-center">
|
|
<div className="h-12 w-12 animate-spin rounded-full border-4 border-primary-200 border-t-primary-600" />
|
|
</div>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<div className="flex min-h-[60vh] flex-col items-center justify-center">
|
|
<div className="text-center">
|
|
<h1 className="text-4xl font-bold tracking-tight text-gray-900 sm:text-5xl md:text-6xl">
|
|
Welcome to{' '}
|
|
<span className="text-primary-600">Keycloak Auth</span>
|
|
</h1>
|
|
<p className="mx-auto mt-6 max-w-2xl text-lg text-gray-600">
|
|
A secure authentication system powered by Keycloak and FastAPI. Login
|
|
with your Keycloak credentials to access protected resources.
|
|
</p>
|
|
|
|
{!isAuthenticated && (
|
|
<div className="mt-10">
|
|
<button
|
|
onClick={login}
|
|
className="inline-flex items-center gap-2 rounded-lg bg-primary-600 px-8 py-4 text-lg font-semibold text-white shadow-lg transition-all hover:bg-primary-700 hover:shadow-xl focus:outline-none focus:ring-4 focus:ring-primary-300"
|
|
>
|
|
<svg
|
|
className="h-6 w-6"
|
|
fill="none"
|
|
viewBox="0 0 24 24"
|
|
stroke="currentColor"
|
|
strokeWidth={2}
|
|
>
|
|
<path
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
d="M11 16l-4-4m0 0l4-4m-4 4h14m-5 4v1a3 3 0 01-3 3H6a3 3 0 01-3-3V7a3 3 0 013-3h7a3 3 0 013 3v1"
|
|
/>
|
|
</svg>
|
|
Login with Keycloak
|
|
</button>
|
|
</div>
|
|
)}
|
|
|
|
{isAuthenticated && (
|
|
<div className="mt-10">
|
|
<a
|
|
href="/dashboard"
|
|
className="inline-flex items-center gap-2 rounded-lg bg-primary-600 px-8 py-4 text-lg font-semibold text-white shadow-lg transition-all hover:bg-primary-700 hover:shadow-xl focus:outline-none focus:ring-4 focus:ring-primary-300"
|
|
>
|
|
<svg
|
|
className="h-6 w-6"
|
|
fill="none"
|
|
viewBox="0 0 24 24"
|
|
stroke="currentColor"
|
|
strokeWidth={2}
|
|
>
|
|
<path
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
d="M4 6a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2H6a2 2 0 01-2-2V6zM14 6a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2h-2a2 2 0 01-2-2V6zM4 16a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2H6a2 2 0 01-2-2v-2zM14 16a2 2 0 012-2h2a2 2 0 012 2v2a2 2 0 01-2 2h-2a2 2 0 01-2-2v-2z"
|
|
/>
|
|
</svg>
|
|
Go to Dashboard
|
|
</a>
|
|
</div>
|
|
)}
|
|
</div>
|
|
|
|
{/* Features Section */}
|
|
<div className="mt-20 grid gap-8 sm:grid-cols-2 lg:grid-cols-3">
|
|
<div className="rounded-lg border border-gray-200 bg-white p-6 shadow-sm">
|
|
<div className="mb-4 flex h-12 w-12 items-center justify-center rounded-lg bg-primary-100">
|
|
<svg
|
|
className="h-6 w-6 text-primary-600"
|
|
fill="none"
|
|
viewBox="0 0 24 24"
|
|
stroke="currentColor"
|
|
strokeWidth={2}
|
|
>
|
|
<path
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
d="M12 15v2m-6 4h12a2 2 0 002-2v-6a2 2 0 00-2-2H6a2 2 0 00-2 2v6a2 2 0 002 2zm10-10V7a4 4 0 00-8 0v4h8z"
|
|
/>
|
|
</svg>
|
|
</div>
|
|
<h3 className="mb-2 text-lg font-semibold text-gray-900">
|
|
Secure Authentication
|
|
</h3>
|
|
<p className="text-gray-600">
|
|
HTTP-only cookies protect your tokens from XSS attacks.
|
|
</p>
|
|
</div>
|
|
|
|
<div className="rounded-lg border border-gray-200 bg-white p-6 shadow-sm">
|
|
<div className="mb-4 flex h-12 w-12 items-center justify-center rounded-lg bg-primary-100">
|
|
<svg
|
|
className="h-6 w-6 text-primary-600"
|
|
fill="none"
|
|
viewBox="0 0 24 24"
|
|
stroke="currentColor"
|
|
strokeWidth={2}
|
|
>
|
|
<path
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
d="M9 12l2 2 4-4m5.618-4.016A11.955 11.955 0 0112 2.944a11.955 11.955 0 01-8.618 3.04A12.02 12.02 0 003 9c0 5.591 3.824 10.29 9 11.622 5.176-1.332 9-6.03 9-11.622 0-1.042-.133-2.052-.382-3.016z"
|
|
/>
|
|
</svg>
|
|
</div>
|
|
<h3 className="mb-2 text-lg font-semibold text-gray-900">
|
|
Keycloak Integration
|
|
</h3>
|
|
<p className="text-gray-600">
|
|
Enterprise-grade identity management with Keycloak SSO.
|
|
</p>
|
|
</div>
|
|
|
|
<div className="rounded-lg border border-gray-200 bg-white p-6 shadow-sm">
|
|
<div className="mb-4 flex h-12 w-12 items-center justify-center rounded-lg bg-primary-100">
|
|
<svg
|
|
className="h-6 w-6 text-primary-600"
|
|
fill="none"
|
|
viewBox="0 0 24 24"
|
|
stroke="currentColor"
|
|
strokeWidth={2}
|
|
>
|
|
<path
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
d="M13 10V3L4 14h7v7l9-11h-7z"
|
|
/>
|
|
</svg>
|
|
</div>
|
|
<h3 className="mb-2 text-lg font-semibold text-gray-900">
|
|
FastAPI Backend
|
|
</h3>
|
|
<p className="text-gray-600">
|
|
High-performance Python backend with automatic API documentation.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|