In this Code Pattern, we will learn how to build a service in IBM integration bus which can be exposed as a proxy to achieve digest authentication. We will learn how the digest authentication mechanism works in background and what logic needs to be built for a platform which doesn’t support digest authentication of its own. We will also learn how to expose the IIB service on a IBM cloud Kubernetes cluster and consume it via a sample client. Entire façade application and client application is built on IBM integration bus and deployed on Kubernetes node using a Docker image.
When the reader has completed this code pattern, they will understand how to:
- Create a message flow and build logic for digest Authentication.
- Deploy and test application locally.
- Deploy and test application expose the IIB service to Kubernetes.
- User sends request to IIB application on cloud.
- Application sends request to server seeking authorisation.
- Request is rejected by the server asking for an authorisation and server responds with the details to create authorisation.
- Application builds authorisation logic.
- Application sends another request to server seeking authorisation.
- Request is successfully authorised.
- Application saves authorisation header or cookies in cache for next http request and respond with success.
- User sends next request to IIB application on cloud.
- Application synchronise request and cache before seeking server authorisation.
- Request sent to server, server authorises user and success response sent back to user.
- IBM Cloud: IBM Cloud is a suite of cloud computing services from IBM that offers both platform as a service (PaaS) and infrastructure as a service (IaaS). With IBM Cloud IaaS, organizations can deploy and access virtualized IT resources.
- Docker: Docker provides container software that is ideal for developers and teams looking to get started and experimenting with container-based applications.
- Kubernetes: Kubernetes is an open-source container-orchestration system for automating deployment, scaling and management of containerized applications.
- SoapUI: SoapUI is an open-source web service testing application for service-oriented architectures and representational state transfers.
- IBM Integration bus: IIB allows business information to flow between disparate applications across multiple hardware and software platforms. Rules can be applied to the data flowing through the message broker to route and transform the information IIB provides access to various inbuilt nodes which provide ready to use capability.
- Digest Authentication: Digest access authentication is one of the agreed-upon methods a web server can use to negotiate credentials, such as username or password, with a user's web browser. This can be used to confirm the identity of a user before sending sensitive information, such as online banking transaction history.
-
Access to IBM cloud tools: To interact with IBM cloud, IBM Cloud CLI will need to be installed beforehand. Please follow steps in below link to setup your IBM cloud tools. https://console.bluemix.net/docs/containers/cs_cli_install.html#cs_cli_install
-
IBM Integration Bus toolkit: In this code pattern we will use IIB toolkit version 10.0.0.9 to demo the logic and implementation. This logic can be implemented by any development tool available to you.
- Create Service
- Deploy service locally and test
- Create cluster and deploy on IBM cloud
- Test API on Cloud
This is the main flow where request is received at Http Input node and once the transaction is complete it responds by the HTTP reply node. All the steps shown in the below image are executed since user submits request till it receives a response i.e. all the logic is implemented in a single transaction.
Below are brief details on the functionality of each node. These functionalities can be replicated by similar tools/nodes available on other development platforms.
HTTP Input
: This node is the start of a transaction and accepts the request to be processed. In HTTP node property we need to configure the URI which will be exposed as an API.
SetEndpointAndPayload
: This is a node to store server URLs, user name and password to access digest authentication server. These configurations can be done in different ways on different development tools.
DigestAuthentication subflow
: This is the component where the core logic is built. Details of its implementation will be in the next section.
SetdigestHdrORCookies
: This node is used to set authorization in HTTP request header. For a successful authentication, the http request header must have either a valid authorisation header or cookies information.
Set Payload
: This node simply outputs the response which server has sent after successful authentication.
This is the core component which builds the authorization header or cookies. This is a re-usable component for iib tool and can be integrated with different flows in an application.
SetHTTPDestination
: This node overrides and set the request URL and the request method to be set on HTTP Request node.
ComputeResponse
: First time when a request is sent to the digest authentication enabled server, it will always fail. The reason for failure is that the request sent to the server is plain http but for successful authentication, it needs to be with an authorization header or cookies. There are few steps in this node to build authorization logic.
- Capturing response data: When server rejects access, it sends back the information to the client asking for authorisation header along with its server information in HTTP response header . In WWW-Authenticate element of header response, there will be information about nonce, realm, qop which will be used to create authorisation header.
- Calculating hash: Once the required values are captured. Following hash values needs to be created using the md5 algorithm.
- Creating a response seed: Response seed is the combination of generated md5 hash, nonce, ncvalue, cnonce and qop. This response seed is again encrypted with the md5 algorithm to generate the final response seed which will be set in the authorisation header.
- Creating authorization Header: In this step the all the parameters and their values are set and this header is sent to server for authorisation.
SetHeader
: This node is used to save the authorisation header in the http request header before sending request to the server for authentication.
ComputeCookie
: After sending the request with authorisation header, the response from the server should be a success. With this success response the server sends the cookie information which can be used to authenticate without calculating the authorisation header every time. One can either store cookies or the authorisation header to successfully authenticate the request next time.
For demo purpose, we will create 2 services. One with authorisation logic and another as a sample client to access the first service.
DigestAuthentication
: This service contains the logic of implementing digest authorisation. This service will be exposed on uri /digesthttpapi for external clients to access.
MyHttpApiClient
: This service is a simple client without any logic and it will be consuming the first service. This client service will be exposed on the uri /myhttpapiclient
For simplicity, one can package the service and the client service in a single bar or in multiple bar files. DigestAuthentication is packaged in DigestAuthenticationDemo.bar
.
Test locally: For tests, we have used a sample api using digest authentication and is available on internet for testing. Below are the details which can also be found in code.
url: http://httpbin.org/digest-auth/auth/user/passwd
username: user
Password: passwd
Below is the result on testing on local environment.
IBM integration bus provide a very useful functionality called flow exerciser which captures the path which the transaction as taken for each request.
First request: On the first transaction, we can see that the transaction went through digest authentication subflow to do all the logic for authentication.
Next request: On the second or next requests, flow has skipped the digest authentication subflow and just reused the authorization header from cache for better performance. Cookies/authorization header can expired depending on security implementation hence one need to recall digest authentication subflow to re-create headers/cookies.
Steps:
-
Login to your IBM cloud account: https://www.ibm.com/cloud/
-
Create cluster: Under containers section, go to clusters and click on create cluster.
- Create private repository: It takes some time for cluster to be created hence in the meantime please create your private repository. This private repository image is a replica of public image of IBM integration bus available on docker hub.
ibmcloud login --sso -a https://api.eu-gb.bluemix.net
docker pull ibmcom/iib
ibmcloud cr namespace-add iib10-ns
docker tag ibmcom/iib registry.eu-gb.bluemix.net/iib10-ns/iib10repo:iib10latest
docker push registry.eu-gb.bluemix.net/iib10-ns/iib10repo:iib10latest
- Once the cluster is in normal state then issue below commands to access your cluster
ibmcloud login --sso -a https://api.eu-gb.bluemix.net
ibmcloud cs region-set uk-south
ibmcloud cs cluster-config mycluster
export KUBECONFIG=%HOMEPATH%\.bluemix\plugins\container-service\clusters\mycluster\kube-config-mil01-mycluster.yml
kubectl get nodes
- Once the above commands as executed successfully then we need to deploy our IIB image on the kubernetes cluster and expose the webadmin and http port. This can be done with below commands
kubectl run ku-iib --image=registry.eu-gb.bluemix.net/iib10-ns/iib10repo:iib10latest --env="LICENSE=accept" --env="NODENAME=IIB10NODE"
kubectl expose deployment/ku-iib --type=NodePort --port=4414 --target-port=4414 --name=iib10node-svc-4414
kubectl expose deployment/ku-iib --type=NodePort --port=7800 --target-port=7800 --name=iib10node-http-7800
Now one can see the information on kubernetes dashborad as below
- To access your IIB webadmin we will be public ip. Please run below command to get the info.
bx cs workers mycluster
- Under services link you can check port on which the IIB webadmin and http port are mapped.
- Deploy the bar on IBM cloud : Access the IIB web admin on from the IP and port from above steps and then deploy the DigestAuthenticationDemo.bar
- Create a sample API on App Connect on IBM cloud. In below screenshot, you can see that we have used the /digesthttpapi url which we deployed on the IBM cloud. Please watch the video for details.
- Test the client application using browser interface provided in App Connect and it should produce below result.
- Test the client application using SOAP UI. It should produce same result as above. Please ensure you add X-IBM-Client-Id value in the header.
This code pattern is licensed under the Apache Software License, Version 2. Separate third party code objects invoked within this code pattern are licensed by their respective providers pursuant to their own separate licenses. Contributions are subject to the Developer Certificate of Origin, Version 1.1 (DCO) and the Apache Software License, Version 2.