strukt / console
Strukt CLI Console
1.0.0
2025-03-26 19:39 UTC
Requires
- php: >=7.0
- strukt/fs: 1.1.0
This package is auto-updated.
Last update: 2025-03-31 21:47:27 UTC
README
This is a console framework that utilises DocBlock
to parse command description and format.
Block Spaces (IMPORTANT)
This package uses DocBlock
to generate your commands. The DocBlock
must be in single spaces
and NOT tabs. Be conservative with the spaces and don't leave any that are unnecessary
otherwise the commands will not work.
Usage
Sample Command:
namespace Command; use Strukt\Console\Input; use Strukt\Console\Output; use \Strukt\Console\Command as AbstractCommand; /** * mysql:auth MySQL Authentication * * Usage: * * mysql:auth <database> --username <username> --password <password> [--host <127.0.0.1>] * * Arguments: * * database MySQL database name - optional argument * * Options: * * --username -u MySQL Username * --password -p MySQL Password * --host -h MySQL Host - optional default 127.0.0.1 */ class MySQLAuth extends AbstractCommand{ public function execute(Input $in, Output $out){ $out->add(sprintf("%s:%s:%s", $in->get("database"), $in->get("username"), $in->get("password"))); } }
Add this in your executable file:
#!/usr/bin/php <?php $app = new Strukt\Console\Application("Strukt Console"); $app->add(new Command\MySQLAuth); $app->run($_SERVER["argv"]);
Call command:
php console mysql:auth payroll -u root -p p@55w0rd
Prompt for input and masked input, you may but need not describe promted input in command docblock:
... //prompt for input $username = $in->getInput("Username:"); $nickname = $in->getInput("Nickname:"); //masked input $password = $in->getMaskedInput("Password:"); $cpassword = $in->getMaskedInput("Confirm Password:"); ...