Skip to main content
Version: 2.4

Admin API

Table of Contents#

Route#

API:/apisix/admin/routes/{id}?ttl=0

Description:Route matches requests based on preset rules, and loads the appropriate plugin according to the matching result, then forwarding requests to target Upstream.

Note: When the Admin API is enabled, it will occupy the API prefixed with /apisix/admin. Therefore, in order to avoid conflicts between your design API and /apisix/admin, it is recommended to use a different port for the Admin API. You can customize the Admin API port through port_admin in conf/config.yaml.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/routesNULLFetch resource list
GET/apisix/admin/routes/{id}NULLFetch resource
PUT/apisix/admin/routes/{id}{...}Create resource by ID
POST/apisix/admin/routes{...}Create resource, and ID is generated by server
DELETE/apisix/admin/routes/{id}NULLRemove resource
PATCH/apisix/admin/routes/{id}{...}Standard PATCH. Update some attributes of the existing Route, and other attributes not involved will remain as they are; if you want to delete an attribute, set the value of the attribute Set to null to delete; especially, when the value of the attribute is an array, the attribute will be updated in full
PATCH/apisix/admin/routes/{id}/{path}{...}SubPath PATCH, specify the attribute of Route to be updated through {path}, update the value of this attribute in full, and other attributes that are not involved will remain as they are. The difference between the two PATCH can refer to the following examples

URI Request Parameters:

parameterRequiredTypeDescriptionExample
ttlFalseAuxiliaryExpires after target secondsttl=1

Request Body Parameters:

ParameterRequiredTypeDescriptionExample
nameFalseAuxiliaryIdentifies route names.customer-xxxx
descFalseAuxiliaryroute description, usage scenarios, and more.customer xxxx
uriTrue, can't be used with urisMatch RulesIn addition to full matching such as /foo/bar/foo/gloo, using different Router allows more advanced matching, see Router for more."/hello"
urisTrue, can't be used with uriMatch RulesThe uri in the form of a non-empty list means that multiple different uris are allowed, and match any one of them.["/hello", "/word"]
hostFalse, can't be used with hostsMatch RulesCurrently requesting a domain name, such as foo.com; PAN domain names such as *.foo.com are also supported."foo.com"
hostsFalse, can't be used with hostMatch RulesThe host in the form of a non-empty list means that multiple different hosts are allowed, and match any one of them.{"foo.com", "*.bar.com"}
remote_addrFalse, can't be used with remote_addrsMatch RulesThe client requests an IP address: 192.168.1.101, 192.168.1.102, and CIDR format support 192.168.1.0/24. In particular, APISIX also fully supports IPv6 address matching: ::1, fe80::1, fe80::1/64, etc."192.168.1.0/24"
remote_addrsFalse, can't be used with remote_addrMatch RulesThe remote_addr in the form of a non-empty list indicates that multiple different IP addresses are allowed, and match any one of them.{"127.0.0.1", "192.0.0.0/8", "::1"}
methodsFalseMatch RulesIf empty or without this option, there are no method restrictions, and it can be a combination of one or more: GET,POST,PUT,DELETE,PATCH, HEAD,OPTIONS,CONNECT,TRACE.{"GET", "POST"}
priorityFalseMatch RulesIf different routes contain the same uri, determine which route is matched first based on the attribute priority. Larger value means higher priority. The default value is 0.priority = 10
varsFalseMatch RulesA list of one or more {var, operator, val} elements, like this: {{var, operator, val}, {var, operator, val}, ...}}. For example: {"arg_name", "==", "json"} means that the current request parameter name is json. The var here is consistent with the internal variable name of Nginx, so you can also use request_uri, host, etc. For more details, see lua-resty-expr{{"arg_name", "==", "json"}, {"arg_age", ">", 18}}
filter_funcFalseMatch RulesUser-defined filtering function. You can use it to achieve matching requirements for special scenarios. This function accepts an input parameter named vars by default, which you can use to get Nginx variables.function(vars) return vars["arg_name"] == "json" end
pluginsFalsePluginSee Plugin for more
scriptFalseScriptSee Script for more
upstreamFalseUpstreamEnabled Upstream configuration, see Upstream for more
upstream_idFalseUpstreamEnabled upstream id, see Upstream for more
service_idFalseServiceBinded Service configuration, see Service for more
plugin_config_idFalse, can't be used with scriptPluginBinded plugin config object, see Plugin Config for more
labelsFalseMatch RulesKey/value pairs to specify attributes{"version":"v2","build":"16","env":"production"}
enable_websocketFalseAuxiliaryenable websocket(boolean), default false.
statusFalseAuxiliaryenable this route, default 1.1 to enable, 0 to disable
create_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670
update_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670

For the same type of parameters, such as host and hosts, remote_addr and remote_addrs cannot exist at the same time, only one of them can be selected. If enabled at the same time, the API will respond with an error.

Config Example:

{    "id": "1",                  # id, unnecessary.    "uris": ["/a","/b"],        # A set of uri.    "methods": ["GET","POST"],  # Can fill multiple methods    "hosts": ["a.com","b.com"], # A set of host.    "plugins": {},              # Bound plugin    "priority": 0,              # If different routes contain the same `uri`, determine which route is matched first based on the attribute` priority`, the default value is 0.    "name": "route-xxx",    "desc": "hello world",    "remote_addrs": ["127.0.0.1"], # A set of Client IP.    "vars": [],                 # A list of one or more `{var, operator, val}` elements    "upstream_id": "1",         # upstream id, recommended    "upstream": {},             # upstream, not recommended    "filter_func": "",          # User-defined filtering function}

Example:

# Create a route$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -i -d '{    "uri": "/index.html",    "hosts": ["foo.com", "*.bar.com"],    "remote_addrs": ["127.0.0.0/8"],    "methods": ["PUT", "GET"],    "enable_websocket": true,    "upstream": {        "type": "roundrobin",        "nodes": {            "39.97.63.215:80": 1        }    }}'
HTTP/1.1 201 CreatedDate: Sat, 31 Aug 2019 01:17:15 GMT...
# Create a route expires after 60 seconds, then it's deleted automatically$ curl http://127.0.0.1:9080/apisix/admin/routes/2?ttl=60 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -i -d '{    "uri": "/aa/index.html",    "upstream": {        "type": "roundrobin",        "nodes": {            "39.97.63.215:80": 1        }    }}'
HTTP/1.1 201 CreatedDate: Sat, 31 Aug 2019 01:17:15 GMT...

# Add an upstream node to the Route$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "upstream": {        "nodes": {            "39.97.63.216:80": 1        }    }}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will be updated to:{    "39.97.63.215:80": 1,    "39.97.63.216:80": 1}

# Update the weight of an upstream node to the Route$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "upstream": {        "nodes": {            "39.97.63.216:80": 10        }    }}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will be updated to:{    "39.97.63.215:80": 1,    "39.97.63.216:80": 10}

# Delete an upstream node for the Route$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "upstream": {        "nodes": {            "39.97.63.215:80": null        }    }}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will be updated to:{    "39.97.63.216:80": 10}

# Replace methods of the Route  --  array$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "methods": ["GET", "POST"]}'HTTP/1.1 200 OK...
After successful execution, methods will not retain the original data, and the entire update is:["GET", "POST"]

# Replace upstream nodes of the Route -- sub path$ curl http://127.0.0.1:9080/apisix/admin/routes/1/upstream/nodes -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "39.97.63.200:80": 1}'HTTP/1.1 200 OK...
After successful execution, nodes will not retain the original data, and the entire update is:{    "39.97.63.200:80": 1}

# Replace methods of the Route -- sub path$ curl http://127.0.0.1:9080/apisix/admin/routes/1/methods -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d'["POST", "DELETE", " PATCH"]'HTTP/1.1 200 OK...
After successful execution, methods will not retain the original data, and the entire update is:["POST", "DELETE", "PATCH"]

# disable route$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "status": 0}'HTTP/1.1 200 OK...
After successful execution, status nodes will be updated to:{    "status": 0}

# enable route$ curl http://127.0.0.1:9080/apisix/admin/routes/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "status": 1}'HTTP/1.1 200 OK...
After successful execution, status nodes will be updated to:{    "status": 1}

Response Parameters

Return response from etcd currently.

Back to TOC

Service#

API:/apisix/admin/services/{id}

Description:A Service is an abstraction of an API (which can also be understood as a set of Route abstractions). It usually corresponds to the upstream service abstraction. Between Route and Service, usually the relationship of N:1.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/servicesNULLFetch resource list
GET/apisix/admin/services/{id}NULLFetch resource
PUT/apisix/admin/services/{id}{...}Create resource by ID
POST/apisix/admin/services{...}Create resource, and ID is generated by server
DELETE/apisix/admin/services/{id}NULLRemove resource
PATCH/apisix/admin/services/{id}{...}Standard PATCH. Update some attributes of the existing Service, and other attributes not involved will remain as they are; if you want to delete an attribute, set the value of the attribute Set to null to delete; especially, when the value of the attribute is an array, the attribute will be updated in full
PATCH/apisix/admin/services/{id}/{path}{...}SubPath PATCH, specify the attribute of Service to be updated through {path}, update the value of this attribute in full, and other attributes that are not involved will remain as they are. The difference between the two PATCH can refer to the following examples

Request Body Parameters:

ParameterRequiredTypeDescriptionExample
pluginsFalsePluginSee Plugin for more
upstreamFalseUpstreamEnabled Upstream configuration, see Upstream for more
upstream_idFalseUpstreamEnabled upstream id, see Upstream for more
nameFalseAuxiliaryIdentifies service names.customer-xxxx
descFalseAuxiliaryservice usage scenarios, and more.customer xxxx
labelsFalseMatch RulesKey/value pairs to specify attributes{"version":"v2","build":"16","env":"production"}
enable_websocketFalseAuxiliaryenable websocket(boolean), default false.
create_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670
update_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670

Config Example:

{    "id": "1",          # id    "plugins": {},      # Bound plugin    "upstream_id": "1", # upstream id, recommended    "upstream": {},     # upstream, not recommended    "name": "service-test",    "desc": "hello world",    "enable_websocket": true,}

Example:

$ curl http://127.0.0.1:9080/apisix/admin/services/201  -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -i -d '{    "plugins": {        "limit-count": {            "count": 2,            "time_window": 60,            "rejected_code": 503,            "key": "remote_addr"        }    },    "enable_websocket": true,    "upstream": {        "type": "roundrobin",        "nodes": {            "39.97.63.215:80": 1        }    }}'
HTTP/1.1 201 Created...

# Add an upstream node to the Service$ curl http://127.0.0.1:9080/apisix/admin/services/201 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "upstream": {        "nodes": {            "39.97.63.216:80": 1        }    }}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will be updated to:{    "39.97.63.215:80": 1,    "39.97.63.216:80": 1}

# Update the weight of an upstream node to the Service$ curl http://127.0.0.1:9080/apisix/admin/services/201 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "upstream": {        "nodes": {            "39.97.63.216:80": 10        }    }}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will be updated to:{    "39.97.63.215:80": 1,    "39.97.63.216:80": 10}

# Delete an upstream node for the Service$ curl http://127.0.0.1:9080/apisix/admin/services/201 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "upstream": {        "nodes": {            "39.97.63.215:80": null        }    }}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will be updated to:{    "39.97.63.216:80": 10}

# Replace upstream nodes of the Service$ curl http://127.0.0.1:9080/apisix/admin/services/201/upstream/nodes -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "39.97.63.200:80": 1}'HTTP/1.1 200 OK...
After successful execution, upstream nodes will not retain the original data, and the entire update is:{    "39.97.63.200:80": 1}

Response Parameters

Return response from etcd currently.

Back to TOC

Consumer#

API:/apisix/admin/consumers/{username}

Description:Consumers are consumers of certain types of services and can only be used in conjunction with a user authentication system. Consumer regards the username property as the identity, so only the HTTP PUT method is supported for creating a new consumer.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/consumersNULLFetch resource list
GET/apisix/admin/consumers/{username}NULLFetch resource
PUT/apisix/admin/consumers{...}Create resource by username
DELETE/apisix/admin/consumers/{username}NULLRemove resource

Request Body Parameters:

ParameterRequiredTypeDescriptionExample
usernameTrueNameConsumer name
pluginsFalsePluginSee Plugin for more
descFalseAuxiliaryIdentifies route names, usage scenarios, and more.customer xxxx
labelsFalseMatch RulesKey/value pairs to specify attributes{"version":"v2","build":"16","env":"production"}
create_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670
update_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670

Config Example:

{    "plugins": {},          # Bound plugin    "username": "name",     # Consumer name    "desc": "hello world",  # Consumer desc}

The binding authentication plug-in is a bit special. When it needs to be used in conjunction with the consumer, it needs to provide user name, password and other information; on the other hand, when it is bound with route / service, it does not require any parameters. Because at this time, it is based on the user request data to infer which consumer the user corresponds to.

Example:

$ curl http://127.0.0.1:9080/apisix/admin/consumers  -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -i -d '{    "username": "jack",    "plugins": {        "key-auth": {            "key": "auth-one"        },        "limit-count": {            "count": 2,            "time_window": 60,            "rejected_code": 503,            "key": "remote_addr"        }    }}'HTTP/1.1 200 OKDate: Thu, 26 Dec 2019 08:17:49 GMT...
{"node":{"value":{"username":"jack","plugins":{"key-auth":{"key":"auth-one"},"limit-count":{"time_window":60,"count":2,"rejected_code":503,"key":"remote_addr","policy":"local"}}},"createdIndex":64,"key":"\/apisix\/consumers\/jack","modifiedIndex":64},"prevNode":{"value":"{\"username\":\"jack\",\"plugins\":{\"key-auth\":{\"key\":\"auth-one\"},\"limit-count\":{\"time_window\":60,\"count\":2,\"rejected_code\":503,\"key\":\"remote_addr\",\"policy\":\"local\"}}}","createdIndex":63,"key":"\/apisix\/consumers\/jack","modifiedIndex":63},"action":"set"}

Since v2.2, we can bind multiple authentication plugins to the same consumer.

Response Parameters

Return response from etcd currently.

Back to TOC

Upstream#

API:/apisix/admin/upstreams/{id}

Description:Upstream configuration can be directly bound to the specified Route or it can be bound to Service, but the configuration in Route has a higher priority. The priority behavior here is very similar to Plugin.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/upstreamsNULLFetch resource list
GET/apisix/admin/upstreams/{id}NULLFetch resource
PUT/apisix/admin/upstreams/{id}{...}Create resource by ID
POST/apisix/admin/upstreams{...}Create resource, and ID is generated by server
DELETE/apisix/admin/upstreams/{id}NULLRemove resource
PATCH/apisix/admin/upstreams/{id}{...}Standard PATCH. Update some attributes of the existing Upstream, and other attributes not involved will remain as they are; if you want to delete an attribute, set the value of the attribute Set to null to delete; especially, when the value of the attribute is an array, the attribute will be updated in full
PATCH/apisix/admin/upstreams/{id}/{path}{...}SubPath PATCH, specify the attribute of Upstream to be updated through {path}, update the value of this attribute in full, and other attributes that are not involved will remain as they are. The difference between the two PATCH can refer to the following example

Request Body Parameters:

In addition to the basic complex equalization algorithm selection, APISIX's Upstream also supports logic for upstream passive health check and retry, see the table below.

NameOptionalDescription
typerequiredthe balancer algorithm
nodesrequired, can't be used with service_nameHash table, the key of the internal element is the upstream machine address list, the format is Address + Port, where the address part can be IP or domain name, such as 192.168.1.100:80, foo.com:80, etc. Value is the weight of the node. In particular, when the weight value is 0, it has a special meaning, which usually means that the upstream node is invalid and never wants to be selected. The nodes can be empty, which means it is a placeholder and will be filled later. Clients use such an upstream will get 502 response.
service_namerequired, can't be used with nodesthe name of service used in the service discovery, see discovery for more details
discovery_typerequired, if service_name is usedthe type of service discovery, see discovery for more details
hash_onoptionalThis option is only valid if the type is chash. Supported types vars(Nginx variables), header(custom header), cookie, consumer, the default value is vars.
keyoptionalThis option is only valid if the type is chash. Find the corresponding node id according to hash_on and key. When hash_on is set as vars, key is the required parameter, for now, it support nginx built-in variables like uri, server_name, server_addr, request_uri, remote_port, remote_addr, query_string, host, hostname, arg_***, arg_*** is arguments in the request line, Nginx variables list. When hash_on is set as header, key is the required parameter, and header name is customized. When hash_on is set to cookie, key is the required parameter, and cookie name is customized. When hash_on is set to consumer, key does not need to be set. In this case, the key adopted by the hash algorithm is the consumer_name authenticated. If the specified hash_on and key can not fetch values, it will be fetch remote_addr by default.
checksoptionalConfigure the parameters of the health check. For details, refer to health-check.
retriesoptionalPass the request to the next upstream using the underlying Nginx retry mechanism, the retry mechanism is enabled by default and set the number of retries according to the number of available backend nodes. If retries option is explicitly set, it will override the default value. 0 means disable retry mechanism.
timeoutoptionalSet the timeout for connection, sending and receiving messages.
nameoptionalIdentifies upstream names
descoptionalupstream usage scenarios, and more.
pass_hostoptionalpass pass the client request host, node not pass the client request host, using the upstream node host, rewrite rewrite host by the configured upstream_host. Default to pass.
upstream_hostoptionalThis option is only valid if the pass_host is rewrite.
schemeoptionalThe scheme used when talk with the upstream. The value is one of ['http', 'https', 'grpc', 'grpcs'], default to 'http'.
labelsoptionalKey/value pairs to specify attributes
create_timeoptionalepoch timestamp in second, like 1602883670, will be created automatically if missing
update_timeoptionalepoch timestamp in second, like 1602883670, will be created automatically if missing

type can be one of:

  • roundrobin: roundrobin with weight
  • chash: consistent hash
  • ewma: pick one of node which has minimum latency. See https://en.wikipedia.org/wiki/EWMA_chart for details.
  • least_conn: pick node which has the lowest (active_conn + 1) / weight. Note the active connection concept is the same with Nginx: it is a connection in used by a request.

hash_on can be set to different types:

  1. when it is vars, the key is required. The key can be any Nginx builtin variables, without the prefix '$'.
  2. when it is header, the key is required. It is equal to "http_key".
  3. when it is cookie, the key is required. It is equal to "cookie_key".
  4. when it is consumer, the key is optional. The key is the consumer_name set by authentication plugin.
  5. when it is vars_combinations, the key is required. The key can be any Nginx builtin variables combinations, such as $request_uri$remote_addr.
  6. If there is no value for either hash_on or key, remote_addr will be used as key.

Config Example:

{    "id": "1",                  # id    "retries": 1,               # retry times    "timeout": {                # Set the timeout for connection, sending and receiving messages.        "connect":15,        "send":15,        "read":15,    },    "nodes": {"host:80": 100},  # Upstream machine address list, the format is `Address + Port`    "type":"roundrobin",    "checks": {},               # Health check parameters    "hash_on": "",    "key": "",    "name": "upstream-for-test",    "desc": "hello world",}

Example:

$ curl http://127.0.0.1:9080/apisix/admin/upstreams/100  -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -i -X PUT -d '{    "type":"roundrobin",    "nodes":{        "127.0.0.1:80":1,        "127.0.0.2:80":2,        "foo.com:80":3    }}'HTTP/1.1 201 CreatedDate: Thu, 26 Dec 2019 04:19:34 GMTContent-Type: text/plain...

# Add a node to the Upstream$ curl http://127.0.0.1:9080/apisix/admin/upstreams/100 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "nodes": {        "39.97.63.216:80": 1    }}'HTTP/1.1 200 OK...
After successful execution, nodes will be updated to:{    "39.97.63.215:80": 1,    "39.97.63.216:80": 1}

# Update the weight of a node to the Upstream$ curl http://127.0.0.1:9080/apisix/admin/upstreams/100 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "nodes": {        "39.97.63.216:80": 10    }}'HTTP/1.1 200 OK...
After successful execution, nodes will be updated to:{    "39.97.63.215:80": 1,    "39.97.63.216:80": 10}

# Delete a node for the Upstream$ curl http://127.0.0.1:9080/apisix/admin/upstreams/100 -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "nodes": {        "39.97.63.215:80": null    }}'HTTP/1.1 200 OK...
After successful execution, nodes will be updated to:{    "39.97.63.216:80": 10}

# Replace the nodes of the Upstream$ curl http://127.0.0.1:9080/apisix/admin/upstreams/100/nodes -H'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PATCH -i -d '{    "39.97.63.200:80": 1}'HTTP/1.1 200 OK...
After the execution is successful, nodes will not retain the original data, and the entire update is:{    "39.97.63.200:80": 1}

Response Parameters

Return response from etcd currently.

Back to TOC

SSL#

API:/apisix/admin/ssl/{id}

Description:SSL.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/sslNULLFetch resource list
GET/apisix/admin/ssl/{id}NULLFetch resource
PUT/apisix/admin/ssl/{id}{...}Create resource by ID
POST/apisix/admin/ssl{...}Create resource, and ID is generated by server
DELETE/apisix/admin/ssl/{id}NULLRemove resource

Request Body Parameters:

ParameterRequiredTypeDescriptionExample
certTrueCertificatehttps certificate
keyTruePrivate keyhttps private key
certsFalseAn array of certificatewhen you need to configure multiple certificate for the same domain, you can pass extra https certificates (excluding the one given as cert) in this field
keysFalseAn array of private keyhttps private keys. The keys should be paired with certs above
snisTrueMatch Rulesa non-empty arrays of https SNI
labelsFalseMatch RulesKey/value pairs to specify attributes{"version":"v2","build":"16","env":"production"}
create_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670
update_timeFalseAuxiliaryepoch timestamp in second, will be created automatically if missing1602883670
statusFalseAuxiliaryenable this SSL, default 1.1 to enable, 0 to disable

Config Example:

{    "id": "1",      # id    "cert": "cert", # Certificate    "key": "key",   # Private key    "snis": ["t.com"]    # https SNI}

Global Rule#

API:/apisix/admin/global_rules/{id}

Description: Set plugins which run globally. Those plugins will be run before any Route/Service level plugins.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/global_rulesNULLFetch resource list
GET/apisix/admin/global_rules/{id}NULLFetch resource
PUT/apisix/admin/global_rules/{id}{...}Create resource by ID
DELETE/apisix/admin/global_rules/{id}NULLRemove resource
PATCH/apisix/admin/global_rules/{id}{...}Standard PATCH. Update some attributes of the existing global rule, and other attributes not involved will remain as they are; if you want to delete an attribute, set the value of the attribute Set to null to delete; especially, when the value of the attribute is an array, the attribute will be updated in full
PATCH/apisix/admin/global_rules/{id}/{path}{...}SubPath PATCH, specify the attribute of global rule to be updated through {path}, update the value of this attribute in full, and other attributes that are not involved will remain as they are.

Request Body Parameters:

ParameterRequiredDescriptionExample
pluginsTrueSee Plugin
create_timeFalseepoch timestamp in second, will be created automatically if missing1602883670
update_timeFalseepoch timestamp in second, will be created automatically if missing1602883670

Plugin config#

API:/apisix/admin/plugin_configs/{id}

Description: Provide a group of plugins which can be reused across routes.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/plugin_configsNULLFetch resource list
GET/apisix/admin/plugin_configs/{id}NULLFetch resource
PUT/apisix/admin/plugin_configs/{id}{...}Create resource by ID
DELETE/apisix/admin/plugin_configs/{id}NULLRemove resource
PATCH/apisix/admin/plugin_configs/{id}{...}Standard PATCH. Update some attributes of the existing plugin config, and other attributes not involved will remain as they are; if you want to delete an attribute, set the value of the attribute Set to null to delete; especially, when the value of the attribute is an array, the attribute will be updated in full
PATCH/apisix/admin/plugin_configs/{id}/{path}{...}SubPath PATCH, specify the attribute of plugin config to be updated through {path}, update the value of this attribute in full, and other attributes that are not involved will remain as they are.

Request Body Parameters:

ParameterRequiredDescriptionExample
pluginsTrueSee Plugin
descFalsedescription, usage scenarios, and more.customer xxxx
labelsFalseKey/value pairs to specify attributes{"version":"v2","build":"16","env":"production"}
create_timeFalseepoch timestamp in second, will be created automatically if missing1602883670
update_timeFalseepoch timestamp in second, will be created automatically if missing1602883670

Back to TOC

Plugin Metadata#

API:/apisix/admin/plugin_metadata/{plugin_name}

Description: plugin metadata.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/plugin_metadata/{plugin_name}NULLFetch resource
PUT/apisix/admin/plugin_metadata/{plugin_name}{...}Create resource by plugin name
DELETE/apisix/admin/plugin_metadata/{plugin_name}NULLRemove resource

Request Body Parameters:

A json object with a data structure defined according to metadata_schema of the plugin ({plugin_name}).

Config Example:

$ curl http://127.0.0.1:9080/apisix/admin/plugin_metadata/example-plugin  -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -i -X PUT -d '{    "skey": "val",    "ikey": 1}'HTTP/1.1 201 CreatedDate: Thu, 26 Dec 2019 04:19:34 GMTContent-Type: text/plain

Back to TOC

Plugin#

API:/apisix/admin/plugins/{plugin_name}

Description: plugin

Request Methods:

MethodRequest URIRequest BodyDescription
GET      /apisix/admin/plugins/listNULLFetch resource list
GET      /apisix/admin/plugins/{plugin_name}NULLFetch resource

Request Body Parameters:

Get the plugin ({plugin_name}) of the data structure.

Example:

curl "http://127.0.0.1:9080/apisix/admin/plugins/list" -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1'["zipkin","request-id",...]
curl "http://127.0.0.1:9080/apisix/admin/plugins/key-auth" -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1'{"properties":{"disable":{"type":"boolean"}},"additionalProperties":false,"type":"object"}

API:/apisix/admin/plugins?all=true

Description: all the attributes of all plugins, each plugin includes name, priority, type, schema, consumer_schema and version.

Request Methods:

MethodRequest URIRequest BodyDescription
GET/apisix/admin/plugins?all=trueNULLFetch resource

Back to TOC