xobotyi / rsync
rsync wrapper library for php
Fund package maintenance!
Patreon
Installs: 29 410
Dependents: 1
Suggesters: 0
Security: 0
Stars: 95
Watchers: 9
Forks: 6
Open Issues: 1
Requires
- php: >=7.1
Requires (Dev)
- codacy/coverage: ^1.4.0
- phpunit/phpunit: ^6.5.3
This package is auto-updated.
Last update: 2024-12-22 02:04:14 UTC
README
About
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
Why Rsync?
- 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)
Requirements
- 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 +
Installation
Install with composer
composer require xobotyi/rsync
Docs
The code is well documented, for methods and parameters descriptions see the sources.
Usage
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";