1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
|
<?php
/**
* Database class to create backups
*
* This file is part of Zoph.
*
* Zoph 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 2 of the License, or
* (at your option) any later version.
*
* Zoph 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 Zoph; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* @package Zoph
* @author Jeroen Roos
*/
namespace db;
use db\exception\backup as databaseBackupException;
/**
* Create a backup of the database
*
* @package Zoph
* @author Jeroen Roos
*/
class backup {
private $host;
private $dbname;
private $user;
private $pass;
public function __construct(string $rootpwd = null) {
$db=db::getLoginDetails();
$this->host = escapeshellarg($db["host"]);
$this->dbname = escapeshellarg($db["dbname"]);
if ($rootpwd) {
$this->user = escapeshellarg("root");
$this->pass = escapeshellarg($rootpwd);
} else {
$this->user = escapeshellarg($db["user"]);
$this->pass = escapeshellarg($db["pass"]);
}
}
public function execute() {
$mysqldumpDescSpec = array(
1 => array("pipe", "w"),
2 => array("pipe", "w")
);
$mysqldump = proc_open("mysqldump" .
" -h " . $this->host .
" -u " . $this->user .
" -p" . $this->pass .
" " . $this->dbname, $mysqldumpDescSpec, $mysqlPipes);
$backup = stream_get_contents($mysqlPipes[1]);
$mysqlError = stream_get_contents($mysqlPipes[2]);
if (proc_close($mysqldump) !== 0) {
throw new databaseBackupException("MySQL: " . $mysqlError);
}
return gzencode($backup, 9);
}
}
|