summaryrefslogtreecommitdiff
path: root/manager/application/controllers/ManageAccountController.php
diff options
context:
space:
mode:
Diffstat (limited to 'manager/application/controllers/ManageAccountController.php')
-rw-r--r--manager/application/controllers/ManageAccountController.php52
1 files changed, 52 insertions, 0 deletions
diff --git a/manager/application/controllers/ManageAccountController.php b/manager/application/controllers/ManageAccountController.php
index cc7efa0..c893a4b 100644
--- a/manager/application/controllers/ManageAccountController.php
+++ b/manager/application/controllers/ManageAccountController.php
@@ -153,6 +153,35 @@ class ManageAccountController extends Zend_Controller_Action
return;
}
+
+ public function assurerChallengeAction()
+ {
+ // Validate form
+ $form = $this->getAssurerChallengeForm();
+ if (!$this->getRequest()->isPost() || !$form->isValid($_POST)) {
+ $this->view->assurer_challenge_form = $form;
+ return $this->render('assurer-challenge-form');
+ }
+
+ // Form is valid -> get values for processing
+ $values = $form->getValues();
+
+ // Get user data
+ $user['id'] = $this->getUserId();
+
+ // Assign the assurer challenge
+ $challenge = array(); // Make sure the array is empty
+ $challenge['user_id'] = $user['id'];
+ $challenge['variant_id'] = $values['variant'];
+ $challenge['pass_date'] = date('Y-m-d H:i:s');
+ $this->db->insert('cats_passed', $challenge);
+
+ // Maybe user is now assurer
+ $this->fixAssurerFlag($user['id']);
+
+ return;
+ }
+
/**
* Get and check the user ID of the current user
*
@@ -312,4 +341,27 @@ class ManageAccountController extends Zend_Controller_Action
return $form;
}
+
+ protected function getAssurerChallengeForm()
+ {
+ $form = new Zend_Form();
+ $form->setAction('/manage-account/assurer-challenge')
+ ->setMethod('post');
+
+ $variant = new Zend_Form_Element_Select('variant');
+ $variant->setLabel(I18n::_('Variant'));
+ // Get the available variants from the database
+ $query = 'select `id`, `test_text` from `cats_variant`
+ where `type_id` = 1';
+ $options = $this->db->fetchPairs($query);
+ $variant->setOptions($options)
+ ->setRequired(true);
+ $form->addElement($variant);
+
+ $submit = new Zend_Form_Element_Submit('submit');
+ $submit->setLabel(I18n::_('Challenge Me'));
+ $form->addElement($submit);
+
+ return $form;
+ }
}