This is a lightweight and extendable PHP-Api Framework designed to help developers quickly build RESTful APIs. It provides easy management of API parameters (GET, POST) with support for defining allowed parameters, their required status, and data types. It also allows for flexible response formatting, making it easy to create custom APIs.
This framework can be easily integrated into any PHP project using Composer.
- Standardized API Parameter Handling: Easily manage allowed API parameters, including data types and required status.
- Flexible Parameter Validation: Validate that only expected parameters are included, check for required parameters, and validate parameter data types.
- Custom Response Wrapper: Define a custom response structure using a flexible wrapper.
- Flexible HTTP Method Support: Supports GET, POST, PUT, DELETE HTTP methods.
- Meta Data: The response includes metadata such as response code, server host, number of results, and script execution time.
- Data Type Management: Support for defining and managing data types for each parameter.
To use the PHP-Api Framework in your project, follow these steps:
Ensure that Composer is installed on your system. If it's not installed yet, you can install it using the following command:
curl -sS https://getcomposer.org/installer | php
{
"require": {
"t045t/php-api": "dev-develop"
},
"repositories": [
{
"type": "vcs",
"url": "https://github.com/DevT045T/php-api.git"
}
],
"minimum-stability": "dev",
"prefer-stable": true
}
Then run:
composer install
This will install the framework from the develop
branch and download all necessary files.
Ensure that Composer's autoloader is included in your project. Add this line at the beginning of your PHP file:
require 'vendor/autoload.php';
You can now use the framework in your project. For more information on how to use it, refer to the Usage section of this documentation.
use devt045t\Api;
use devt045t\ApiParameter;
use devt045t\DataTypes;
use devt045t\HttpStatusCodes;
use devt045t\HttpMethods;
$api = new Api();
// Define allowed parameters
$param1 = new ApiParameter();
$param1
->name('username')
->required(true)
->methods([HttpMethods::POST])
->type(DataTypes::STRING);
$param2 = new ApiParameter();
$param2
->name('password')
->required(true)
->methods([HttpMethods::POST])
->type(DataTypes::INT);
// Add parameters to API instance
$api
->addParameter($param1)
->addParameter($param2);
// Set the allowed request methods
$api->setAllowedRequestMethod([HttpMethods::OPTIONS, HttpMethods::POST]);
// Validate parameters
$api->validate();
// Set the response data
$api->setResponse(['message' => 'Parameters received successfully']);
// Set the custom response code (optional)
$api->setResponseCode(HttpStatusCodes::OK);
// Send the response
$api->send();
The default response wrapper looks like this:
{
"meta": {
"response_code": 200,
"host": "http://example.com",
"count": 1,
"runtime": 0.02
},
"data": {
"message": "Parameters received successfully"
}
}
You can modify the structure of the response wrapper by setting a custom wrapper:
$customWrapper = [
"status" => "{{ response_code }}",
"details" => [
"host" => "{{ host }}",
"total_count" => "{{ count }}",
"execution_time" => "{{ runtime }}"
],
"content" => "{{ data }}"
];
$api->setCustomWrapper($customWrapper);
$api->setResponse(['message' => 'Parameters received successfully']);
$api->send();
The response will be wrapped in the custom format:
{
"status": 200,
"details": {
"host": "http://example.com",
"total_count": 1,
"execution_time": 0.02
},
"content": {
"message": "Parameters received successfully"
}
}
-
Parameter Management:
addParameter(ApiParameter $parameter)
: Adds an allowed API parameter to the API instance, defining its name, required status, and data type.getAllParameters()
: Returns all given GET and POST parameters as an array.getGETParameters()
: Returns all given GET parameters as an array.getPOSTParameters()
: Returns all given POST parameters as an array.
-
Validation:
validate()
: Validates that all required data is correct and in the expected format. It checks:- If only allowed parameters are present.
- If all required parameters are provided.
- If parameter data types match the expected types.
sendErrorResponse(int $responseCode, string $errorMessage, array $errorDetails = [])
: Sends an error response if validation fails, with the status code, error message, and details of the error.
-
Response Management:
setResponse($data)
: Sets the response data. The data can be any type (array, object, string, etc.).setResponseCode(int $code)
: Sets the HTTP response code. Defaults to200
.send()
: Sends the response to the client. Automatically formats the response in JSON.setCustomWrapper(array $wrapper)
: Sets a custom wrapper for the response. If no custom wrapper is provided, the default one is used.prepareResponseWrapper()
: Prepares the response based on the current wrapper settings.
-
Request Information:
getRequestMethod()
: Returns the HTTP request method (GET, POST, PUT, DELETE).__get(string $property)
: ✨Magic✨ getter method for accessing properties dynamically through the$parameters
array. Returns the property’s value or null if not found.
The ApiParameter
class helps you define the parameters for your API. Each parameter can be configured with the following properties:
- Name: The name of the parameter (e.g.,
username
,age
). - Required: Whether the parameter is required for the request. Default is
false
. - Data Type: The data type for the parameter (e.g.,
string
,integer
,boolean
). - Methods: The allowed HTTP methods for the parameter (e.g.,
POST
orGET
).
use devt045t\ApiParameter;
use devt045t\DataTypes;
$param = new ApiParameter();
$param->name('username')->required(true)->methods([HttpMethods::POST])->type(DataTypes::STRING);
- The framework provides data type validation using
DataTypes::isType($value, $dataType)
, ensuring that each parameter's value matches its defined type.
- Custom Wrapper: Allows you to define the format of the API response (metadata, count, host, runtime, etc.). This is ideal for adjusting the structure of the response to match your front-end or external service requirements.
Example of custom wrapper placeholders:
{{ response_code }}
{{ host }}
{{ count }}
{{ runtime }}
{{ data }}
You can use these placeholders to customize the structure of the API response.
This project is licensed under the MIT License - see the LICENSE file for details.
Feel free to fork this project, make improvements, and submit pull requests. Contributions are always welcome!