definiations of permission levels
This commit is contained in:
		| @@ -2,7 +2,6 @@ | ||||
|  | ||||
| namespace ManiaControl\Admin; | ||||
|  | ||||
| use ManiaControl\FileUtil; | ||||
| use ManiaControl\ManiaControl; | ||||
| use ManiaControl\Players\Player; | ||||
| use ManiaControl\Players\PlayerManager; | ||||
| @@ -47,6 +46,7 @@ class AuthenticationManager { | ||||
| 		$this->authCommands = new AuthCommands($maniaControl); | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Set MasterAdmins | ||||
| 	 * | ||||
| @@ -109,9 +109,13 @@ class AuthenticationManager { | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function grantAuthLevel(Player &$player, $authLevel) { | ||||
| 		if (!$player || !is_numeric($authLevel)) return false; | ||||
| 		if(!$player || !is_numeric($authLevel)) { | ||||
| 			return false; | ||||
| 		} | ||||
| 		$authLevel = (int)$authLevel; | ||||
| 		if ($authLevel >= self::AUTH_LEVEL_MASTERADMIN) return false; | ||||
| 		if($authLevel >= self::AUTH_LEVEL_MASTERADMIN) { | ||||
| 			return false; | ||||
| 		} | ||||
|  | ||||
| 		$mysqli        = $this->maniaControl->database->mysqli; | ||||
| 		$authQuery     = "INSERT INTO `" . PlayerManager::TABLE_PLAYERS . "` ( | ||||
| @@ -148,7 +152,9 @@ class AuthenticationManager { | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function sendNotAllowed(Player $player) { | ||||
| 		if (!$player) return false; | ||||
| 		if(!$player) { | ||||
| 			return false; | ||||
| 		} | ||||
| 		return $this->maniaControl->chat->sendError('You do not have the required Rights to perform this Command!', $player->login); | ||||
| 	} | ||||
|  | ||||
| @@ -163,6 +169,29 @@ class AuthenticationManager { | ||||
| 		return ($player->authLevel >= $neededAuthLevel); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Checks the permission  by a right name | ||||
| 	 * | ||||
| 	 * @param Player $player | ||||
| 	 * @param        $rightName | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function checkPermission(Player $player, $rightName) { | ||||
| 		$right = $this->maniaControl->settingManager->getSetting($this, $rightName); | ||||
| 		return $this->checkRight($player, $right); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Defines a Minimum Right Level needed for an action | ||||
| 	 * | ||||
| 	 * @param $rightName | ||||
| 	 * @param $authLevelNeeded | ||||
| 	 */ | ||||
| 	public function definePermissionLevel($rightName, $authLevelNeeded) { | ||||
| 		$this->maniaControl->settingManager->initSetting($this, $rightName, $authLevelNeeded); | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Name of the Authentication Level from Level Int | ||||
| 	 * | ||||
|   | ||||
| @@ -140,7 +140,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener { | ||||
| 		// Pagers | ||||
| 		// Config | ||||
| 		$pagerSize = 6.; | ||||
| 		$pagesId   = 'MapListPages'; | ||||
| 		$pagesId   = 'MxListPages'; | ||||
|  | ||||
| 		$pagerPrev = new Quad_Icons64x64_1(); | ||||
| 		$frame->add($pagerPrev); | ||||
| @@ -184,7 +184,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener { | ||||
| 		$i = 0; | ||||
| 		$y -= 10; | ||||
| 		$pageFrames = array(); | ||||
| 		foreach($maps as $map) { //TODO pagers, order possabilities | ||||
| 		foreach($maps as $map) { //TODO order possabilities | ||||
| 			if(!isset($pageFrame)) { | ||||
| 				$pageFrame = new Frame(); | ||||
| 				$frame->add($pageFrame); | ||||
| @@ -372,7 +372,6 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener { | ||||
| 		$maniaLink->setScript($script); | ||||
|  | ||||
| 		// Pagers | ||||
|  | ||||
| 		// Config | ||||
| 		$pagerSize = 6.; | ||||
| 		$pagesId   = 'MapListPages'; | ||||
|   | ||||
| @@ -2,6 +2,7 @@ | ||||
|  | ||||
| namespace ManiaControl\Maps; | ||||
|  | ||||
| use ManiaControl\Admin\AuthenticationManager; | ||||
| use ManiaControl\Callbacks\CallbackListener; | ||||
| use ManiaControl\Callbacks\CallbackManager; | ||||
| use ManiaControl\FileUtil; | ||||
| @@ -24,6 +25,8 @@ class MapManager implements CallbackListener { | ||||
| 	const TABLE_MAPS                 = 'mc_maps'; | ||||
| 	const CB_MAPS_UPDATED            = 'MapManager.MapsUpdated'; | ||||
| 	const CB_KARMA_UPDATED           = 'MapManager.KarmaUpdated'; | ||||
| 	const SETTING_PERMISSION_ADD_MAP = 'Add Maps'; | ||||
| 	const SETTING_PERMISSION_REMOVE_MAP = 'Remove Maps'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Public Properties | ||||
| @@ -60,6 +63,10 @@ class MapManager implements CallbackListener { | ||||
| 		$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MC_ONINIT, $this, 'handleOnInit'); | ||||
| 		$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MC_BEGINMAP, $this, 'handleBeginMap'); | ||||
| 		$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_MAPLISTMODIFIED, $this, 'mapsModified'); | ||||
|  | ||||
| 		//Define Rights | ||||
| 		$this->maniaControl->authenticationManager->definePermissionLevel(self::SETTING_PERMISSION_ADD_MAP,AuthenticationManager::AUTH_LEVEL_ADMIN); | ||||
| 		$this->maniaControl->authenticationManager->definePermissionLevel(self::SETTING_PERMISSION_REMOVE_MAP,AuthenticationManager::AUTH_LEVEL_ADMIN); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
|   | ||||
| @@ -17,6 +17,7 @@ class SettingManager { | ||||
| 	const TYPE_REAL      = 'real'; | ||||
| 	const TYPE_BOOL      = 'bool'; | ||||
| 	const TYPE_ARRAY     = 'array'; | ||||
| 	//const TYPE_AUTH_LEVEL = 'auth'; //TODO | ||||
|  | ||||
| 	/** | ||||
| 	 * Private properties | ||||
|   | ||||
		Reference in New Issue
	
	Block a user