| <?php␊ |
| /* -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */␊ |
| /*␊ |
| # ***** BEGIN LICENSE BLOCK *****␊ |
| # This file is part of InDefero, an open source project management application.␊ |
| # Copyright (C) 2008 CĂ©ondo Ltd and contributors.␊ |
| #␊ |
| # InDefero is free software; you can redistribute it and/or modify␊ |
| # it under the terms of the GNU General Public License as published by␊ |
| # the Free Software Foundation; either version 2 of the License, or␊ |
| # (at your option) any later version.␊ |
| #␊ |
| # InDefero is distributed in the hope that it will be useful,␊ |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of␊ |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the␊ |
| # GNU General Public License for more details.␊ |
| #␊ |
| # You should have received a copy of the GNU General Public License␊ |
| # along with this program; if not, write to the Free Software␊ |
| # Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA␊ |
| #␊ |
| # ***** END LICENSE BLOCK ***** */␊ |
| ␊ |
| ␊ |
| /**␊ |
| * Allow an admin to create a user.␊ |
| */␊ |
| class IDF_Form_Admin_UserCreate extends Pluf_Form␊ |
| {␊ |
| public $request = null;␊ |
| ␊ |
| public function initFields($extra=array())␊ |
| {␊ |
| $this->request = $extra['request'];␊ |
| $this->fields['first_name'] = new Pluf_Form_Field_Varchar(␊ |
| array('required' => false,␊ |
| 'label' => __('First name'),␊ |
| 'initial' => '',␊ |
| 'widget_attrs' => array(␊ |
| 'maxlength' => 50,␊ |
| 'size' => 15,␊ |
| ),␊ |
| ));␊ |
| $this->fields['last_name'] = new Pluf_Form_Field_Varchar(␊ |
| array('required' => true,␊ |
| 'label' => __('Last name'),␊ |
| 'initial' => '',␊ |
| 'widget_attrs' => array(␊ |
| 'maxlength' => 50,␊ |
| 'size' => 20,␊ |
| ),␊ |
| ));␊ |
| ␊ |
| $this->fields['login'] = new Pluf_Form_Field_Varchar(␊ |
| array('required' => true,␊ |
| 'label' => __('Login'),␊ |
| 'max_length' => 15,␊ |
| 'min_length' => 3,␊ |
| 'initial' => '',␊ |
| 'help_text' => __('The login must be between 3 and 15 characters long and contains only letters and digits.'),␊ |
| 'widget_attrs' => array(␊ |
| 'maxlength' => 15,␊ |
| 'size' => 10,␊ |
| ),␊ |
| ));␊ |
| ␊ |
| $this->fields['email'] = new Pluf_Form_Field_Email(␊ |
| array('required' => true,␊ |
| 'label' => __('Email'),␊ |
| 'initial' => '',␊ |
| 'help_text' => __('Double check the email address as the password is directly sent to the user.'),␊ |
| ));␊ |
| ␊ |
| $this->fields['language'] = new Pluf_Form_Field_Varchar(␊ |
| array('required' => true,␊ |
| 'label' => __('Language'),␊ |
| 'initial' => '',␊ |
| 'widget' => 'Pluf_Form_Widget_SelectInput',␊ |
| 'widget_attrs' => array(␊ |
| 'choices' => ␊ |
| Pluf_L10n::getInstalledLanguages()␊ |
| ),␊ |
| ));␊ |
| ␊ |
| $this->fields['ssh_key'] = new Pluf_Form_Field_Varchar(␊ |
| array('required' => false,␊ |
| 'label' => __('Add a public SSH key'),␊ |
| 'initial' => '',␊ |
| 'widget_attrs' => array('rows' => 3,␊ |
| 'cols' => 40),␊ |
| 'widget' => 'Pluf_Form_Widget_TextareaInput',␊ |
| 'help_text' => __('Be careful to provide the public key and not the private key!')␊ |
| ));␊ |
| ␊ |
| ␊ |
| }␊ |
| ␊ |
| /**␊ |
| * Save the model in the database.␊ |
| *␊ |
| * @param bool Commit in the database or not. If not, the object␊ |
| * is returned but not saved in the database.␊ |
| * @return Object Model with data set from the form.␊ |
| */␊ |
| function save($commit=true)␊ |
| {␊ |
| if (!$this->isValid()) {␊ |
| throw new Exception(__('Cannot save the model from an invalid form.'));␊ |
| }␊ |
| $password = Pluf_Utils::getPassword();␊ |
| $user = new Pluf_User();␊ |
| $user->setFromFormData($this->cleaned_data);␊ |
| $user->active = true;␊ |
| $user->staff = false;␊ |
| $user->administrator = false;␊ |
| $user->setPassword($password);␊ |
| $user->create();␊ |
| /**␊ |
| * [signal]␊ |
| *␊ |
| * Pluf_User::passwordUpdated␊ |
| *␊ |
| * [sender]␊ |
| *␊ |
| * IDF_Form_Admin_UserCreate␊ |
| *␊ |
| * [description]␊ |
| *␊ |
| * This signal is sent when a user is created␊ |
| * by the staff.␊ |
| *␊ |
| * [parameters]␊ |
| *␊ |
| * array('user' => $user)␊ |
| *␊ |
| */␊ |
| $params = array('user' => $user);␊ |
| Pluf_Signal::send('Pluf_User::passwordUpdated',␊ |
| 'IDF_Form_Admin_UserCreate', $params);␊ |
| // Create the ssh key as needed␊ |
| if ('' !== $this->cleaned_data['ssh_key']) {␊ |
| $key = new IDF_Key();␊ |
| $key->user = $user;␊ |
| $key->content = $this->cleaned_data['ssh_key'];␊ |
| $key->create();␊ |
| }␊ |
| // Send an email to the user with the password␊ |
| Pluf::loadFunction('Pluf_HTTP_URL_urlForView');␊ |
| $url = Pluf::f('url_base').Pluf_HTTP_URL_urlForView('IDF_Views::login', array(), array(), false);␊ |
| $context = new Pluf_Template_Context(␊ |
| array('password' => Pluf_Template::markSafe($password),␊ |
| 'user' => $user,␊ |
| 'url' => Pluf_Template::markSafe($url),␊ |
| 'admin' => $this->request->user,␊ |
| ));␊ |
| $tmpl = new Pluf_Template('idf/gadmin/users/createuser-email.txt');␊ |
| $text_email = $tmpl->render($context);␊ |
| $email = new Pluf_Mail(Pluf::f('from_email'), $user->email,␊ |
| __('Your details to access your forge.'));␊ |
| $email->addTextMessage($text_email);␊ |
| $email->sendMail();␊ |
| return $user;␊ |
| }␊ |
| ␊ |
| function clean_ssh_key()␊ |
| {␊ |
| $key = trim($this->cleaned_data['ssh_key']);␊ |
| if (strlen($key) == 0) {␊ |
| return '';␊ |
| }␊ |
| $key = str_replace(array("\n", "\r"), '', $key);␊ |
| if (!preg_match('#^ssh\-[a-z]{3}\s(\S+)\s\S+$#', $key, $matches)) {␊ |
| throw new Pluf_Form_Invalid(__('The format of the key is not valid. It must start with ssh-dss or ssh-rsa, a long string on a single line and at the end a comment.'));␊ |
| }␊ |
| return $key;␊ |
| }␊ |
| ␊ |
| function clean_last_name()␊ |
| {␊ |
| $last_name = trim($this->cleaned_data['last_name']);␊ |
| if ($last_name == mb_strtoupper($last_name)) {␊ |
| return mb_convert_case(mb_strtolower($last_name), ␊ |
| MB_CASE_TITLE, 'UTF-8');␊ |
| }␊ |
| return $last_name;␊ |
| }␊ |
| ␊ |
| function clean_first_name()␊ |
| {␊ |
| $first_name = trim($this->cleaned_data['first_name']);␊ |
| if ($first_name == mb_strtoupper($first_name)) {␊ |
| return mb_convert_case(mb_strtolower($first_name), ␊ |
| MB_CASE_TITLE, 'UTF-8');␊ |
| }␊ |
| return $first_name;␊ |
| }␊ |
| ␊ |
| function clean_email()␊ |
| {␊ |
| $this->cleaned_data['email'] = mb_strtolower(trim($this->cleaned_data['email']));␊ |
| $guser = new Pluf_User();␊ |
| $sql = new Pluf_SQL('email=%s', array($this->cleaned_data['email']));␊ |
| if ($guser->getCount(array('filter' => $sql->gen())) > 0) {␊ |
| throw new Pluf_Form_Invalid(sprintf(__('The email "%s" is already used.'), $this->cleaned_data['email']));␊ |
| }␊ |
| return $this->cleaned_data['email'];␊ |
| }␊ |
| ␊ |
| public function clean_login()␊ |
| {␊ |
| $this->cleaned_data['login'] = mb_strtolower(trim($this->cleaned_data['login']));␊ |
| if (preg_match('/[^a-z0-9]/', $this->cleaned_data['login'])) {␊ |
| throw new Pluf_Form_Invalid(sprintf(__('The login "%s" can only contain letters and digits.'), $this->cleaned_data['login']));␊ |
| }␊ |
| $guser = new Pluf_User();␊ |
| $sql = new Pluf_SQL('login=%s', $this->cleaned_data['login']);␊ |
| if ($guser->getCount(array('filter' => $sql->gen())) > 0) {␊ |
| throw new Pluf_Form_Invalid(sprintf(__('The login "%s" is already used, please find another one.'), $this->cleaned_data['login']));␊ |
| }␊ |
| return $this->cleaned_data['login'];␊ |
| }␊ |
| }␊ |