function testModel_FormValid() { $request = new Model_FormTest_Request(); $model = new A_Model_Form(); // check not post $this->assertFalse($model->isValid($request)); // test post mode no fields or rules $request->setMethod('POST'); $this->assertTrue($model->isValid($request)); // test post mode with field and param value but no rules $request->set('foo', 'bar'); $field = $model->newField('foo'); $this->assertTrue($model->isValid($request)); $this->assertEqual($model->get('foo'), 'bar'); // add rule $field->addRule(new A_Rule_Notnull('foo', 'error')); // param not set $request->set('foo', null); $this->assertFalse($model->isValid($request)); $this->assertTrue($model->isError()); $this->assertEqual($model->getErrorMsg(), array('foo' => array('error'))); $this->assertEqual($model->getErrorMsg(' '), 'error'); // param not set $request->set('foo', 'bar'); $this->assertTrue($model->isValid($request)); }
function index($locator) { $usersmodel = $this->_load()->model('Users'); $view = $this->_load()->view('Form'); // Instantiate a new form model/controller $form = new A_Model_Form(); // Hand the Form the fields and rules from the model // $form->addRule($usersmodel->getRules()); $form->addField($usersmodel->getFields()); // Now add an additional field, the second password field. Which must match the first password field. // The $form get the Rules for the first password field from $usersmodel $form->addField($passwordfield = new A_Model_Form_Field('password2')); // now we add an additional rule, specific for the form we are dealing with. $form->addRule(new A_Rule_Match('password', 'password2', 'Password 2 must match Password 1')); //$form->run($locator); //dump($form); // ask the form if it is valid. The form checks internally if the model fields are valid? if ($form->isValid($this->request)) { // save $usersmodel->save($form->getSaveValues()); // redirect to user detail page or whatever } else { // show errors if submitted $view->setErrorMsg($form->getErrorMsg()); } $view->setValues($form->getValues()); $this->response->setRenderer($view); }
function edit($locator) { $template = $this->_load('controller')->template(); $posts = $this->_load('app')->model('posts', $locator->get('Db')); $form = new A_Model_Form(); // Hand the Form the fields and rules from the model $form->addRule($posts->getRules()); $form->addField($posts->getFields()); // Get list of users to create authorlist in form $users = $this->_load('app')->model('users', $locator->get('Db')); $authorlist = $users->findAuthorlist()->toArray(); $form->newField('authorlist'); $form->set('authorlist', $authorlist); // ask the form if it is valid. The form checks internally if the model fields are valid if ($form->isValid($this->request)) { // save $result = $posts->save($form->getSaveValues()); if ($result->isError()) { $form->setErrorMsg('databaseerror', 'Could not save to the database'); } } elseif (!$this->_request()->has('save') && $this->_request()->has('id')) { $id = $this->_request()->get('id'); // load data $rows = $posts->find($id); if (isset($rows[0])) { foreach ($rows[0] as $name => $value) { $form->newField($name)->setValue($value); } } } $template->set('errorMsg', $form->getErrorMsg(', ')); $template->import($form->getValues()); $this->response->set('maincontent', $template->render()); }
function index($locator) { $model = $this->_load()->model('Users'); $form = new A_Model_Form(); $form->addField($model->getFields()); # $input->setRequired($model->getRequired()); // get required fields from model # $input->addRule(new AddressRules); // modularity! # $input->addRule(new PhoneRules); // modularity! $form->addRule($model->getRules()); // modularity! // Now add an additional field, the second password field. Which must match the first password field. // The $form get the Rules for the first password field from $usersmodel $form->addField($passwordfield = new A_Model_Form_Field('password2')); // now we add an additional rule, specific for the form we are dealing with. $form->addRule(new A_Rule_Match('password', 'password2', 'Password 2 must match Password 1')); // $form->addRule(new MyRules); // $form->addFilter(new MyFilters);dump($form); $view = $this->_load()->view('Form4'); if ($this->request->isPost()) { if ($form->isValid($this->request)) { try { $model->save($form); // redirect to user detail page or whatever } catch (A_Model_Exception $e) { // bummer! } exit; } else { $view->setErrorMsg($form->getErrorMsg()); } $view->setValues($form->getValues()); } echo $view->render(); }
function index($locator) { $usersession = $locator->get('UserSession'); $usersmodel = $this->_load()->model('Users'); $form = new A_Model_Form(); $form->addField($usersmodel->getFields()); $base = $locator->get('Config')->get('BASE'); // If the user is loged in: if ($usersession->isLoggedIn()) { // and wants to log out if ($this->request->get('op') == 'logout') { $usersession->logout(); $this->_flash('Message', 'You are now logged-out'); $this->response->setRedirect($base); // For now I do a redirect but you can also do: //$layout = $this->_load()->template('login.tpl'); //$layout->set('message', 'you are now loged out'); } else { // else just show the logout form $layout = $this->_load()->template('logout'); $layout->set('BASE', $base); $layout->set('message', 'Please log out'); $this->response->setRenderer($layout); } } else { // If not loged in and user wants to log in $layout = $this->_load()->template('login'); if ($this->_request('op') == 'login') { if ($form->isValid($this->request)) { if ($row = $usersmodel->findAuthorized($form->get('username'), $form->get('password'))) { $usersession->login($form->get('username')); $this->_flash('Message', 'You are now logged-in'); $url = 'http://skeleton/examples/login/'; $this->response->setRedirect($url); } } } else { $layout->set('message', 'Please log in'); } $layout->set('errmsg', 'Please fill in correct username and password'); $layout->set('errmsg', $form->getErrorMsg(' ,')); $layout->set('BASE', $base); $layout->set('username', $form->get('username')); $this->_response()->setRenderer($layout); } }
public function index($locator) { $request = $locator->get('Request'); $response = $locator->get('Response'); $usersession = $locator->get('UserSession'); $errmsg = ''; $usernamestr = ''; if (!$usersession->isLoggedIn()) { if ($request->get('op') == 'login') { $form = new A_Model_Form(); $username = new A_Model_Form_Field('username'); $username->addFilter(new A_Filter_Regexp('/[^a-zA-Z0-9]/', '')); $username->addFilter(new A_Filter_ToLower()); $username->addRule(new A_Rule_Notnull('username', 'Username required')); $username->addRule(new A_Rule_Length(4, 20, 'username', 'Username must be 4 characters long')); $form->addField($username); $password = new A_Model_Form_Field('password'); $password->addFilter(new A_Filter_Regexp('/[^a-zA-Z0-9\\!\\@\\#\\$\\%\\^\\&\\*\\(\\)\\-\\_\\=\\+]/', '')); $password->addRule(new A_Rule_Notnull('password', 'Password required')); $password->addRule(new A_Rule_Length(4, 20, 'password', 'Password must be 4 characters long')); $form->addField($password); if ($form->isValid($request)) { $user = $this->_load()->model('UsersModel'); if ($row = $user->findAuthorized($username->value, $password->value)) { $usersession->merge($row); $usersession->login($username->value, $password->value); } } else { $errmsg = 'Errors: ' . $form->getErrorMsg(', '); $usernamestr = $username->value; } } } if ($usersession->isLoggedIn()) { $page_template = new A_Template_Strreplace('templates/logout.html'); } else { $page_template = new A_Template_Strreplace('templates/login.html'); $page_template->set('errmsg', $errmsg); $page_template->set('username', $usernamestr); } $response->setContent($page_template->render()); }
function index($locator) { $model = new A_Model_Form(); // get fieldeter object from controller $model->addField($field1 = new A_Model_Form_Field('field1')); $field1->addFilter(new A_Filter_Regexp('/[^0-9]/', '')); $field1->addRule(new A_Rule_Notnull('field1', 'Please enter Field 1')); $field1->addRule(new A_Rule_Range(1, 10, 'field1', 'Field 1 must be 1-10')); $field1->setType(array('renderer' => 'A_Html_Form_Select', 'values' => array(5, 10, 15), 'labels' => array('five', 'ten', 'fifteen'))); $model->addField($field2 = new A_Model_Form_Field('field2')); $field2->addFilter(new A_Filter_Regexp('/[^0-9]/', '')); $field2->addRule(new A_Rule_Notnull('field2', 'Please enter Field 2')); $field2->addRule(new A_Rule_Match('field1', 'field2', 'Field 2 must match Field 1')); $field2->setType(array('renderer' => 'A_Html_Form_Text', 'size' => '10')); $model->addField($field3 = new A_Model_Form_Field('field3')); $field3->addFilter(new A_Filter_Regexp('/[^a-zA-Z]/', '')); $field3->addRule(new A_Rule_Length(5, 20, 'field3', 'Field 3 must be 5-20 characters')); // create fieldeter object then add it to the controller $model->addField($field4 = new A_Model_Form_Field('field4')); $field4->addFilter(new A_Filter_Regexp('/[^a-zA-Z]/', '')); $field4->addFilter(new A_Filter_ToUpper()); $field4->addRule(new A_Rule_Notnull('field4', 'Please enter Field 4')); $model->excludeRules('field3'); //$model->run($locator); $request = $locator->get('Request'); if ($model->isValid($request)) { echo 'DONE<br/><br/><a href="../">Return to Examples</a>'; } else { if (!$model->isSubmitted()) { $model->set('field1', 15); $model->set('field2', 'init'); $model->set('field3', 'init'); $model->set('field4', 'init'); } //dump($model); // create HTML form generator $form = new A_Html_Form(); $form->setModel($model)->setWrapper('A_Html_Div', array('class' => 'fieldclass', 'style' => 'border:1px solid red;'))->select(array('name' => 'field1', 'values' => array(5, 10, 15), 'labels' => array('five', 'ten', 'fifteen'), 'id' => 'field1', 'label' => 'Field 1 (Numbers only in range 1-10)', 'after' => $field1->getErrorMsg(', ')))->text(array('name' => 'field2', 'id' => 'field2', 'label' => 'Field 2 (Must match Field 1)', 'after' => $field2->getErrorMsg(', ')))->text(array('name' => 'field3', 'id' => 'field3', 'label' => 'Field 3 (Letters only min length 5)', 'after' => $field3->getErrorMsg(', ')))->text(array('name' => 'field4', 'id' => 'field4', 'label' => 'Field 4 (Convert letters to uppercase)', 'after' => $field4->getErrorMsg(', ')))->submit('submit', 'Submit'); echo $form->render(); # include 'templates/example_form2.php'; } }
function index($locator) { $session = $locator->get('Session'); $user = $locator->get('UserSession'); #dump($user, 'USER: '******''; $session->start(); // controller and view use session $form = new A_Model_Form(); $field = new A_Model_Form_Field('userid'); $field->addRule(new A_Rule_Notnull('userid', 'User ID required')); $form->addField($field); $field = new A_Model_Form_Field('password'); $field->addRule(new A_Rule_Notnull('password', 'Password required')); $form->addField($field); // If username and password valid and isPost if ($form->isValid($this->request)) { // How to translate URL in correct action variable? $model = $this->_load('app')->model('users'); $userdata = $model->login($form->get('userid'), $form->get('password')); if ($userdata) { // user record matching userid and password found unset($userdata['password']); // don't save passwords in the session $user->login($userdata); $this->_redirect($locator->get('Config')->get('BASE') . 'login/'); // build redirect URL back to this page } else { $errmsg = $model->getErrorMsg(); } } elseif ($form->isSubmitted()) { // submitted form has errors $errmsg = $form->getErrorMsg(', '); } $template = $this->_load()->template(); $template->set('errmsg', $errmsg); $template->set('userid', $form->get('userid')); $template->set('user', $user); $this->response->set('maincontent', $template); }
public function setpassword($locator) { $request = $this->request; $usermodel = $this->_load('app')->model('users'); $form = new A_Model_Form(); $field = new A_Model_Form_Field('password'); $field->addRule(new A_Rule_Notnull('password', 'Please fill in the password.')); $field2 = new A_Model_Form_Field('passwordagain'); $field2->addRule(new A_Rule_Notnull('passwordagain', 'Please fill in the passwordagain.')); $form->addRule(new A_Rule_Match('passwordagain', 'password', 'Fields password and passwordagain do not match')); $form->addField($field); $form->addField($field2); if ($request->isPost()) { $resetkey = $request->get('resetkey'); if ($form->isValid($this->request)) { $resetkey = $request->get('resetkey'); $result = $usermodel->findResetkey($resetkey); if ($result === true) { $usermodel->resetPassword($request->get('password'), $resetkey); $this->response->setPartial('maincontent', 'user/password/resetpasswordsuccess'); } else { $this->response->setPartial('maincontent', 'user/password/resetpassworderror', array('message' => 'reset failed')); } } else { $this->response->setPartial('maincontent', 'user/password/resetpasswordform', array('message' => 'reset form invalid', 'resetkey' => $resetkey)); } } }