2013-12-17 17:38:44 +01:00
< ? php
2014-02-10 22:54:49 +01:00
namespace ManiaControl\Update ;
2013-12-17 17:38:44 +01:00
use ManiaControl\Admin\AuthenticationManager ;
use ManiaControl\Callbacks\CallbackListener ;
2014-01-31 00:04:40 +01:00
use ManiaControl\Callbacks\TimerListener ;
2013-12-17 17:38:44 +01:00
use ManiaControl\Commands\CommandListener ;
2014-05-02 17:50:30 +02:00
use ManiaControl\Files\BackupUtil ;
2014-02-10 16:52:16 +01:00
use ManiaControl\Files\FileUtil ;
2014-08-05 01:49:13 +02:00
use ManiaControl\Logger ;
2014-02-10 22:54:49 +01:00
use ManiaControl\ManiaControl ;
2013-12-17 17:38:44 +01:00
use ManiaControl\Players\Player ;
use ManiaControl\Players\PlayerManager ;
/**
2014-05-02 04:03:33 +02:00
* Manager checking for ManiaControl Core Updates
2014-05-02 17:50:30 +02:00
*
* @ author ManiaControl Team < mail @ maniacontrol . com >
* @ copyright 2014 ManiaControl Team
* @ license http :// www . gnu . org / licenses / GNU General Public License , Version 3
2013-12-17 17:38:44 +01:00
*/
2014-01-31 00:04:40 +01:00
class UpdateManager implements CallbackListener , CommandListener , TimerListener {
2014-01-19 22:32:09 +01:00
/*
2013-12-17 17:38:44 +01:00
* Constants
*/
2014-05-24 16:39:12 +02:00
const SETTING_ENABLE_UPDATECHECK = 'Enable Automatic Core Update Check' ;
2014-05-02 17:50:30 +02:00
const SETTING_UPDATECHECK_INTERVAL = 'Core Update Check Interval (Hours)' ;
const SETTING_UPDATECHECK_CHANNEL = 'Core Update Channel (release, beta, nightly)' ;
const SETTING_PERFORM_BACKUPS = 'Perform Backup before Updating' ;
const SETTING_AUTO_UPDATE = 'Perform update automatically' ;
const SETTING_PERMISSION_UPDATE = 'Update Core' ;
2014-01-31 16:55:01 +01:00
const SETTING_PERMISSION_UPDATECHECK = 'Check Core Update' ;
2014-05-02 17:50:30 +02:00
const CHANNEL_RELEASE = 'release' ;
const CHANNEL_BETA = 'beta' ;
const CHANNEL_NIGHTLY = 'nightly' ;
2014-05-02 04:03:33 +02:00
/*
2014-07-25 16:28:47 +02:00
* Public properties
2014-05-02 04:03:33 +02:00
*/
2014-05-04 15:09:11 +02:00
/** @var PluginUpdateManager $pluginUpdateManager */
2014-08-03 01:34:18 +02:00
/** @deprecated see getPluginUpdateManager() */
2014-05-02 04:03:33 +02:00
public $pluginUpdateManager = null ;
2014-05-02 17:50:30 +02:00
2014-01-19 22:32:09 +01:00
/*
2014-07-25 16:28:47 +02:00
* Private properties
2013-12-17 17:38:44 +01:00
*/
2014-05-04 15:09:11 +02:00
/** @var ManiaControl $maniaControl */
2013-12-17 17:38:44 +01:00
private $maniaControl = null ;
2014-05-02 04:03:33 +02:00
private $currentBuildDate = null ;
2014-07-25 16:28:47 +02:00
/** @var UpdateData $coreUpdateData */
private $coreUpdateData = null ;
2013-12-17 17:38:44 +01:00
/**
2014-08-03 01:34:18 +02:00
* Construct a new update manager instance
2014-05-02 17:50:30 +02:00
*
2013-12-31 17:17:40 +01:00
* @ param ManiaControl $maniaControl
2013-12-17 17:38:44 +01:00
*/
public function __construct ( ManiaControl $maniaControl ) {
$this -> maniaControl = $maniaControl ;
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
// Settings
$this -> maniaControl -> getSettingManager () -> initSetting ( $this , self :: SETTING_ENABLE_UPDATECHECK , true );
$this -> maniaControl -> getSettingManager () -> initSetting ( $this , self :: SETTING_AUTO_UPDATE , true );
$this -> maniaControl -> getSettingManager () -> initSetting ( $this , self :: SETTING_UPDATECHECK_INTERVAL , 1 );
$this -> maniaControl -> getSettingManager () -> initSetting ( $this , self :: SETTING_UPDATECHECK_CHANNEL , $this -> getUpdateChannels ());
$this -> maniaControl -> getSettingManager () -> initSetting ( $this , self :: SETTING_PERFORM_BACKUPS , true );
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
// Callbacks
$updateInterval = $this -> maniaControl -> getSettingManager () -> getSettingValue ( $this , self :: SETTING_UPDATECHECK_INTERVAL );
$this -> maniaControl -> getTimerManager () -> registerTimerListening ( $this , 'hourlyUpdateCheck' , 1000 * 60 * 60 * $updateInterval );
$this -> maniaControl -> getCallbackManager () -> registerCallbackListener ( PlayerManager :: CB_PLAYERCONNECT , $this , 'handlePlayerJoined' );
$this -> maniaControl -> getCallbackManager () -> registerCallbackListener ( PlayerManager :: CB_PLAYERDISCONNECT , $this , 'handlePlayerDisconnect' );
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
// Permissions
$this -> maniaControl -> getAuthenticationManager () -> definePermissionLevel ( self :: SETTING_PERMISSION_UPDATE , AuthenticationManager :: AUTH_LEVEL_ADMIN );
$this -> maniaControl -> getAuthenticationManager () -> definePermissionLevel ( self :: SETTING_PERMISSION_UPDATECHECK , AuthenticationManager :: AUTH_LEVEL_MODERATOR );
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
// Chat commands
$this -> maniaControl -> getCommandManager () -> registerCommandListener ( 'checkupdate' , $this , 'handle_CheckUpdate' , true , 'Checks if there is a core update.' );
$this -> maniaControl -> getCommandManager () -> registerCommandListener ( 'coreupdate' , $this , 'handle_CoreUpdate' , true , 'Performs the core update.' );
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
// Children
2014-05-02 04:03:33 +02:00
$this -> pluginUpdateManager = new PluginUpdateManager ( $maniaControl );
}
2014-05-18 21:46:10 +02:00
/**
2014-07-25 16:28:47 +02:00
* Get the possible update channels
2014-05-18 21:46:10 +02:00
*
2014-05-27 23:00:39 +02:00
* @ return string []
2014-05-18 21:46:10 +02:00
*/
public function getUpdateChannels () {
// TODO: change default channel on release
return array ( self :: CHANNEL_BETA , self :: CHANNEL_RELEASE , self :: CHANNEL_NIGHTLY );
}
2014-07-25 16:28:47 +02:00
/**
* Return the plugin update manager
*
* @ return PluginUpdateManager
*/
public function getPluginUpdateManager () {
return $this -> pluginUpdateManager ;
}
2013-12-17 17:38:44 +01:00
/**
2014-02-10 16:46:41 +01:00
* Perform Hourly Update Check
2013-12-17 17:38:44 +01:00
*/
2014-06-14 15:48:27 +02:00
public function hourlyUpdateCheck () {
2014-08-03 01:34:18 +02:00
$updateCheckEnabled = $this -> maniaControl -> getSettingManager () -> getSettingValue ( $this , self :: SETTING_ENABLE_UPDATECHECK );
2014-01-28 16:23:50 +01:00
if ( ! $updateCheckEnabled ) {
2014-05-02 04:03:33 +02:00
$this -> setCoreUpdateData ();
2014-06-14 15:48:27 +02:00
} else {
$this -> checkUpdate ();
2013-12-17 17:38:44 +01:00
}
}
2014-05-02 17:50:30 +02:00
/**
* Set Core Update Data
*
* @ param UpdateData $coreUpdateData
*/
public function setCoreUpdateData ( UpdateData $coreUpdateData = null ) {
$this -> coreUpdateData = $coreUpdateData ;
}
/**
* Start an Update Check
*/
public function checkUpdate () {
$this -> checkCoreUpdateAsync ( array ( $this , 'handleUpdateCheck' ));
}
/**
* Checks a Core Update asynchronously
*
* @ param callable $function
*/
2014-05-04 15:09:11 +02:00
public function checkCoreUpdateAsync ( $function ) {
2014-05-02 17:50:30 +02:00
$updateChannel = $this -> getCurrentUpdateChannelSetting ();
$url = ManiaControl :: URL_WEBSERVICE . 'versions?current=1&channel=' . $updateChannel ;
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getFileReader () -> loadFile ( $url , function ( $dataJson , $error ) use ( & $function ) {
2014-06-14 15:48:27 +02:00
if ( $error ) {
2014-08-05 01:49:13 +02:00
Logger :: logError ( 'Error on UpdateCheck: ' . $error );
2014-06-14 15:48:27 +02:00
return ;
}
2014-05-02 17:50:30 +02:00
$versions = json_decode ( $dataJson );
if ( ! $versions || ! isset ( $versions [ 0 ])) {
2014-05-07 21:09:13 +02:00
call_user_func ( $function );
2014-05-02 17:50:30 +02:00
} else {
$updateData = new UpdateData ( $versions [ 0 ]);
call_user_func ( $function , $updateData );
}
});
}
/**
* Retrieve the Update Channel Setting
*
* @ return string
*/
2014-05-04 15:09:11 +02:00
public function getCurrentUpdateChannelSetting () {
2014-08-03 01:34:18 +02:00
$updateChannel = $this -> maniaControl -> getSettingManager () -> getSettingValue ( $this , self :: SETTING_UPDATECHECK_CHANNEL );
2014-05-02 17:50:30 +02:00
$updateChannel = strtolower ( $updateChannel );
2014-05-18 21:46:10 +02:00
if ( ! in_array ( $updateChannel , $this -> getUpdateChannels ())) {
2014-05-02 17:50:30 +02:00
$updateChannel = self :: CHANNEL_RELEASE ;
}
return $updateChannel ;
}
2013-12-17 17:38:44 +01:00
/**
2014-05-07 21:09:13 +02:00
* Handle the fetched Update Data of the hourly Check
2014-05-02 17:50:30 +02:00
*
2014-05-02 04:03:33 +02:00
* @ param UpdateData $updateData
2013-12-17 17:38:44 +01:00
*/
2014-05-07 21:09:13 +02:00
public function handleUpdateCheck ( UpdateData $updateData = null ) {
2014-05-02 04:03:33 +02:00
if ( ! $this -> checkUpdateData ( $updateData )) {
// No new update available
2014-01-20 21:54:58 +01:00
return ;
}
2014-05-02 04:03:33 +02:00
if ( ! $this -> checkUpdateDataBuildVersion ( $updateData )) {
// Server incompatible
2014-08-05 01:49:13 +02:00
Logger :: logError ( " Please update Your Server to ' { $updateData -> minDedicatedBuild } ' in order to receive further Updates! " );
2014-01-20 21:54:58 +01:00
return ;
}
2014-05-02 17:50:30 +02:00
2014-05-07 21:09:13 +02:00
if ( $this -> coreUpdateData != $updateData ) {
if ( $this -> isNightlyUpdateChannel ()) {
2014-08-05 01:49:13 +02:00
Logger :: log ( " New Nightly Build ( { $updateData -> releaseDate } ) available! " );
2014-05-07 21:09:13 +02:00
} else {
2014-08-05 01:49:13 +02:00
Logger :: log ( " New ManiaControl Version { $updateData -> version } available! " );
2014-05-07 21:09:13 +02:00
}
$this -> setCoreUpdateData ( $updateData );
2014-05-02 04:03:33 +02:00
}
2014-05-02 17:50:30 +02:00
2014-05-02 04:03:33 +02:00
$this -> checkAutoUpdate ();
2013-12-17 17:38:44 +01:00
}
2014-01-20 21:54:58 +01:00
/**
2014-05-02 04:03:33 +02:00
* Check if the given Update Data has a new Version and fits for the Server
2014-05-02 17:50:30 +02:00
*
2014-05-02 04:03:33 +02:00
* @ param UpdateData $updateData
* @ return bool
2014-01-20 21:54:58 +01:00
*/
2014-05-02 04:03:33 +02:00
public function checkUpdateData ( UpdateData $updateData = null ) {
if ( ! $updateData || ! $updateData -> url ) {
// Data corrupted
return false ;
2014-01-20 21:54:58 +01:00
}
2014-05-02 17:50:30 +02:00
2014-05-02 04:03:33 +02:00
$isNightly = $this -> isNightlyUpdateChannel ();
$buildDate = $this -> getNightlyBuildDate ();
2014-05-02 17:50:30 +02:00
2014-05-02 04:03:33 +02:00
if ( $isNightly || $buildDate ) {
return $updateData -> isNewerThan ( $buildDate );
2014-04-14 14:38:00 +02:00
}
2014-05-02 17:50:30 +02:00
2014-05-02 04:03:33 +02:00
return ( $updateData -> version > ManiaControl :: VERSION );
2014-01-20 21:54:58 +01:00
}
2014-05-02 17:50:30 +02:00
/**
* Check if ManiaControl is running the Nightly Update Channel
*
* @ param string $updateChannel
* @ return bool
*/
public function isNightlyUpdateChannel ( $updateChannel = null ) {
if ( ! $updateChannel ) {
$updateChannel = $this -> getCurrentUpdateChannelSetting ();
}
return ( $updateChannel === self :: CHANNEL_NIGHTLY );
}
/**
* Get the Build Date of the local Nightly Build Version
*
* @ return string
*/
public function getNightlyBuildDate () {
if ( ! $this -> currentBuildDate ) {
2014-05-03 21:37:28 +02:00
$nightlyBuildDateFile = ManiaControlDir . 'core' . DIRECTORY_SEPARATOR . 'nightly_build.txt' ;
2014-05-02 17:50:30 +02:00
if ( file_exists ( $nightlyBuildDateFile )) {
$this -> currentBuildDate = file_get_contents ( $nightlyBuildDateFile );
}
}
return $this -> currentBuildDate ;
}
2013-12-17 17:38:44 +01:00
/**
2014-05-02 04:03:33 +02:00
* Check if the Update Data is compatible with the Server
2014-05-02 17:50:30 +02:00
*
2014-05-02 04:03:33 +02:00
* @ param UpdateData $updateData
* @ return bool
2013-12-17 17:38:44 +01:00
*/
2014-05-02 04:03:33 +02:00
public function checkUpdateDataBuildVersion ( UpdateData $updateData = null ) {
if ( ! $updateData ) {
// Data corrupted
return false ;
2014-04-29 23:53:55 +02:00
}
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
$version = $this -> maniaControl -> getClient () -> getVersion ();
2014-05-02 04:03:33 +02:00
if ( $updateData -> minDedicatedBuild > $version -> build ) {
// Server not compatible
return false ;
2014-04-16 01:22:31 +02:00
}
2014-05-02 17:50:30 +02:00
return true ;
2014-02-10 21:32:41 +01:00
}
2013-12-31 18:25:07 +01:00
/**
2014-05-02 04:03:33 +02:00
* Check if an automatic Update should be performed
2013-12-31 18:25:07 +01:00
*/
2014-05-02 04:03:33 +02:00
public function checkAutoUpdate () {
2014-08-03 01:34:18 +02:00
$autoUpdate = $this -> maniaControl -> getSettingManager () -> getSettingValue ( $this , self :: SETTING_AUTO_UPDATE );
2014-05-02 04:03:33 +02:00
if ( ! $autoUpdate ) {
// Auto update turned off
return ;
}
if ( ! $this -> coreUpdateData ) {
// No update available
return ;
}
2014-08-03 01:34:18 +02:00
if ( $this -> maniaControl -> getPlayerManager () -> getPlayerCount ( false ) > 0 ) {
2014-05-02 04:03:33 +02:00
// Server not empty
2013-12-31 18:25:07 +01:00
return ;
}
2014-04-16 22:53:14 +02:00
2014-05-02 17:50:30 +02:00
$this -> performCoreUpdate ();
2014-02-10 21:32:41 +01:00
}
2013-12-27 23:26:27 +01:00
/**
* Perform a Core Update
2014-05-02 17:50:30 +02:00
*
2014-05-02 04:03:33 +02:00
* @ param Player $player
2013-12-27 23:26:27 +01:00
* @ return bool
*/
2014-05-04 15:09:11 +02:00
public function performCoreUpdate ( Player $player = null ) {
2014-05-02 04:03:33 +02:00
if ( ! $this -> coreUpdateData ) {
$message = 'Update failed: No update Data available!' ;
2014-03-31 21:41:05 +02:00
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
2014-02-09 18:22:47 +01:00
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-01-28 16:23:50 +01:00
return false ;
}
2014-05-02 17:50:30 +02:00
2014-08-05 01:49:13 +02:00
Logger :: log ( " Starting Update to Version v { $this -> coreUpdateData -> version } ... " );
2014-05-02 17:50:30 +02:00
2014-05-03 21:37:28 +02:00
$directories = array ( 'core' , 'plugins' );
2014-05-02 04:03:33 +02:00
if ( ! FileUtil :: checkWritePermissions ( $directories )) {
$message = 'Update not possible: Incorrect File System Permissions!' ;
2014-03-31 21:41:05 +02:00
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
2013-12-27 23:26:27 +01:00
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-02-10 21:32:41 +01:00
return false ;
2013-12-27 23:26:27 +01:00
}
2014-05-02 17:50:30 +02:00
2014-08-03 01:34:18 +02:00
$performBackup = $this -> maniaControl -> getSettingManager () -> getSettingValue ( $this , self :: SETTING_PERFORM_BACKUPS );
2014-05-02 04:03:33 +02:00
if ( $performBackup && ! BackupUtil :: performFullBackup ()) {
$message = 'Creating Backup before Update failed!' ;
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
2014-05-02 04:03:33 +02:00
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-05-02 04:03:33 +02:00
}
2014-05-02 17:50:30 +02:00
2014-06-17 23:27:28 +02:00
$updateData = $this -> coreUpdateData ;
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getFileReader () -> loadFile ( $updateData -> url , function ( $updateFileContent , $error ) use (
2014-07-25 16:28:47 +02:00
$updateData , & $player
) {
2014-05-04 15:10:34 +02:00
if ( ! $updateFileContent || $error ) {
$message = " Update failed: Couldn't load Update zip! { $error } " ;
2014-05-02 18:21:38 +02:00
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
2014-05-02 18:21:38 +02:00
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-05-02 18:21:38 +02:00
return ;
}
2014-05-02 17:50:30 +02:00
$tempDir = FileUtil :: getTempFolder ();
2014-08-03 13:13:52 +02:00
if ( ! $tempDir ) {
$message = " Update failed: Can't save Update zip! " ;
if ( $player ) {
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-08-03 13:13:52 +02:00
return ;
}
2014-02-09 18:22:47 +01:00
$updateFileName = $tempDir . basename ( $updateData -> url );
2014-05-02 17:50:30 +02:00
2014-02-09 18:22:47 +01:00
$bytes = file_put_contents ( $updateFileName , $updateFileContent );
if ( ! $bytes || $bytes <= 0 ) {
2014-05-02 04:03:33 +02:00
$message = " Update failed: Couldn't save Update zip! " ;
2014-03-31 21:41:05 +02:00
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
2014-02-09 18:22:47 +01:00
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-05-02 04:03:33 +02:00
return ;
2014-02-09 18:22:47 +01:00
}
2014-05-02 17:50:30 +02:00
$zip = new \ZipArchive ();
2014-02-09 18:22:47 +01:00
$result = $zip -> open ( $updateFileName );
if ( $result !== true ) {
2014-05-04 15:14:58 +02:00
$message = " Update failed: Couldn't open Update Zip. ( { $result } ) " ;
2014-03-31 21:41:05 +02:00
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( $message , $player );
2014-02-09 18:22:47 +01:00
}
2014-08-05 01:49:13 +02:00
Logger :: logError ( $message );
2014-08-03 13:13:52 +02:00
unlink ( $updateFileName );
2014-05-02 04:03:33 +02:00
return ;
2014-02-09 18:22:47 +01:00
}
2014-05-02 17:50:30 +02:00
2014-02-09 18:22:47 +01:00
$zip -> extractTo ( ManiaControlDir );
$zip -> close ();
unlink ( $updateFileName );
2014-06-20 18:51:25 +02:00
FileUtil :: deleteTempFolder ();
2014-05-02 17:50:30 +02:00
2014-04-29 23:53:55 +02:00
// Set the Nightly Build Date
2014-06-17 23:27:28 +02:00
$this -> setNightlyBuildDate ( $updateData -> releaseDate );
2014-05-02 17:50:30 +02:00
2014-05-02 04:03:33 +02:00
$message = 'Update finished!' ;
2014-03-31 21:41:05 +02:00
if ( $player ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendSuccess ( $message , $player );
2014-02-09 18:22:47 +01:00
}
2014-08-05 01:49:13 +02:00
Logger :: log ( $message );
2014-05-02 17:50:30 +02:00
2014-06-17 23:27:28 +02:00
$this -> maniaControl -> restart ();
2014-02-09 18:22:47 +01:00
});
2014-05-02 17:50:30 +02:00
2013-12-27 23:26:27 +01:00
return true ;
}
2014-01-28 16:23:50 +01:00
/**
2014-05-02 17:50:30 +02:00
* Set the Build Date of the local Nightly Build Version
*
* @ param string $date
2014-05-02 16:13:45 +02:00
* @ return bool
2014-01-28 16:23:50 +01:00
*/
2014-05-17 14:14:27 +02:00
public function setNightlyBuildDate ( $date ) {
2014-05-03 21:37:28 +02:00
$nightlyBuildDateFile = ManiaControlDir . 'core' . DIRECTORY_SEPARATOR . 'nightly_build.txt' ;
2014-05-02 17:50:30 +02:00
$success = ( bool ) file_put_contents ( $nightlyBuildDateFile , $date );
$this -> currentBuildDate = $date ;
return $success ;
}
/**
* Handle ManiaControl PlayerJoined callback
*
* @ param Player $player
*/
public function handlePlayerJoined ( Player $player ) {
if ( ! $this -> coreUpdateData ) {
return ;
}
// Announce available update
2014-08-03 01:34:18 +02:00
if ( ! $this -> maniaControl -> getAuthenticationManager () -> checkPermission ( $player , self :: SETTING_PERMISSION_UPDATE )) {
2014-05-02 17:50:30 +02:00
return ;
}
if ( $this -> isNightlyUpdateChannel ()) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendSuccess ( 'New Nightly Build (' . $this -> coreUpdateData -> releaseDate . ') available!' , $player -> login );
2014-05-02 17:50:30 +02:00
} else {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendInformation ( 'New ManiaControl Version ' . $this -> coreUpdateData -> version . ' available!' , $player -> login );
2014-01-28 16:23:50 +01:00
}
}
2014-01-24 19:00:26 +01:00
2013-12-27 23:26:27 +01:00
/**
2014-05-02 17:50:30 +02:00
* Handle Player Disconnect Callback
*
* @ param Player $player
2013-12-27 23:26:27 +01:00
*/
2014-05-02 17:50:30 +02:00
public function handlePlayerDisconnect ( Player $player ) {
$this -> checkAutoUpdate ();
}
/**
* Handle //checkupdate command
*
* @ param array $chatCallback
* @ param Player $player
*/
public function handle_CheckUpdate ( array $chatCallback , Player $player ) {
2014-08-03 01:34:18 +02:00
if ( ! $this -> maniaControl -> getAuthenticationManager () -> checkPermission ( $player , self :: SETTING_PERMISSION_UPDATECHECK )) {
$this -> maniaControl -> getAuthenticationManager () -> sendNotAllowed ( $player );
2014-05-02 17:50:30 +02:00
return ;
2013-12-27 23:26:27 +01:00
}
2014-05-02 17:50:30 +02:00
2014-06-17 23:27:28 +02:00
$this -> checkCoreUpdateAsync ( function ( UpdateData $updateData = null ) use ( & $player ) {
if ( ! $this -> checkUpdateData ( $updateData )) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendInformation ( 'No Update available!' , $player -> login );
2014-05-02 17:50:30 +02:00
return ;
}
2014-06-17 23:27:28 +02:00
if ( ! $this -> checkUpdateDataBuildVersion ( $updateData )) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( " Please update Your Server to ' { $updateData -> minDedicatedBuild } ' in order to receive further Updates! " , $player -> login );
2014-05-02 17:50:30 +02:00
return ;
}
2014-06-17 23:27:28 +02:00
$isNightly = $this -> isNightlyUpdateChannel ();
2014-05-02 17:50:30 +02:00
if ( $isNightly ) {
2014-06-17 23:27:28 +02:00
$buildDate = $this -> getNightlyBuildDate ();
2014-05-02 17:50:30 +02:00
if ( $buildDate ) {
if ( $updateData -> isNewerThan ( $buildDate )) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendInformation ( " No new Build available! (Current Build: ' { $buildDate } ') " , $player -> login );
2014-05-04 15:14:58 +02:00
return ;
2014-05-02 17:50:30 +02:00
} else {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendSuccess ( " New Nightly Build ( { $updateData -> releaseDate } ) available! (Current Build: ' { $buildDate } ') " , $player -> login );
2014-05-02 17:50:30 +02:00
}
} else {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendSuccess ( " New Nightly Build (' { $updateData -> releaseDate } ') available! " , $player -> login );
2014-05-02 17:50:30 +02:00
}
} else {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendSuccess ( 'Update for Version ' . $updateData -> version . ' available!' , $player -> login );
2014-05-02 17:50:30 +02:00
}
2014-05-04 15:14:58 +02:00
2014-06-17 23:27:28 +02:00
$this -> coreUpdateData = $updateData ;
2014-05-02 17:50:30 +02:00
});
}
/**
* Handle //coreupdate command
*
* @ param array $chatCallback
* @ param Player $player
*/
public function handle_CoreUpdate ( array $chatCallback , Player $player ) {
2014-08-03 01:34:18 +02:00
if ( ! $this -> maniaControl -> getAuthenticationManager () -> checkPermission ( $player , self :: SETTING_PERMISSION_UPDATE )) {
$this -> maniaControl -> getAuthenticationManager () -> sendNotAllowed ( $player );
2014-05-02 17:50:30 +02:00
return ;
}
2014-06-17 23:27:28 +02:00
$this -> checkCoreUpdateAsync ( function ( UpdateData $updateData = null ) use ( & $player ) {
2014-05-02 17:50:30 +02:00
if ( ! $updateData ) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( 'Update is currently not possible!' , $player );
2014-05-02 17:50:30 +02:00
return ;
}
2014-06-17 23:27:28 +02:00
if ( ! $this -> checkUpdateDataBuildVersion ( $updateData )) {
2014-08-03 01:34:18 +02:00
$this -> maniaControl -> getChat () -> sendError ( " The Next ManiaControl Update requires a newer Dedicated Server Version! " , $player );
2014-05-02 17:50:30 +02:00
return ;
}
2014-06-17 23:27:28 +02:00
$this -> coreUpdateData = $updateData ;
2014-05-02 17:50:30 +02:00
2014-06-17 23:27:28 +02:00
$this -> performCoreUpdate ( $player );
2014-05-02 17:50:30 +02:00
});
2013-12-27 23:26:27 +01:00
}
2013-12-17 17:38:44 +01:00
}