How to consume an external API with Laravel and Guzzle

Created January 9, 2021

Introduction

Laravel provides a wrapper for the Guzzle HTTP client. It allows you to quickly make HTTP requests to communicate with external APIs.

In this tutorial, you will learn how to use the Laravel HTTP Client, and consume an external API and store the data in a database.

Prerequisite

Before you start, you would need to have a Laravel application up and running.

I will be using a DigitalOcean Ubuntu Droplet for this demo. If you wish, you can use my affiliate code to get free $100 DigitalOcean credit to spin up your servers!

If you do not have that yet, you can follow the steps from this tutorial on how to do that:

Or you could use this awesome script to do the installation:

You would also need a QuizAPI account and an API Key.

QuizAPI is a simple REST API that is free for developers, and it provides a large number of different tech related quizzes and questions.

Creating a new table

Let's start by creating a new table called questions where we will store the output of the requests to the QuizAPI.

To create a new table, you could use the following artisan command:

php artisan make:migration create_questions_table

Output:

Created Migration: 2021_01_09_192430_create_questions_table

This would generate a new migration file for you at:

database/migrations/2021_01_09_192430_create_questions_table.php

The Laravel migrations will use the Schema facade to create and modify database tables and columns. To keep this simple we will only store the question itself and the available answers:

        Schema::create('tasks', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('question');
            $table->string('answer_a')->nullable();
            $table->string('answer_b')->nullable();
            $table->string('answer_c')->nullable();
            $table->string('answer_d')->nullable();
            $table->timestamps();
        });

After that, to run the migration, use this artisan command here:

php artisan migrate

Output:

Migrating: 2021_01_09_192430_create_questions_table
Migrated:  2021_01_09_192430_create_questions_table (0.02 seconds)

For more information about Laravel migrations, make sure to check out this post here.

Create the Model

Once we have our questions table ready, let's go ahead and add a Question model:

php artisan make:model Question

Output:

Model created successfully.

Create the Controller

php artisan make:controller QuestionController

Output:

Controller created successfully.

QuizAPI overview

The URL that we will be hitting on the QuizAPI is the following:

https://quizapi.io/api/v1/questions

There we need to pass a couple of parameters:

QuizAPI Key

For more information, make sure to check out the official QuizAPI documentation.

The output that you would get will look like this once you hit the API endpoint:

[
  {
    "id": 711,
    "question": "Are arrays supported in shell scripts?",
    "description": null,
    "answers": {
      "answer_a": "True",
      "answer_b": "False",
      "answer_c": "Yes but only under certain conditions",
      "answer_d": null,
      "answer_e": null,
      "answer_f": null
    },
    "multiple_correct_answers": "false",
    "correct_answers": {
      "answer_a_correct": "true",
      "answer_b_correct": "false",
      "answer_c_correct": "false",
      "answer_d_correct": "false",
      "answer_e_correct": "false",
      "answer_f_correct": "false"
    },
    "correct_answer": null,
    "explanation": null,
    "tip": null,
    "tags": [
      {
        "name": "BASH"
      },
      {
        "name": "Linux"
      }
    ],
    "category": "Linux",
    "difficulty": "Easy"
  }
]

For simplicity, we will want to grab only the question title and the answers from A to D.

Feel free to extend the method and the database table to grab all of the information.

Building the method

Once we have all that in place, we are ready to start building our method, which will be used to trigger the HTTP requests to the QuizAPI, get a question, and store it in our questions table.

With your favorite text editor, open the QuestionController.php file at:

app/Http/Controllers/QuestionController.php

First, make sure to include the Question model:

use App\Models\Question;

Note: if you are on Laravel 7, you need to use the following instead:

use App\Question;

After that, also include the HTTP client:

use Illuminate\Support\Facades\Http;

And then create a new public method called fetch, for example:

public function fetch()
{

}

Inside the fetch method, we can start adding our logic:

        $response = Http::get('https://quizapi.io/api/v1/questions', [
            'apiKey' => 'YOUR_API_KEY_HERE',
            'limit' => 10,
        ]);

With the Http client, we are making a GET request, and we are hitting the `/api/v1/questions1 endpoint. We are also passing 2 parameters: the API Key and the number of questions that we want to get.

Next, as the output would be in a JSON format we can add use the following to decode it:

$quizzes = json_decode($response->body());

Then once we have the response body, let's go ahead and use a foreach loop to store the response in our questions table:

        foreach($quizzes as $quiz){
                $question = new Question;
                $question->question = $quiz->question;
                $question->answer_a = $quiz['answers']->answer_a;
                $question->answer_b = $quiz['answers']->answer_b;
                $question->answer_c = $quiz'answers']->answer_c;
                $question->answer_d = $quiz['answers']->answer_d;
                $question->save();
        }
        return "DONE";

The whole fetch method will look like this:

    public function fetch()
    {
        $response = Http::get('https://quizapi.io/api/v1/questions', [
            'apiKey' => 'YOUR_API_KEY_HERE',
            'limit' => 10,
        ]);
        $quizzes = json_decode($response->body());
        foreach($quizzes as $quiz){
                $question = new Question;
                $question->question = $quiz->question;
                $question->answer_a = $quiz->answers->answer_a;
                $question->answer_b = $quiz->answers->answer_b;
                $question->answer_c = $quiz->answers->answer_c;
                $question->answer_d = $quiz->answers->answer_d;
                $question->save();
        }
        return "DONE";
    }

Now let's create a simple route which we will hit and trigger the fetch method.

Add the route

Let's now add the route! To do so, edit the web.php file at:

routes/web.php

And add the following GET route:

Route::get('/fetch', 'QuestionController@fetch');

Now, if you hit the route and then check your database, you will see 10 new questions in there:

Laravel Http client

Conclusion

This is pretty much it! Now you know how to use the Laravel HTTP Client to consume an external API and store the information in your database. For more information, make sure to check out the official documentation here.

The next step would be to create a view where you could render the data that you've stored in your questions table!

I hope that this helps!