PrestaShop Developer Conference
PrestaShop Developer Conference
Hybrid format! Paris, France & Online - November 19, 2025
Let's talk code, commerce and open source.

Warning: You are browsing the documentation for PrestaShop 8, which is outdated.

You might want to read an updated version of this page for the current version, PrestaShop 9. Read the updated version of this page

Learn how to update to the latest version.

CLI Context helper

The legacy framework of PrestaShop was not built to be run from a Command Line.

The consequence is that many of its functions require specific data to be properly initialized, and these parts are being initialized when an HTTP request is handled by the framework.

In order to use legacy classes and components in Console, you need to initialize these parts. To make it easy, you can use the LegacyContextLoader helper class.

It loads the needed property in Context using, when needed, a fake Employee or Controller instance.

It is available as a Symfony service prestashop.adapter.legacy_context_loader.

Example:

MyCustomCommand extends ContainerAwareCommand
{

    protected function configure()
    {
        $this->setName('my-custom-command');
    }

    protected function execute(InputInterface $input, OutputInterface $output)
    {
        $this->getContainer()->get('prestashop.adapter.legacy_context_loader')->loadGenericContext();
        
        ...
    }
});

You can load a generic context thanks to loadGenericContext() or choose which data you want to initialize using the method of LegacyContextLoader.