Panel/modules/teamspeak3/site/iserverbackup.php
2025-09-11 13:29:15 -04:00

195 lines
No EOL
5.7 KiB
PHP

<?php
/*
*Copyright (C) 2010-2011 Psychokiller
*
*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 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 <http://www.gnu.org/licenses/>.
*/
if(!defined('SECURECHECK')) {die($lang['error_file_alone']);}
if($hoststatus===false) { echo $lang['nohoster']; } else {
if(!is_dir('site/backups/server/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'))
{
mkdir('site/backups/server/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/',0777);
}
if(!is_dir('site/backups/server/hostbackups/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'))
{
mkdir('site/backups/server/hostbackups/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/',0777);
}
$error = '';
$noerror = '';
$files='';
$serverlist=$ts3->serverList();
if(isset($_POST['hostbackup']))
{
$path='site/backups/server/hostbackups/';
}
else
{
$path='site/backups/server/';
}
if(isset($_POST['create']))
{
if($serverlist['success']===true)
{
foreach($serverlist['data'] AS $key=>$value)
{
$selectserver=$ts3->selectServer($value['virtualserver_port'], 'port', true);
if($selectserver['success']===true)
{
$snapshotcreate=$ts3->serverSnapshotCreate();
if($snapshotcreate['success']===true)
{
if(!is_dir($path.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.date("d-m-Y", time()).'/'))
{
mkdir($path.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.date("d-m-Y", time()).'/',0777);
}
$handler=fopen($path.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.date("d-m-Y", time()).'/server_'.time().'_'.$_SESSION['server_ip'].'-'.$value['virtualserver_port'].'.txt', 'a+');
fwrite($handler, $snapshotcreate['data']);
fclose($handler);
$noerror .= sprintf($lang['serverbackupok'], $_SESSION['server_ip'], $value['virtualserver_port']).'<br />';
}
else
{
$error .= sprintf($lang['serverbackuperr'], $_SESSION['server_ip'], $value['virtualserver_port']).'<br />';
}
}
else
{
$error .= sprintf($lang['serverbackuperr'], $_SESSION['server_ip'], $value['virtualserver_port']).'<br />';
}
}
}
else
{
$error .= $lang['serverlistcallerr'].'<br />';
}
}
if(isset($_POST['deploy']))
{
$handler=file($path.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.$_POST['backupdate'].'/server_'.$_POST['backupid'].'_'.$_POST['fileport'].'.txt');
$selectserver=$ts3->selectServer($_POST['deployon'], 'port', true);
if($selectserver['success']===true)
{
$snapshot_deploy=$ts3->serverSnapshotDeploy($handler[0]);
if($snapshot_deploy['success']===false)
{
for($i=0; $i+1==count($snapshot_deploy['errors']); $i++)
{
$error .= $snapshot_deploy['errors'][$i].'<br />';
}
}
else
{
$noerror .= $lang['serverbackdeployok'].'<br />';
}
}
else
{
for($i=0; $i+1==count($selectserver['errors']); $i++)
{
$error .= $selectserver['errors'][$i].'<br />';
}
}
}
if(isset($_POST['delete']))
{
if(@unlink($path.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.$_POST['backupdate'].'/server_'.$_POST['backupid'].'_'.$_POST['fileport'].'.txt'))
{
$noerror .= $lang['serverbackdelok'].'<br />';
}
else
{
$error .= $lang['serverbackdelerr'].'<br />';
}
}
if(isset($_POST['backupdate']))
{
$handler=@opendir('site/backups/server/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.$_POST['backupdate'].'/');
while($datei=@readdir($handler))
{
if($datei!='.' AND $datei!='..' AND $datei!='hostbackups')
{
$datei=str_replace('.txt', '', $datei);
$datei_info=explode('_', $datei);
$files[0][]=array('timestamp'=>$datei_info[1], 'server'=>$datei_info[2]);
}
}
}
$handler=@opendir('site/backups/server/hostbackups/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/');
while($datei=@readdir($handler))
{
if($datei!='.' AND $datei!='..')
{
$folder[1][]=$datei;
}
}
$handler=@opendir('site/backups/server/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/');
while($datei=@readdir($handler))
{
if($datei!='.' AND $datei!='..')
{
$folder[2][]=$datei;
}
}
if(isset($_POST['backupdate']))
{
$handler=@opendir('site/backups/server/hostbackups/'.$_SESSION['server_ip'].'-'.$_SESSION['server_tport'].'/'.$_POST['backupdate'].'/');
while($datei=@readdir($handler))
{
if($datei!='.' AND $datei!='..')
{
$datei=str_replace('.txt', '', $datei);
$datei_info=explode('_', $datei);
$files[1][]=array('timestamp'=>$datei_info[1], 'server'=>$datei_info[2]);
}
}
}
if(!empty($serverlist['data']))
{
foreach($serverlist['data'] AS $key=>$value)
{
$serverlist['data'][$key]=secure($serverlist['data'][$key]);
}
}
if(!empty($folder[1]))
{
foreach($folder[1] AS $key=>$value)
{
$getdate=explode('-', $value);
$newdate=mktime(0,0,0, $getdate[1], $getdate[0], $getdate[2]);
$folder[1][$key]=$newdate;
}
rsort($folder[1]);
foreach($folder[1] AS $key=>$value)
{
$newdate=date("d-m-Y", $value);
$folder[1][$key]=$newdate;
}
}
$smarty->assign('error', $error);
$smarty->assign('noerror', $noerror);
$smarty->assign('serverlist', $serverlist['data']);
if(isset($files)) $smarty->assign('files', $files);
if(isset($folder)) $smarty->assign('folder', $folder);
}
?>