rcm / api-lib
Rcm Api Library
0.12.1
2019-04-16 16:14 UTC
Requires
Requires (Dev)
Suggests
- bower-asset/angular: Required for JS
- bower-asset/es6-promise-polyfill: ^1.2 for older browser support
- rcm/i18n: Required by default, can over-ride in config: Translate::class
- rwoverdijk/assetmanager: Required if using asset manager config
- zendframework/zend-http: Required if using ZF2 controllers
- zendframework/zend-mvc: Required if using ZF2 controllers
- zendframework/zend-stdlib: Required if using ZF2 controllers
This package is auto-updated.
Last update: 2026-06-17 07:32:59 UTC
README
API basic response library making use of Middleware (like Zend Expressive) OR ZF2's MVC framework
Makes it easy to quickly create a common API data format.
Include a JavaScript (Angular.JS) library for the client.
Several types of common error message types are supported:
- Array
- Exception
- HttpStatusCode
- InputFilter (Zend)
- String
- Custom types can also be injected
EXAMPLE: Middleware (like Zend Expressive)
// From a Middleware that extends Reliv\RcmApiLib\Middleware\AbstractJsonController /** EXAMPLE: InputFilter (Zend) **/ public function __invoke( ServerRequestInterface $request, ResponseInterface $response, callable $next ) { $inputFilter = new RcmGoogleAnalyticsFilter(); $inputFilter->setData($data); if (!$inputFilter->isValid()) { return $this->getApiResponse( [], 400, $inputFilter ); } }
Returns something like:
{
"data": [],
"messages": [
{
"type": "inputFilter",
"source": "validation",
"code": "error",
"value": "Some information was missing or invalid on the form. Please check the form and try again.",
"primary": true,
"params": [],
"key": "inputFilter.validation.error"
},
{
"type": "validatorMessage",
"source": "my-value",
"code": "isEmpty",
"value": "Value is required and can't be empty",
"primary": null,
"params": [],
"key": "validatorMessage.my-value.isEmpty"
}
]
}
/** EXAMPLE: General **/ public function __invoke( ServerRequestInterface $request, ResponseInterface $response, callable $next ) { return $this->getApiResponse( ['my' => 'response'], 400, new ApiMessage( 'my-type', 'my-message-value {my-param}', 'my-source', 'my-code', true, ['my-param' => 'my-value'] ) ); }
EXAMPLE: Zend Framework
// From a ZF2 Controller that extends \Reliv\RcmApiLib\Controller\AbstractRestfulJsonController // @see \Reliv\RcmApiLib\Controller\ExampleRestfulJsonController // Add exception message $this->addApiMessage( new \Exception('Some exception') ); // Add generic message as array $this->addApiMessage( [ 'key' => 'ArrayError', 'value' => 'Some {param} Message', 'primary' => true, 'type' => 'Array', 'code' => 'mycode', 'params' => ['param' => 'array message'] ] ); // Add generic message as object $this->addApiMessage( new ApiMessage('MYKEY', 'Some Message') ); // Add HTTP sttus message $this->addApiMessage( new HttpStatusCodeApiMessage(403) ); // Add inputFilter message $inputFilter = new \Zend\InputFilter\InputFilter(); // Use you own inputFilter here $this->addApiMessage( $inputFilter ); // Return the response return $this->getApiResponse( null, $statusCode = 200, $inputFilter, true ); // Return the response with your data and no messages return $this->getApiResponse( ['myThing' => 'someThing'], );
Author:
James Jervis jjervis@relivinc.com Copyright (c) 2015, Reliv' International, Inc. https://github.com/reliv/rcm-api-lib