Why Build A Chain.io Adapter
The Chain.io network functions by linking together adapters written by different companies to build flows that exchange information between software packages that are not directly compatible.
For example, you might be a developer for the world's greatest CO2 Emissions calculator. Your system can take shipment details from a shipper via your API, and as the shipment moves through its lifecycle, you can regularly update the shipper with the actual carbon usage across all of the various shipment legs based on the calculations you make within your software.
You've carefully crafted an API endpoint that allows your customers to post all of their shipment details, and you provide the option to subscribe to a webhook which provides updated emissions data at various points in the shipment's lifecycle.
You have a problem though. Many of your customers use LegacyCo's transportation management system (we'll call it LegacyTMS). LegacyTMS does not have the ability to connect to your API, and your customers don't have the internal resources to build a middleware solution to take data extracts from LegacyTMS and turn them into your API call.
Returning data is also difficult. LegacyTMS can't subscribe to your webhook. In fact, the only way to get emissions data into LegacyTMS is to put a CSV file on a unique SFTP site for each customer.
Instead of coaching each of your customers through building a custom integration or doing a ton of professional services work, you decide to let Chain.io do the heavy lifting. You'll write an adapter that listens for calls from Chain.io's Shipment Registration webhook and converts them into your API call, and you'll write a second adapter that takes your webhooks' output and makes a call to Chain.io's Emissions Update API.
Why is this better than just building connectivity to LegacyTMS directly?
- You don't have to know how LegacyTMS works. Chain.io's simple interfaces are modern and readable. You make API calls and listen to webhooks in modern JSON formats, and Chain.io handles the complexities of integrating with non-API based systems. If LegacyTMS' CSV implementation is non-standard and needs pipe characters instead of commas, Chain.io will handle it, and you won't need to know the different.
- You instantly support multiple systems. If your next customer is on another TMS on the Chain.io network (we'll call it NewTMS), you won't need to know the difference. You'll make the same calls to Chain.io and we'll handle the differences between the LegacyTMS and NewTMS implementations.
- You don't have to build complex logging, instrumentation, retries, visibility, and all of the other things that make middleware hard. What if LegacyTMS is down for a day, or a customer changes their password and forgets to tell you? Chain.io provides dashboards, automatic alerting and visibility directly to your customers so they don't need to bother you or your support team to maintain their own connections.
Updated about 1 year ago