Rsync is a pure PHP 7.1+ dependency-free wrapper for rsync client. It provides you a simple way to abstract from command line control rsync right from php. Library uses PSR-4 autoloader standard and always has 100% tests coverage.
There is no need to tell about rsync, except the fact that php doesn't has any faster or equal built-in way to upload files to remote server.
Library supports whole bunch of options and parameters implemented in rsync client version 3.1.2
- It is small and fully covered with tests
- It is well documented
- I'm eating my own sweet pie=)
- Supports whole bunch of parameters and options of rsync and ssh
- Easy to use
- Works on Windows (ofcourse id you installed ssh and rsync clients for Windows)
- PHP 7.1+
- PHP config
variables_order
must containE
, 4ex:variables_order=EGPCS
.
Otherwise you will have to manually specify absolute path to rsync and ssh binaries (at least on Windows) - rsync client 3.1.2 +
Install with composer
composer require xobotyi/rsync
The code is well documented, for methods and parameters descriptions see the sources.
Simplest:
use xobotyi\rsync\Rsync;
$rsync = new Rsync();
$rsync->sync('/path/to/source', '/path/to/destination');
If you need SSH:
use xobotyi\rsync\Rsync;
use xobotyi\rsync\SSH;
$rsync = new Rsync([
Rsync::CONF_CWD => __DIR__,
Rsync::CONF_EXECUTABLE => '/even/alternative/executable/rsync.exe',
Rsync::CONF_SSH => [
SSH::CONF_EXECUTABLE => '/even/alternative/executable/ssh.exe',
SSH::CONF_OPTIONS => [
SSH::OPT_OPTION => ['BatchMode=yes', 'StrictHostKeyChecking=no'],
SSH::OPT_IDENTIFICATION_FILE => './path/to/ident',
SSH::OPT_PORT => 2222,
],
],
]);
$rsync->sync('./relative/path/to/source', 'user@some.remote.lan:/abs/path/to/destination');
echo './relative/path/to/source ' . ($rsync->getExitCode() === 0 ? 'successfully synchronized with remote.' : 'not synchronised due to errors.') . "\n";
$rsync->setExecutable('ssh')
->setOption(SSH::OPT_OPTION, false)// 'false' value turns off the options
->setOptions([
SSH::OPT_IDENTIFICATION_FILE => './new/path/to/ident',
SSH::OPT_PORT => 22,
]);
$rsync->sync('/new/path/to/source', 'user@some.remote.lan:/abs/path/to/destination');
echo '/new/path/to/source ' . ($rsync->getExitCode() === 0 ? 'successfully synchronized with remote.' : 'not synchronised due to errors.') . "\n";