Updating the Phone Book Application

Let’s enhance the phone book application to work as a web service.

This time, the phone book application is going to work as a web service. The two main tasks that need to be performed are defining the API along with the endpoints and implementing the API. A third task that needs to be determined concerns data exchange between the application server and its clients. There exist four main approaches regarding data exchange:

  • Using plain text

  • Using HTML

  • Using JSON

  • Using a hybrid approach that combines plain text and JSON data

HTML might not be the best option for a service because we need to separate the data from the HTML tags and parse the data, we are going to use the first approach. Therefore, the service is going to work with plaintext data. We begin by defining the API that supports the operation of the phone book application.

Defining the API

The API has support for the following URLs:

  • /list: This lists all available entries.

  • /insert/name/surname/telephone/: This inserts a new entry. Later on, we are going to see how to extract the desired information from a URL that contains user data.

  • /delete/telephone/: This deletes an entry based on the value of telephone.

  • /search/telephone/: This searches for an entry based on the value of telephone.

  • /status: This is an extra URL that returns the number of entries in the phone book.

Note: The list of endpoints does not follow standard REST conventions.

This time we not using the default Go router, which means that we define and configure our own http.NewServeMux() variable. This changes the way we provide handler functions: a handler function with the func(http.ResponseWriter, *http. Request) signature has to be converted into an http.HandlerFunc type and be used by the ServeMux type and its own Handle() method. Therefore, when using a different ServeMux than the default one, we should do that conversion explicitly by calling http.HandlerFunc(), which makes the http.HandlerFunc type act as an adapter that allows the use of ordinary functions because HTTP handlers provided that they have the required signature. This is not a problem when using the default Go router (DefaultServeMux) because the http.HandleFunc() function does that conversion automatically and internally.

Note: To make things clearer, the http.HandlerFunc type has support for a method named HandlerFunc()—both the type and method are defined in the http package. The similarly named the http.HandleFunc() function (without an r) is used with the default Go router.

As an example, for the /time endpoint and the timeHandler() handler function, we should call mux.Handle() as mux.Handle("/time", http.HandlerFunc(timeHandler)). If we were using http.HandleFunc() and as a consequence DefaultServeMux, then we should have called http.HandleFunc("/time", timeHandler) instead.

Implementing the handlers

The new version of the phone book is going to be created on a dedicated GitHub repository for storing and sharing it. After creating the repository, we need to do the following:

Get hands-on with 1300+ tech skills courses.