Skip to content

A minimal REST API boilerplate containing JWT for authentication, inspired by Laravel Breeze 🚀

Notifications You must be signed in to change notification settings

thenasty1337/laravel-jwt-rest-api

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GitHub README banner_ JWT Laravel JWT REST API

License: MIT

This repository contains a Laravel 10 with JWT authentication boilerplate using the tymon/jwt-auth package, inspired by the Laravel Breeze package (API stack).

Next.js frontend

We created a dedicated frontend using Next.js, Tailwind CSS and NextAuth. You can find the repository here.

Features

  • JWT authentication (login, register, password reset, email verification)
  • Profile updating
  • Password changing
  • Tests (using Pest)
  • Laravel Telescope (disabled by default)

Installation

Note: the application does not have a package.json since this project purely a REST API that will not use any JavaScript or asset builders such as Vite.

  1. cp .env.example .env
  2. composer install
  3. php artisan jwt:secret (generate a secret key that will be used to sign your tokens)
  4. php artisan migrate:fresh --seed

User authentication

In order to list all the users in the database, you can run php artisan user:list. By default, a user with the '[email protected]' email will be seeded.

In order to authenticate, you have to log in using valid credentials. User data and an access token will be returned. You can use this access token to do subsequent requests to the API.

The access token has a TTL of 1 hour until it expires. The access token should be refreshed within this time window to avoid becoming unauthenticated.

The access token can be refreshed for two weeks. After that, the user has to log in again.

Telescope

This boilerplate comes with Laravel Telescope installed. You can access the Telescope dashboard at the /telescope URL (prefixed with your local URL).

Larastan

This project uses Larastan. You can run the static analysis using ./vendor/bin/phpstan analyse. Important note: a resource class requires a @mixin annotation so that PHPStan knows what model the resource is using.

Husky

This project uses Husky to run Larastan, Pint and Pest before pushing to the repository.

Testing

This boilerplate comes with Pest as its testing framework. In order to run the tests, run ./vendor/bin/pest.

Contributing

Feel free to open a pull request if you want to contribute to this project. All contributions / suggestions are welcome ✨

License

This project is open-sourced software licensed under the MIT license.

About

A minimal REST API boilerplate containing JWT for authentication, inspired by Laravel Breeze 🚀

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 99.9%
  • Other 0.1%