nailfor/shazam-api

Fast API development

v0.1.8 2024-09-06 14:25 UTC

This package is not auto-updated.

Last update: 2025-01-10 16:09:10 UTC


README

This library allows API developers to quick create APIs in a minimalist way.

Features

All models are inherited from Illuminate\Database\Eloquent\Model so most methods work natively

Installation

The preferred way to install this extension is through composer.

Either run

composer require nailfor/shazam-api

Configure

Add config/app.php

    'providers' => [
        ...
        nailfor\shazam\API\Providers\RouteServiceProvider::class,
    ];

config/shazam.php

<?php

use nailfor\shazam\Http\Controllers\Controller;
use nailfor\shazam\API\Models\Paginator;

return [
    'namespace' => 'App',
    'path' => 'Http/Controllers',
    'routes' => [
        //there is subdirectory of Http/Controllers for routing
        'API',
    ],
    'paginator' => Paginator::class,
    'pages' => [
        'perPage' => 'per_page',
        'page' => 'page',
    ],

    'debug' => env('SQL_DEBUG', false),
];

Usage

Basic usage

Repositories

  • Create dir Repositories\API in your app
  • Add UserRepository.php like that
<?php

namespace App\Repositories\API;

use App\Models\User;
use nailfor\shazam\API\Repositories\APIRepository;

class UserRepository extends APIRepository
{
    protected static string $model = User::class;
}

Controllers

  • Create subdirectory API in Http/Controllers directory
  • Add UserController.php with
<?php

namespace App\Http\Controllers\API;

use App\Repositories\API\UserRepository;
use nailfor\shazam\API\Http\Controllers\ApiController;

class UserController extends ApiController
{
    public function __construct(UserRepository $model)
    {
        parent::__construct($model);
    }
}

You can specify rules for your controllers with

class UserController extends ApiController
{
    //By default can't store and destroy
    protected array $can = [
        'store',
    ];

    //By default can index and show
    protected array $cant = [
        'index',
        'show',
    ];
    ...
}

Request validations

  • Create subdirectory in Http/Requests
  • Add request file or just run ./artisan make:request StoreRequest

StoreRequest.php

<?php

namespace App\Http\Requests;

use Illuminate\Foundation\Http\FormRequest;

class StoreRequest extends FormRequest
{
    /**
     * Determine if the user is authorized to make this request.
     */
    public function authorize(): bool
    {
        return true;
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array<mixed>|string>
     */
    public function rules(): array
    {
        return [
            'id' => 'required',
        ];
    }

    public function messages(): array
    {
        return [
            'id.required' => 'Id is require',
        ];
    }
}

Now you can edit your controller class like that

class UserController extends ApiController
{
    protected static array $requests = [
        'store' => StoreRequest::class,
    ];
    ...
}

When 'store' is one of Laravel CRUD operations: index, show, store and destroy

  • Edit app\Http\Kernel.php, find "protected $middlewareGroups = [...]" and add to each
    \nailfor\shazam\API\Http\Middleware\RequestValidator::class,

After that you can do get request like http:://localhost/api/user

Credits

License

The GNU License (GNU). Please see License File for more information.