Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ionbazan/laravel-container-debug
Lists available services in Laravel IoC Container. Works with Laravel 5.4-10.x
https://github.com/ionbazan/laravel-container-debug
container debug laravel laravel-package php symfony
Last synced: 3 months ago
JSON representation
Lists available services in Laravel IoC Container. Works with Laravel 5.4-10.x
- Host: GitHub
- URL: https://github.com/ionbazan/laravel-container-debug
- Owner: IonBazan
- License: mit
- Created: 2020-07-15T17:46:59.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-04-14T14:57:53.000Z (9 months ago)
- Last Synced: 2024-10-04T00:25:44.653Z (3 months ago)
- Topics: container, debug, laravel, laravel-package, php, symfony
- Language: PHP
- Homepage: https://packagist.org/packages/ion-bazan/laravel-container-debug
- Size: 31.3 KB
- Stars: 3
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Laravel Container Debug command
[![Laravel 5.4|6|7|8|9|10|11](https://img.shields.io/badge/Laravel-5.4+_|_6_|_7_|_8_|_9_|_10_|_11-informational.svg)](http://laravel.com)
[![Latest version](https://img.shields.io/packagist/v/ion-bazan/laravel-container-debug.svg)](https://packagist.org/packages/ion-bazan/laravel-container-debug)
[![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/IonBazan/laravel-container-debug/test.yml)](https://github.com/IonBazan/laravel-container-debug/actions)
[![PHP version](https://img.shields.io/packagist/php-v/ion-bazan/laravel-container-debug.svg)](https://packagist.org/packages/ion-bazan/laravel-container-debug)
[![Codecov](https://img.shields.io/codecov/c/gh/IonBazan/laravel-container-debug)](https://codecov.io/gh/IonBazan/laravel-container-debug)
[![Mutation testing badge](https://img.shields.io/endpoint?style=flat&url=https%3A%2F%2Fbadge-api.stryker-mutator.io%2Fgithub.com%2FIonBazan%2Flaravel-container-debug%2Fmaster)](https://dashboard.stryker-mutator.io/reports/github.com/IonBazan/laravel-container-debug/master)
[![Downloads](https://img.shields.io/packagist/dt/ion-bazan/laravel-container-debug.svg)](https://packagist.org/packages/ion-bazan/laravel-container-debug)
[![License](https://img.shields.io/packagist/l/ion-bazan/laravel-container-debug.svg)](https://packagist.org/packages/ion-bazan/laravel-container-debug)Symfony-inspired package to list available services in Laravel IoC Container. Works with Laravel 5.4-11.x.
# Example output
```
+--------------------------------------------------------------+-------------------------------------------------------------+--------+-------+
| Service ID | Class | Shared | Alias |
+--------------------------------------------------------------+-------------------------------------------------------------+--------+-------+
| IonBazan\Laravel\ContainerDebug\Tests\IContainerContractStub | IonBazan\Laravel\ContainerDebug\Tests\ContainerConcreteStub | No | No |
| IonBazan\Laravel\ContainerDebug\Tests\SingletonService | IonBazan\Laravel\ContainerDebug\Tests\SingletonService | Yes | No |
| alias.b | alias for "service.b" | No | Yes |
| alias.c | alias for "service.c" | No | Yes |
| service.a | IonBazan\Laravel\ContainerDebug\Tests\ServiceStubA | No | No |
| service.b | IonBazan\Laravel\ContainerDebug\Tests\ServiceStubB | No | No |
| service.c | IonBazan\Laravel\ContainerDebug\Tests\ServiceStubC | No | No |
| service.d | N/A | No | No |
| simple.value.array | [10,20] | No | No |
| simple.value.int | 10 | No | No |
| simple.value.string | test | No | No |
+--------------------------------------------------------------+-------------------------------------------------------------+--------+-------+
```# Installation
```bash
composer require --dev ion-bazan/laravel-container-debug
```Thanks to Laravel's Package Auto-Discovery, you don't need to register the ServiceProvider.
## Laravel without auto-discovery
If you don't use auto-discovery, add the Service Provider to the `providers` array in your `config/app.php`:
```php
\IonBazan\Laravel\ContainerDebug\ServiceProvider::class,
```## Lumen
For Lumen, register the Service Provider in your `bootstrap/app.php`:
```php
$app->register(\IonBazan\Laravel\ContainerDebug\ServiceProvider::class);
```# Usage
**TL;DR:** `php artisan container:debug --help`
Usage is pretty straightforward:
- to list all services: `php artisan container:debug`
- to check specific service: `php artisan container:debug MyFooService`
- to list all tags with tagged services: `php artisan container:debug --tags`
- to list all services with tag: `php artisan container:debug --tag=foo`The command does it best to find the service you want by stripping slashes in service names and looking for any occurrences of given name in service names.
For example, to display `service.foo` service information, simply use `php artisan container:debug foo`. If there are more services with the similar name, a prompt will be shown to choose the one you are looking for.To get the class name of the service, it must be initialized. To check how much time it took for each service, you may use `--profile` option.