Admin API Reference Guide
This page outlines the admin endpoint, which allows you to manage and review licenses in
Immuta.
Note
Additional fields may be included in some responses you receive; however, these attributes are for internal purposes and are therefore undocumented.
Admin workflow
- Add an Immuta license key to increase the number of seats or enable features.
- View a list of license keys.
- View the status of license seat capacity and features.
- View license usage.
- Delete a license key.
Add an Immuta license key
Endpoint
| Method | Path | Purpose | 
|---|---|---|
| POST | /admin/license | Add a license key to the Immuta tenant to increase the number of seats or enable features. | 
Query Parameters
| Parameter | Description | Required | 
|---|---|---|
| licenseKey | stringThe license key, as a payload. | Yes | 
Response Schema
| Attribute | Description | 
|---|---|
| licenseKey | stringThe license key. | 
| id | integerThe ID of the license. | 
| uuid | stringThe unique universal identifier. | 
| features | arrayThe features included in the license. | 
| handlers | arrayThe data handlers included in the license. | 
| expires | timestampThe date the license expires. | 
| seats | integerThe number of user seats available. | 
| createdAt | timestampThe date the license key was generated. | 
| notice | stringThis notice appears on the login page. | 
| noticeOnExpire | stringThis notice appears on the login page after the license expires. | 
Request example
This example request adds a license key (saved in the example-payload.json file) to the Immuta tenant.
curl \
    --request POST \
    --header "Content-Type: application/json" \
    --header "Authorization: Bearer dea464c07bd07300095caa8"
    --data @example-payload.json \
    https://www.organization.immuta.com/admin/license
Request payload example
{
  "licensekey": "licensekey0123456789abcdefghijklstring"
}
Response example
{
  "id": 1,
  "licenseKey": "licensekey0123456789abcdefghijklstring",
  "seats": 20,
  "softSeats": 0,
  "expires": "2022-09-09T00:00:00.000Z",
  "uuid": "4ceaf808-the-u-u--id4a753fc5a",
  "deleted": false,
  "invalidated": false,
  "features": {
    "FPE": {
      "enabled": true
    }
  },
  "handlers": {},
  "hardExpiration": false,
  "renewalToken": null,
  "notice": null,
  "noticeOnExpire": null,
  "classifyUsername": null,
  "classifyToken": null,
  "createdAt": "2021-09-09T13:47:02.473Z",
  "updatedAt": "2021-10-07T17:55:54.806Z",
  "expired": false
}
View license keys
| Method | Path | Purpose | 
|---|---|---|
| GET | /admin/license | Get a list of all license keys. | 
| GET | /admin/license/licenseStatus | Get the status of a license key's features and seat capacity. | 
Get a list of license keys
Endpoint
| Method | Path | 
|---|---|
| GET | /admin/license | 
Query Parameters
None.
Response Schema
| Attribute | Description | 
|---|---|
| id | integerThe ID of the license. | 
| uuid | stringThe unique universal identifier. | 
| features | arrayThe features included in the license. | 
| handlers | arrayThe data handlers included in the license. | 
| expires | timestampThe date the license expires. | 
| seats | integerThe number of user seats available. | 
| createdAt | timestampThe date the license key was generated. | 
| notice | stringThis notice appears on the login page. | 
| noticeOnExpire | stringThis notice appears on the login page after the license expires. | 
Request example
This example request gets the license key for the https://www.organization.immuta.com Immuta tenant.
curl \
    --request GET \
    --header "Content-Type: application/json" \
    --header "Authorization: Bearer dea464c07bd07300095caa8" \
    https://www.organization.immuta.com/admin/license
Response example
[
  {
    "id": 1,
    "uuid": "4cthe808-uniq-uec9-univ-ersal753fcid",
    "features": {
      "FPE": {
        "enabled": true
      }
    },
    "handlers": {},
    "expires": "2022-09-09T00:00:00.000Z",
    "seats": 20,
    "createdAt": "2021-09-09T13:47:02.473Z",
    "notice": null,
    "noticeOnExpire": null
  }
]
Get the status of a license
Endpoint
| Method | Path | Purpose | 
|---|---|---|
| GET | /admin/license/licenseStatus | Get the status of a license key's features and seat capacity. | 
Query Parameters
None.
Response Schema
| Attribute | Description | 
|---|---|
| activeUserCount | integerThe number of active users in the Immuta tenant. | 
| licenseSeats | integerThe total number of seats available in the license. | 
| canAddUser | booleanWhentrue, the administrator can add user accounts to the Immuta tenant. | 
| hardSeats | integerThe number of licensed seats available. | 
Request example
This example request gets the number of seats and active users for the license key associated with the
https://www.organization.immuta.com Immuta tenant.
curl \
    --request GET \
    --header "Content-Type: application/json" \
    --header "Authorization: Bearer dea464c07bd07300095caa8" \
    https://www.organization.immuta.com/admin/license/licenseStatus
Response example
{
  "activeUserCount": 1,
  "licenseSeats": 20,
  "canAddUser": true,
  "hardSeats": 20
}
Get License Usage
Endpoint
| Method | Path | Purpose | 
|---|---|---|
| GET | /admin/license/usage | Get the license usage summary. This endpoint returns a summary of the number of active and inactive users and a list of users. | 
Query Parameters
| Parameter | Description | Required | 
|---|---|---|
| offset | integerThe start index of the records to return. You can combine theoffsetandsizeparameters to return a specific set of user records. For example, to return the second and third user records in the response, you would setoffset=1andsize=2. The default start index is0. | No | 
| size | integerThe number of user records to return. The default size is10. | No | 
Response Schema
| Attribute | Description | 
|---|---|
| users | array[]An array of user records. | 
| users.userType | stringThe type of user. Value can bedataConsumerorpolicyOwner. | 
| users.name | stringThe name of the user. | 
| users.email | stringThe user's email address. | 
| users.iamid | stringThe IAM the user belongs to. | 
| users.userid | stringThe user's username. | 
| users.active | booleanIftrue, the user is active. This is determined by whether Immuta has tracked any activity by the user in the last year. | 
| summary | objectThe summary of license usage that covers all users, not just the subset returned by a call to this endpoint. | 
| summary.dataConsumers | arrayIncludes a summary of thedataConsumerstype. | 
| summary.dataConsumers.totalCount | integerThe total number of users of this type known to Immuta. | 
| summary.dataConsumers.activeCount | integerThe number of active data consumers known to Immuta, determined by whether Immuta has tracked any activity by the user in the last year. Minimum value is0. | 
| summary.dataConsumers.inactiveCount | integerThe number of inactive data consumers known to Immuta, determined by whether Immuta has tracked any activity by the user in the last year. Minimum value is0. | 
| summary.policyOwners | objectIncludes a summary of thepolicyOwnerstype. | 
| summary.policyOwners.totalCount | integerThe total number of users of this type known to Immuta. | 
Request example
This request gets the license usage for 5 users in the
https://www.organization.immuta.com Immuta tenant.
curl \
    --request GET \
    --header "Content-Type: application/json" \
    --header "Authorization: Bearer dea464c07bd07300095caa8" \
    https://www.organization.immuta.com/admin/license/usage?offset=0&size=5
Response example
{
  "summary": {
    "dataConsumers": {
      "totalCount": 25,
      "activeCount": 10,
      "inactiveCount": 25
    },
    "policyOwners": {
      "totalCount": 1
    }
  },
  "users": [{
      "userType": "policyOwner",
      "name": "Kris",
      "email": "kris@example.com",
      "userid": "kris@example.com",
      "iamid": "bim"
    },
    {
      "userType": "dataConsumer",
      "active": true,
      "name": "Taylor",
      "email": "taylor@example.com",
      "userid": "taylor@example.com",
      "iamid": "AzureOIDC"
    },
    {
      "userType": "dataConsumer",
      "active": true,
      "name": "Deepu",
      "email": "deepu@example.com",
      "userid": "deepu@example.com",
      "iamid": "AzureSAML"
    },
    {
      "userType": "dataConsumer",
      "active": false,
      "name": "Marc",
      "email": "marc@example.com",
      "userid": "marc@example.com",
      "iamid": "OIDC"
    },
    {
      "userType": "dataConsumer",
      "active": true,
      "name": "Mandeep",
      "email": "mandeep@example.com",
      "userid": "mandeep@example.com",
      "iamid": "SAML"
    }
  ]
}
Delete a license key
Endpoint
| Method | Path | Purpose | 
|---|---|---|
| DELETE | /admin/license/{licenseId} | Delete the specified license key. | 
Query Parameters
| Parameter | Description | Required | 
|---|---|---|
| licenseId | integerThe ID of the license key you want to delete. | Yes | 
Response Schema
| Attribute | Description | 
|---|---|
| id | integerThe license key ID. | 
| licenseKey | stringThe license key. | 
| seats | integerThe number of seats in the license. | 
| softSeats | integerThe number of users that can be added beyondseatswithout access being blocked. | 
| expires | timestampThe date the license expires. | 
| uuid | stringThe unique universal identifier. | 
| deleted | booleanIftrue, the license key has been deleted. | 
| features | arrayThe features included in the license. | 
| handlers | arrayThe data handlers included in the license. | 
| hardExpiration | booleanWhentrue, all data access is blocked when the license expires. | 
| notice | stringThis notice appears on the login page. | 
| noticeOnExpire | stringThis notice appears on the login page after the license expires. | 
| createdAt | timestampThe date the license key was generated. | 
| updatedAt | timestampThe date the license key was deleted. | 
| hardDelete | booleanIftrue, the license key cannot be re-added after it is deleted. | 
| expired | booleanIftrue, the license has expired. | 
Request example
This example request deletes the license key with the ID 1.
curl \
    --request GET \
    --header "Content-Type: application/json" \
    --header "Authorization: Bearer dea464c07bd07300095caa8" \
    https://www.organization.immuta.com/admin/license/1
Response example
{
  "id": 1,
  "licenseKey": "<your-license-key>",
  "seats": 20,
  "softSeats": 0,
  "expires": "2022-09-09T00:00:00.000Z",
  "uuid": "4cthe808-uniq-uec9-univ-ersal753fcid",
  "deleted": true,
  "invalidated": false,
  "features": {
    "FPE": {
      "enabled": true
    }
  },
  "handlers": {},
  "hardExpiration": false,
  "notice": null,
  "noticeOnExpire": null,
  "createdAt": "2021-09-09T13:47:02.473Z",
  "updatedAt": "2021-09-13T16:53:39.280Z",
  "hardDelete": false,
  "expired": false
}