@riligar/auth-react 1.10.0 → 1.11.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +100 -85
- package/dist/index.esm.js +118 -14
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +144 -22
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -11,115 +11,130 @@ bun add @riligar/auth-react
|
|
|
11
11
|
## Basic Usage
|
|
12
12
|
|
|
13
13
|
```jsx
|
|
14
|
-
import { AuthProvider, useAuth, useSignIn,
|
|
14
|
+
import { AuthProvider, useAuth, useSignIn, Protect, SignedIn, SignedOut, SignIn } from '@riligar/auth-react'
|
|
15
15
|
|
|
16
16
|
// 1. Wrap your app with AuthProvider
|
|
17
17
|
function App() {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
18
|
+
return (
|
|
19
|
+
<AuthProvider
|
|
20
|
+
apiUrl="https://your-api.com"
|
|
21
|
+
apiKey="your-api-key"
|
|
22
|
+
>
|
|
23
|
+
<Routes>
|
|
24
|
+
<Route
|
|
25
|
+
path="/login"
|
|
26
|
+
element={<SignIn />}
|
|
27
|
+
/>
|
|
28
|
+
<Route element={<Protect />}>
|
|
29
|
+
<Route
|
|
30
|
+
path="/"
|
|
31
|
+
element={<Home />}
|
|
32
|
+
/>
|
|
33
|
+
</Route>
|
|
34
|
+
</Routes>
|
|
35
|
+
</AuthProvider>
|
|
36
|
+
)
|
|
28
37
|
}
|
|
29
38
|
|
|
30
|
-
// 2. Use
|
|
31
|
-
function
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
return (
|
|
45
|
-
<form onSubmit={handleSubmit}>
|
|
46
|
-
<input name="email" type="email" placeholder="Email" required />
|
|
47
|
-
<input name="password" type="password" placeholder="Password" required />
|
|
48
|
-
<button>Sign In</button>
|
|
49
|
-
</form>
|
|
50
|
-
);
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
function Home() {
|
|
54
|
-
const { user, isAuthenticated } = useAuth();
|
|
55
|
-
|
|
56
|
-
if (!isAuthenticated) return <p>Not authenticated</p>;
|
|
57
|
-
|
|
58
|
-
return <h1>Hello, {user?.email}!</h1>;
|
|
39
|
+
// 2. Use control components for conditional rendering
|
|
40
|
+
function Header() {
|
|
41
|
+
return (
|
|
42
|
+
<header>
|
|
43
|
+
<SignedIn>
|
|
44
|
+
<UserMenu />
|
|
45
|
+
</SignedIn>
|
|
46
|
+
<SignedOut>
|
|
47
|
+
<SignInButton />
|
|
48
|
+
</SignedOut>
|
|
49
|
+
</header>
|
|
50
|
+
)
|
|
59
51
|
}
|
|
60
52
|
```
|
|
61
53
|
|
|
62
|
-
##
|
|
54
|
+
## Components
|
|
63
55
|
|
|
64
|
-
|
|
65
|
-
- ✅ **JWKS** - Signature verification with `/.well-known/jwks.json`
|
|
66
|
-
- ✅ **Auto refresh** - Tokens renewed automatically
|
|
67
|
-
- ✅ **Social login** - OAuth provider support
|
|
68
|
-
- ✅ **Cross-tab sync** - Synchronized state across tabs
|
|
69
|
-
- ✅ **Route protection** - Protected routes automatically
|
|
70
|
-
- ✅ **SSR friendly** - Server-side rendering compatible
|
|
71
|
-
- ✅ **LocalStorage** - Token persistence in browser
|
|
56
|
+
### Authentication Components
|
|
72
57
|
|
|
73
|
-
|
|
58
|
+
| Component | Description |
|
|
59
|
+
| ----------------------- | -------------------------------------------- |
|
|
60
|
+
| `<SignIn />` | Sign in form with email/password, magic link |
|
|
61
|
+
| `<SignUp />` | Registration form |
|
|
62
|
+
| `<MagicLink />` | Magic link request form |
|
|
63
|
+
| `<MagicLinkCallback />` | Magic link verification |
|
|
64
|
+
| `<ForgotPassword />` | Password reset request |
|
|
65
|
+
| `<ResetPassword />` | Password reset form |
|
|
66
|
+
| `<VerifyEmail />` | Email verification |
|
|
67
|
+
| `<UserProfile />` | User profile management modal |
|
|
74
68
|
|
|
75
|
-
###
|
|
69
|
+
### Control Components
|
|
76
70
|
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
71
|
+
| Component | Description |
|
|
72
|
+
| --------------- | -------------------------------------------- |
|
|
73
|
+
| `<SignedIn>` | Renders children only when authenticated |
|
|
74
|
+
| `<SignedOut>` | Renders children only when NOT authenticated |
|
|
75
|
+
| `<AuthLoading>` | Renders children while auth is loading |
|
|
76
|
+
| `<AuthLoaded>` | Renders children when auth has loaded |
|
|
77
|
+
| `<Protect />` | Protected route wrapper |
|
|
84
78
|
|
|
85
|
-
###
|
|
79
|
+
### Unstyled Buttons
|
|
86
80
|
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
socialRedirect
|
|
93
|
-
} from '@riligar/auth-react';
|
|
94
|
-
|
|
95
|
-
// Check if authenticated
|
|
96
|
-
if (isAuthenticated()) {
|
|
97
|
-
console.log('User logged in');
|
|
98
|
-
}
|
|
81
|
+
| Component | Description |
|
|
82
|
+
| ------------------- | ------------------------- |
|
|
83
|
+
| `<SignInButton />` | Navigates to sign-in page |
|
|
84
|
+
| `<SignUpButton />` | Navigates to sign-up page |
|
|
85
|
+
| `<SignOutButton />` | Signs out the user |
|
|
99
86
|
|
|
100
|
-
|
|
101
|
-
const user = getCurrentUser();
|
|
87
|
+
## Hooks
|
|
102
88
|
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
89
|
+
```jsx
|
|
90
|
+
const { user, loading, error, isAuthenticated } = useAuth()
|
|
91
|
+
const { user, updateProfile, changePassword, changeEmail } = useUser()
|
|
92
|
+
const signIn = useSignIn()
|
|
93
|
+
const signUp = useSignUp()
|
|
94
|
+
const signOut = useSignOut()
|
|
108
95
|
```
|
|
109
96
|
|
|
97
|
+
## Features
|
|
98
|
+
|
|
99
|
+
- ✅ **JWT Tokens** - Secure token-based authentication
|
|
100
|
+
- ✅ **JWKS** - Signature verification with `/.well-known/jwks.json`
|
|
101
|
+
- ✅ **Auto refresh** - Tokens renewed automatically
|
|
102
|
+
- ✅ **Social login** - OAuth provider support
|
|
103
|
+
- ✅ **Cross-tab sync** - Synchronized state across tabs
|
|
104
|
+
- ✅ **Route protection** - Protected routes automatically
|
|
105
|
+
- ✅ **Control components** - Clerk-style conditional rendering
|
|
106
|
+
- ✅ **SSR friendly** - Server-side rendering compatible
|
|
107
|
+
|
|
108
|
+
## Backwards Compatibility
|
|
109
|
+
|
|
110
|
+
The following deprecated aliases are still available:
|
|
111
|
+
|
|
112
|
+
| Deprecated | Use Instead |
|
|
113
|
+
| -------------------- | ------------------- |
|
|
114
|
+
| `SignInForm` | `SignIn` |
|
|
115
|
+
| `SignUpForm` | `SignUp` |
|
|
116
|
+
| `MagicLinkForm` | `MagicLink` |
|
|
117
|
+
| `MagicLinkVerify` | `MagicLinkCallback` |
|
|
118
|
+
| `ForgotPasswordForm` | `ForgotPassword` |
|
|
119
|
+
| `ResetPasswordForm` | `ResetPassword` |
|
|
120
|
+
| `VerifyEmailCard` | `VerifyEmail` |
|
|
121
|
+
| `AccountModal` | `UserProfile` |
|
|
122
|
+
| `ProtectedRoute` | `Protect` |
|
|
123
|
+
| `useProfile` | `useUser` |
|
|
124
|
+
|
|
110
125
|
## Backend Configuration
|
|
111
126
|
|
|
112
127
|
The SDK expects your backend to expose:
|
|
113
128
|
|
|
114
|
-
-
|
|
115
|
-
-
|
|
116
|
-
-
|
|
117
|
-
-
|
|
118
|
-
-
|
|
119
|
-
-
|
|
129
|
+
- `/.well-known/jwks.json` - Public keys for JWT verification
|
|
130
|
+
- `/auth/sign-in` - Login (returns `{ token, user }`)
|
|
131
|
+
- `/auth/sign-up` - Registration (returns `{ token, user }`)
|
|
132
|
+
- `/auth/sign-out` - Logout
|
|
133
|
+
- `/auth/refresh` - Token renewal
|
|
134
|
+
- `/auth/sign-in/:provider` - Social login
|
|
120
135
|
|
|
121
136
|
## Build
|
|
122
137
|
|
|
123
138
|
```bash
|
|
124
139
|
bun run build
|
|
125
|
-
```
|
|
140
|
+
```
|
package/dist/index.esm.js
CHANGED
|
@@ -2,7 +2,7 @@ import { create } from 'zustand';
|
|
|
2
2
|
import { useMemo, useEffect, createContext, useState, useRef } from 'react';
|
|
3
3
|
import { useShallow } from 'zustand/react/shallow';
|
|
4
4
|
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
5
|
-
import { Navigate, Outlet } from 'react-router-dom';
|
|
5
|
+
import { Navigate, Outlet, useNavigate } from 'react-router-dom';
|
|
6
6
|
import { Paper, Stack, Image, Title, Text, TextInput, PasswordInput, Anchor, Button, Divider, Group, Center, Loader, Modal, Box, Avatar, Collapse, Card, Tooltip, ThemeIcon } from '@mantine/core';
|
|
7
7
|
import { useForm } from '@mantine/form';
|
|
8
8
|
import { IconMail, IconLock, IconArrowRight, IconBrandGoogle, IconBrandGithub, IconUser, IconSend, IconCheck, IconX, IconRefresh, IconPhoto, IconTrash, IconPencil, IconShield, IconKey, IconUserCircle } from '@tabler/icons-react';
|
|
@@ -892,8 +892,8 @@ const useSession = () => useAuthStore(useShallow(s => ({
|
|
|
892
892
|
// Loading States Hook
|
|
893
893
|
const useAuthLoading = () => useAuthStore(s => s.loadingStates);
|
|
894
894
|
|
|
895
|
-
// Profile Management Hook
|
|
896
|
-
const
|
|
895
|
+
// Profile Management Hook (novo nome estilo Clerk)
|
|
896
|
+
const useUser = () => useAuthStore(useShallow(s => ({
|
|
897
897
|
user: s.user,
|
|
898
898
|
updateProfile: s.updateProfile,
|
|
899
899
|
changePassword: s.changePassword,
|
|
@@ -904,6 +904,9 @@ const useProfile = () => useAuthStore(useShallow(s => ({
|
|
|
904
904
|
error: s.error
|
|
905
905
|
})));
|
|
906
906
|
|
|
907
|
+
// Alias deprecado para backwards compatibility
|
|
908
|
+
const useProfile = useUser;
|
|
909
|
+
|
|
907
910
|
// Application Logo Hook
|
|
908
911
|
const useApplicationLogo = () => {
|
|
909
912
|
const applicationInfo = useAuthStore(s => s.applicationInfo);
|
|
@@ -911,11 +914,11 @@ const useApplicationLogo = () => {
|
|
|
911
914
|
return applicationInfo?.image || null;
|
|
912
915
|
};
|
|
913
916
|
|
|
914
|
-
function
|
|
917
|
+
function Protect({
|
|
915
918
|
fallback = /*#__PURE__*/jsx("p", {
|
|
916
919
|
children: "\u231B Carregando..."
|
|
917
920
|
}),
|
|
918
|
-
redirectTo =
|
|
921
|
+
redirectTo = '/login'
|
|
919
922
|
}) {
|
|
920
923
|
const {
|
|
921
924
|
user,
|
|
@@ -969,7 +972,7 @@ function AuthCard({
|
|
|
969
972
|
|
|
970
973
|
var img = "";
|
|
971
974
|
|
|
972
|
-
function
|
|
975
|
+
function SignIn({
|
|
973
976
|
// Configuração
|
|
974
977
|
logo,
|
|
975
978
|
// Removido default, será calculado abaixo
|
|
@@ -1137,7 +1140,7 @@ function SignInForm({
|
|
|
1137
1140
|
});
|
|
1138
1141
|
}
|
|
1139
1142
|
|
|
1140
|
-
function
|
|
1143
|
+
function SignUp({
|
|
1141
1144
|
// Configuração
|
|
1142
1145
|
logo,
|
|
1143
1146
|
title = 'Criar Conta',
|
|
@@ -1271,7 +1274,7 @@ function SignUpForm({
|
|
|
1271
1274
|
});
|
|
1272
1275
|
}
|
|
1273
1276
|
|
|
1274
|
-
function
|
|
1277
|
+
function MagicLink({
|
|
1275
1278
|
// Configuração
|
|
1276
1279
|
logo,
|
|
1277
1280
|
title = 'Login sem Senha',
|
|
@@ -1349,7 +1352,7 @@ function MagicLinkForm({
|
|
|
1349
1352
|
});
|
|
1350
1353
|
}
|
|
1351
1354
|
|
|
1352
|
-
function
|
|
1355
|
+
function MagicLinkCallback({
|
|
1353
1356
|
// Configuração
|
|
1354
1357
|
logo,
|
|
1355
1358
|
// Token pode ser passado diretamente ou extraído da URL
|
|
@@ -1459,7 +1462,7 @@ function MagicLinkVerify({
|
|
|
1459
1462
|
});
|
|
1460
1463
|
}
|
|
1461
1464
|
|
|
1462
|
-
function
|
|
1465
|
+
function ForgotPassword({
|
|
1463
1466
|
// Configuração
|
|
1464
1467
|
logo,
|
|
1465
1468
|
title = 'Recuperar Senha',
|
|
@@ -1537,7 +1540,7 @@ function ForgotPasswordForm({
|
|
|
1537
1540
|
});
|
|
1538
1541
|
}
|
|
1539
1542
|
|
|
1540
|
-
function
|
|
1543
|
+
function ResetPassword({
|
|
1541
1544
|
// Configuração
|
|
1542
1545
|
logo,
|
|
1543
1546
|
title = 'Nova Senha',
|
|
@@ -1676,7 +1679,7 @@ function ResetPasswordForm({
|
|
|
1676
1679
|
});
|
|
1677
1680
|
}
|
|
1678
1681
|
|
|
1679
|
-
function
|
|
1682
|
+
function VerifyEmail({
|
|
1680
1683
|
// Configuração
|
|
1681
1684
|
logo,
|
|
1682
1685
|
// Token pode ser passado diretamente ou extraído da URL
|
|
@@ -1840,7 +1843,7 @@ function VerifyEmailCard({
|
|
|
1840
1843
|
});
|
|
1841
1844
|
}
|
|
1842
1845
|
|
|
1843
|
-
function
|
|
1846
|
+
function UserProfile({
|
|
1844
1847
|
// Controle do modal
|
|
1845
1848
|
opened,
|
|
1846
1849
|
onClose,
|
|
@@ -2515,5 +2518,106 @@ function AccountModal({
|
|
|
2515
2518
|
});
|
|
2516
2519
|
}
|
|
2517
2520
|
|
|
2518
|
-
|
|
2521
|
+
/**
|
|
2522
|
+
* Renderiza children apenas quando o usuário está autenticado
|
|
2523
|
+
* Equivalente ao <SignedIn> do Clerk
|
|
2524
|
+
*/
|
|
2525
|
+
function SignedIn({
|
|
2526
|
+
children
|
|
2527
|
+
}) {
|
|
2528
|
+
const {
|
|
2529
|
+
user,
|
|
2530
|
+
loading
|
|
2531
|
+
} = useAuth();
|
|
2532
|
+
if (loading || !user) return null;
|
|
2533
|
+
return children;
|
|
2534
|
+
}
|
|
2535
|
+
|
|
2536
|
+
/**
|
|
2537
|
+
* Renderiza children apenas quando o usuário NÃO está autenticado
|
|
2538
|
+
* Equivalente ao <SignedOut> do Clerk
|
|
2539
|
+
*/
|
|
2540
|
+
function SignedOut({
|
|
2541
|
+
children
|
|
2542
|
+
}) {
|
|
2543
|
+
const {
|
|
2544
|
+
user,
|
|
2545
|
+
loading
|
|
2546
|
+
} = useAuth();
|
|
2547
|
+
if (loading || user) return null;
|
|
2548
|
+
return children;
|
|
2549
|
+
}
|
|
2550
|
+
|
|
2551
|
+
/**
|
|
2552
|
+
* Renderiza children enquanto a autenticação está carregando
|
|
2553
|
+
* Equivalente ao <ClerkLoading> do Clerk
|
|
2554
|
+
*/
|
|
2555
|
+
function AuthLoading({
|
|
2556
|
+
children
|
|
2557
|
+
}) {
|
|
2558
|
+
const {
|
|
2559
|
+
loading
|
|
2560
|
+
} = useAuth();
|
|
2561
|
+
if (!loading) return null;
|
|
2562
|
+
return children;
|
|
2563
|
+
}
|
|
2564
|
+
|
|
2565
|
+
/**
|
|
2566
|
+
* Renderiza children quando a autenticação terminou de carregar
|
|
2567
|
+
* Equivalente ao <ClerkLoaded> do Clerk
|
|
2568
|
+
*/
|
|
2569
|
+
function AuthLoaded({
|
|
2570
|
+
children
|
|
2571
|
+
}) {
|
|
2572
|
+
const {
|
|
2573
|
+
loading
|
|
2574
|
+
} = useAuth();
|
|
2575
|
+
if (loading) return null;
|
|
2576
|
+
return children;
|
|
2577
|
+
}
|
|
2578
|
+
|
|
2579
|
+
function SignInButton({
|
|
2580
|
+
children,
|
|
2581
|
+
redirectTo = '/login',
|
|
2582
|
+
...props
|
|
2583
|
+
}) {
|
|
2584
|
+
const navigate = useNavigate();
|
|
2585
|
+
return /*#__PURE__*/jsx("button", {
|
|
2586
|
+
onClick: () => navigate(redirectTo),
|
|
2587
|
+
...props,
|
|
2588
|
+
children: children || 'Sign In'
|
|
2589
|
+
});
|
|
2590
|
+
}
|
|
2591
|
+
|
|
2592
|
+
function SignUpButton({
|
|
2593
|
+
children,
|
|
2594
|
+
redirectTo = '/register',
|
|
2595
|
+
...props
|
|
2596
|
+
}) {
|
|
2597
|
+
const navigate = useNavigate();
|
|
2598
|
+
return /*#__PURE__*/jsx("button", {
|
|
2599
|
+
onClick: () => navigate(redirectTo),
|
|
2600
|
+
...props,
|
|
2601
|
+
children: children || 'Sign Up'
|
|
2602
|
+
});
|
|
2603
|
+
}
|
|
2604
|
+
|
|
2605
|
+
function SignOutButton({
|
|
2606
|
+
children,
|
|
2607
|
+
onSignOut,
|
|
2608
|
+
...props
|
|
2609
|
+
}) {
|
|
2610
|
+
const signOut = useSignOut();
|
|
2611
|
+
const handleClick = async () => {
|
|
2612
|
+
await signOut();
|
|
2613
|
+
onSignOut?.();
|
|
2614
|
+
};
|
|
2615
|
+
return /*#__PURE__*/jsx("button", {
|
|
2616
|
+
onClick: handleClick,
|
|
2617
|
+
...props,
|
|
2618
|
+
children: children || 'Sign Out'
|
|
2619
|
+
});
|
|
2620
|
+
}
|
|
2621
|
+
|
|
2622
|
+
export { UserProfile as AccountModal, AuthCard, AuthLoaded, AuthLoading, AuthProvider, ForgotPassword, ForgotPassword as ForgotPasswordForm, MagicLink, MagicLinkCallback, MagicLink as MagicLinkForm, MagicLinkCallback as MagicLinkVerify, Protect, Protect as ProtectedRoute, ResetPassword, ResetPassword as ResetPasswordForm, SignIn, SignInButton, SignIn as SignInForm, SignOutButton, SignUp, SignUpButton, SignUp as SignUpForm, SignedIn, SignedOut, UserProfile, VerifyEmail, VerifyEmail as VerifyEmailCard, changeEmail, changePassword, configure, decodeJWT, forgotPassword, getApplicationInfo, getCurrentUser, getSession, isAuthenticated, refreshToken, resendVerification, resetPassword, sendMagicLink, signIn, signOut, signUp, socialRedirect, updateProfile, useApplicationLogo, useAuth, useAuthLoading, useAuthStore, useCheckToken, useEmailVerification, useMagicLink, usePasswordReset, useUser as useProfile, useSession, useSignIn, useSignOut, useSignUp, useUser, verifyEmail, verifyMagicLink };
|
|
2519
2623
|
//# sourceMappingURL=index.esm.js.map
|