184 lines
5.5 KiB
PHP
184 lines
5.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api;
|
|
|
|
use Illuminate\Http\JsonResponse;
|
|
use App\Enum\HttpResponseCodes;
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Support\Collection;
|
|
use Illuminate\Support\Str;
|
|
|
|
class ApiController extends Controller
|
|
{
|
|
/**
|
|
* Resource name
|
|
* @var string
|
|
*/
|
|
protected $resourceName = '';
|
|
|
|
|
|
/**
|
|
* Return generic json response with the given data.
|
|
*
|
|
* @param array $data Response data.
|
|
* @param integer $respondCode Response status code.
|
|
* @param array $headers Response headers.
|
|
*/
|
|
public function respondJson(array $data, int $respondCode = HttpResponseCodes::HTTP_OK, array $headers = []): JsonResponse
|
|
{
|
|
return response()->json($data, $respondCode, $headers);
|
|
}
|
|
|
|
/**
|
|
* Return forbidden message
|
|
*
|
|
* @param string $message Response message.
|
|
*/
|
|
public function respondForbidden(string $message = 'You do not have permission to access the resource.'): JsonResponse
|
|
{
|
|
return response()->json(['message' => $message], HttpResponseCodes::HTTP_FORBIDDEN);
|
|
}
|
|
|
|
/**
|
|
* Return forbidden message
|
|
*
|
|
* @param string $message Response message.
|
|
*/
|
|
public function respondNotFound(string $message = 'The resource was not found.'): JsonResponse
|
|
{
|
|
return response()->json(['message' => $message], HttpResponseCodes::HTTP_NOT_FOUND);
|
|
}
|
|
|
|
/**
|
|
* Return too large message
|
|
*
|
|
* @param string $message Response message.
|
|
*/
|
|
public function respondTooLarge(string $message = 'The request entity is too large.'): JsonResponse
|
|
{
|
|
return response()->json(['message' => $message], HttpResponseCodes::HTTP_REQUEST_ENTITY_TOO_LARGE);
|
|
}
|
|
|
|
/**
|
|
* Return no content
|
|
*/
|
|
public function respondNoContent(): JsonResponse
|
|
{
|
|
return response()->json([], HttpResponseCodes::HTTP_NO_CONTENT);
|
|
}
|
|
|
|
/**
|
|
* Return created
|
|
*/
|
|
public function respondCreated(): JsonResponse
|
|
{
|
|
return response()->json([], HttpResponseCodes::HTTP_CREATED);
|
|
}
|
|
|
|
/**
|
|
* Return accepted
|
|
*/
|
|
public function respondAccepted(): JsonResponse
|
|
{
|
|
return response()->json([], HttpResponseCodes::HTTP_ACCEPTED);
|
|
}
|
|
|
|
/**
|
|
* Return single error message
|
|
*
|
|
* @param string $message Error message.
|
|
* @param integer $responseCode Resource code.
|
|
*/
|
|
public function respondError(string $message, int $responseCode = HttpResponseCodes::HTTP_UNPROCESSABLE_ENTITY): JsonResponse
|
|
{
|
|
return response()->json([
|
|
'message' => $message
|
|
], $responseCode);
|
|
}
|
|
|
|
/**
|
|
* Return formatted errors
|
|
*
|
|
* @param array $errors Error messages.
|
|
* @param integer $responseCode Resource code.
|
|
*/
|
|
public function respondWithErrors(array $errors, int $responseCode = HttpResponseCodes::HTTP_UNPROCESSABLE_ENTITY): JsonResponse
|
|
{
|
|
$keys = array_keys($errors);
|
|
$error = $errors[$keys[0]];
|
|
|
|
if (count($keys) > 1) {
|
|
$additional_errors = (count($keys) - 1);
|
|
$error .= sprintf(' (and %d more %s', $additional_errors, Str::plural('error', $additional_errors));
|
|
}
|
|
|
|
return response()->json([
|
|
'message' => $error,
|
|
'errors' => $errors
|
|
], $responseCode);
|
|
}
|
|
|
|
/**
|
|
* Return resource data
|
|
*
|
|
* @param array|Model|Collection $data Resource data.
|
|
* @param array $options Respond options.
|
|
*/
|
|
protected function respondAsResource(
|
|
mixed $data,
|
|
array $options = [],
|
|
$validationFn = null
|
|
): JsonResponse {
|
|
$isCollection = $options['isCollection'] ?? false;
|
|
$appendData = $options['appendData'] ?? null;
|
|
$resourceName = $options['resourceName'] ?? null;
|
|
$respondCode = ($options['respondCode'] ?? HttpResponseCodes::HTTP_OK);
|
|
|
|
if ($data === null || ($data instanceof Collection && $data->count() === 0)) {
|
|
$validationData = [];
|
|
if (array_key_exists('appendData', $options) === true) {
|
|
$validationData = $options['appendData'];
|
|
}
|
|
|
|
if ($validationFn === null || $validationFn($validationData) === true) {
|
|
return $this->respondNotFound();
|
|
}
|
|
}
|
|
|
|
if (is_null($resourceName) === true || empty($resourceName) === true) {
|
|
$resourceName = $this->resourceName;
|
|
}
|
|
|
|
if (is_null($resourceName) === true || empty($resourceName) === true) {
|
|
$resourceName = get_class($this);
|
|
$resourceName = substr($resourceName, (strrpos($resourceName, '\\') + 1));
|
|
$resourceName = substr($resourceName, 0, strpos($resourceName, 'Controller'));
|
|
$resourceName = strtolower($resourceName);
|
|
}
|
|
|
|
$dataArray = [];
|
|
if ($data instanceof Collection) {
|
|
$dataArray = $data->toArray();
|
|
} elseif (is_array($data) === true) {
|
|
$dataArray = $data;
|
|
} elseif ($data instanceof Model) {
|
|
$is_multiple = false;
|
|
$dataArray = $data->toArray();
|
|
}
|
|
|
|
$resource = [];
|
|
if ($isCollection === true) {
|
|
$resource = [Str::plural($resourceName) => $dataArray];
|
|
} else {
|
|
$resource = [Str::singular($resourceName) => $dataArray];
|
|
}
|
|
|
|
if ($appendData !== null) {
|
|
$resource += $appendData;
|
|
}
|
|
|
|
return response()->json($resource, $respondCode);
|
|
}
|
|
}
|