- Migrations 'organizations' (id, name, siret, monthly_volume_bucket, rubis_count, onboarding_completed_at) + alter users (organization_id FK + signature).
- Modèle Organization avec relation hasMany Users, User étendu avec belongsTo Organization.
- Signup transactionnel : crée une org vide ('') puis l'user, puis émet le access token. Le nom de l'org reste vide tant que l'utilisateur n'a pas franchi la première étape de l'onboarding (PATCH /organizations/me).
- Réponses /auth/* alignées sur le contrat SPA AuthSession : { data: { accessToken, expiresAt, user } }. Drop passwordConfirmation (le SPA n'envoie pas ce champ).
- Endpoints :
- GET /account/profile (déjà), PATCH /account/profile (nouveau, fullName/email/signature).
- GET /organizations/me + PATCH /organizations/me (name/siret/monthlyVolumeBucket).
- Pose automatique d'onboardingCompletedAt à la première mise en place du nom de l'org — remplace l'astuce 'signature !== null' utilisée côté MSW.
- Transformers convertissent les IDs en string (pour matcher packages/shared/src/types).
- HMR boundaries élargies : transformers/validators/services se rechargent maintenant à chaud (sinon les modifs ne sont pas vues sans restart manuel).
26 lines
696 B
TypeScript
26 lines
696 B
TypeScript
import UserTransformer from '#transformers/user_transformer'
|
|
import { updateProfileValidator } from '#validators/user'
|
|
import type { HttpContext } from '@adonisjs/core/http'
|
|
|
|
export default class ProfileController {
|
|
/**
|
|
* GET /account/profile
|
|
*/
|
|
async show({ auth, serialize }: HttpContext) {
|
|
return serialize(UserTransformer.transform(auth.getUserOrFail()))
|
|
}
|
|
|
|
/**
|
|
* PATCH /account/profile
|
|
*/
|
|
async update({ auth, request, serialize }: HttpContext) {
|
|
const user = auth.getUserOrFail()
|
|
const payload = await request.validateUsing(updateProfileValidator)
|
|
|
|
user.merge(payload)
|
|
await user.save()
|
|
|
|
return serialize(UserTransformer.transform(user))
|
|
}
|
|
}
|