123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150 |
- #!/usr/bin/env php
- <?php
- /* Copyright (C) 2012 Laurent Destailleur <eldy@users.sourceforge.net>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- * or see https://www.gnu.org/
- *
- * Get a distant dump file and load it into a mysql database
- */
- $sapi_type = php_sapi_name();
- $script_file = basename(__FILE__);
- $path = dirname(__FILE__).'/';
- // Test if batch mode
- if (substr($sapi_type, 0, 3) == 'cgi') {
- echo "Error: You are using PHP for CGI. To execute ".$script_file." from command line, you must use PHP for CLI mode.\n";
- exit;
- }
- // Global variables
- $error = 0;
- $sourceserver = isset($argv[1]) ? $argv[1] : ''; // user@server:/src/file
- $password = isset($argv[2]) ? $argv[2] : '';
- $dataserver = isset($argv[3]) ? $argv[3] : '';
- $database = isset($argv[4]) ? $argv[4] : '';
- $loginbase = isset($argv[5]) ? $argv[5] : '';
- $passwordbase = isset($argv[6]) ? $argv[6] : '';
- // Include Dolibarr environment
- $res = 0;
- if (!$res && file_exists($path."../../master.inc.php")) {
- $res = @include $path."../../master.inc.php";
- }
- if (!$res && file_exists($path."../../htdocs/master.inc.php")) {
- $res = @include $path."../../htdocs/master.inc.php";
- }
- if (!$res && file_exists("../master.inc.php")) {
- $res = @include "../master.inc.php";
- }
- if (!$res && file_exists("../../master.inc.php")) {
- $res = @include "../../master.inc.php";
- }
- if (!$res && file_exists("../../../master.inc.php")) {
- $res = @include "../../../master.inc.php";
- }
- if (!$res && preg_match('/\/nltechno([^\/]*)\//', $_SERVER["PHP_SELF"], $reg)) {
- $res = @include $path."../../../dolibarr".$reg[1]."/htdocs/master.inc.php"; // Used on dev env only
- }
- if (!$res && preg_match('/\/nltechno([^\/]*)\//', $_SERVER["PHP_SELF"], $reg)) {
- $res = @include "../../../dolibarr".$reg[1]."/htdocs/master.inc.php"; // Used on dev env only
- }
- if (!$res) {
- die("Failed to include master.inc.php file\n");
- }
- include_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
- /*
- * Main
- */
- $login = '';
- $server = '';
- if (preg_match('/^(.*)@(.*):(.*)$/', $sourceserver, $reg)) {
- $login = $reg[1];
- $server = $reg[2];
- $sourcefile = $reg[3];
- $targetfile = basename($sourcefile);
- }
- if (empty($sourceserver) || empty($server) || empty($login) || empty($sourcefile) || empty($password) || empty($database) || empty($loginbase) || empty($passwordbase)) {
- print "Usage: $script_file login@server:/src/file.(sql|gz|bz2) passssh databaseserver databasename loginbase passbase\n";
- print "Return code: 0 if success, <>0 if error\n";
- print "Warning, this script may take a long time.\n";
- exit(-1);
- }
- $targetdir = '/tmp';
- print "Get dump file from server ".$server.", path ".$sourcefile.", connect with login ".$login." loaded into localhost\n";
- $sftpconnectstring = $sourceserver;
- print 'SFTP connect string : '.$sftpconnectstring."\n";
- //print 'SFTP password '.$password."\n";
- // SFTP connect
- if (!function_exists("ssh2_connect")) {
- dol_print_error('', 'ssh2_connect function does not exists');
- exit(1);
- }
- $connection = ssh2_connect($server, 22);
- if ($connection) {
- if (!@ssh2_auth_password($connection, $login, $password)) {
- dol_syslog("Could not authenticate with username ".$login." . and password ".preg_replace('/./', '*', $password), LOG_ERR);
- exit(-5);
- } else {
- //$stream = ssh2_exec($connection, '/usr/bin/php -i');
- /*
- print "Generate dump ".$filesys1.'.bz2'."\n";
- $stream = ssh2_exec($connection, "mysqldump -u debian-sys-maint -p4k9Blxl2snq4FHXY -h 127.0.0.1 --single-transaction -K --tables -c -e --hex-blob --default-character-set=utf8 saasplex | bzip2 -1 > ".$filesys1.'.bz2');
- stream_set_blocking($stream, true);
- // The command may not finish properly if the stream is not read to end
- $output = stream_get_contents($stream);
- */
- $sftp = ssh2_sftp($connection);
- print 'Get file '.$sourcefile.' into '.$targetdir.$targetfile."\n";
- ssh2_scp_recv($connection, $sourcefile, $targetdir.$targetfile);
- $fullcommand = "cat ".$targetdir.$targetfile." | mysql -h".$databaseserver." -u".$loginbase." -p".$passwordbase." -D ".$database;
- if (preg_match('/\.bz2$/', $targetfile)) {
- $fullcommand = "bzip2 -c -d ".$targetdir.$targetfile." | mysql -h".$databaseserver." -u".$loginbase." -p".$passwordbase." -D ".$database;
- }
- if (preg_match('/\.gz$/', $targetfile)) {
- $fullcommand = "gzip -d ".$targetdir.$targetfile." | mysql -h".$databaseserver." -u".$loginbase." -p".$passwordbase." -D ".$database;
- }
- print "Load dump with ".$fullcommand."\n";
- $output = array();
- $return_var = 0;
- print strftime("%Y%m%d-%H%M%S").' '.$fullcommand."\n";
- exec($fullcommand, $output, $return_var);
- foreach ($output as $line) {
- print $line."\n";
- }
- //ssh2_sftp_unlink($sftp, $fileinstalllock);
- //print $output;
- }
- } else {
- print 'Failed to connect to ssh2 to '.$server;
- exit(-6);
- }
- exit(0);
|