1. Go to this page and download the library: Download afonzeca/arun library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
afonzeca / arun example snippets
namespace App\Console\Domains;
use ArunCore\Annotations as SET;
/**
* Class TableDomain
*
* @SET\DomainEnabled(true)
* @SET\DomainSyn("This Domain allows to interact with tables")
*
* @package App\Console\Domains
*/
class TableDomain extends DomainCommand
{
/**
*
* @SET\ActionEnabled(true)
* @SET\ActionSyn("This action allows to create a table with a specified name")
* @SET\ActionOption("--set-key=<name>:Set the primary key name")
* @SET\ActionOption("--use-camelCaseForNaming:Use camelCase for defining table name")
*
* @param string $tableName
*
* @throws \Exception
*/
public function create(string $tableName)
{
$this->cOut->writeln(sprintf("Creating table %s", $tableName));
}
}
public function create(string $tableName, string $primaryKey="id", string $defaultDb="mydb")
{
// It will print "users" because it is the parameter passed from CLI
printf("Default Db %s\n",$defaultDb);
// your code here
printf("Primary key %s\n",$primaryKey);
// your code here
printf("Creating table...%s\n",$tableName);
// your code here
//....
//other code...
//....
}
}
if($this->hasOption("u")){
printf("The value of -u is %s\n",$this->getOptionValue("u"));
}
use Monolog\Logger;
use Monolog\Handler\StreamHandler;
use Monolog\Formatter\LineFormatter;
return [
Psr\Log\LoggerInterface::class => DI\factory(function () {
$logger = new Logger('mylog');
$fileHandler = new StreamHandler('app/var/mylog.log', Logger::DEBUG);
$fileHandler->setFormatter(new LineFormatter());
$logger->pushHandler($fileHandler);
return $logger;
}),
];
namespace App\Console\Domains;
use ArunCore\Annotations as SET;
/**
* Class TableDomain
*
* @SET\DomainEnabled(true)
* @SET\DomainSyn("This Domain allows to interact with tables")
*
* @package App\Console\Domains
*/
class TableDomain extends DomainCommand
{
/**
* TableDomain constructor.
* @param \Psr\Log\LoggerInterface $logger
*/
protected $logger;
public function __construct(\Psr\Log\LoggerInterface $logger)
{
$this->logger = $logger;
}
/**
*
* @SET\ActionEnabled(true)
* @SET\ActionSyn("This method says hello to a specified name")
* @SET\ActionOption("--set-key=<name>:Set the primary key name")
* @SET\ActionOption("--use-camelCaseForNaming:Use camelCase for defining table name")
* @SET\ActionOption("--u=<value>:Set username to be used for the RDBMS")
* @SET\ActionOption("--l=<value>:Logs something")
*
* @param string $tableName
*
* @throws \Exception
*/
public function create(string $tableName, string $primaryKey = "id", string $defaultDb = "mydb")
{
// It will print "users" because it is the parameter passed from CLI
printf("Default Db %s\n", $defaultDb);
// your code here
printf("Primary key %s\n", $primaryKey);
// your code here
printf("Creating table...%s\n", $tableName);
// your code here
//....
//other code...
//....
if ($this->hasOption("u")) {
printf("The value of -u is %s\n", $this->getOptionValue("u"));
}
if ($this->hasOption("l")) {
$this->logger->error($this->getOptionValue("l"));
}
}
}
protected $logger;
public function __construct(\Psr\Log\LoggerInterface $logger)
{
$this->logger = $logger;
}
if ($this->hasOption("l")) {
$this->logger->error($this->getOptionValue("l"));
}
/**
* This file TableDomain.php has been generated by "Arun - CLI Microframework for Php7.2+" released under the following terms
*
* Copyright 2018 Angelo FONZECA ( https://www.linkedin.com/in/angelo-f-1806868/ )
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless ole\Domains;
use ArunCore\Annotations as SET;
/**
* Class TableDomain - This Domain allows to interact with tables
*
* @SET\DomainSyn("This Domain allows to interact with tables")
* @SET\DomainEnabled(true)
*
* @SET\DomainEOA("TableDomain")
*/
class TableDomain extends DomainCommand
{
}
...
...
...
namespace App\Console\Domains;
use ArunCore\Annotations as SET;
/**
* Class TableDomain - This Domain allows to interact with tables
*
* @SET\DomainSyn("This Domain allows to interact with tables")
* @SET\DomainEnabled(true)
*
* @SET\DomainEOA("TableDomain")
*/
class TableDomain extends DomainCommand
{
/**
*
* create - This action allows to create a table with a specified name
*
* @SET\ActionEnabled(true)
* @SET\ActionSyn("This action allows to create a table with a specified name")
*
* @SET\ActionEOA("create")
*/
public function create()
{
$this->cOut->writeln("This action must be defined.");
}
}
use ArunCore\Annotations as SET;
/**
* Class TableDomain - This Domain allows to interact with tables
*
* @SET\DomainSyn("This Domain allows to interact with tables")
* @SET\DomainEnabled(true)
*
* @SET\DomainEOA("TableDomain")
*/
class TableDomain extends DomainCommand
{
/**
*
* create - This action allows to create a table with a specified name
*
* @SET\ActionEnabled(true)
* @SET\ActionSyn("This action allows to create a table with a specified name")
*
* @var string $tableName
* @SET\ActionEOA("create")
*/
public function create(string $tableName)
{
$this->cOut->writeln(sprintf("Creating table %s", $tableName));
}
}
use ArunCore\Annotations as SET;
/**
* Class TableDomain - This Domain allows to interact with tables
*
* @SET\DomainSyn("This Domain allows to interact with tables")
* @SET\DomainEnabled(true)
*
* @SET\DomainEOA("TableDomain")
*/
class TableDomain extends DomainCommand
{
/**
*
* create - This action allows to create a table with a specified name
*
* @SET\ActionEnabled(true)
* @SET\ActionSyn("This action allows to create a table with a specified name")
*
* @var string $tableName
* @var string $primaryKey='id'
* @var string $defaultDb='mydb'
* @SET\ActionEOA("create")
*/
public function create(string $tableName, string $primaryKey='id', string $defaultDb='mydb')
{
$this->cOut->writeln(sprintf("Creating table %s", $tableName));
}
}
* @SET\ActionOption("--set-key=<name>:Set the primary key name")
* @SET\ActionOption("--use-camelCaseForNaming:Use camelCase for defining table name")