X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/timetracker.git/blobdiff_plain/10eda5d259af06b3777d6ee662e0ac36f86507fe..251996aed11c648ecaa30f77383e0384bfadf7a5:/admin_team_add.php diff --git a/admin_team_add.php b/admin_team_add.php new file mode 100644 index 00000000..b41571c7 --- /dev/null +++ b/admin_team_add.php @@ -0,0 +1,104 @@ +getMethod() == 'POST') { + $cl_team_name = trim($request->getParameter('team_name')); + $cl_manager_name = trim($request->getParameter('manager_name')); + $cl_manager_login = trim($request->getParameter('manager_login')); + if (!$auth->isPasswordExternal()) { + $cl_password1 = $request->getParameter('password1'); + $cl_password2 = $request->getParameter('password2'); + } + $cl_manager_email = trim($request->getParameter('manager_email')); +} + +$form = new Form('teamForm'); +$form->addInput(array('type'=>'text','maxlength'=>'200','name'=>'team_name','value'=>$cl_team_name)); +$form->addInput(array('type'=>'text','maxlength'=>'100','name'=>'manager_name','value'=>$cl_manager_name)); +$form->addInput(array('type'=>'text','maxlength'=>'100','name'=>'manager_login','value'=>$cl_manager_login)); +if (!$auth->isPasswordExternal()) { + $form->addInput(array('type'=>'text','maxlength'=>'30','name'=>'password1','aspassword'=>true,'value'=>$cl_password1)); + $form->addInput(array('type'=>'text','maxlength'=>'30','name'=>'password2','aspassword'=>true,'value'=>$cl_password2)); +} +$form->addInput(array('type'=>'text','maxlength'=>'100','name'=>'manager_email','value'=>$cl_manager_email)); +$form->addInput(array('type'=>'submit','name'=>'btn_submit','value'=>$i18n->getKey('button.submit'))); + +if ($request->getMethod() == 'POST') { + // Validate user input. + if (!ttValidString($cl_team_name, true)) $errors->add($i18n->getKey('error.field'), $i18n->getKey('label.team_name')); + if (!ttValidString($cl_manager_name)) $errors->add($i18n->getKey('error.field'), $i18n->getKey('label.manager_name')); + if (!ttValidString($cl_manager_login)) $errors->add($i18n->getKey('error.field'), $i18n->getKey('label.manager_login')); + if (!$auth->isPasswordExternal()) { + if (!ttValidString($cl_password1)) $errors->add($i18n->getKey('error.field'), $i18n->getKey('label.password')); + if (!ttValidString($cl_password2)) $errors->add($i18n->getKey('error.field'), $i18n->getKey('label.confirm_password')); + if ($cl_password1 !== $cl_password2) + $errors->add($i18n->getKey('error.not_equal'), $i18n->getKey('label.password'), $i18n->getKey('label.confirm_password')); + } + if (!ttValidEmail($cl_manager_email, true)) $errors->add($i18n->getKey('error.field'), $i18n->getKey('label.email')); + + if ($errors->isEmpty()) { + if (!ttUserHelper::getUserByLogin($cl_manager_login)) { + // Create a new team. + if (!defined('CURRENCY_DEFAULT')) define('CURRENCY_DEFAULT', '$'); + $team_id = ttTeamHelper::insert(array('name'=>$cl_team_name,'currency'=>CURRENCY_DEFAULT)); + if ($team_id) { + // Team created, now create a team manager. + $user_id = ttUserHelper::insert(array( + 'team_id' => $team_id, + 'role' => ROLE_MANAGER, + 'name' => $cl_manager_name, + 'login' => $cl_manager_login, + 'password' => $cl_password1, + 'email' => $cl_manager_email)); + } + if ($team_id && $user_id) { + header('Location: admin_teams.php'); + } else + $errors->add($i18n->getKey('error.db')); + } else + $errors->add($i18n->getKey('error.user_exists')); + } +} + +$smarty->assign('auth_external', $auth->isPasswordExternal()); +$smarty->assign('forms', array($form->getName()=>$form->toArray())); +$smarty->assign('onload', 'onLoad="document.teamForm.team.focus()"'); +$smarty->assign('content_page_name', 'admin_team_add.tpl'); +$smarty->assign('title', $i18n->getKey('title.create_team')); +$smarty->display('index.tpl'); +?> \ No newline at end of file