SmartAuth
SmartAuth est le module d'authentification JWT pour Dolibarr, conçu pour les applications SmartMaker.
Pourquoi SmartAuth ?
Nativement Dolibarr propose une API où chaque utilisateur dispose d'une seule clé d'API donnant accès à tout son périmètre fonctionnel.
Ce fonctionnement pose problème : si vous développez une application mobile qui ne devrait avoir accès qu'à l'agenda de l'utilisateur, avec la clé native l'application pourra également accéder aux factures et autres éléments.
Notre approche
Avec SmartAuth, un utilisateur peut avoir autant de clés d'API qu'il souhaite, chaque clé ayant ses propres droits. Si une clé est liée à une application, elle ne sera pas réutilisable par une autre.
Avantages :
- Cloisonnement des accès : chaque application a sa propre clé
- Révocation ciblée : si un appareil est volé, supprimez uniquement sa clé
- Traçabilité : journaux de connexion par appareil
Journaux de connexion
Installation
Téléchargez SmartAuth gratuitement sur le DoliStore : https://www.dolistore.com/product.php?id=2509&l=fr
Flux d'authentification JWT
Schéma global
┌─────────────┐ ┌─────────────┐ ┌─────────────┐
│ Mobile │ │ api.php │ │ Dolibarr │
│ (React) │ │ (JWT) │ │ (PHP) │
└──────┬──────┘ └──────┬──────┘ └──────┬──────┘
│ │ │
│ 1. POST /login │ │
│ {login, password} │ │
│──────────────────────>│ │
│ │ 2. Vérifier user │
│ │──────────────────────>│
│ │ │
│ │ 3. User valide │
│ │<──────────────────────│
│ 4. {accessToken, │ │
│ refreshToken} │ │
│<──────────────────────│ │
│ │ │
│ 5. GET /items │ │
│ Authorization: Bearer│ │
│──────────────────────>│ │
│ │ 6. Valider token │
│ │ + charger user │
│ │──────────────────────>│
│ │ │
│ 7. Données │ │
│<──────────────────────│ │
Tokens JWT
SmartAuth utilise deux tokens :
| Token | Durée | Usage |
|---|---|---|
accessToken | 15 minutes | Authentifier les requêtes API |
refreshToken | 7 jours | Obtenir un nouveau accessToken |
Endpoints d'authentification
| Méthode | Route | Description | Protégé |
|---|---|---|---|
| GET | /login | Récupérer les infos de connexion (logo, etc.) | Non |
| POST | /login | Authentification (login + password) | Non |
| GET | /refresh | Renouveler l'accessToken | Non |
| POST | /logout | Déconnexion (invalide le refreshToken) | Oui |
| POST | /device | Enregistrer un appareil pour les notifications | Oui |
Configuration côté api.php
Routes d'authentification
<?php
require_once '../smartmaker-api-prepend.php';
use SmartAuth\Api\AuthController;
use SmartAuth\Api\RouteController as Route;
// Routes publiques
Route::get('login', AuthController::class, 'index'); // Infos connexion
Route::post('login', AuthController::class, 'login'); // Authentification
Route::get('refresh', AuthController::class, 'refresh'); // Refresh token
// Routes protégées
Route::post('logout', AuthController::class, 'logout', true); // Déconnexion
Route::post('device', AuthController::class, 'device', true); // Enregistrer device
// Vos routes métier...
Route::get('items', ItemController::class, 'index', true);
// Fallback
json_reply('Access denied', 403);
Le fichier smartmaker-api-prepend.php
Ce fichier (généré par SmartBoot) contient :
- Les entêtes obligatoires de Dolibarr
- Le chargement de l'autoloader SmartAuth
- L'initialisation de la couche JWT
- L'autoloader des classes de votre module
<note important>Ne modifiez pas ce fichier sauf si vous savez ce que vous faites.</note>
Utilisation côté React
Configuration du Provider
// appConfig.js
export const config = {
api: {
prefixUrl: import.meta.env.VITE_API_URL,
paths: {
login: "login",
logout: "logout",
refresh: "refresh",
},
},
};
Login avec useApi
import { useApi, useGlobalStates } from '@cap-rel/smartcommon';
const LoginPage = () => {
const api = useApi();
const [, setSession] = useGlobalStates('session');
const handleLogin = async (data) => {
const response = await api.public.post('login', { json: data });
if (response.success) {
// Stocker les tokens
setSession(response.data);
}
};
return (
<form onSubmit={handleSubmit(handleLogin)}>
{/* ... */}
</form>
);
};
Refresh automatique
Le hook useApi gère automatiquement le refresh du token :
// Quand l'accessToken expire, useApi : // 1. Intercepte l'erreur 401 // 2. Appelle GET /refresh avec le refreshToken // 3. Met à jour les tokens en session // 4. Rejoue la requête originale
Logout
const handleLogout = async () => {
await api.private.post('logout');
setSession(null);
navigate('/login');
};
Gestion des appareils
Enregistrer un appareil
Pour les notifications push, enregistrez l'appareil après le login :
const registerDevice = async (pushToken) => {
await api.private.post('device', {
json: {
token: pushToken,
platform: 'android', // ou 'ios', 'web'
name: 'Mon téléphone',
},
});
};
Structure côté Dolibarr
SmartAuth stocke les appareils dans une table dédiée :
| Champ | Description |
|---|---|
fkuser | Date de dernière utilisation |
Sécurité
Bonnes pratiques
- HTTPS obligatoire : Les tokens JWT transitent en clair
- Stockage sécurisé : Utilisez
useGlobalStatesqui persiste en localStorage chiffré - Rotation des tokens : Le refreshToken est à usage unique
- Révocation : Supprimez les clés depuis l'interface Dolibarr
En cas de vol d'appareil
- Connectez-vous à Dolibarr
- Allez dans votre profil utilisateur
- Supprimez la clé API de l'appareil volé
- Les tokens associés seront immédiatement invalidés
Voir aussi
- Back (PHP) - Routes et Controllers
- Requêtes API - Utilisation de useApi
- Configuration - Configuration du Provider
- Dépôt SmartAuth : https://inligit.fr/cap-rel/dolibarr/plugin-smartauth/

