PHPackages                             papoon/inspector - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. papoon/inspector

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

papoon/inspector
================

Framework-agnostic service container inspector

00[5 issues](https://github.com/papoon/inspector/issues)PHPCI passing

Since Aug 26Pushed 8mo agoCompare

[ Source](https://github.com/papoon/inspector)[ Packagist](https://packagist.org/packages/papoon/inspector)[ RSS](/packages/papoon-inspector/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (2)DependenciesVersions (1)Used By (0)

Service Container Inspector
===========================

[](#service-container-inspector)

[![Coverage Status](https://camo.githubusercontent.com/78b9e7eb6b2abd4140a0c22c03431e124b64d31b90425a5126b9b71dd61cdb7f/68747470733a2f2f636f6465636f762e696f2f67682f7061706f6f6e2f696e73706563746f722f6272616e63682f6d61696e2f67726170682f62616467652e737667)](https://codecov.io/gh/papoon/inspector)

A powerful tool for inspecting, visualizing, and tracking mutations in PHP service containers (Laravel, Symfony, PSR-11).

---

Features
--------

[](#features)

- Web dashboard for service inspection and visualization
- CLI commands for analysis and export
- Mutation tracking (bindings, aliases, etc.)
- Dependency graph export (Graphviz/D3.js)
- Service comparison across environments
- Tagged service listing
- Circular dependency and duplicate binding detection

---

Installation
------------

[](#installation)

```
composer require papoon/inspector --dev
```

---

Quick Start
-----------

[](#quick-start)

### Web Dashboard

[](#web-dashboard)

```
php -S localhost:8000 -t public
```

Visit  in your browser.

### CLI Usage

[](#cli-usage)

List services:

```
php bin/inspect inspector:list-services
```

Compare containers:

```
php bin/inspect inspector:compare-containers local staging prod
```

Export service map:

```
php bin/inspect inspector:export-map json
```

---

Usage in Laravel
----------------

[](#usage-in-laravel)

1. **Wrap your container with the Inspector adapter:**

    ```
    use Inspector\Adapters\LaravelAdapter;
    use Illuminate\Container\Container;

    $container = app();
    $adapter = new LaravelAdapter($container);
    ```
2. **Track mutations:**

    ```
    use Inspector\MutationEventDispatcher;

    $dispatcher = new MutationEventDispatcher();
    $dispatcher->listen(function ($mutation) {
        logger()->info('Container mutation', $mutation);
    });
    $adapter->setMutationDispatcher($dispatcher);
    ```
3. **Use adapter methods for mutations:**

    ```
    $adapter->bind('foo', function () { return new Foo(); });
    $adapter->alias('foo', 'bar');
    ```
4. **Inspect services and mutations:**

    ```
    use Inspector\Inspector;

    $inspector = new Inspector($adapter);
    $services = $inspector->browseServices();
    $mutations = $inspector->getMutations();
    ```

---

Usage in Symfony
----------------

[](#usage-in-symfony)

1. **Wrap your container with the Inspector adapter:**

    ```
    use Inspector\Adapters\SymfonyAdapter;
    use Symfony\Component\DependencyInjection\ContainerBuilder;

    $container = $this->container;
    $adapter = new SymfonyAdapter($container);
    ```
2. **Track mutations:**

    ```
    use Inspector\MutationEventDispatcher;

    $dispatcher = new MutationEventDispatcher();
    $dispatcher->listen(function ($mutation) {
        // Log or display mutation events
    });
    $adapter->setMutationDispatcher($dispatcher);
    ```
3. **Use adapter methods for mutations:**

    ```
    $adapter->setDefinition('foo', new Definition(Foo::class));
    $adapter->removeDefinition('foo');
    ```
4. **Inspect services and mutations:**

    ```
    use Inspector\Inspector;

    $inspector = new Inspector($adapter);
    $services = $inspector->browseServices();
    $mutations = $inspector->getMutations();
    ```

---

Test Coverage
-------------

[](#test-coverage)

To generate a coverage report locally:

```
vendor/bin/phpunit --coverage-html coverage
```

Open `coverage/index.html` in your browser to view the report.

---

Contributing
------------

[](#contributing)

Pull requests and issues are welcome!
Please ensure all code is covered by tests and passes CI.

---

License
-------

[](#license)

MIT

###  Health Score

15

—

LowBetter than 3% of packages

Maintenance42

Moderate activity, may be stable

Popularity0

Limited adoption so far

Community6

Small or concentrated contributor base

Maturity13

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/cd9caaa35c5286db0cca31ec62bfe427e0ca05a06d5ce7c5455ac83a6e9989ff?d=identicon)[papoon](/maintainers/papoon)

---

Top Contributors

[![papoon](https://avatars.githubusercontent.com/u/6783398?v=4)](https://github.com/papoon "papoon (42 commits)")

### Embed Badge

![Health badge](/badges/papoon-inspector/health.svg)

```
[![Health](https://phpackages.com/badges/papoon-inspector/health.svg)](https://phpackages.com/packages/papoon-inspector)
```

###  Alternatives

[mydnic/laravel-kustomer

A fully featured feedback component for Laravel, gather user feedbacks, chat, etc

41049.2k1](/packages/mydnic-laravel-kustomer)[halimtuhu/array-images

A Laravel Nova field for distribute your images as array of object.

1441.2k](/packages/halimtuhu-array-images)[samueltissot/wp_route

2017.6k](/packages/samueltissot-wp-route)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
