Skip to main content

Kong Plugin

Prerequisites

  1. A GraphQL endpoint configured for the Kong Gateway with an associated Service and Route.
  2. Use of Docker or another containerized runtime to run the Kong Gateway.
  3. An Inigo account setup as documented in our Getting Started guide.
  4. From #3, An Inigo service token value to set an INIGO_SERVICE_TOKEN environment variable.
  5. The Inigo CLI installed and logged in to Inigo.
  6. A copy of your GraphQL schema file that can be applied using the Inigo CLI.
  7. A local copy of the schema.lua to configure the custom Inigo plugin.

Note: This documentation assumes that Kong Konnect is used to configure the Kong Gateway (Data Plane Node), but it's not a requirement. If you run Kong standalone, the instructions are the same, just without the Kong Konnect integration.

Apply the GraphQL Schema to Inigo

When using the Kong plugin, the GraphQL schema must be managed by Inigo to take full advantage of the observability, security, and API management functions that Inigo offers. The schema can be configured using the Service configuration, and applied using inigo apply per the documentation. With a published schema, the Inigo plugin will be able to download and apply the latest schema version.

Note: When using the Kong plugin, it's recommended to integrate Inigo into your CI/CD pipeline to automate the schema deployments.

Configure the Custom Inigo Plugin in Kong Konnect

In Kong Konnect, under Plugins, click New Plugin. On the Select a Plugin screen, click the Custom Plugins tab. Click Create to begin the process of creationg the custom Inigo plugin.

As shown in Figure 1, upload the schema.lua in the Upload Schema File field.


Figure 1. Upload Schema File.

After creating the Inigo plugin, click Enable. Proceed to configure the following, as shown in Figure 2:

  1. Set the plugin to Scoped.
  2. Set the Gateway Service and the Route that are configured for your GraphQL endpoint.
  3. Remove grpc and grpcs from the Protocols.

Figure 2. Configure Inigo Plugin.

Configure Inigo Plugin via Kong's Declarative Configuration (alternative approach)

Add Inigo plugin to the desired route in Kong's yaml configuration file like in the example below:

services:
- name: starwars
url: http://starwars:8888/query
routes:
- name: starwars
paths:
- /query
plugins:
- name: inigo

Run the Kong Gateway With the Inigo Plugin

Inigo provides a prebuilt container image of the Kong Gateway with the Inigo plugin preinstalled. The image can be pulled from inigolabs/inigo_kong. Replace the default Kong Gateway image with inigohub/inigo_kong and also add the INIGO_SERVICE_TOKEN to the docker run command, as shown in the following example:

docker run -d \
-e "KONG_ROLE=data_plane" \
-e "KONG_DATABASE=off" \
-e "KONG_VITALS=off" \
-e "KONG_CLUSTER_MTLS=pki" \
-e "KONG_CLUSTER_CONTROL_PLANE=...konghq.com:443" \
-e "KONG_CLUSTER_SERVER_NAME=...konghq.com" \
-e "KONG_CLUSTER_TELEMETRY_ENDPOINT=...konghq.com:443" \
-e "KONG_CLUSTER_TELEMETRY_SERVER_NAME=...konghq.com" \
-e "KONG_CLUSTER_CERT=-----BEGIN CERTIFICATE-----
...
-----END CERTIFICATE-----" \
-e "KONG_CLUSTER_CERT_KEY=-----BEGIN PRIVATE KEY-----
...
-----END PRIVATE KEY-----" \
-e "KONG_LUA_SSL_TRUSTED_CERTIFICATE=system" \
-e "KONG_KONNECT_MODE=on" \
-e "INIGO_SERVICE_TOKEN=ey..." \
-p 8000:8000 \
-p 8443:8443 \
inigohub/inigo_kong

After starting the Kong Gateway, the Inigo agent, embedded in the Inigo Kong plugin, will connect back to Inigo's cloud service. Inigo will now capture metrics and enforce configured security and access policies for queries running through the Kong Gateway.

Common issues

  • Issue: Route with Inigo plugin on it responds with instance handle not found.
    Explanation: There was an issue during Inigo plugin initialization. The exact error message is printed in logs. The first thing to make sure is that INIGO_SERVICE_TOKEN env var is provided.