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/consolewith 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\Commandapp/console yourCommandNameSplit 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:emailswith newly created way:
app/cron emails