Skip to content

lionix-team/laravel-api-boilerplate

 
 

Repository files navigation

Laravel API Boilerplate

This repository is forked from laravel/laravel and represents configrations, console commands and abstractions our team came with developing Web APIs with Laravel.

Artisan Code Generator Shorthand

In order to minimize boilerplate code generation process we came up with the idea to union needed commands in one to generate required components for new entities.

Signature Short Description
app:make-api {name} {--pivot} Generate model, factory, resource, policy and migration

Note: with --pivot option a pivot model will be generated (pivot model wont have resource and policy for obvious reasons).

Linting

Application utilizes squizlabs/php_codesniffer to lint the codebase. Codesniffer configrations are based in phpcs.xml and contain basic rules we use to while developing. Feel free to modify it to your needs.

Following artisan console command was added on top of the PHP_CodeSniffer:

Signature Short Description
app:lint {--fix} Lint application code with PHP_CodeSniffer

Response macros

We added some of the most used JSON response macros to the application to have all our responses consistent and structured.

/**
 * @param mixed $data
 * @param int? $status (200)
 */
response()->success(new UserResource($user)); // {"success":true,"data":{"id":1,"email":"[email protected]"}}
{
    "success":true,
    "data":{
        "id": 1,
        "email": "[email protected]"
    }
}

/**
 * @param string $message
 * @param int? $status (200)
 */
response()->successMessage(trans('messages.success')); // {"success":true,"data":{"message":"messages.success"}}

/**
 * @param mixed $data
 */
response()->created(new UserResource($user)); // {"success":true,"data":{"id":1,"email":"[email protected]"}} <- status code 201

/**
 * @param string $message
 */
response()->createdMessage(trans('messages.created')); // {"success":true,"data":{"message":"messages.created"}} <- status code 201

/**
 * @param mixed $data
 * @param int? $status (400)
 */
response()->error(trans('messages.invalid_email')); // {"success":false,"error":"messages.invalid_email"} <- status code 400

/**
 * @param string $message
 * @param int? $status (400)
 */
response()->errorMessage(trans('messages.invalid_email')); // {"success":false,"error":{"message":"messages.invalid_email"}}

/**
 * @param \Illuminate\Contracts\Pagination\LengthAwarePaginator $paginator
 * @param string $resourceClassName
 */
response()->paginated(User::paginate(), UserResource::class);
// {
//     "success":true,
//     "data": [
//         {"id":1,"email":"[email protected]"},
//         {"id":2,"email":"[email protected]"}
//     ],
//     "pagination": {
//         "total":2,
//         "count":2,
//         "per_page":10,
//         "current_page":1,
//         "total_pages":1
//     }
// }

Todo

  • Add PHP_CodeSniffer lint.
  • Remove package.json and sass/js default resources.
  • Add app:make-api shorthand command.
  • Setup common response marcos.
  • Adjust test, request, console command stubs.
  • Remove console, channels, web routes and configure the route service providers.
  • Install and configure laravel/passport.
  • Add Services/Repositories.
  • Setup testing environment (phpunit.xml, exception handler, passport migraitions, response macro, resource helpers).

About

A PHP framework for web artisans

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 99.3%
  • Shell 0.7%