nowise/uup-application-options

Uniform CLI command line and HTTP request options.

1.0.6 2022-01-25 02:13 UTC

This package is auto-updated.

Last update: 2024-04-25 06:45:20 UTC


README

Supports transparent/uniform handling of runtime options from CLI command and HTTP request.

This package supports short/long options, other options and reading password from terminal (masked echo output). For HTTP request options, an optional filter can be applied.

USAGE:

In your command action class, define a method that checks whether to return command line options (CLI) or from request option (HTTP).

private function getApplicationOptions(): ApplicationOptionsInterface
{
    if (php_sapi_name() == 'cli') {
        return new CommandLineOptions();
    } else {
        return new HttpRequestOptions();
    }
}

Calling getApplicationOptions will provide uniform access to application options, whether these come from command line or the HTTP request. From your application perspective the origin of options is transparent.

From within the application, a number of convenient methods can be used for checking if options was passed and retrieve them with type safety.

public function setup() 
{
    $this->options = $this->getApplicationOptions();
}

public function execute(): void 
{
    // 
    // Example of setting defaults:
    // 
    if ($this->options->isMissing('user')) {
        $this->options->setOption('user', 'adam');
    }
    
    // 
    // Take action if option is defined:
    // 
    if ($this->options->hasOption('email')) {
        $this->sendEmail($this->options->getString('email'));
    }
}

A number of other getters exist, for example for boolean, float and integer values. These takes a second default value that is returned of option is missing.

ORIGIN:

If origin matters, it can be checked:

if ($this->options->getOrigin() == ApplicationOptionsInterface::ORIGIN_HTTP) {
    throw new RuntimeException("This action can't be run from a HTTP context");
}

OPTION ALIAS:

For command line options, the default behavior is to return options by stripping leading dashes ('-'). To support short command options mapped to long options, pass a mapping array.

private function getApplicationOptions(): ApplicationOptionsInterface
{
    if (php_sapi_name() == 'cli') {
        return new CommandLineOptions([
            '-f' => 'file',
            '-U' => 'user'
        ]);
    } else {
        return new HttpRequestOptions();
    }
}

These two short option will now be an alias for their equivalent long option. Some builtin aliases are implicit handled for command line options. These short options are:

  • -h => help
  • -V => version
  • -d => debug
  • -v => verbose
  • -q => quiet

These are processed before user defined mappings, making it possible to easily redefine the builtin mapping.

OPTION VALUES:

Option values are any value after the equal character ('='). For options without a value, the option key will be read having boolean true as its value.

DASHES:

Processing of command line options (CLI) will strip leading dashes and use the remaining string as the command option key.

OPTION FILTERING:

Command line options are considered safe. For HTTP request, it's possible to pass an array of sanitation filter to be applied.

private function getApplicationOptions(): ApplicationOptionsInterface
{
    if (php_sapi_name() == 'cli') {
        return new CommandLineOptions();
    } else {
        return new HttpRequestOptions(
            new HttpRequestFilter([
                'user'  => FILTER_SANITIZE_STRING,
                'email' => FILTER_SANITIZE_EMAIL
            ])
        );
    }
}

The default behavior is to not filter HTTP request options. For larger applications, some framework for purify HTML input might be used that could be wrapped in a class that implements the FilterInterface and used instead of passing an instance of the HttpRequestFilter class.

BOOLEANS:

Special treatment of boolean options are implemented. For example, option values "1", "true", "on" and "yes" yields true. Analogous "0", "false", "off" and "no" yields false.

Example: Call getBoolean to have the value for filter option evaluated as boolean.

$this->options->getBoolean("filter");