Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Table of Contents
stylenone

Overview

The connection routing component allows CDCM to connect to external systems using different authentication mechanisms. The supported authentication mechanisms are:

  • OAuth 2.0

  • OAuth 1.0a

  • Fixed headers (e.g. Basic Auth)

  • Forwarded headers

Description

CDCM often interacts with various external systems in an infrastructure. For example, a server-side guard JavaScript may call an external system while verifying that a concept may be saved, or CDCMs creates a UI for the selection of a work product reference by accessing the REST API of Storage Location. These calls to external systems may require different forms of authentication. It is not safe to assume that all external systems may be authenticated using the authenticated users bear token obtained from the customer’s identity provider (IDP hereafter); some system may not be directly integrated with the customers IDP or may not support REST calls using the IDP’s bearer token (e.g. IBM ELM). Also for some external systems it may be desirable to authenticate with a Service Principal (aka technical user).

The Connection routing Routing feature configures the authentication calls to all external systems. For each outbound call to an external system CDCM consults the connection-routing.ymlfile to determine how this call should be authenticated.

...

By default all outgoing calls to external systems are authenticated using the logged in user’s bear token obtained from the IDP.

Usage

Connection routing let’s you define the type of authentication mechanism, based on a set of URIs with ant paths. An ant path supports optional wildcards. Connection routing will choose the authentication mechanism based on matching ant paths. The connection routing configuration file connection-routing.yml let’s you define a list of external server connections

...

and a list of connections, that define the authentication mechanism used, based on the common key (in this example elm):

Code Block
languageyaml
  elm:
    connection-type: OAUTH10A
    consumer-key: my-consumer-key
    consumer-secret: my-consumer-secret
    root-services: https://example.com/oauth10a/rootservices
    service-principal-enabled: false

If an outgoing Http request matches https://my.elm.host1/** connection routing will use OAuth 1.0a for authentication with the external server.

Supported

...

Authentication Mechanisms

The supported authentication mechanism are OAuth 2.0, OAuth1.0a, Fixed Headers and Bearer Token Forward. They operate in different ways and require different connections settings in the connection-routing.yml file.

OAuth 2.0 using a Authorization Code

This uses the standard OAuth 2.0 Flow using the Authorization Grant Authorization Code as described in RFC6749. The user authenticates using the configured IDP and connection routing will use the resulting token for outgoing connections to the external servers.

OAuth 2.0 using Client Credentials

This uses the the standard OAuth 2.0 Flow using the Authorization Grant Client Credentials as described in RFC6749. This is a “technical-user” authentication flow as connection routing only requires the client-id and the client-secret to authenticate with the external servers. No additional user authentication is required.

OAuth 1.0a Standard Flow

This uses the standard OAuth 1.0a Flow as described in the OAuth 1.0a specification. The user authenticates using the configured OAuth 1.0a server and connection routing will use the resulting token for outgoing connections to the external servers.

OAuth 1.0a Technical User Flow

OAuth 1.0a has no notion of a technical user authentication flow. To implement a technical user flow on top of OAuth 1.0a IBM ELM among other systems allow authentication using the consumer-secret and the consumer-key. This is comparable to OAuth 2.0 using the Authorization Grant Authorization Code.

Fixed Header

Fixed header authentication flow takes a set of headers and values and adds them to outgoing requests. This can be used to authenticate via Http Basic Auth by sending an Authorization header with Base64 encoded credentials. This is not limited to the Authorization header. Arbitrary headers and values and therefore even cookies can be set using this authentication flow.

Bearer Token Forward

This authentication flow uses the bearer token in the Authorization header in the incoming request for the request to the external server. This could e.g. be a JWT or an OAuth2.0 token.

Connections via the Gateway Proxy

Connections to external servers can be established via the Gateway Proxy. Simply provide the Gateway URI and the external URIs, that should be proxied in connection-routing.yml.

If the Proxy itself requires authentication, it can be referenced in the Connections Configuration and the Connection Routing Configuration in the same way that authentication to external servers is configured.

See Example Configuration

See Reference

Configuration

Connection routing is configured using the file connection-routing.yml. This file has to be put in the application’s working directory.

Kubernetes

The connection-routing.yml can be placed into a kubernetes secret, and mounted into the CDCM container. The name of this secret is "cdcm-connection-routing", the value of is the connection-routing.yml file.

...

There are two ways to do this:

  1. The simplest way to achieve this is to use kubectl:Use kubectl

Code Block
kubectl create secret generic cdcm-connection-routing --from-file=connection-routing.yml=./connection-routing.yml -n cdcm
  1. f the secret has to be created manually or from a vault, you can use this template:

Code Block
apiVersion: v1
data:
  connection-routing.yml: <base64 encoded content of the file connection-routing.yml>
kind: Secret
metadata:
  name: cdcm-connection-routing
  namespace: cdcm
type: Opaque

...

Code Block
kubectl apply -f connection-routing.yml -n <namespace>

Example connection-routing.yml

This examples defines various external servers and their required authentication mechanisms and a Gateway Proxy configuration. Connections to the Gateway Proxy in this example are authenticated using OAuth 2.0.

Code Block
gateway-proxy:
    uri: http://gateway-proxy.host/proxy/stream
    root-uris:
        - https://elmdemo.smartfacts.com:9443/**

connection-routing:
  - cdcm-connection-id: proxy-oauth2
    methods: ALL
    root-uris:
      - http://gateway-proxy.host/proxy/**
  -
    cdcm-connection-id: forward-bearer
    methods: ALL
    root-uris:
      - https://host1/**
      - https://host2/data/**
  -
    cdcm-connection-id: oauth20
    methods: GET,POST
    root-uris:
      - https://host3:4552/v1.0/**

  -
    cdcm-connection-id: oauth10a
    methods: ALL
    root-uris:
      - https://host4/oauth10a/**

  -
    cdcm-connection-id: fixed-headers
    methods: ALL
    root-uris:
      - https://host5:8080/**

connections:
  forward-bearer:
    connection-type: BEARER_TOKEN_FORWARD
  proxy-oauth20:
    connection-type: OAUTH20
    client-id: <client-id>
    client-secret: <client-secret>
    user-info-uri: <user-info-uri>
    scopes: openid, profile, email, Sites.Read.All
    authorization-uri: <authorization-uri>
    token-uri: <token-uri>
  oauth20:
    connection-type: OAUTH20
    client-id: <client-id>
    client-secret: <client-secret>
    user-info-uri: <user-info-uri>
    scopes: openid, profile, email, Sites.Read.All
    authorization-uri: <authorization-uri>
    token-uri: <token-uri>
  oauth10a:
    connection-type: OAUTH10A
    consumer-key: <key>
    consumer-secret: <secret>
    root-services: <root-services-uri>
    service-principal-enabled: false
  fixed-headers:
    connection-type: FIXED_HEADERS
    headers:
      Authorization: <auth-header-value>
      X-Custom-Auth-Header: <custom-auth-header-value>

Reference

Gateway Proxy

Key

Description

uri

The URI of the gateway proxy stream endpoint.

E.g. http://gateway-proxy.host/proxy/stream

root-uris

A list of URIs that can use ant path notation as described in the Spring Framework documentation.
Connections to URIs matching one of the root-uriswill be established via the Gateway Proxy

Configuration Routing Table

Key

Description

cdcm-connection-id

The shared key that links an entry in the connection-routing table to an entry in the connections table

methods

A comma-separated set of Http method names for which connection routing should match the root-uris.

Possible values are GET, POST, PUT, DELETE, OPTIONS, PATCH and ALL

root-uris

A list of URIs that can use ant path notation as described in the Spring Framework documentation.

Connections Table

Common entries

Key

Descripton

connection-type

The type of the authentication mechanism to use for this connection.

Possible values are OAUTH20, OAUTH10A, FIXED_HEADERS and BEARER_TOKEN_FORWARD

OAuth 2.0

Key

Description

client-id

The client id as given in the OAuth 2.0 IDP.

client-secret

The client secret as given by the OAuth 2.0 IDP.

user-info-uri

The user info uri of the OAuth 2.0 IDP

authorization-uri

The authorization uri of the OAuth 2.0 IDP

token-uri

The token uri of the OAuth 2.0 IDP

scopes

The scopes for this client as configured in the OAuth2.0 IDP

OAuth 1.0a

Key

Value

consumer-key

The consumer key as given by the OAuth 1.0a Server

consumer-secret

The consumer secret as given by the OAuth 1.0a Server

root-services

The root-services uri of the OAuth 1.0a Server

service-principal-enabled

Controls if connection routing uses a technical user or initiates a normal authentication flow.
Possible values are: true and false
If set to true a technical user will be used, if set to false the normal flow is initiated.

Fixed Headers

Key

Value

headers

A map of header names to header values. Connection routing will add all headers in the outgoing requests to the corresponding external servers.

Bearer Token Forward

This authentication mechanism has no additional configuration