xman12/psysh-bundle

A port of the PHP REPL PsySH for Symfony.

Maintainers

Package info

github.com/xman12/PsyshBundle

Type:symfony-bundle

pkg:composer/xman12/psysh-bundle

Fund package maintenance!

theofidry

Statistics

Installs: 2

Dependents: 0

Suggesters: 0

Stars: 0

1.0.3 2026-04-06 08:40 UTC

This package is auto-updated.

Last update: 2026-04-06 08:41:33 UTC


README

Package version Build Status License

A bundle to use the PHP REPL PsySH with Symfony. Learn more at psysh.org.

Requirements: PHP 8.1+, Symfony 6.4+

What does it do?

  • Loads PsySH with the full application container
  • Exposes the following variables out of the box:
Variable Description
$container The Symfony service container (TestContainer)
$kernel The application kernel
$parameters All container parameters
$self The PsySH shell instance itself

You can also add your own variables via configuration.

Documentation

  1. Install
  2. Usage
    1. PsySH as a debugger
    2. Reflect like a boss
    3. PsySH for breakpoints
  3. Customize PsySH
  4. Credits

Install

Install via Composer:

composer require --dev xman12/psysh-bundle

With Symfony Flex, the bundle is registered automatically in config/bundles.php. If you manage bundles manually, add it only for dev/test environments:

// config/bundles.php
return [
    // ...
    xman12\PsyshBundle\PsyshBundle::class => ['dev' => true, 'test' => true],
];

Usage

Interactive shell

bin/console psysh

Once inside the shell, you have immediate access to $container, $kernel, $parameters and $self.

PsySH Shell

Inline breakpoints

Place a psysh() call anywhere in your code to drop into an interactive shell at that point:

use function xman12\PsyshBundle\psysh;

class OrderService
{
    public function process(Order $order): void
    {
        // Drop into a shell with $order available and the current object bound
        psysh(['order' => $order], $this);
    }
}

Go further with the docs.

Customize PsySH

Adding a custom command

Tag any class extending Psy\Command\Command with psysh.command. With autoconfigure enabled (the default in Symfony 6.4), no explicit tag is needed — the bundle detects these classes automatically:

# config/services.yaml
services:
    _defaults:
        autoconfigure: true
        autowire: true

    Acme\Shell\MyCommand: ~

To add the tag explicitly:

services:
    Acme\Shell\MyCommand:
        tags:
            - { name: psysh.command }

The bundle autoconfigures any service that inherits from Psy\Command\Command or Psy\Command\ReflectingCommand.

Adding custom variables

Declare extra shell variables in config/packages/dev/psysh.yaml:

# config/packages/dev/psysh.yaml
psysh:
    variables:
        foo: bar
        router: "@router"
        some: [thing, else]
        debug: "%kernel.debug%"

Variables can be:

  • scalar values
  • container parameter references (e.g. %kernel.debug%)
  • service references (prefixed with @, e.g. "@router")
  • arrays

After running bin/console psysh, inspect available variables with ls:

>>> ls
Variables: $container, $kernel, $parameters, $self, $foo, $router, $some, $debug

Credits

This bundle is developed by Théo FIDRY. This project has been made possible thanks to: