Move busui to seperate repository
[bus.git] / usersAdd.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<?php
 
//
// Open Web Analytics - An Open Source Web Analytics Framework
//
// Copyright 2006 Peter Adams. All rights reserved.
//
// Licensed under GPL v2.0 http://www.gnu.org/copyleft/gpl.html
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// $Id$
//
 
require_once(OWA_BASE_DIR.'/owa_adminController.php');
require_once(OWA_BASE_DIR.'/eventQueue.php');
 
/**
 * Add User Controller
 * 
 * @author      Peter Adams <peter@openwebanalytics.com>
 * @copyright   Copyright &copy; 2006 Peter Adams <peter@openwebanalytics.com>
 * @license     http://www.gnu.org/copyleft/gpl.html GPL v2.0
 * @category    owa
 * @package     owa
 * @version             $Revision$            
 * @since               owa 1.0.0
 */
 
class owa_usersAddController extends owa_adminController {
                
        function __construct($params) {
        
                parent::__construct($params);
                
                $this->setRequiredCapability('edit_users');
                $this->setNonceRequired();
                
                // Check for user with the same email address
                // this is needed or else the change password feature will not know which account
                // to chane the password for.
                $v1 = owa_coreAPI::validationFactory('entityDoesNotExist');
                $v1->setConfig('entity', 'base.user');
                $v1->setConfig('column', 'email_address');
                $v1->setValues(trim($this->getParam('email_address')));
                $v1->setErrorMessage($this->getMsg(3009));
                $this->setValidation('email_address', $v1);
                
                // Check user name.
                $v2 = owa_coreAPI::validationFactory('entityDoesNotExist');
                $v2->setConfig('entity', 'base.user');
                $v2->setConfig('column', 'user_id');
                $v2->setValues(trim($this->getParam('user_id')));
                $v2->setErrorMessage($this->getMsg(3001));
                $this->setValidation('user_id', $v2);
 
                return;
        }
        
        function action() {
                                
                $userManager = owa_coreApi::supportClassFactory('base', 'userManager');                         
                                
                                
                $user_params = array( 'user_id'                 => trim($this->params['user_id']),
                                                          'real_name'           => $this->params['real_name'],
                                                      'role'                    => $this->params['role'],
                                                          'email_address'       => trim($this->params['email_address'])); 
                                                                  
                $temp_passkey = $userManager->createNewUser($user_params);
                
                // log account creation event to event queue
                $eq = &eventQueue::get_instance();
                $eq->log(array( 'user_id'       => $this->params['user_id'],
                                                'real_name' => $this->params['real_name'],
                                                'role'          => $this->params['role'],
                                                'email_address' => $this->params['email_address'],
                                                'temp_passkey' => $temp_passkey), 
                                                'base.new_user_account');
                
                
                $this->setRedirectAction('base.users');
                $this->set('status_code', 3000);
                                
                return;
        }
        
        function errorAction() {
                $this->setView('base.options');
                $this->setSubview('base.usersProfile');
                $this->set('error_code', 3009);
                //assign original form data so the user does not have to re-enter the data
                $this->set('profile', $this->params);
                
                return;
                
        }
        
}
 
 
?>