-
Notifications
You must be signed in to change notification settings - Fork 46
Session Api
The session api allows clients to use an authorized session which is a requirement for client-side encryption.
Action | Url | Method | Session required | Description |
---|---|---|---|---|
request | /api/1.0/session/request |
GET | no | Request the information to open a session |
open | /api/1.0/session/open |
POST | no | Open a new session |
close | /api/1.0/session/close |
GET | no | Close an existing session |
keepalive | /api/1.0/session/keepalive |
GET | no | Keep the session alive |
The request action returns all requirements that the client must meet in order to open an authenticated session.
There are no arguments for this action.
The success status code is 200 Ok
.
The returned object only contains a challenge or token if the user has set those up.
If nothing is required, the result is an empty object.
Argument | Type | Description |
---|---|---|
challenge | object | An object with the password challenge. The property type specifies the challenge type. |
token | array | An array with available 2FA token. One of them must be used. |
The open action will open an authenticated session with read and write access to all api endpoints.
Which arguments are required can be found out with the request action.
Argument | Type | Default | Required | Description |
---|---|---|---|---|
challenge | string | - | yes (if enabled) | The solution of the password challenge |
token | object | - | yes (if enabled) | An object with the id of the token as property and the token as value |
The success status code is 200 Ok
.
The keys
property is only available if encryption is used.
Argument | Type | Description |
---|---|---|
success | boolean | Whether or not the action was successful |
keys | object | An object with the CSE keychains. The name of the property is the keychain and the value are the encrypted keychain contents |
- This api endpoint has a rate limit of 6 requests per minute
- After five failed login attempts, the client will be deauthorized.
- If the
token
argument is provided with more than one token, all of them have to be correct or the validation will fail
The close action will close the current session.
There are no arguments for this action.
The success status code is 200 Ok
.
The action will return an object with the property success
with the value true
.
The keepalive action will prevent the session from being closed.
There are no arguments for this action.
The success status code is 200 Ok
.
The action will return an object with the property success
with the value true
.
- The setting
user.session.lifetime
determines the session lifetime
The passwords app will send the nc_passwords
session cookie and the X-API-SESSION
header with each request.
If you use the session cookie, you need to send the most recent cookie you received from the server with every following request.
If you use the header, you need to send the most recent header you received from the server with every following request.
Node: If the value of the cookie or header changes, it's likely that the server has terminated the previous session.
To remain compatible with older clients which do neither support encryption nor sessions, the api does currently not require an authorized session if the user does not use encryption.
This will change by the end of 2023.
If a client tries to open an authorized session with invalid credentials more than five times, it will be blocked.
If the client used an app or device token to access the api, the token will be deleted. If the client used the password to access the api, the api will no longer accept password authentication.
The user will receive a notification about the incident.