A supergraph solution to API orchestration and API composition challenges in the enterprise
Introduction & Recap
In the previous post in this series, we discussed the complexities of building and consuming APIs in enterprise data landscapes. These environments involve multiple data domains managed by different teams and numerous applications, leading to challenges due to constrained resources and conflicting goals.
The supergraph architecture framework, developed from our experience with federated data access and GraphQL federation, addresses these challenges by proposing strategies for constructing domain APIs (subgraphs) and data access API platforms (supergraphs).
Supergraph offers an operating model for team collaboration, acting as an API marketplace with API producers and consumers. It facilitates onboarding API producers, provides high-quality supergraph APIs for consumers, and emphasizes high-quality domain APIs with capabilities like filtering, sorting, and pagination.
The supergraph architecture lays the foundation for an operating model and system design that enable federated domain ownership. In enterprise data and API landscapes, this helps address challenges with federated data access and makes use cases like API orchestration and API composition easier to tackle.
API orchestration
What is API orchestration?
API orchestration involves managing multiple API calls and sequencing the requests/results to perform a complex task or workflow. In our reference context, an example of API orchestration might involve the following sequence:
- Restaurant API: Check menu and availability.
- Payment API: Process the payment.
- Delivery API: Schedule the delivery.
The orchestration layer handles these steps in sequence, ensuring each step completes successfully before moving to the next, and combines their responses into a single, cohesive outcome for the user.
Challenges with API orchestration
Orchestration is largely driven by API consumers based on end-user requirements. It is challenging as it typically spans multiple domains. Orchestration using traditional methods requires the same type of “glue” code/endpoints that aggregation does, only in this case, that glue is more complex as we can see from our example. Orchestration also usually involves multiple mutations, which further compounds the challenge.
Once again, we’ve run into the challenge of ownership: Should the consumer team own orchestration code? Does that team have the necessary skills to build performant orchestration endpoints?
Operational challenges like these must be addressed to build a powerful orchestration layer on top of domain APIs/data.
Solving API orchestration challenges
A good API platform must provide the semantics for the definition of complex workflows that may be interspersed with business logic functions. Similar to how the supergraph architecture allows for relationships between domain CRUD APIs and business logic, the response of API calls can be chained to functions that can act independently (or even call other CRUD APIs from the supergraph) or vice versa.
The substrate for this capability is made possible by the fact that every piece of data from any source (databases, APIs, etc.) and types in business logic code are standardized on the supergraph’s semantic layer. This enables a supergraph to provide the semantics for developers, including API consumers, to articulate a workflow using just declarative configuration. Integrations with third-party orchestration software like Camunda, Orkus, Temporal, etc., make this experience even more seamless for developers. Read more about API orchestration.
API composition
API composition, which can be thought of as a special case (or evolution) of API integration and orchestration, refers to the technique of combining multiple API responses into a single unified response with hierarchical information from the different calls. Put another way, composition fetches related data from disparate sources in a cohesive way – so, aggregation and orchestration for a read operation.
An example of API composition would be the following data for a user of our food delivery application:
- The user’s past orders.
- For each order, get some information about the restaurant where the order was placed.
- For each order, get payment information.
Getting this information involves making a request to three different domains in a sequence, at each step using the response from the previous, and finally combining the overall result set into a single hierarchical response that represents the relationship between the three entities (orders, restaurants, and payments).
Challenges with API composition and how to solve them
The supergraph architecture advocates for awareness of the underlying sources or domain and standardization across a heterogeneous set of sources. This allows a supergraph to provide a self-service model for API composition, without requiring any custom development, by making available the following two capabilities:
- Joins: Fetch data from A and related data from B.
- Nested filters: Fetch data from A, filtered by a property value of its related data B.
Read more about API composition.
Conclusion: A practitioner’s API platform design checklist
Building on the work from the previous post on the supergraph architecture, we can compile the following comprehensive checklist for any API platform (referred to as a supergraph) design that seeks to address the challenges of API integration, API aggregation, API composition, and API orchestration.
Measuring the effectiveness of a platform’s design to meet these criteria and the time/effort investment required to build these capabilities will provide any architect with a clear indication of the likely success of their platform initiative.