Register User
Create a new user with role assignments.
POST /api/auth/register
Create a new user and assign roles. Only users with the CREATE_USER permission can register new users.
Auth: Required — CREATE_USER permission
Headers
| Header | Required | Value |
|---|---|---|
Authorization | Yes | Bearer <access_token> |
x-tenant-id | Yes | Tenant UUID |
Request Body
| Field | Type | Required | Description |
|---|---|---|---|
email | string | Yes | User email (must be unique) |
password | string | Yes | User password |
firstName | string | Yes | First name |
lastName | string | Yes | Last name |
roles | string[] | Yes | Array of role names to assign |
Example
curl -X POST https://api.reten.ai/api/auth/register \
-H "Authorization: Bearer <token>" \
-H "x-tenant-id: <tenant-id>" \
-H "Content-Type: application/json" \
-d '{
"email": "newuser@example.com",
"password": "SecurePass123!",
"firstName": "Jane",
"lastName": "Doe",
"roles": ["FDE"]
}'const response = await fetch("https://api.reten.ai/api/auth/register", {
method: "POST",
headers: {
"Authorization": "Bearer <token>",
"x-tenant-id": "<tenant-id>",
"Content-Type": "application/json",
},
body: JSON.stringify({
email: "newuser@example.com",
password: "SecurePass123!",
firstName: "Jane",
lastName: "Doe",
roles: ["FDE"],
}),
});
const user = await response.json();import requests
response = requests.post(
"https://api.reten.ai/api/auth/register",
headers={
"Authorization": "Bearer <token>",
"x-tenant-id": "<tenant-id>",
},
json={
"email": "newuser@example.com",
"password": "SecurePass123!",
"firstName": "Jane",
"lastName": "Doe",
"roles": ["FDE"],
},
)
user = response.json()Response 201 Created
{
"id": "770e8400-e29b-41d4-a716-446655440000",
"email": "newuser@example.com",
"firstName": "Jane",
"lastName": "Doe"
}Error Responses
| Status | Description |
|---|---|
400 | Validation error |
403 | Insufficient permissions or trying to assign a higher role |
409 | Email already exists |