Goibibo

Goibibo


Explore Goibibo’s Public API with JavaScript

Goibibo is a popular online travel booking platform that provides various services like hotel bookings, flight tickets, and bus rentals. Goibibo also provides a public API that developers can leverage to build their travel-related applications.

In this tutorial, we will explore Goibibo’s public API and show you how to make API requests using JavaScript. We will use AJAX (Asynchronous JavaScript and XML) to send HTTP requests and update the web page in real-time with API data.

Getting Started

To get started, you need an API key. If you don’t have one, you can get it from Goibibo’s API developer portal at https://developer.goibibo.com/register. Once you have an API key, you’re ready to make API requests.

Making API Requests

We will use the jQuery AJAX library to make API requests and handle the response. Here’s an example of how to make a request to Goibibo’s flights API to get the list of flights from Bangalore to Delhi.

$.ajax({
    url: 'https://developer.goibibo.com/api/search/',
    type: 'POST',
    data: {
        app_id: 'your_app_id',
        app_key: 'your_app_key',
        format: 'json',
        source: 'BLR',
        destination: 'DEL',
        dateofdeparture: '20211120',
        seatingclass: 'E',
        adults: '1',
        children: '0',
        infants: '0',
        counter: '100',
    },
    success: function (data) {
        console.log(data);
    },
});

Let’s break down this code block.

  • The url parameter is the endpoint of the API we’re requesting.
  • The type parameter is the HTTP method to use for the request. In this case, we’re using POST.
  • The data parameter is the data we’re sending to the server in the request body.
  • The success function is called when the API responds with data.

The data object contains the parameters that the API expects. In this case, we’re requesting flights from Bangalore to Delhi on 20th November 2021 with seating class E.

Handling API Responses

When the Goibibo API responds, it will return a JSON structured response. Here’s an example of the JSON response that we’ll get from our previous API request:

{
    "data": [
        {
            "origin": "BLR",
            "destination": "DEL",
            "airline": "6E",
            "flightno": "191",
            "departdate": "2021-11-20",
            "arrivedate": "2021-11-20",
            "arrivetime": "21:40:00",
            "seatingclass": "E",
            "currency": "INR",
            "totalfare": 7897,
            "adultbasefare": 6600,
            "adultsurcharges": 1290,
            "adulttax": 1007,
            "childfare": 0,
            "childbasefare": 0,
            "childsurcharges": 0,
            "childtax": 0,
            "infantfare": 0,
            "infantbasefare": 0,
            "infantsurcharges": 0,
            "infanttax": 0,
            "commercials": [
                {
                    "farebasis": "PSAKW",
                    "faretype": "P",
                    "index": "0",
                    "farebreakdown": [
                        {
                            "faretype": "Basic",
                            "amount": 6600
                        },
                        {
                            "faretype": "Surcharge",
                            "amount": 1290
                        },
                        {
                            "faretype": "Tax",
                            "amount": 1007
                        }
                    ]
                }
            ]
        }
    ]
}

We can use the success function to handle this response and update our webpage. For example, we can create a loop to iterate over all the flights and display them on the webpage.

success: function(response) {
  var flights = response.data;

  for (var i=0; i<flights.length; i++) {
    var flight = flights[i];
    var flightInfo = `
      <div class="flight">
        <h3>${flight.airline} ${flight.flightno}</h3>
        <p>${flight.origin} to ${flight.destination}</p>
        <ul>
          <li>Departure: ${flight.departdate} ${flight.departtime}</li>
          <li>Arrival: ${flight.arrivedate} ${flight.arrivetime}</li>
          <li>Total fare: ${flight.totalfare} ${flight.currency}</li>
        </ul>
      </div>
    `;
    $('#flights').append(flightInfo);
  }
}

This code block creates a div element for each flight and adds it to the #flights element on the webpage.

Conclusion

You’ve learned how to make API requests to Goibibo’s public API and handle the JSON responses using JavaScript. Now, you can explore the many endpoints available through Goibibo’s API developer portal and integrate them into your own travel-related applications.