feat(idnot): POST /api/v1/idnot/auth avec body {code} | ci: docker_tag=ext
All checks were successful
build-and-push-ext / build_push (push) Successful in 1m28s

This commit is contained in:
Debian Dev4 2025-09-18 19:36:23 +00:00
parent 1bd368c948
commit 387e7ed65c
6 changed files with 59 additions and 13 deletions

View File

@ -55,7 +55,7 @@ VITE_BOOTSTRAPURL=https://dev4.4nkweb.com/ws/
SUCCES='4242 4242 4242 4242' SUCCES='4242 4242 4242 4242'
DECLINED='4000 0025 0000 3155' DECLINED='4000 0025 0000 3155'
CORS_ALLOWED_ORIGINS=http://local.4nkweb.com:3000,https://dev4.4nkweb.com CORS_ALLOWED_ORIGINS=http://local.4nkweb.com:3000,https://dev4.4nkweb.com
ENABLE_SUBSCRIPTION_STUB=true
# ================================= /!\ sensible ======================== # ================================= /!\ sensible ========================
@ -86,4 +86,5 @@ STRIPE_STANDARD_ANNUAL_SUBSCRIPTION_PRICE_ID=
STRIPE_UNLIMITED_SUBSCRIPTION_PRICE_ID= STRIPE_UNLIMITED_SUBSCRIPTION_PRICE_ID=
STRIPE_UNLIMITED_ANNUAL_SUBSCRIPTION_PRICE_ID= STRIPE_UNLIMITED_ANNUAL_SUBSCRIPTION_PRICE_ID=
SIGNER_API_KEY=your-api-key-change-this SIGNER_API_KEY=your-api-key-change-this
VITE_JWT_SECRET_KEY=52b3d77617bb00982dfee15b08effd52cfe5b2e69b2f61cc4848cfe1e98c0bc9

View File

@ -11,6 +11,12 @@
## v0.1.3 ## v0.1.3
## v0.1.4 ## v0.1.4
## v0.1.5
- IdNot: appel backend changé en POST `/api/v1/idnot/auth` avec `{ code }` dans le corps (évite erreurs 502 proxy sur URL longue).
- Documentation et tests mis à jour.
- Rappel déploiement: builder et pousser limage tagguée `ext` pour récupération par `lecoffre_node`.
- Sous-chemin Next activé: `basePath: '/lecoffre'`. - Sous-chemin Next activé: `basePath: '/lecoffre'`.
- Normalisation SSR du `targetOrigin` de liframe sur lorigine de `NEXT_PUBLIC_4NK_URL`. - Normalisation SSR du `targetOrigin` de liframe sur lorigine de `NEXT_PUBLIC_4NK_URL`.
- CI: build-arg optionnel `NEXT_PUBLIC_4NK_URL` depuis les secrets. - CI: build-arg optionnel `NEXT_PUBLIC_4NK_URL` depuis les secrets.

View File

@ -42,3 +42,40 @@ Analyse synthétique de `lecoffre-front` (Next.js) : périmètre, dépendances,
### Déploiement ### Déploiement
- **Dockerfile**: présent (build Next standalone) - **Dockerfile**: présent (build Next standalone)
- **Intégration**: orchestré via `lecoffre_node` (voir analyse dédiée) - **Intégration**: orchestré via `lecoffre_node` (voir analyse dédiée)
## Scripts npm, build et configuration
### Scripts
- **dev**: `next dev`
- **build**: `NEXT_TELEMETRY_DISABLED=1 next build --no-lint`
- **start**: `next start`
- **lint**: `next lint`
- **format**: `prettier --write src`
### next.config.js
- `output: 'standalone'`, `basePath: '/lecoffre'`
- `typescript.ignoreBuildErrors: true` (risque: masquage derreurs)
- Exposition de nombreuses variables `NEXT_PUBLIC_*` via `env`, `publicRuntimeConfig` et `serverRuntimeConfig`
### Docker (multistage)
- Étapes: `deps` (install), `development` (dev), `builder` (build), `ext` (runtime)
- BuildKit SSH pour `le-coffre-resources` (clé non copiée dans limage)
- Port runtime 3000; utilisateur nonroot `lecoffreuser`
### Dépendances (extraits)
- UI: `@mui/material`, `@emotion/*`, `react-select`, `react-toastify`
- Utilitaires: `jwt-decode`, `file-saver`, `jszip`, `pdf-lib`, `sass`, `sharp`
- Ressources: `le-coffre-resources` (SSH Git 4NK)
- Versions Node/Next: Node 19alpine; Next `^14.2.3`
## Risques et recommandations
- Désactiver `ignoreBuildErrors` et corriger les erreurs TypeScript avant build
- Envisager Node LTS (20/22) pour les images
- Vérifier quaucune info sensible nest exposée via `NEXT_PUBLIC_*`
- Assurer la cohérence `basePath` `/lecoffre` avec Nginx et les liens internes
- Introduire du code splitting ciblé (`React.lazy`/`Suspense`) sur pages lourdes
- Centraliser létat (Redux/Context) pour limiter le prop drilling dans `src/front`
## Changements IdNot
- Lauthentification IdNot appelle désormais le backend en POST avec le code dautorisation dans le corps JSON sur `/api/v1/idnot/auth`.
- Ce changement évite des erreurs en reverse proxy liées à des segments dURL très longs.

View File

@ -1,6 +1,6 @@
{ {
"name": "lecoffre-front", "name": "lecoffre-front",
"version": "0.1.4", "version": "0.1.5",
"private": true, "private": true,
"scripts": { "scripts": {
"dev": "next dev", "dev": "next dev",

View File

@ -43,19 +43,20 @@ export default class Auth extends BaseApiService {
} }
} }
public async idNotAuth(autorizationCode: string | string[]): Promise<{ idNotUser: any; authToken: string }> { public async idNotAuth(autorizationCode: string | string[]): Promise<{ idNotUser: any; authToken: string }> {
const variables = FrontendVariables.getInstance(); const variables = FrontendVariables.getInstance();
const baseBackUrl = this.getBaseUrl(); const baseBackUrl = this.getBaseUrl();
const url = new URL(`${baseBackUrl}/idnot/auth/${autorizationCode}`); const url = new URL(`${baseBackUrl}/idnot/auth`);
try { const code = Array.isArray(autorizationCode) ? autorizationCode[0] : autorizationCode;
return await this.postRequest<{ idNotUser: any; authToken: string }>(url); try {
} catch (err) { return await this.postRequest<{ idNotUser: any; authToken: string }>(url, { code });
this.onError(err); } catch (err) {
return Promise.reject(err); this.onError(err);
} return Promise.reject(err);
} }
}
public async getIdNotUser(): Promise<{ success: boolean; data: any }> { public async getIdNotUser(): Promise<{ success: boolean; data: any }> {
const variables = FrontendVariables.getInstance(); const variables = FrontendVariables.getInstance();

View File

@ -11,6 +11,7 @@ Axes de tests pour `lecoffre-front` (sans exemples dimplémentation).
### Données et intégrations ### Données et intégrations
- **API Back**: validation des URL via `NEXT_PUBLIC_BACK_API_*` et `NEXT_PUBLIC_API_URL` - **API Back**: validation des URL via `NEXT_PUBLIC_BACK_API_*` et `NEXT_PUBLIC_API_URL`
- **IdNot Auth**: vérifier que lappel se fait en POST `/api/v1/idnot/auth` avec `{ code }` dans le corps, et quaucune URL longue nest utilisée.
- **Idnot/Docaposte**: vérification des redirections et scopes - **Idnot/Docaposte**: vérification des redirections et scopes
### Non-régressions UI/UX ### Non-régressions UI/UX