Migrating data services from desktop operations to API-based web applications is not always a pleasant journey full of joy.
After the business requirements are laid out, such migration generally started from some prototypes or trials. For example, wrapping the functions of reading and processing data into backend-end RESTFul APIs, while transforming the desktop frontend into web-based applications. The development procedure moved quite faster and more smoothly, which provided many successful outputs and added confidence to the whole migration process.
The initial success caused nobody able to resist the temptation that directly applying these prototypes internally, even to external practical projects. Moreover, the success may continue in several small and simple applications. However, when business or application logic became more complicated, some problems began to pop up:
- Oversized Response – When a new requirement came in, the developers tend to adjust the current API and add more resources. Sooner or later, the developers often end up with bloated APIs that have resources users don’t need at all. In addition, as the API took on too many responsibilities, it is hard to change. The developers tend to have to comb through and write a lot of code to fix the API once they get feedback from users.
- Poor compatibility – For example, an API was originally designed for serving single-point resources. Suddenly, the API was requested to provide multiple-points resources. As a result, the response body was adjusted to use some collection data type instead of a single value. Just such a simple change would force the API consumers to adjust their applications accordingly. It is not a good user experience. In fact, such a case could be avoided through a good API design at the beginning.
- Efficiency degrading – As we mentioned before, the initial migration mainly modeled the behaviors of the corresponding desktop application. Under such a case, the API was implemented from the perspective of desktop applications, which could neglect the impacts of network data transfer speed, parallel or concurrent requests, the data structure, etc. As more and more web requests ask for access to the API, it was found that the API response time became longer – longer.
- Vague responsibilities – Without a detailed introduction to business or application logic, our optimistic programmers are likely to make judgments based on their own experience and put it into practice. As a result, everyone is not on the same page. Consequently, misunderstandings can lead to criticism, explanation, and frustration. It should not happen in a good teamwork atmosphere.
Now you may already get to know that such a migration method is a typically Code-Frist approach. Other approaches to API development include Design-First and API-First, both of which advocate for designing the API’s contract first before writing any code. They are relatively new approaches but are quickly catching on, especially with the use of API description formats.
There are many introductions and comparisons of the advantages or disadvantages of these API development approaches. Generally, most of them think the latter two approaches (API or Design First) much outperform the Code-First approach. If so, why is it still hard to completely follow them to migrate the services at present? This may be due to the following main reasons:
- In many cases, the business or application logic is not very clear or incomplete, and there is no way to set a complete API boundary. The code-first approach has to be utilized to test ideas first. The legend of crossing the river by feeling the stones
- Second, the organization does not elevate the APIs to the strategic position (i.e., the first-class citizens), which requires company-wide buy-in—a difficult thing to do as not everyone at the organization may understand the importance and business value of APIs. In many cases, they underestimate the status of APIs. But they also sometimes seriously overestimate the functionality of the APIs and think the APIs can do everything.
- In addition, many developers still adhere to desktop development thinking. They think the most important is only to make the API workable, which may ignore the goodness of good API design and the overall arrangement and utilization of other network resources at the early stage of API developments.
Although it is difficult to completely embrace an API Design First approach to migrate existing data services, we can still improve the Code First approach by following some ideas of Design First, and gradually transit from Code First to Design First in a long run. The key point is to make everything transparent.
- The API design and development should be product-oriented with a relatively complete context or boundaries, rather than simple ideas. Prototypes are only applied to test something and should be dropped eventually. They should not enter the practical applications.
- Adopt well-identified system architects and follow API and software design patterns, such as “Close to change, open to extending” and “Simple Responsibility Principle”, etc. These best practices could assure the whole development procedure is flexible and robust to a great extent. A Code First team can mitigate some of their risks by taking the developer experience seriously and ensuring that they are communicating between teams on what they’re building.
- Communication – Open discussions, open documents, causal or formal business or technical meetings to put everybody on the same page. Teams can find ways to include more than developers in the API design discussion.
We do not advocate for the Design-First approach for all API design and development for all cases. In fact, it depends on the real situation in an organization. Generally,
- When Delivery Speedy Matters, follow Code First Approach
- When Reuse and Extendibility Matters, apply Design First Approach
- Even if the current conditions in an organization do not allow for a full Design-First approach, it is necessary to ensure transparency of the project.
References