API Management -- conceptual architecture for Retail industry
technical architecture api management apis retail logistics design patternAPI Management within Retail business
An API -Application Programming Interface- driven economy forms the backbone of the ongoing digital revolution. In simple terms, API allows a business to offer consistent, secure, and reusable business functions to the market. This approach is critical to enable a consistent customer experience when engaging with the business, irrespective of the channel used.
Ability to offer the same business service on a different plan is the added benefit of API driven economy. E.g. being able to offer the same service as part of Gold, Silver, or Bronze plan.
Many of the retail companies have started investigating API platforms as part of their digital strategy. A decent sized retail company would have hundreds of stores if not thousands. As soon as we get to these number in a distributed and remote deployment pattern, IoT style of integration patterns should be considered for management and deployment of edge services (functional devices and services deployed in individual stores).
In a previous article, I have outlined how the retail IT services scenario is lot similar to IoT style of design pattern.
Logistics vertical has been dealing with these IoT style issues for a long time. There are many learning from logistics vertical that should go into an architecture for digital strategy of a retail industry.
Overview of API Management
I am using APIMan.io as a API management solution for the purpose of this article. In terms of functionality, API management as a solution can be broken down into two components:
- API Manager
- API Gateway
API Manager
Provides centralised management of APIs. API Manager is the brains of the API management platform. Using API Manager end-user can perform following functions:
- Manage policies like throttling, centralised security, mutual authentication, etc.
- Manage plans by combining multiple policies if required.
- Create, implement, and define APIs
- Track and configure metrics for APIs
- Publishing APIs in the Gateway
- Creating API consumers
- Creating API contracts for consumers
- Registering consumers in the Gateway
All functions provided by API Manager are exposed as REST API. API Manager also provides a simple User Interface UI to facilitate user interaction.
API Gateway
API Gateway is a lightweight embeddable artifact, which is responsible for applying the policies configured in the API Manager, to control all the requests to managed APIs. It can deployed independently of API Manager. API Gateway exposes following functions using a simple REST API:
- Publish and API
- Register a Client App (with contracts)
- Retire an API
- Unregister a Client App
The beauty of this lightweight API gateway is that, it can be pre-configured and deployed into simple cheap devices like a Raspberry Pi. (At the time of writing this article, the total cost of each gateway would be less that $100). Then its just a matter of shipping these Gateways out to the stores. These pre-configured Gateways can be managed centrally using the API Manager. They can also be secured by using mutual authentication between API Manager and API Gateway.
Multiple units could be shipped to local store(s) if any failover strategies are to be employed.
API Gateway can be deployed in traditional model (physical, virtual, cloud, etc). Rasberry Pi is suggested as an option as it fits the IoT pattern of replace the faulty device with a new one as apposed to fixing the faulty device.
Conceptual architecture
The diagram below shows the system architecture at a conceptual level. This architecture is derived by leveraging the IoT patterns commonly used by logistics vertical and combining it with the distributed deployment of capability of APIMan.
The API Gateways deployed at local stores may not always have a live connection to the API Manager or the central IT. As such the local API Gateways would aggregate the information and requests received from local devices, services and applications and if required forward it to the central IT services using a simple store and forward design pattern.
Benefits of this strategy
- The core processing and management is centralised.
- API Gateways have a large footprint. And this strategy commoditises API Gateways.
- Core IT services can be provided to any pop up stores during an event by simply deploying the API Gateway at the pop up store during the event.
- Similar process would work for temporary shops out of the back of a van or mobile trucks (or delivery stores).
- Ability to deploy IoT devices and functions at the edge (local stores) and update the appropriate API Gateways as required.
- Enable the delivery trucks to update the store inventory as soon as they enter a desired zone (loading bay) via the store’s API Gateway.