When we talk about creating an architecture for the future, integrations should always be a part of the discussion.  These include importing, exporting, and direct integrations via an API.  It is limiting to assume that an application will always stand on its own.  Even a solution that proves better than all others is served by providing a way for other application data to be brought in.

Simple Integrations

Importing and exporting data are the easiest ways to integrate with other systems.  While there can be some challenging mappings, these often are little more than selecting the fields to work with and connecting in a one-to-one manner.  Even the most complicated import or export processes can off-load some of the most onerous work to a manual process.  This approach is not the most desirable, but it is an option.

A Common Language

When your architecture provides hooks for imports and exports you are making those mappings easier.  These in and out methods can combine to become a form of language your system speaks.  When someone wants to bring data into your system, they need to translate that data into your language or format.  Therefore, these features off-load work the implementation team would have to do to more directly integrate with other systems.  Better yet, a well-defined export and import process puts the onus on others to work with your system instead of creating customizations for other systems.

Full Integration

Importing and exporting data are ways to integrate with other systems.  However, those are limited integrations.  It is difficult (if not impossible) to do a realtime integration via these methods.  That is where an API can save the day.  The application programming interface is rarely easy and requires coding.  Nevertheless, it provides far more lee-way and control in system integrations.  There are some problems that can only be solved by creating this level of integration.

Rob Broadhead

Rob is a founder of, and frequent contributor to, Develpreneur. This includes the Building Better Developers podcast. He is also a lifetime learner as a developer, designer, and manager of software solutions. Rob is the founder of RB Consulting and has managed to author a book about his family experiences and a few about becoming a better developer. In his free time, he stays busy raising five children (although they have grown into adults). When he has a chance to breathe, he is on the ice playing hockey to relax or working on his ballroom dance skills.

Leave a Reply