black-bits / laravel-api-consumer
Awesome Laravel Api Consumer
Requires
- php: ^7.1
- illuminate/support: 5.1.*|5.2.*|5.3.*|5.4.*|5.5.*|5.6.*
- kitetail/zttp: ^0.3.0
Requires (Dev)
- larapack/dd: ^1.0
- phpunit/phpunit: ^7.0
This package is auto-updated.
Last update: 2024-12-29 04:12:47 UTC
README
This Laravel package lets you generate API Consumers with Endpoints and Shapes which usage is similar to Laravel's Eloquent models.
You can generate one Consumer per API service you want to consume. Each Consumer can have any number of Endpoints with multiple Shapes.
An Endpoint represents e.g. a resource on a REST API like /users. Endpoints return Collections of Shapes. You can model the methods the API offers here.
A Shape represents an Object returned by an Endpoint and allows you to e.g. transform or validate the Object's properties.
Disclaimer
This package is currently in development and is not production ready.
Installation
You can install the package via composer
composer require black-bits/laravel-api-consumer
Next you can publish the config
php artisan vendor:publish --provider="BlackBits\ApiConsumer\ApiConsumerServiceProvider"
Usage
To make a new Api Consumer Service you can simply run
php artisan make:api-consumer ConsumerName
To add an endpoint (e.g. UserEndpoint) to this service run the following command, this will also create a default shape (UserShape) for that Endpoint
php artisan make:api-consumer-endpoint UserEndpoint -c ConsumerName
To add a custom Collection Callback run the following command. You can use this e.g. to create a filter that only shows Users that receive a newsletter
php artisan make:api-consumer-collection-callback ReceivesNewsletter
You can find an example implementation here: black-bits/laravel-api-consumer-showcase
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Security
If you discover any security related issues, please email hello@blackbits.io instead of using the issue tracker.
Credits
Support us
Black Bits, Inc. is a web and consulting agency specialized in Laravel and AWS based in Grants Pass, Oregon. You'll find an overview of what we do on our website.
License
The MIT License (MIT). Please see License File for more information.