POST
/
tyk
/
org
/
keys
/
{keyID}
Create an organisation key
curl --request POST \
  --url https://{tenant}/tyk/org/keys/{keyID} \
  --header 'Content-Type: application/json' \
  --header 'X-Tyk-Authorization: <api-key>' \
  --data '{
  "access_rights": {
    "itachi-api": {
      "allowed_urls": [
        {
          "methods": [
            "GET"
          ],
          "url": "/users"
        }
      ],
      "api_id": "8ddd91f3cda9453442c477b06c4e2da4",
      "api_name": "Itachi api",
      "limit": {
        "per": 60,
        "quota_max": 10000,
        "quota_remaining": 10000,
        "quota_renewal_rate": 3600,
        "rate": 1000,
        "throttle_interval": 10,
        "throttle_retry_limit": 10
      },
      "versions": [
        "Default"
      ]
    }
  },
  "alias": "portal-key",
  "allowance": 1000,
  "apply_policies": [
    "5ead7120575961000181867e"
  ],
  "date_created": "2024-08-09T14:40:34.87614+03:00",
  "enable_detailed_recording": true,
  "last_updated": "1723203634",
  "meta_data": {
    "new-update-key-sample": "update-key-sample",
    "tyk_developer_id": "62b3fb9a1d5e4f00017226f5",
    "update": "sample policy update",
    "user_type": "mobile_user"
  },
  "org_id": "5e9d9544a1dcd60001d0ed20",
  "per": 60,
  "quota_max": 10000,
  "quota_renewal_rate": 3600,
  "quota_renews": 1723207234,
  "rate": 1000,
  "tags": [
    "security",
    "edge",
    "edge-eu"
  ],
  "throttle_interval": 10,
  "throttle_retry_limit": 10
}'
{
  "action": "added",
  "key": "e389ae00a2b145feaf28d6cc11f0f86d",
  "status": "ok"
}

Authorizations

X-Tyk-Authorization
string
header
required

Api key

Path Parameters

keyID
string
required

The Key ID

Query Parameters

reset_quota
enum<string>

Adding the reset_quota parameter and setting it to 1, will cause Tyk reset the organisations quota in the live quota manager, it is recommended to use this mechanism to reset organisation-level access if a monthly subscription is in place.

Available options:
1

Body

application/json
access_rights
object | null
alias
string
Example:

"portal-developer@example.org"

allowance
number
Example:

1000

apply_policies
string[] | null
Example:
["641c15dd0fffb800010197bf"]
apply_policy_id
string
deprecated

deprecated use apply_policies going forward instead to send a list of policies ids

Example:

"641c15dd0fffb800010197bf"

basic_auth_data
object
certificate
string
data_expires
integer
Example:

0

date_created
string<date-time>
Example:

"2024-03-13T03:56:46.568042549Z"

enable_detail_recording
boolean
deprecated

deprecated use enable_detailed_recording going forward instead

Example:

false

enable_detailed_recording
boolean
Example:

true

enable_http_signature_validation
boolean
Example:

false

expires
integer
Example:

1712895619

hmac_enabled
boolean
Example:

false

hmac_string
string
id_extractor_deadline
integer
is_inactive
boolean
Example:

false

jwt_data
object
last_check
integer
Example:

0

last_updated
string
Example:

"1710302206"

max_query_depth
integer
Example:

-1

meta_data
object | null
Example:
{
"tyk_developer_id": "62b3fb9a1d5e4f00017226f5"
}
monitor
object
oauth_client_id
string
oauth_keys
object | null
org_id
string
Example:

"5e9d9544a1dcd60001d0ed20"

per
number
Example:

5

quota_max
integer
Example:

20000

quota_remaining
integer
Example:

20000

quota_renewal_rate
integer
Example:

31556952

quota_renews
integer
Example:

1710302205

rate
number
Example:

1

rsa_certificate_id
string
session_lifetime
integer
Example:

0

smoothing
object | null
tags
string[] | null
Example:
["edge", "edge-eu"]
throttle_interval
number
Example:

10

throttle_retry_limit
integer
Example:

1000

Response

OK

action
string
Example:

"modified"

key
string
Example:

"b13d928b9972bd18"

key_hash
string
status
string
Example:

"ok"