Download the PHP package ahmedebead/cake-rest-api without Composer
On this page you can find all versions of the php package ahmedebead/cake-rest-api. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download ahmedebead/cake-rest-api
More information about ahmedebead/cake-rest-api
Files in ahmedebead/cake-rest-api
Package cake-rest-api
Short Description Rest API plugin for CakePHP 4.x
License MIT
Informations about the package cake-rest-api
CakeRestApi Plugin for CakePHP
This plugin simplifies the CakeRestApi API development for your CakePHP 4.x application. It simply converts the output of your controller into a JSON response.
Installation
You can install this plugin into your CakePHP application using composer.
The recommended way to install composer packages is:
After installation, Load the plugin
Add this file to /src/Application.php
Or, you can load the plugin using the shell command
Usage
No major change requrires in the way you code in your CakePHP application. Simply, just add one parameter to your route configuration isRest
like,
And extend your controller to RestController
and everything will be handled by the plugin itself. For example,
And that's it. You will see the response as below.
Doesn't it too simple? Whatever viewVars
you set from your controller's action using set()
method, will be converted into JSON response.
Response Format
This plugin returns the response in the following format.
The status
key may contain OK or NOK based on your response code. For all successful responses, the code will be 200 and the value of this key will be OK.
In case of error or exception, the value of status
will become NOK. Also, based on your application's debug
setting, it will contain the exception and trace data.
The result
key contains the actual response. It holds all the variables set from your controller. This key will not be available in case of error/exception.
These properties are also available in your controller's beforeFilter
method, so you can put additional authentication logic there.
Reporting Issues
If you have a problem with this plugin or found any bug, please open an issue on GitHub.