summaryrefslogblamecommitdiffstats
path: root/modules-available/adduser/page.inc.php
blob: 87aaeef1fbf21251e24fceb47efec1b6df435a26 (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11

     

                               
 





                                                                                
                                                                                                                                     
                                                                      



                                                                        
                                                                                                                                            



                                                                           




                                                                                 







                                                                                                                                                                             
                                                          


                                                                                                            



                                                                           
                 
         
 



                                                                                        
                                                                                                                              

                                                              

                                                                    
         
 
 
<?php

class Page_AddUser extends Page
{

	protected function doPreprocess()
	{
		User::load();

		if (isset($_POST['action']) && $_POST['action'] === 'adduser') {
			// Check required fields
			if (empty($_POST['user']) || empty($_POST['pass1']) || empty($_POST['pass2']) || empty($_POST['fullname'])) {
				Message::addError('main.empty-field');
				Util::redirect('?do=AddUser');
			} elseif ($_POST['pass1'] !== $_POST['pass2']) {
				Message::addError('password-mismatch');
				Util::redirect('?do=AddUser');
			} elseif (!User::hasPermission('superadmin') && Database::queryFirst('SELECT userid FROM user LIMIT 1') !== false) {
				Message::addError('adduser-disabled');
				Util::redirect('?do=Session&action=login');
			} else {
				$data = array(
					'user' => $_POST['user'],
					'pass' => Crypto::hash6($_POST['pass1']),
					'fullname' => $_POST['fullname'],
					'phone' => $_POST['phone'],
					'email' => $_POST['email'],
				);
				if (Database::exec('INSERT INTO user SET login = :user, passwd = :pass, fullname = :fullname, phone = :phone, email = :email', $data) != 1) {
					Util::traceError('Could not create new user in DB');
				}
				// Make it superadmin if first user. This method sucks as it's a race condition but hey...
				$ret = Database::queryFirst('SELECT Count(*) AS num FROM user');
				if ($ret !== false && $ret['num'] == 1) {
					Database::exec('UPDATE user SET permissions = 1');
					EventLog::clear();
					EventLog::info('Created first user ' . $_POST['user']);
				} else {
					EventLog::info(User::getName() . ' created user ' . $_POST['user']);
				}
				Message::addInfo('adduser-success');
				Util::redirect('?do=Session&action=login');
			}
		}
	}

	protected function doRender()
	{
		// No user was added, check if current user is allowed to add a new user
		// Currently you can only add users if there is no user yet. :)
		if (!User::hasPermission('superadmin') && Database::queryFirst('SELECT userid FROM user LIMIT 1') !== false) {
			Message::addError('adduser-disabled');
		} else {
			Render::addTemplate('page-adduser', $_POST);
		}
	}

}