This commit is contained in:
Daniel 2014-05-15 12:39:10 +02:00
commit 6c85b6e42d
5 changed files with 70 additions and 37 deletions

View file

@ -93,7 +93,8 @@
$this->checkPermission($request, $response); $this->checkPermission($request, $response);
// Check achievements // Check achievements
$this->checkAchievements($request, $response); $this->checkAchievements($request, $response, 'date');
$this->checkAchievements($request, $response, 'achievement');
// Set Seminary and Character data // Set Seminary and Character data
$this->set('loggedSeminary', self::$seminary); $this->set('loggedSeminary', self::$seminary);
@ -148,7 +149,7 @@
/** /**
* Check for newly achieved Achievements. * Check for newly achieved Achievements.
*/ */
private function checkAchievements(\nre\core\Request $request, \nre\core\Response $response) protected function checkAchievements(\nre\core\Request $request, \nre\core\Response $response, $checkConditions=null)
{ {
// Do not check MediaController // Do not check MediaController
if($this->request->getParam(0, 'toplevel') != \nre\configs\AppConfig::$defaults['toplevel']) { if($this->request->getParam(0, 'toplevel') != \nre\configs\AppConfig::$defaults['toplevel']) {
@ -160,6 +161,11 @@
return; return;
} }
// Set conditions to check
if(!is_null($checkConditions) && !is_array($checkConditions)) {
$checkConditions = array($checkConditions);
}
// Get unachieved Achievments // Get unachieved Achievments
$achievements = $this->Achievements->getUnachhievedAchievementsForCharacter(self::$seminary['id'], self::$character['id']); $achievements = $this->Achievements->getUnachhievedAchievementsForCharacter(self::$seminary['id'], self::$character['id']);
if(in_array('user', self::$character['characterroles'])) { if(in_array('user', self::$character['characterroles'])) {
@ -169,6 +175,11 @@
// Check conditions // Check conditions
foreach($achievements as &$achievement) foreach($achievements as &$achievement)
{ {
// Check condition to test
if(!is_null($checkConditions) && !in_array($achievement['condition'], $checkConditions)) {
continue;
}
// Check deadline // Check deadline
if(!is_null($achievement['deadline']) && $achievement['deadline'] < date('Y-m-d H:i:s')) { if(!is_null($achievement['deadline']) && $achievement['deadline'] < date('Y-m-d H:i:s')) {
continue; continue;

View file

@ -73,10 +73,14 @@
// Check permission // Check permission
if(count(array_intersect(array('admin','moderator'), SeminaryController::$character['characterroles'])) == 0) if(count(array_intersect(array('admin','moderator'), SeminaryController::$character['characterroles'])) == 0)
{ {
$previousQuestgroup = $this->Questgroups->getPreviousQuestgroup($questgroup['id']); // Only check permissions if Character has not entered Quest before
if(!is_null($previousQuestgroup)) { if(!$this->Questgroups->hasCharacterEnteredQuestgroup($questgroup['id'], $character['id']))
if(!$this->Questgroups->hasCharacterSolvedQuestgroup($previousQuestgroup['id'], $character['id'])) { {
throw new \nre\exceptions\AccessDeniedException(); $previousQuestgroup = $this->Questgroups->getPreviousQuestgroup($questgroup['id']);
if(!is_null($previousQuestgroup)) {
if(!$this->Questgroups->hasCharacterSolvedQuestgroup($previousQuestgroup['id'], $character['id'])) {
throw new \nre\exceptions\AccessDeniedException();
}
} }
} }
} }

View file

@ -53,6 +53,21 @@
/**
* Prefilter that is executed before running the Controller.
*
* @param Request $request Current request
* @param Response $response Current response
*/
public function preFilter(\nre\core\Request $request, \nre\core\Response $response)
{
parent::preFilter($request, $response);
$this->checkAchievements($request, $response, array('character', 'quest'));
$this->checkAchievements($request, $response, 'achievement');
}
/** /**
* Action: index. * Action: index.
* *

View file

@ -318,8 +318,7 @@
/** /**
* Determine if the given Character has solved the Quests form * Determine if the given Character has solved a Questgroup.
* this Questgroup.
* *
* @param int $questgroupId ID of Questgroup to check * @param int $questgroupId ID of Questgroup to check
* @param int $characterId ID of Character to check * @param int $characterId ID of Character to check
@ -330,39 +329,20 @@
// Get data of Questgroup // Get data of Questgroup
$questgroup = $this->getQuestgroupById($questgroupId); $questgroup = $this->getQuestgroupById($questgroupId);
// Chack all Quests // Check last Quest(s)
$currentQuest = $this->Quests->getFirstQuestOfQuestgroup($questgroup['id']); $solvedLastQuest = false;
if(!is_null($currentQuest)) $lastQuests = $this->Quests->getLastQuestsOfQuestgroup($questgroup['id']);
foreach($lastQuests as &$lastQuest)
{ {
if(!$this->Quests->hasCharacterSolvedQuest($currentQuest['id'], $characterId)) { if($this->Quests->hasCharacterSolvedQuest($lastQuest['id'], $characterId))
return false;
}
// Get next Quests
$nextQuests = !is_null($currentQuest) ? $this->Quests->getNextQuests($currentQuest['id']) : null;
while(!is_null($currentQuest) && !empty($nextQuests))
{ {
// Get choosed Quest $solvedLastQuest = true;
$currentQuest = null; break;
foreach($nextQuests as &$nextQuest) {
if($this->Quests->hasCharacterEnteredQuest($nextQuest['id'], $characterId)) {
$currentQuest = $nextQuest;
}
}
// Check Quest
if(is_null($currentQuest)) {
return false;
}
// Check status
if(!$this->Quests->hasCharacterSolvedQuest($currentQuest['id'], $characterId)) {
return false;
}
$nextQuests = !is_null($currentQuest) ? $this->Quests->getNextQuests($currentQuest['id']) : null;
} }
} }
if(!$solvedLastQuest) {
return false;
}
// Check all child Questgroups // Check all child Questgroups
$questgroup['hierarchy'] = $this->Questgroupshierarchy->getHierarchyForQuestgroup($questgroup['id']); $questgroup['hierarchy'] = $this->Questgroupshierarchy->getHierarchyForQuestgroup($questgroup['id']);

View file

@ -137,6 +137,29 @@
} }
/**
* Get all Quests a Qusetgroup that do not have a following
* Quest.
*
* @param int $questId ID of Questgroup
* @return array List of last Quests
*/
public function getLastQuestsOfQuestgroup($questgroupId)
{
return $this->db->query(
'SELECT id, questtype_id, title, url, xps, task '.
'FROM quests '.
'WHERE questgroup_id = ? AND NOT EXISTS ('.
'SELECT quest_id '.
'FROM quests_previousquests '.
'WHERE quests_previousquests.previous_quest_id = quests.id'.
')',
'i',
$questgroupId
);
}
/** /**
* Get Quests that follow-up a Quest. * Get Quests that follow-up a Quest.
* *