Download the PHP package iafilin/eloquenthttpadapter without Composer
On this page you can find all versions of the php package iafilin/eloquenthttpadapter. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download iafilin/eloquenthttpadapter
More information about iafilin/eloquenthttpadapter
Files in iafilin/eloquenthttpadapter
Package eloquenthttpadapter
Short Description EloquentHttpAdapter is a Laravel package that allows you to work with RESTful API data using an Eloquent-like syntax. This package makes it easy to perform HTTP requests and handle responses as if working with a standard Eloquent model.
License MIT
Homepage https://github.com/iafilin/eloquenthttpadapter
Informations about the package eloquenthttpadapter
EloquentHttpAdapter
EloquentHttpAdapter is a Laravel package that provides an alternative to calebporzio/sushi. It allows you to work with RESTful API data using an Eloquent-like syntax.
This package was originally developed to integrate Filament with APIs, making it a convenient tool for admin panels. However, thanks to its flexibility, it can also be used for any task requiring API integration with an Eloquent-like interface.
Installation
Install the package via Composer:
Usage
Setting Up a Model
To enable API integration, use the InteractsWithHttp
trait and define a custom httpClient
method to configure the HTTP client:
Registering a Fetch Parameters Resolver
You can define the logic for building HTTP query parameters using the registerFetchParamsResolver
method. This allows dynamic configuration of pagination, filtering, and sorting parameters.
Additionally, within the resolver, you have access to the getQuery()
object, which lets you retrieve Eloquent wheres
conditions and use them to generate HTTP parameters.
Example setup:
API Requirements
To ensure compatibility with the package, your API should follow these conventions:
-
Standard REST endpoints:
POST /api/resource
— Create records.GET /api/resource
— Fetch records (paginated or full list).GET /api/resource/{id}
— Fetch a single record.PUT /api/resource/{id}
— Update a record.DELETE /api/resource/{id}
— Delete a record.
- Response Structure:
- Lists: Should include
data
,total
,per_page
, andcurrent_page
. - Single Record: Should return attributes directly without nesting.
- Lists: Should include
Example paginated response:
-
Pagination:
- Support for
page
andper_page
query parameters.
- Support for
- Filters and Sorting:
- Filters:
filter[column]=value
. - Sorting:
sort=column
for ascending andsort=-column
for descending.
- Filters:
CRUD Operations
Once your model is set up, you can use standard Eloquent methods to interact with your API:
Create a Record
Read Records
Update a Record
Delete a Record
Customizing HTTP Requests
You can fully customize HTTP request behavior by overriding the httpClient
method in your model. For example, adding headers or specific configurations:
If you have any questions or suggestions, feel free to open an issue or contribute! 💡
Customizing API Fetch Parameters with registerFetchParamsResolver
The registerFetchParamsResolver
method allows you to customize the HTTP query parameters sent to your API for fetching data. It provides a powerful way to dynamically build parameters like pagination, filters, and sorting based on the current Eloquent query or incoming user requests.
With access to the Eloquent query object ($this->getQuery()
), you can parse wheres
, orders
, and other query conditions, transforming them into HTTP parameters compatible with your API.
Key Benefits:
- Dynamic configuration: Automatically adapt HTTP query parameters to match user input or specific query requirements.
- Seamless integration: Utilize existing Eloquent query methods while maintaining API compatibility.
- Support for complex queries: Build filters, pagination, and sorting logic based on both application and API needs.
Example Usage:
This makes it easy to dynamically adapt HTTP query parameters based on user input or predefined conditions in your Laravel application.
Error Handling
The package automatically logs errors during API interactions and returns null
in case of failure. This ensures graceful handling of API downtime or errors without throwing exceptions.
License
This package is open-source and licensed under the MIT license.
All versions of eloquenthttpadapter with dependencies
illuminate/support Version ^9.0|^10.0|^11.0|^12.0
illuminate/http Version ^9.0|^10.0|^11.0|^12.0
illuminate/database Version ^9.0|^10.0|^11.0|^12.0