tlx3/laravel-jwt-starter

Boilerplate for using your own API based JWT authentication on Laravel applications

1.1 2017-08-09 16:59 UTC

This package is not auto-updated.

Last update: 2024-12-22 04:53:24 UTC


README

In a microservice oriented architecture, a client component will communicate with set of microservices where interactions need to be authenticated and authorized. Usually, the users of these microservices will authenticate using the same API in this system. Often, the creation of a login page and authentication middleware will need to be replicated in each of these microservices.

Given a Laravel application, this package will create a generic login with relevant jwt middleware to authenticate the user into your authentication API. This Laravel boilerplate can be added to an existing or new project with minimal configuration. It publishes the respective views, css, and middleware into your project. These can be configured to your needs.

Installation

To install this package you will need:

  • Laravel 5
  • PHP 5.4 +

Run composer require tlx3/laravel-jwt-starter Register this package's Service Provider by adding it to the providers section of your config/app.php file:

   'providers' => [
       // ... other providers omitted
       TLX3\LaravelJWTStarter\LaravelJWTStarterServiceProvider::class,
   ],

Then to publish the necessary middleware, views, and css:

php artisan vendor:publish
or
php artisan vendor:publish  --provider="TLX3\LaravelJWTStarter\LaravelJWTStarterServiceProvider"

Also, you will need to install these packages

  • Forms & HTML - laravelcollective/html
    • composer require "laravelcollective/html"
    • Update service providers and aliases in config/app.php file
    • 'providers' => [
           // ...
           Collective\Html\HtmlServiceProvider::class,
           // ...
       ],
       ...
       'aliases' => [
           // ...
           'Form' => Collective\Html\FormFacade::class,
           'Html' => Collective\Html\HtmlFacade::class,
           // ...
       ],
  • PHP-JWT - firebase/php-jwt
    • composer require firebase/php-jwt
  • Guzzle - guzzlehttp/guzzle
    • composer require guzzlehttp/guzzle

This project integrates these three packages for a form builder, token decoder, and HTTP Client. These packages have numerous features that will help with development over time by reducing overhead.

1) Environment variables

Set your authentication API endpoint, JWT secret, and successful login response code in your .env file, you can add/remove to fit your requirements in auth:

AUTH_URL=
JWT_SECRET=
STATUS_CODE=

2) Middleware

Update $routeMiddleware in app/Http/Middleware/kernel.php file with the additional middleware added. You should modify these along with the login.blade.php view to fit your application logic:

    protected $routeMiddleware = [
        // ... other middleware omitted
        'checkToken' => \App\Http\Middleware\CheckToken::class,
        'notLoggedIn' => \App\Http\Middleware\NotLoggedIn::class,
        'logout' => \App\Http\Middleware\Logout::class,
        'login' => \App\Http\Middleware\Login::class,
    ];

3) Routes

Update routes/web.php with these routes. You can modify and change these routes to fit your project, I've added a filler home page as a landing page after logging in:

    Route::get('login', function () {
        return view('login');
    })->middleware('notLoggedIn');

    Route::post('authenticate', function () {
        return View::make('home');
    })->middleware('login');

    // routes that require user to have been authenticated
    Route::group(['middleware' => 'checkToken'], function () {
        Route::get('home', function () {
            return View::make('home');
        });

        Route::get('logout', function () {
            return View::make('login');
        })->middleware('logout');
    });

4) Usage

After installation you can now go to /login and attempt to login and access protected routes as set prior. Alongside the routes, you will probably want to modify both views/login.blade.php and app/Http/Middleware/Login.php to fit your application logic. The authentication inputs are set here along with the .env variables names that you can customize. You should also modify Login and CheckToken middleware to decode the token for neccessary payload items if needed.

License

MIT