Joseki/Console requires PHP 5.4 or higher.
The best way to install Joseki/Console is using Composer:
$ composer require joseki/console
- 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
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
app/console yourCommandName
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