Secure your Services Using Authentication
If you are following the getting started workflow, make sure you have completed Improve Performance with Proxy Caching before moving on.
API gateway authentication is an important way to control the data that is allowed to be transmitted using your APIs. Basically, it checks that a particular consumer has permission to access the API, using a predefined set of credentials.
Kong Gateway has a library of plugins that provide simple ways to implement the best known and most widely used . Here are some of the commonly used ones:
- Basic Authentication
- Key Authentication
- OAuth 2.0 Authentication
- LDAP Authentication Advanced
- OpenID Connect
Authentication plugins can be configured to apply to service entities within the Kong Gateway. In turn, service entities are mapped one-to-one with the upstream services they represent, essentially meaning that the authentication plugins apply directly to those upstream services.
Why use API Gateway Authentication?
With authentication turned on, Kong Gateway won’t proxy requests unless the client successfully authenticates first. This means that the upstream (API) doesn’t need to authenticate client requests, and it doesn’t waste critical resources validating credentials.
Kong Gateway has visibility into all authentication attempts, successful, failed, and so on, which provides the ability to catalog and dashboard those events to prove the right controls are in place, and to achieve compliance. Authentication also gives you an opportunity to determine how a failed request is handled. This might mean simply blocking the request and returning an error code, or in some circumstances, you might still want to provide limited access.
In this example, you’re going to enable the Key Authentication plugin. API key authentication is one of the most popular ways to conduct API authentication and can be implemented to create and delete access keys as required.
For more information, see .
Using Kong Manager
Using the Admin API
Using decK (YAML)
- Access your Kong Manager instance and your default workspace.
- Go to the Routes page and select the mocking route you created.
- Click View.
- On the Scroll down and select the Plugins tab, then click Add a Plugin.
- In the Authentication section, find the Key Authentication plugin and click Enable.
In the Create new key-auth plugin dialog, the plugin fields are automatically scoped to the route because the plugin is selected from the mocking Routes page.
For this example, this means that you can use all of the default values.
Click Create.
Once the plugin is enabled on the route, key-auth displays under the Plugins section on the route’s overview page.
Now, if you try to access the route without providing an API key, the request will fail, and you’ll see the message
Before Kong proxies requests for this route, it needs an API key. For this example, since you installed the Key Authentication plugin, you need to create a consumer with an associated key first.
Call the Admin API on port 8001
and configure plugins to enable key authentication. For this example, apply the plugin to the /mock route you created:
cURL
HTTPie
http :8001/routes/mocking/plugins \
name=key-auth
Try to access the service again:
cURL
curl -i http://<admin-hostname>:8000/mock
http :8000/mock
Since you added key authentication, you should be unable to access it:
HTTP/1.1 401 Unauthorized
...
{
"message": "No API key found in request"
}
Before Kong proxies requests for this route, it needs an API key. For this example, since you installed the Key Authentication plugin, you need to create a consumer with an associated key first.
Under the
mocking
route in theroutes
section of thekong.yaml
file, add a plugin section and enable thekey-auth
plugin:plugins:
- name: key-auth
Your file should now look like this:
_format_version: "1.1"
services:
- host: mockbin.org
name: example_service
port: 80
protocol: http
routes:
- name: mocking
paths:
- /mock
strip_path: true
plugins:
- name: key-auth
plugins:
config:
minute: 5
policy: local
- name: proxy-cache
config:
content_type:
- "application/json; charset=utf-8"
cache_ttl: 30
Sync the configuration:
deck sync
Now, if you try to access the route at http://<admin-hostname>:8000/mock
without providing an API key, the request will fail, and you’ll see the message "No API key found in request".
Before Kong proxies requests for this route, it needs an API key. For this example, since you installed the Key Authentication plugin, you need to create a consumer with an associated key first.
Set up Consumers and Credentials
Using Kong Manager
Using the Admin API
Using decK (YAML)
- In Kong Manager, go to API Gateway > Consumers.
- Click New Consumer.
- Enter the Username and Custom ID. For this example, use
consumer
for each field. - Click Create.
- On the Consumers page, find your new consumer and click View.
- Scroll down the page and click the Credentials tab.
- Click New Key Auth Credential.
- Set the key to apikey and click Create.
The new Key Authentication ID displays on the Consumers page under the Credentials tab.
To create a consumer, call the Admin API and the consumer’s endpoint. The following creates a new consumer called consumer:
cURL
HTTPie
http :8001/consumers \
username=consumer \
custom_id=consumer
Once provisioned, call the Admin API to provision a key for the consumer created above. For this example, set the key to apikey
.
cURL
HTTPie
curl -i -X POST http://<admin-hostname>:8001/consumers/consumer/key-auth \
--data key=apikey
http :8001/consumers/consumer/key-auth \
key=apikey
If no key is entered, Kong automatically generates the key.
Result:
HTTP/1.1 201 Created
...
{
"consumer": {
"id": "2c43c08b-ba6d-444a-8687-3394bb215350"
},
"created_at": 1568255693,
"id": "86d283dd-27ee-473c-9a1d-a567c6a76d8e",
"key": "apikey"
}
You now have a consumer with an API key provisioned to access the route.
Add a
consumers
section to yourkong.yaml
file and create a new consumer:consumers:
- custom_id: consumer
username: consumer
keyauth_credentials:
- key: apikey
Your file should now look like this:
_format_version: "1.1"
services:
- host: mockbin.org
port: 80
protocol: http
routes:
- name: mocking
paths:
- /mock
plugins:
- name: key-auth
consumers:
- custom_id: consumer
username: consumer
keyauth_credentials:
- key: apikey
plugins:
- name: rate-limiting
config:
minute: 5
policy: local
- name: proxy-cache
config:
content_type:
- "application/json; charset=utf-8"
cache_ttl: 30
strategy: memory
-
deck sync
You now have a consumer with an API key provisioned to access the route.
Using a Web Browser
Using the Admin API
To validate the Key Authentication plugin, access your route through your browser by appending ?apikey=apikey
to the url:
To validate the Key Authentication plugin, access the mocking route again, using the header apikey
with a key value of apikey
.
cURL
HTTPie
curl -i http://<admin-hostname>:8000/mock/request \
-H 'apikey:apikey'
http :8000/mock/request apikey:apikey
You should get an HTTP/1.1 200 OK
message in response.
(Optional) Disable the plugin
If you are following this getting started guide topic by topic, you will need to use this API key in any requests going forward. If you don’t want to keep specifying the key, disable the plugin before moving on.
Using Kong Manager
Using the Admin API
Using decK (YAML)
- Go to the Plugins page and click on View for the key-auth row.
- Use the toggle at the top of the page to switch the plugin from Enabled to Disabled.
Find the plugin ID and copy it:
cURL
HTTPie
curl -X GET http://<admin-hostname>:8001/routes/mocking/plugins/
http :8001/routes/mocking/plugins
Output:
"id": "2512e48d9-7by0-674c-84b7-00606792f96b"
Disable the plugin:
cURL
HTTPie
curl -X PATCH http://<admin-hostname>:8001/routes/mocking/plugins/{<plugin-id>} \
--data enabled=false
http -f patch :8001/routes/mocking/plugins/{<plugin-id>} \
enabled=false
Disable the key-auth plugin in the
kong.yaml
file by settingenabled
tofalse
:Sync the configuration:
$ deck sync
In this topic, you:
- Enabled the Key Authentication plugin.
- Created a new consumer named
consumer
. - Gave the consumer an API key of
apikey
so that it could access the route with authentication.