Skip to content

Email + password login

POST
/v1/auth/login
curl --request POST \
--url https://kynectlocal-production.up.railway.app/v1/v1/auth/login \
--header 'Content-Type: application/json' \
--data '{ "email": "hello@example.com", "password": "example", "tenantSlug": "example" }'

Authenticates a user and returns a short-lived access token and a rotating refresh token.

Media type application/json
object
email
required
string format: email
password
required
string
tenantSlug
required

Tenant slug to scope authentication

string
Example generated
{
"email": "hello@example.com",
"password": "example",
"tenantSlug": "example"
}

Success

Media type application/json
object
data
required
object
accessToken
required

JWT access token (RS256, 15 min expiry)

string
refreshToken
required

Opaque refresh token (single-use, 30 days)

string
user
required
object
id
required

User identifier

string format: uuid
email
required

User email address

string format: email
firstName
required

First name

string
lastName
required

Last name

string
isSuperAdmin
required

Platform super-admin flag

boolean
tenantId
required

Tenant this user belongs to

string format: uuid
status
required

Account status: active | suspended

string
Example generated
{
"data": {
"accessToken": "example",
"refreshToken": "example",
"user": {
"id": "2489E9AD-2EE2-8E00-8EC9-32D5F69181C0",
"email": "hello@example.com",
"firstName": "example",
"lastName": "example",
"isSuperAdmin": true,
"tenantId": "2489E9AD-2EE2-8E00-8EC9-32D5F69181C0",
"status": "example"
}
}
}

Validation error

Media type application/json
object
error
required

Error envelope

object
code
required

Machine-readable error code

string
message
required

Human-readable error description

string
details

Additional context, e.g. validation field errors

Example generated
{
"error": {
"code": "example",
"message": "example",
"details": "example"
}
}

Unauthenticated

Media type application/json
object
error
required

Error envelope

object
code
required

Machine-readable error code

string
message
required

Human-readable error description

string
details

Additional context, e.g. validation field errors

Example generated
{
"error": {
"code": "example",
"message": "example",
"details": "example"
}
}

Forbidden

Media type application/json
object
error
required

Error envelope

object
code
required

Machine-readable error code

string
message
required

Human-readable error description

string
details

Additional context, e.g. validation field errors

Example generated
{
"error": {
"code": "example",
"message": "example",
"details": "example"
}
}

Not found

Media type application/json
object
error
required

Error envelope

object
code
required

Machine-readable error code

string
message
required

Human-readable error description

string
details

Additional context, e.g. validation field errors

Example generated
{
"error": {
"code": "example",
"message": "example",
"details": "example"
}
}

Unprocessable

Media type application/json
object
error
required

Error envelope

object
code
required

Machine-readable error code

string
message
required

Human-readable error description

string
details

Additional context, e.g. validation field errors

Example generated
{
"error": {
"code": "example",
"message": "example",
"details": "example"
}
}