public function register() { $signedUser = $this->app->user(); // auth if (Util\Auth::isAuth($signedUser)) { header('Location: /profile'); exit; } // check $user = new \Rebond\Core\User\Model(); $form = new \Rebond\Core\User\Form($user); $tpl = new Util\Template(Util\Template::MODULE, ['app', 'User']); // register $register = Util\Converter::toString('register', 'post'); if (isset($register)) { if ($form->setFromPost()->validate(['username', 'email', 'password'])->isValid()) { $user->setStatus(0); $user->setPassword(Util\Security::encryptPassword($user->getPassword())); $resultUpload = Util\Media::upload($user->getUsername()); if ($resultUpload['result'] == ResultType::ERROR) { Util\Session::set('siteError', $resultUpload['message']); } else { if ($resultUpload['result'] == ResultType::SUCCESS) { $user->setAvatarId($resultUpload['mediaId']); } $user->save(); } // send email if (Mail::register($this->app->site()->getTitle(), $user)) { return $tpl->render('register-success'); } // mail could not be sent $user->setStatus(1); $userRole = new \Rebond\Core\UserRole\Model(); $userRole->setUserId($user->getId()); $userRole->setRoleId(\Rebond\Core\Role\Model::MEMBER); $userRole->save(); return $tpl->render('register-success-nomail'); } else { Util\Session::set('siteError', $form->getValidation()->getMessage()); } } // confirm email $confirm = Util\Converter::toString('confirm'); if (isset($confirm)) { $signedUser = \Rebond\Core\UserSecurity\Service::getUserBySecure($confirm, \Rebond\Core\UserSecurity\Model::CONFIRM); if (isset($signedUser) && $signedUser->getId() != 0) { $userRole = new \Rebond\Core\UserRole\Model(); $userRole->setUserId($signedUser->getId()); $userRole->setRoleId(\Rebond\Core\Role\Model::MEMBER); $userRole->save(); Util\Session::set('allSuccess', Util\Lang::lang('hi', [$signedUser->getUsername()])); Util\Session::set('signedUser', $signedUser->getId()); $this->app->setUser($signedUser); return $tpl->render('register-confirm'); } } $tpl->set('item', $form); return $tpl->render('register'); }
public function user_role() { // auth Auth::isAdminAuthorized($this->signedUser, 'admin.user', true, '/user'); // check $id = \Rebond\Util\Converter::int('id'); $save = \Rebond\Util\Converter::int('save', 'post'); $roleIds = \Rebond\Util\Converter::arr('role', 'post'); $user = \Rebond\Core\User\Data::loadById($id); if (!isset($user)) { Session::adminError('itemNotFound', [$id], '/user'); } $form = new \Rebond\Core\User\Form($user); // action if (isset($save)) { Auth::isAdminAuthorized($this->signedUser, 'admin.user.edit', true, '/user/user-role?id=' . $id); \Rebond\Core\UserRole\Data::deleteByUserId($user->getId()); $newRoles = []; if (isset($roleIds)) { foreach ($roleIds as $roleId) { $userRole = new \Rebond\Core\UserRole\Model(); $userRole->setUserId($user->getId()); $userRole->setRoleId($roleId); $newRoles[] = $userRole; } } \Rebond\Core\UserRole\Data::saveAll($newRoles); Session::adminSuccess('saved', '/user'); } // view $this->setTpl(); // main $tplMain = new Template(Template::MODULE, ['core', 'user']); $tplMain->set('item', $form); // layout if (Auth::isAdminAuthorized($this->signedUser, 'admin.user.edit', false)) { $this->tplLayout->set('column1', $tplMain->render('editor-role')); } else { // @todo create viewer-role template $this->tplLayout->set('column1', $tplMain->render('editor-role')); } // master $this->tplMaster->set('layout', $this->tplLayout->render('layout-1-col')); return $this->tplMaster->render('tpl-default'); }
public function register() { $signedUser = $this->app->user(); // auth if (Util\Auth::isAuth($signedUser)) { header('Location: /profile'); exit; } // check $user = new \Rebond\Core\User\Model(); $form = new \Rebond\Core\User\Form($user); $tpl = new Util\Template(Util\Template::MODULE, ['app', 'User']); // register $register = Util\Converter::string('register', 'post'); if (isset($register)) { if ($form->setFromPost()->validate()->isValid()) { $user->setStatus(0); $user->setPassword(Util\Security::encryptPassword($user->getPassword())); $avatarId = Util\Media::generateAvatar($user->getUsername()); $user->setAvatarId($avatarId); $user->save(); // send email if (Mail::register($this->app->site()->getTitle(), $user)) { return $tpl->render('register-success'); } else { $user->setStatus(1); $user->save(); $userRole = new \Rebond\Core\UserRole\Model(); $userRole->setUserId($user->getId()); $userRole->setRoleId(5); // member $userRole->save(); return $tpl->render('register-success-nomail'); } } else { Session::set('siteError', $form->getValidation()->getMessage()); } } // confirm email $confirm = Util\Converter::string('confirm'); if (isset($confirm)) { $signedUser = \Rebond\Core\UserSecurity\Data::loadBySecure($confirm, \Rebond\Core\UserSecurity\Model::CONFIRM); if (isset($signedUser) && $signedUser->getId() != 0) { $userRole = new \Rebond\Core\UserRole\Model(); $userRole->setUserId($signedUser->getId()); $userRole->setRoleId(5); // member $userRole->save(); Util\Session::set('allSuccess', Util\Lang::lang('hi', [$signedUser->getUsername()])); Util\Session::set('signedUser', $signedUser->getId()); $this->app->setUser($signedUser); return $tpl->render('register-confirm'); } } $tpl->set('item', $form); return $tpl->render('register'); }
protected static function mapper(array $row, $alias = 'user_role') { $model = new \Rebond\Core\UserRole\Model(false); if (isset($row[$alias . 'UserId'])) { $model->setUserId($row[$alias . 'UserId']); $model->setUser(\Rebond\Core\User\Data::join($row, $alias . '_user')); } if (isset($row[$alias . 'RoleId'])) { $model->setRoleId($row[$alias . 'RoleId']); $model->setRole(\Rebond\Core\Role\Data::join($row, $alias . '_role')); } return $model; }