A Laravel response helper methods. The package respond
provides a fluent syntax to form array or json responses.
In its configuration file, it allows the addition of custom methods.
You can install the package via composer:
composer require nnjeim/respond
php artisan vendor:publish --provider="Nnjeim\Respond\RespondServiceProvider"
The respond.php
config file allows:
- The presetting of the response format array/json.
- The possibility to edit the response parameters.
- The possibility to add custom methods.
use Nnjeim\Fetch\Fetch;
use Nnjeim\Respond\Respond;
['response' => $response, 'status' => $status] = Fetch::setBaseUri('https://someapi.com/')->get('countries');
if ($status === 200 && $response->success) {
return Respond::toJson()
->setMessage('countries')
->setData($response->data)
->withSuccess();
}
abort(400);
use Nnjeim\Respond\RespondHelper;
private RespondHelper $respond;
private array $data;
private bool $success;
public function __construct(RespondHelper $respond)
{
$this->respond = $respond;
}
.
.
.
$respond = $this
->respond
->toJson()
->setMessage('countries')
->setData($data);
if ($this->success)
{
return $respond->withSuccess()
}
return $respond->withErrors();
Sets the response status code
@return $this setStatusCode(int $statusCode)
Sets the response title message
@return $this setMessage(string $message)
Sets the response meta data. The meta data will be merged with the response data array.
@return $this setMeta(array $meta)
Sets the response data array.
@return $this setData(array $data)
Sets the response errors.
@return $this setErrors(array $errors)
returns an instance of Illuminate\Http\JsonResponse
this method overwrites the config `toJson` set value.
@return $this toJson()
On success response. The default response status code is 200.
@return array|JsonResponse withSuccess()
On created response. The default response status code is 201.
@return array|JsonResponse withCreated()
On accepted response. The default response status code is 202.
@return array|JsonResponse withAccepted()
On success response with no results found. The default status code is 204
@return array|JsonResponse withNoContent()
On error response. The default response status code is 422.
@return array|JsonResponse withErrors(?array $errors = null)
On server error response. The default response status code is 500.
@return array|JsonResponse withServerError()
Record not found error. The default response status code is 404.
@return array|JsonResponse withNotFound()
Not authenticated reponse. The default response status code is 401.
@return array|JsonResponse withNotAuthenticated()
Not authorized reponse. The default response status code is 403.
@return array|JsonResponse withNotAuthorized()
@return array|JsonResponse
[
'response' => [
'success' => true,
'message' => 'message',
'data' => [],
'errors' => [],
],
'status' => 200,
];
In the respond.php
config file, in the responses array add an array entry where the key is name of the method in lower
case and the value contains the desired success, message and status params.
//example
'methodnotallowed' => [
'success' => false,
'message' => 'the method not allowed!',
'status' => Response::HTTP_METHOD_NOT_ALLOWED,
],
Respond::withMethodNotAllowed();
The helpers and methods are tested with 99% coverage.
To run the tests.
composer install
composer test
To run the coverage test.
composer test-coverage
Please see CHANGELOG for more information what has changed recently.