2017 © Pedro Peláez
 

library shellwrap

Use any command-line tool as a PHP function.

image

deminy/shellwrap

Use any command-line tool as a PHP function.

  • Friday, June 29, 2018
  • by deminy
  • Repository
  • 1 Watchers
  • 0 Stars
  • 32 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 57 Forks
  • 0 Open issues
  • 8 Versions
  • 0 % Grown

The README.md

ShellWrap

What is it?

It's a beautiful way to use powerful Linux/Unix tools in PHP. Easily and logically pipe commands together, capture errors as PHP Exceptions and use a simple yet powerful syntax. Works with any command line tool automagically., (*1)

Features

  • Flexible and sexy syntax.
  • Exceptions are thrown if the executable returns an error.
  • Paths to binaries are automatically resolved.
  • All arguments are properly escaped.
  • Callback functions for streaming output.

Examples

 true
)));

// Touch a file to create it
sh::touch('file.html');

// Remove file
sh::rm('file.html');

// Remove file again (this fails, and throws an exception because the file doesn't exist)

try {
    sh::rm('file.html');
} catch (ShellWrapException $e) {
    echo 'Caught failing sh::rm() call';
}


// This throws an exception, as 'invalidoption' is not a valid argument
try {
    echo sh::ls(array('invalidoption' => true));
} catch (ShellWrapException $e) {
    echo 'Caught failing sh::ls() call';
}

// Commands can be written multiple ways
sh::git('reset', array('hard' => true), 'HEAD');
sh::git('reset', '--hard', 'HEAD');
sh::git(array('reset', '--hard', 'HEAD'));

// Arguments passed in are automatically escaped, this expands to
// date --date '2012-10-10 10:00:00'
echo sh::date(array(
    'date' => '2012-10-10 10:00:00'
));

// If arg keys are one letter, is assumes one dash prefixing it
// date -d '2012-10-10 10:00:00'
echo sh::date(array(
    'd' => '2012-10-10 10:00:00'
));


?>

Example: Tailing a file and adding timestamps to output

You can stream the output of a command into a callback function. For example:, (*2)

sh::tail('-f log', function($in) {
    echo "\033[32m" . date('Y-m-d H:i:s') . "\033[39m " . $in;
});

Make sure the file 'log' exists. This will output a timestamp, and the input. Try echoing into the log file., (*3)

The escape codes are to add a little colour to the terminal., (*4)

Interactive Shell

ShellWrap also ships with an interactive shell mode. You can access this by typing:, (*5)

./bin/shellwrap

Warning

Don't use any user inputted data with these commands. Even with very paranoid filtering, you can't know all the potential pitfalls of each command you're using. Use your noggin., (*6)

Acknowledgements

Inspired by the Python project sh by Andrew Moffat, (*7)

The Versions

29/06 2018

dev-master

9999999-dev http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

 

api command command-line exec shell

16/06 2018

dev-fix-cwd

dev-fix-cwd http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

 

api command command-line exec shell

28/12 2016

dev-feature-chain

dev-feature-chain http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

 

api command command-line exec shell

28/12 2016

dev-feature-tidy

dev-feature-tidy http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

 

api command command-line exec shell

23/12 2013

0.4.1

0.4.1.0 http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

 

api command command-line exec shell

23/12 2013

0.4.0

0.4.0.0 http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

 

api command command-line exec shell

13/08 2013

0.3.0

0.3.0.0 http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function.

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

api command command-line exec shell

15/10 2012

0.2.0

0.2.0.0 http://github.com/MrRio/shellwrap

Use any command-line tool as a PHP function

  Sources   Download

MIT

The Requires

  • php >=5.3.0

 

api command command-line exec shell