@univ-lehavre/atlas-auth
v1.0.2
Published
Shared authentication service for Atlas SvelteKit applications
Downloads
622
Maintainers
Readme
@univ-lehavre/atlas-auth
Service d'authentification partagé pour applications SvelteKit Atlas.
About
Ce package encapsule l'authentification Appwrite par magic link: inscription avec validation de domaine, login par secret utilisateur, création du cookie de session, logout, suppression de compte et middleware SvelteKit de lecture de l'utilisateur courant. Il peut résoudre l'identifiant utilisateur via une source externe comme REDCap avant création du token.
Features
- Magic links: Passwordless authentication via email link
- Domain validation: Restrict signups by email domain
- Session management: Session creation and management via cookies
- REDCap integration: Support for user ID resolution from REDCap
- SvelteKit hooks: Ready-to-use authentication middleware
Installation
pnpm add @univ-lehavre/atlas-authUsage
Service Configuration
import { createAuthService } from '@univ-lehavre/atlas-auth';
const authService = createAuthService({
appwrite: {
endpoint: APPWRITE_ENDPOINT,
projectId: APPWRITE_PROJECT,
apiKey: APPWRITE_KEY,
},
loginUrl: PUBLIC_LOGIN_URL,
domainValidation: {
allowedDomainsRegexp: /^(example\.com|university\.edu)$/,
},
});Signup with Magic Link
// POST /api/v1/auth/signup
export const POST = async ({ request }) => {
const body = await request.json();
const token = await authService.signupWithEmail(body.email);
return json({ data: { token } });
};Login via Magic Link
// GET /login?userId=xxx&secret=yyy
export const load = async ({ url, cookies }) => {
const userId = url.searchParams.get('userId');
const secret = url.searchParams.get('secret');
const session = await authService.login(userId, secret, cookies);
redirect(302, '/dashboard');
};Logout
// POST /api/v1/auth/logout
export const POST = async ({ locals, cookies }) => {
await authService.logout(locals.user.id, cookies);
return json({ data: null });
};API
Functions
| Function | Description |
|----------|-------------|
| createAuthService(config) | Creates an authentication service instance |
| validateMagicUrlLogin(userId, secret) | Validates magic URL parameters |
| validateSignupEmail(email, config) | Validates and normalizes an email for signup |
| validateUserId(userId) | Validates a user ID |
| checkRequestBody(body) | Checks for required fields presence |
Exports
| Export | Description |
|--------|-------------|
| . | Main authentication service |
| ./validators | Validation functions |
| ./hooks | SvelteKit middleware |
Scripts
pnpm -F @univ-lehavre/atlas-auth dev # Development
pnpm -F @univ-lehavre/atlas-auth build # Build
pnpm -F @univ-lehavre/atlas-auth test # Tests
pnpm -F @univ-lehavre/atlas-auth lint # ESLintDocumentation
Organization
This package is part of Atlas, a set of tools developed by Le Havre Normandie University to facilitate research and collaboration between researchers.
Atlas is developed as part of two projects led by Le Havre Normandie University:
- Campus Polytechnique des Territoires Maritimes et Portuaires: research and training program focused on maritime and port issues
- EUNICoast: European university alliance bringing together institutions located in European coastal areas
License
MIT
