Files
sogoms/config/scenarios/prokov/auth/login.yaml
Pierre 7e27f87d6f Initial commit - SOGOMS v1.0.0
- sogoctl: supervisor avec health checks et restart auto
- sogoway: gateway HTTP, auth JWT, routing par hostname
- sogoms-db: microservice MariaDB avec pool par application
- Protocol IPC Unix socket JSON length-prefixed
- Config YAML multi-application (prokov)
- Deploy script pour container Alpine gw3

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-15 19:09:00 +01:00

59 lines
1.3 KiB
YAML

# Scénario: Connexion utilisateur
name: login
version: "1.0"
description: Authentifie un utilisateur et retourne un JWT
input:
required:
- email
- password
validation:
email:
type: string
format: email
password:
type: string
min_length: 1
steps:
- id: get_user
service: db
action: query_one
params:
query: "SELECT id, email, name, password FROM users WHERE email = ?"
args: ["{{input.email}}"]
on_error: abort
error_message: "Email ou mot de passe incorrect"
error_status: 401
- id: verify_password
service: auth
action: verify_password
params:
hash: "{{steps.get_user.result.password}}"
password: "{{input.password}}"
on_error: abort
error_message: "Email ou mot de passe incorrect"
error_status: 401
- id: generate_token
service: auth
action: generate_jwt
params:
claims:
sub: "{{steps.get_user.result.id}}"
email: "{{steps.get_user.result.email}}"
name: "{{steps.get_user.result.name}}"
output:
status: 200
body:
success: true
message: "Connexion réussie"
data:
token: "{{steps.generate_token.result.token}}"
user:
id: "{{steps.get_user.result.id}}"
email: "{{steps.get_user.result.email}}"
name: "{{steps.get_user.result.name}}"