thuraaung2493/laravel-api-utils

0.2.1 2024-01-11 10:07 UTC

This package is auto-updated.

Last update: 2024-10-03 11:04:04 UTC


README

It supports Laravel 9+ and PHP 8.2+

Description

This package contains many utility APIs that assist in API creation.

Installation

Require this package with composer using the following command:

composer require thuraaung2493/laravel-api-utils

Publish the config file

php artisan vendor:publish --provider="Thuraaung\APIUtils\LaravelAPIUtilsServiceProvider" --tag="api-utils"

Usage

Responses

All API Response classes implement the Responsable interface.

  use Thuraaung\APIUtils\Http\Responses\API\SuccessResponse;
  use Thuraaung\APIUtils\Http\Responses\API\PaginatedResponse;
  use Thuraaung\APIUtils\Http\Responses\API\FailResponse;
  use Thuraaung\APIUtils\Http\Responses\API\MessageOnlyResponse;
  use Thuraaung\APIUtils\Http\Responses\API\Response;

  // API Success Response with resource data.
  return new SuccessResponse($userResource); // OR
  return Response::of()->sendSuccess($userResource);

  // API Success Response with resource data.
  return new PaginatedResponse($userPaginationResource); // OR
  return Response::of()->paginated($userPaginationResource);

  // API Fail Response with errors.
  return new FailResponse(errors: ['email' => 'Email is invalid.']); // OR
  return Response::of()->sendFail(['email' => 'Email is invalid.']);

  // API Message-Only Response.
  return new MessageOnlyResponse('Login successful.', Status::OK); // OR
  return Response::of()
    ->status(Status::OK)
    ->sendMessage('Login successful.')

API Success JSON Response Format.

{
    "data": "resource",
    "message": "Success.",
    "status": 200
}

API Paginated JSON Response Format.

{
    "data": "resource",
    "links": {},
    "meta": {},
    "message": "Success.",
    "status": 200
}

A JSON Response Format for API Errors.

{
    "title": "Failed!",
    "message": "Something went wrong!",
    "errors": [],
    "status": 500
}

A JSON Response Format for API Messages Only

{
    "message": "Success",
    "status": 500
}

Enums

Headers

    use Thuraaung\APIUtils\Http\Headers\Headers;
    use Thuraaung\APIUtils\Http\Headers\ContentType;
    use Thuraaung\APIUtils\Http\Headers\ContentEncoding;

    // Create headers with pre defined in config.
    Headers::default();
    // Transform array
    Headers::default()->toArray();

    // Other utils methods
    Headers::of()
        ->accept(ContentType::JSON)
        ->contentType(ContentType::JSON)
        ->acceptEncoding(ContentEncoding::GZIP)
        ->contentEncoding(ContentEncoding::GZIP, vapor: false)
        ->contentLength(214)
        ->toArray();

Middleware Classes

Exceptions

App\Exceptions\Handler.php

    use Thuraaung\APIUtils\Exceptions\APIExceptionsHandler;

    class Handler extends APIExceptionsHandler
    {
        // others

        public function register(): void
        {
            $this->handleAuthenticationException()
                ->handleAccessDeniedException()
                ->handleNotFoundException()
                ->handleMethodNotAllowException()
                ->handleNotAcceptableException()
                ->handleUnprocessableEntityException()
                ->handleTooManyRequestsException()
                ->handleMergeExceptions([]);
        }

        protected function isJsonRequest(): bool
        {
            return \request()->isJson() && \request()->is('api/*');
        }
    }