Skip to content

API Portal

Traefik Enterprise includes an API Portal which groups all of the API specifications from your services into a web UI, if they support the OpenAPI format (formerly known as Swagger).

It works by looking for a JSON file on the service endpoint, which should match the file name defined in the configuration, and making it available on the API Portal web app. It does this for all services that expose an API specification file.

The API specifications also allows your services to be tested directly from within the API Portal.

API Portal page

Configuration

In order to enable the API Portal, a path property must be defined in the static configuration.

API Portal Options

path

Required, Default=""

The path option must be a string representing the name of the specification file to look for on the service endpoint. For example, if spec.json is defined as path, the API Portal will try to get this file under the service URL. Thus, the path <service-url>/spec.json must point to the specification file.

apiportal:
  path: spec.json
[apiportal]
  path = "spec.json"

Query parameters are allowed and will be included on the request call to the service, for example /spec/api.yaml?variant=b is a valid path.

It's also possible to define the API spec path on the dynamic configuration, declared on the service definition attached to your router. Doing so overrides the path specified on the static configuration.

labels:
  - "traefik.http.services.myapi-svc.loadbalancer.apiportal.path=/foo/spec.json"
apiVersion: v1
kind: Service
metadata:
  name: myapi-svc
  annotations:
    traefik.ingress.kubernetes.io/service.apiportal.path: /foo/spec.json

spec:
  ports:
    - name: web
      port: 80
  selector:
    app: traefiklabs
    task: whoami
- "traefik.http.services.myapi-svc.loadbalancer.apiportal.path=/foo/spec.json"
"labels": {
    "traefik.http.services.myapi-svc.loadbalancer.apiportal.path": "/foo/spec.json"
}
labels:
  - "traefik.http.services.myapi-svc.loadbalancer.apiportal.path=/foo/spec.json"
http:
  services:
    myapi-svc:
      loadbalancer:
        apiportal:
          path: /foo/spec.json
[http.services.myapi-svc]
  [http.services.myapi-svc.loadbalancer.apiportal]
    path = "/foo/spec.json"

Enabling the API Portal

Where is the API Portal served?

Just like the Dashboard, the API Portal is served by Ingress proxies.

An internal service called apiportal@internal serves the API Portal, which means that it's possible to use all of Traefik's routing capabilities to build the most suitable configuration.

Example

This example shows how to enable the API Portal on port 8888 of the domain apiportal.domain.org.

To do so, create a router through the dynamic configuration that routes all requests coming through the internal entrypoint to the apiportal@internal service. In our case, the entrypoint internal is listening to the address :8888.

First, the applied static configuration should contain the following elements:

# [...]
entrypoints:
  # [...]
  internal:
    address: ":8888"

apiportal:
  path: spec.json
# [...]
[entryPoints]
  # [...]
  [entryPoints.internal]
    address = ":8888"

[apiportal]
  path = "spec.json"

Using the teectl apply command:

teectl apply --file=static.yaml
teectl apply --file=static.toml

Then, apply the following dynamic configuration:

labels:
  - "traefik.http.routers.apiportal.rule=Host(`apiportal.domain.org`)"
  - "traefik.http.routers.apiportal.service=apiportal@internal"
  - "traefik.http.routers.apiportal.entryPoints=internal"
apiVersion: traefik.containo.us/v1alpha1
kind: IngressRoute
metadata:
  name: apiportal
spec:
  entryPoints:
    - internal
  routes:
    - match: Host(`apiportal.domain.org`)
      kind: Rule
      services:
        - name: apiportal@internal
          kind: TraefikService
- "traefik.http.routers.apiportal.rule=Host(`apiportal.domain.org`)"
- "traefik.http.routers.apiportal.service=apiportal@internal"
- "traefik.http.routers.apiportal.entryPoints=internal"
"labels": {
    "traefik.http.routers.apiportal.rule": "Host(`apiportal.domain.org`)",
    "traefik.http.routers.apiportal.service": "apiportal@internal",
    "traefik.http.routers.apiportal.entryPoints": "internal"
}
labels:
  - "traefik.http.routers.apiportal.rule=Host(`apiportal.domain.org`)"
  - "traefik.http.routers.apiportal.service=apiportal@internal"
  - "traefik.http.routers.apiportal.entryPoints=internal"
http:
  routers:
    apiportal:
      rule: Host(`apiportal.domain.org`)
      service: apiportal@internal
      entryPoints:
        - internal
[http.routers.apiportal]
  rule = "Host(`apiportal.domain.org`)"
  service = "apiportal@internal"
  entryPoints = ["internal"]

Using the teectl apply command:

teectl apply --file=dynamic.yaml
teectl apply --file=dynamic.toml

At this point, the API Portal is ready to expose specifications from any service on your network, and the web app is available at apiportal.domain.org. There are some examples of valid JSON files on the OpenAPI specification repository.