joseki/console

Simple Symfony Console integration to Nette Framework

v0.2.2 2015-12-17 07:34 UTC

This package is auto-updated.

Last update: 2024-09-05 21:19:05 UTC


README

Build Status Latest Stable Version

Requirements

Joseki/Console requires PHP 5.4 or higher.

Installation

The best way to install Joseki/Console is using Composer:

$ composer require joseki/console

Setup

  • create file e.g. app/console with the following content:
#!/usr/bin/env php
<?php
/** @var Nette\DI\Container $container */
$container = require __DIR__ . '/bootstrap.php';
$application = $container->getService('Console.cli');
$application->run();
  • register compiler extension in your config.neon:
extensions:
  Console: Joseki\Console\DI\ConsoleExtension
  • profit

Usage

Your console commands can be added via config.neon as a service with a joseki.console.command tag:

services:
  - class: Your\Own\Command
    tags: ['joseki.console.command']

or your can directly register it under Console compiler extension:

Console:
  commands:
    - Your\Own\Command

Running a console command

app/console yourCommandName

Too many commands? Long command names (including namespaces)?

Split your commands by their namespaces into separate console scripts. Separate your cron script from your database generators or migrations or whatever groups of commands you have. Simply register your console alias and namespace prefix of you commands group as follows:

Console:
  console:
    cron: 'myapp:crons'       # accepts only commands from 'myapp:crons' namespace, eg. 'myapp:crons:emails'

Then create a new console file bin/cron:

#!/usr/bin/env php
<?php
/** @var Nette\DI\Container $container */
$container = require __DIR__ . '/bootstrap.php';
$application = $container->getService('Console.console.cron');
$application->run();

and run your commands with suffix name only. Compare old:

app/console myapp:crons:emails

with newly created way:

app/cron emails