myerscode / laravel-sub-request
A helper and facade for making internal API sub requests to your application
Package info
github.com/myerscode/laravel-sub-request
Type:package
pkg:composer/myerscode/laravel-sub-request
Requires
- php: ^8.3
- illuminate/http: ^13.0
- illuminate/routing: ^13.0
- illuminate/support: ^13.0
Requires (Dev)
- larastan/larastan: ^3.9
- laravel/pint: ^1.29
- orchestra/testbench: ^11.0
- phpunit/phpunit: ^13.0
- dev-main
- 13.0.0
- 8.x-dev
- 8.0.1
- 8.0.0
- 7.0.0
- 1.0.1
- 1.0.0
- dev-dependabot/github_actions/codecov/codecov-action-6
- dev-dependabot/github_actions/actions/checkout-6
- dev-dependabot/github_actions/codecov/codecov-action-5
- dev-dependabot/github_actions/stefanzweifel/git-auto-commit-action-7
- dev-feature/laravel-10
- dev-develop
This package is auto-updated.
Last update: 2026-03-26 23:08:05 UTC
README
A helper and facade for making internal sub requests to your application API.
By sending a sub request within the application, you can consume your application's API without sending separate, slower HTTP requests.
Requirements
- PHP 8.5+
- Laravel 13.x
Install
composer require myerscode/laravel-sub-request
The package will be auto-discovered by Laravel.
Usage
You can inject the Dispatcher into your class, use the SubRequest facade, or use the global subrequest helper.
use Myerscode\Laravel\SubRequest\Dispatcher; use Myerscode\Laravel\SubRequest\SubRequest; class MyController { public function __construct(private readonly Dispatcher $subRequest) {} // Using dependency injection public function withInjection() { return $this->subRequest->post('/auth', ['foo' => 'bar']); } // Using the facade public function withFacade() { return SubRequest::dispatch('GET', '/details', ['foo' => 'bar']); } // Using the helper public function withHelper() { return subrequest('GET', '/details', ['foo' => 'bar']); } }
Available Methods
The Dispatcher provides shortcut methods for all HTTP verbs:
$dispatcher->get('/url', $data); $dispatcher->post('/url', $data); $dispatcher->put('/url', $data); $dispatcher->patch('/url', $data); $dispatcher->delete('/url', $data); $dispatcher->options('/url', $data);
License
MIT