Skip to content
Snippets Groups Projects
class.staff.php 23 KiB
Newer Older
  • Learn to ignore specific revisions
  • Jared Hancock's avatar
    Jared Hancock committed
    <?php
    /*********************************************************************
        class.staff.php
    
        Everything about staff.
    
        Peter Rotich <peter@osticket.com>
        Copyright (c)  2006-2012 osTicket
        http://www.osticket.com
    
        Released under the GNU General Public License WITHOUT ANY WARRANTY.
        See LICENSE.TXT for details.
    
        vim: expandtab sw=4 ts=4 sts=4:
    **********************************************************************/
    
    include_once(INCLUDE_DIR.'class.ticket.php');
    
    Jared Hancock's avatar
    Jared Hancock committed
    include_once(INCLUDE_DIR.'class.dept.php');
    include_once(INCLUDE_DIR.'class.team.php');
    include_once(INCLUDE_DIR.'class.group.php');
    include_once(INCLUDE_DIR.'class.passwd.php');
    
    class Staff {
        
        var $ht;
        var $id;
    
        var $dept;
    
    Peter Rotich's avatar
    Peter Rotich committed
        var $departments;
        var $group;
    
    Jared Hancock's avatar
    Jared Hancock committed
        var $teams;
    
    Jared Hancock's avatar
    Jared Hancock committed
        var $stats;
        
    
        function Staff($var) {
    
    Jared Hancock's avatar
    Jared Hancock committed
            $this->id =0;
            return ($this->load($var));
        }
    
    
        function load($var='') {
    
    Jared Hancock's avatar
    Jared Hancock committed
    
            if(!$var && !($var=$this->getId()))
                return false;
    
    
            $sql='SELECT staff.*, staff.created as added, grp.* '
    
                .' FROM '.STAFF_TABLE.' staff '
    
                .' LEFT JOIN '.GROUP_TABLE.' grp ON(grp.group_id=staff.group_id) ';
    
            $sql.=sprintf(' WHERE %s=%s',is_numeric($var)?'staff_id':'username',db_input($var));
    
    Jared Hancock's avatar
    Jared Hancock committed
    
            if(!($res=db_query($sql)) || !db_num_rows($res))
                return NULL;
    
    
    Jared Hancock's avatar
    Jared Hancock committed
            $this->ht=db_fetch_array($res);
            $this->id  = $this->ht['staff_id'];
    
    Peter Rotich's avatar
    Peter Rotich committed
            $this->teams = $this->ht['teams'] = array();
            $this->group = $this->dept = null;
            $this->departments = $this->stats = array();
    
            //WE have to patch info here to support upgrading from old versions.
            if(($time=strtotime($this->ht['passwdreset']?$this->ht['passwdreset']:$this->ht['added'])))
                $this->ht['passwd_change'] = time()-$time; //XXX: check timezone issues.
    
            if($this->ht['timezone_id'])
                $this->ht['tz_offset'] = Timezone::getOffsetById($this->ht['timezone_id']);
            elseif($this->ht['timezone_offset'])
                $this->ht['tz_offset'] = $this->ht['timezone_offset'];
    
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->id);
        }
    
    
        function reload() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->load();
        }
    
        function getHastable() {
            return $this->ht;
        }
    
    
        function getInfo() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->getHastable();
        }
    
        /*compares user password*/
    
        function check_passwd($password) {
    
    Jared Hancock's avatar
    Jared Hancock committed
    
            /*bcrypt based password match*/
    
            if(Passwd::cmp($password, $this->getPasswd()))
    
    Jared Hancock's avatar
    Jared Hancock committed
                return true;
    
            /*Fall back to MD5 && force a password reset if it matches*/
            if(strlen($this->getPasswd()) && !strcmp($this->getPasswd(), MD5($password))) {
                $this->forcePasswdRest();
    
                return true;
            }
    
            return false;
        }
    
        function forcePasswdRest() {
            return db_query('UPDATE '.STAFF_TABLE.' SET change_passwd=1 WHERE staff_id='.db_input($this->getId()));
        }
    
        /* check if passwd reset is due. */
    
        function isPasswdResetDue() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            global $cfg;
    
            return ($cfg && $cfg->getPasswdResetPeriod() 
    
                        && $this->ht['passwd_change']>($cfg->getPasswdResetPeriod()*30*24*60*60));
    
    Jared Hancock's avatar
    Jared Hancock committed
        }
    
        function isPasswdChangeDue() {
            return $this->isPasswdResetDue();
        }
    
        function getTZoffset() {
            return $this->ht['tz_offset'];
        }
    
        function observeDaylight() {
            return $this->ht['daylight_saving']?true:false;
        }
    
    
        function getRefreshRate() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['auto_refresh_rate'];
        }
    
        function getPageLimit() {
            return $this->ht['max_page_size'];
        }
    
    
        function getId() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->id;
        }
    
    
        function getEmail() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['email'];
        }
    
    
        function getUserName() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['username'];
        }
    
    
        function getPasswd() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['passwd'];
        }
    
    
        function getName() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ucfirst($this->ht['firstname'].' '.$this->ht['lastname']);
        }
            
    
        function getFirstName() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['firstname'];
        }
            
    
        function getLastName() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['lastname'];
        }
        
    
        function getSignature() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['signature'];
        }
    
        function getDefaultSignatureType() {
            return $this->ht['default_signature_type'];
        }
    
    
        function getDefaultPaperSize() {
            return $this->ht['default_paper_size'];
        }
    
    
        function forcePasswdChange() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['change_passwd']);
        }
    
    
    Peter Rotich's avatar
    Peter Rotich committed
        function getDepartments() {
    
            if($this->departments)
                return $this->departments;
    
            //Departments the staff is "allowed" to access...
            // based on the group they belong to + user's primary dept + user's managed depts.
            $sql='SELECT DISTINCT d.dept_id FROM '.STAFF_TABLE.' s '
                .' LEFT JOIN '.GROUP_DEPT_TABLE.' g ON(s.group_id=g.group_id) '
                .' INNER JOIN '.DEPT_TABLE.' d ON(d.dept_id=s.dept_id OR d.manager_id=s.staff_id OR d.dept_id=g.dept_id) '
                .' WHERE s.staff_id='.db_input($this->getId());
    
            $depts = array();
            if(($res=db_query($sql)) && db_num_rows($res)) {
                while(list($id)=db_fetch_row($res))
                    $depts[] = $id;
            } else { //Neptune help us! (fallback)
                $depts = array_merge($this->getGroup()->getDepartments(), array($this->getDeptId()));
            }
    
            $this->departments = array_filter(array_unique($depts));
    
    
            return $this->departments;
        }
    
    
        function getDepts() {
    
    Peter Rotich's avatar
    Peter Rotich committed
            return $this->getDepartments();
        }
         
        function getGroupId() {
            return $this->ht['group_id'];
    
    Peter Rotich's avatar
    Peter Rotich committed
        function getGroup() {
         
            if(!$this->group && $this->getGroupId())
                $this->group = Group::lookup($this->getGroupId());
    
            return $this->group;
    
        function getDeptId() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return $this->ht['dept_id'];
        }
    
    
        function getDept() {
    
            if(!$this->dept && $this->getDeptId())
    
    Jared Hancock's avatar
    Jared Hancock committed
                $this->dept= Dept::lookup($this->getDeptId());
    
            return $this->dept;
        }
    
    
    
        function isManager() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return (($dept=$this->getDept()) && $dept->getManagerId()==$this->getId());
        }
    
    
        function isStaff() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return TRUE;
        }
    
    
        function isGroupActive() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['group_enabled']);
        }
    
    
        function isactive() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['isactive']);
        }
    
    
        function isVisible() {
    
    Jared Hancock's avatar
    Jared Hancock committed
             return ($this->ht['isvisible']);
        }
            
    
        function onVacation() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['onvacation']);
        }
    
        function isAvailable() {
            return ($this->isactive() && $this->isGroupActive() && !$this->onVacation());
        }
    
    
        function showAssignedOnly() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['assigned_only']);
        }
    
    
        function isAccessLimited() {
            return $this->showAssignedOnly();
        }
    
        function isAdmin() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['isadmin']);
        }
    
        function isTeamMember($teamId) {
    
            return ($teamId && in_array($teamId, $this->getTeams()));
    
    Jared Hancock's avatar
    Jared Hancock committed
        }
    
        function canAccessDept($deptId) {
    
            return ($deptId && in_array($deptId, $this->getDepts()) && !$this->isAccessLimited());
    
        function canCreateTickets() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['can_create_tickets']);
        }
    
    
        function canEditTickets() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['can_edit_tickets']);
        }
        
    
        function canDeleteTickets() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['can_delete_tickets']);
        }
       
    
        function canCloseTickets() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['can_close_tickets']);
        }
    
        function canAssignTickets() {
            return ($this->ht['can_assign_tickets']);
        }
    
        function canTransferTickets() {
            return ($this->ht['can_transfer_tickets']);
        }
    
        function canBanEmails() {
            return ($this->ht['can_ban_emails']);
        }
      
    
        function canManageTickets() {
    
            return ($this->isAdmin() 
    
    Jared Hancock's avatar
    Jared Hancock committed
                     || $this->canDeleteTickets() 
                        || $this->canCloseTickets());
        }
    
    
        function canManagePremade() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['can_manage_premade']);
        }
    
        function canManageCannedResponses() {
            return $this->canManagePremade();
        }
    
    
        function canManageFAQ() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['can_manage_faq']);
        }
    
        function canManageFAQs() {
            return $this->canManageFAQ();
        }
    
    
        function showAssignedTickets() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($this->ht['show_assigned_tickets']
                    && ($this->isAdmin() || $this->isManager()));
        }
    
    
        function getTeams() {
    
            if(!$this->teams) {
                $sql='SELECT team_id FROM '.TEAM_MEMBER_TABLE
                    .' WHERE staff_id='.db_input($this->getId());
    
    Jared Hancock's avatar
    Jared Hancock committed
                if(($res=db_query($sql)) && db_num_rows($res))
                    while(list($id)=db_fetch_row($res))
                        $this->teams[] = $id;
            }
    
            return $this->teams;
        }
        /* stats */
    
        function resetStats() {
            $this->stats = array();
        }
    
        /* returns staff's quick stats - used on nav menu...etc && warnings */
        function getTicketsStats() {
    
            if(!$this->stats['tickets'])
                $this->stats['tickets'] = Ticket::getStaffStats($this);
    
            return  $this->stats['tickets'];
        }
    
        function getNumAssignedTickets() {
            return ($stats=$this->getTicketsStats())?$stats['assigned']:0;
        }
    
        function getNumClosedTickets() {
            return ($stats=$this->getTicketsStats())?$stats['closed']:0;
        }
    
        //Staff profile update...unfortunately we have to separate it from admin update to avoid potential issues
    
        function updateProfile($vars, &$errors) {
    
    Jared Hancock's avatar
    Jared Hancock committed
    
            $vars['firstname']=Format::striptags($vars['firstname']);
            $vars['lastname']=Format::striptags($vars['lastname']);
            $vars['signature']=Format::striptags($vars['signature']);
    
            if($this->getId()!=$vars['id'])
                $errors['err']='Internal Error';
    
            if(!$vars['firstname'])
                $errors['firstname']='First name required';
            
            if(!$vars['lastname'])
                $errors['lastname']='Last name required';
    
            if(!$vars['email'] || !Validator::is_email($vars['email']))
                $errors['email']='Valid email required';
            elseif(Email::getIdByEmail($vars['email']))
                $errors['email']='Already in-use as system email';
            elseif(($uid=Staff::getIdByEmail($vars['email'])) && $uid!=$this->getId())
                $errors['email']='Email already in-use by another staff member';
    
            if($vars['phone'] && !Validator::is_phone($vars['phone']))
                $errors['phone']='Valid number required';
    
            if($vars['mobile'] && !Validator::is_phone($vars['mobile']))
                $errors['mobile']='Valid number required';
    
    
            if($vars['passwd1'] || $vars['passwd2'] || $vars['cpasswd']) {
    
    Jared Hancock's avatar
    Jared Hancock committed
    
                if(!$vars['passwd1'])
                    $errors['passwd1']='New password required';
                elseif($vars['passwd1'] && strlen($vars['passwd1'])<6)
                    $errors['passwd1']='Must be at least 6 characters';
    
                elseif($vars['passwd1'] && strcmp($vars['passwd1'], $vars['passwd2']))
    
    Jared Hancock's avatar
    Jared Hancock committed
                    $errors['passwd2']='Password(s) do not match';
                
                if(!$vars['cpasswd'])
                    $errors['cpasswd']='Current password required';
                elseif(!$this->check_passwd($vars['cpasswd']))
                    $errors['cpasswd']='Invalid current password!';
            }
    
            if(!$vars['timezone_id'])
                $errors['timezone_id']='Time zone required';
    
            if($vars['default_signature_type']=='mine' && !$vars['signature'])
                $errors['default_signature_type'] = "You don't have a signature";
    
            if($errors) return false;
    
            $sql='UPDATE '.STAFF_TABLE.' SET updated=NOW() '
                .' ,firstname='.db_input($vars['firstname'])
                .' ,lastname='.db_input($vars['lastname'])
                .' ,email='.db_input($vars['email'])
                .' ,phone="'.db_input(Format::phone($vars['phone']),false).'"'
                .' ,phone_ext='.db_input($vars['phone_ext'])
                .' ,mobile="'.db_input(Format::phone($vars['mobile']),false).'"'
                .' ,signature='.db_input($vars['signature'])
                .' ,timezone_id='.db_input($vars['timezone_id'])
                .' ,daylight_saving='.db_input(isset($vars['daylight_saving'])?1:0)
                .' ,show_assigned_tickets='.db_input(isset($vars['show_assigned_tickets'])?1:0)
                .' ,max_page_size='.db_input($vars['max_page_size'])
                .' ,auto_refresh_rate='.db_input($vars['auto_refresh_rate'])
    
                .' ,default_signature_type='.db_input($vars['default_signature_type'])
                .' ,default_paper_size='.db_input($vars['default_paper_size']);
    
    Jared Hancock's avatar
    Jared Hancock committed
    
    
            if($vars['passwd1'])
    
                $sql.=' ,change_passwd=0, passwdreset=NOW(), passwd='.db_input(Passwd::hash($vars['passwd1']));
    
    Jared Hancock's avatar
    Jared Hancock committed
    
            $sql.=' WHERE staff_id='.db_input($this->getId());
    
            //echo $sql;
    
            return (db_query($sql));
        }
    
    
    
        function updateTeams($teams) {
    
            if($teams) {
                foreach($teams as $k=>$id) {
                    $sql='INSERT IGNORE INTO '.TEAM_MEMBER_TABLE.' SET updated=NOW() '
                        .' ,staff_id='.db_input($this->getId()).', team_id='.db_input($id);
    
    Jared Hancock's avatar
    Jared Hancock committed
                    db_query($sql);
                }
            }
            $sql='DELETE FROM '.TEAM_MEMBER_TABLE.' WHERE staff_id='.db_input($this->getId());
            if($teams)
    
                $sql.=' AND team_id NOT IN('.implode(',', $teams).')';
    
    Jared Hancock's avatar
    Jared Hancock committed
            
            db_query($sql);
    
            return true;
        }
    
    
        function update($vars, &$errors) {
            if(!$this->save($this->getId(), $vars, $errors))
    
    Jared Hancock's avatar
    Jared Hancock committed
                return false;
    
            $this->updateTeams($vars['teams']);
            $this->reload();
            
            return true;
        }
    
    
        function delete() {
    
    Jared Hancock's avatar
    Jared Hancock committed
            global $thisstaff;
    
            if(!$thisstaff || !($id=$this->getId()) || $id==$thisstaff->getId())
                return 0;
    
            $sql='DELETE FROM '.STAFF_TABLE.' WHERE staff_id='.db_input($id).' LIMIT 1';
    
            if(db_query($sql) && ($num=db_affected_rows())) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                // DO SOME HOUSE CLEANING
                //Move remove any ticket assignments...TODO: send alert to Dept. manager?
                db_query('UPDATE '.TICKET_TABLE.' SET staff_id=0 WHERE status=\'open\' AND staff_id='.db_input($id));
                //Cleanup Team membership table.
                db_query('DELETE FROM '.TEAM_MEMBER_TABLE.' WHERE staff_id='.db_input($id));
            }
    
            return $num;
        }
    
        /**** Static functions ********/
    
        function getStaffMembers($availableonly=false) {
    
            $sql='SELECT s.staff_id,CONCAT_WS(", ",s.lastname, s.firstname) as name '
                .' FROM '.STAFF_TABLE.' s ';
    
            if($availableonly) {
                $sql.=' INNER JOIN '.GROUP_TABLE.' g ON(g.group_id=s.group_id AND g.group_enabled=1) '
                     .' WHERE s.isactive=1 AND s.onvacation=0';
            }
    
            $sql.='  ORDER BY s.lastname, s.firstname';
            $users=array();
            if(($res=db_query($sql)) && db_num_rows($res)) {
                while(list($id, $name) = db_fetch_row($res))
                    $users[$id] = $name;
            }
    
            return $users;
        }
    
        function getAvailableStaffMembers() {
            return self::getStaffMembers(true);
        }
    
    
        function getIdByUsername($username) {
    
    Jared Hancock's avatar
    Jared Hancock committed
    
            $sql='SELECT staff_id FROM '.STAFF_TABLE.' WHERE username='.db_input($username);
            if(($res=db_query($sql)) && db_num_rows($res))
                list($id) = db_fetch_row($res);
    
            return $id;
        }
    
        function getIdByEmail($email) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                        
            $sql='SELECT staff_id FROM '.STAFF_TABLE.' WHERE email='.db_input($email);
            if(($res=db_query($sql)) && db_num_rows($res))
                list($id) = db_fetch_row($res);
    
            return $id;
        }
    
    
        function lookup($id) {
    
    Jared Hancock's avatar
    Jared Hancock committed
            return ($id && is_numeric($id) && ($staff= new Staff($id)) && $staff->getId()==$id)?$staff:null;
        }
    
    
        function login($username, $passwd, &$errors, $strike=true) {
    
    Jared Hancock's avatar
    Jared Hancock committed
    
    
            if($_SESSION['_staff']['laststrike']) {
                if((time()-$_SESSION['_staff']['laststrike'])<$cfg->getStaffLoginTimeout()) {
                    $errors['err']='You\'ve reached maximum failed login attempts allowed.';
    
                } else { //Timeout is over.
    
    Jared Hancock's avatar
    Jared Hancock committed
                    //Reset the counter for next round of attempts after the timeout.
                    $_SESSION['_staff']['laststrike']=null;
                    $_SESSION['_staff']['strikes']=0;
                }
            }
       
    
            if(!$errors && ($user=new StaffSession($username)) && $user->getId() && $user->check_passwd($passwd)) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                //update last login && password reset stuff.
                $sql='UPDATE '.STAFF_TABLE.' SET lastlogin=NOW() ';
                if($user->isPasswdResetDue() && !$user->isAdmin())
                    $sql.=',change_passwd=1';
                $sql.=' WHERE staff_id='.db_input($user->getId());
                db_query($sql);
                //Now set session crap and lets roll baby!
                $_SESSION['_staff']=array(); //clear.
                $_SESSION['_staff']['userID']=$username;
                $user->refreshSession(); //set the hash.
                $_SESSION['TZ_OFFSET']=$user->getTZoffset();
    
    Peter Rotich's avatar
    Peter Rotich committed
                $_SESSION['TZ_DST']=$user->observeDaylight();
    
    
                $ost->logDebug('Staff login', 
                        sprintf("%s logged in [%s]", $user->getUserName(), $_SERVER['REMOTE_ADDR'])); //Debug.
    
    Jared Hancock's avatar
    Jared Hancock committed
                $sid=session_id(); //Current ID
                session_regenerate_id(TRUE);
                //Destroy old session ID - needed for PHP version < 5.1.0 TODO: remove when we move to php 5.3 as min. requirement.
    
                if(($session=$ost->getSession()) && is_object($session) && $sid)
    
    Jared Hancock's avatar
    Jared Hancock committed
                    $session->destroy($sid);
    
    Jared Hancock's avatar
    Jared Hancock committed
                session_write_close();
            
                return $user;
            }
        
            //If we get to this point we know the login failed.
            $_SESSION['_staff']['strikes']+=1;
            if(!$errors && $_SESSION['_staff']['strikes']>$cfg->getStaffMaxLogins()) {
                $errors['err']='Forgot your login info? Contact Admin.';
                $_SESSION['_staff']['laststrike']=time();
                $alert='Excessive login attempts by a staff member?'."\n".
                       'Username: '.$_POST['username']."\n".'IP: '.$_SERVER['REMOTE_ADDR']."\n".'TIME: '.date('M j, Y, g:i a T')."\n\n".
                       'Attempts #'.$_SESSION['_staff']['strikes']."\n".'Timeout: '.($cfg->getStaffLoginTimeout()/60)." minutes \n\n";
    
                $ost->logWarning('Excessive login attempts ('.$_POST['username'].')', $alert, ($cfg->alertONLoginError()));
    
            } elseif($_SESSION['_staff']['strikes']%2==0) { //Log every other failed login attempt as a warning.
    
    Jared Hancock's avatar
    Jared Hancock committed
                $alert='Username: '.$_POST['username']."\n".'IP: '.$_SERVER['REMOTE_ADDR'].
                       "\n".'TIME: '.date('M j, Y, g:i a T')."\n\n".'Attempts #'.$_SESSION['_staff']['strikes'];
    
                $ost->logWarning('Failed staff login attempt ('.$_POST['username'].')', $alert, false);
    
        function create($vars, &$errors) {
    
    Jared Hancock's avatar
    Jared Hancock committed
            if(($id=self::save(0, $vars, $errors)) && $vars['teams'] && ($staff=Staff::lookup($id)))
    
    Jared Hancock's avatar
    Jared Hancock committed
                $staff->updateTeams($vars['teams']);
    
            return $id;
        }
    
    
        function save($id, $vars, &$errors) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                
            $vars['username']=Format::striptags($vars['username']);
            $vars['firstname']=Format::striptags($vars['firstname']);
            $vars['lastname']=Format::striptags($vars['lastname']);
            $vars['signature']=Format::striptags($vars['signature']);
    
            if($id && $id!=$vars['id'])
                $errors['err']='Internal Error';
                
            if(!$vars['firstname'])
                $errors['firstname']='First name required';
            if(!$vars['lastname'])
                $errors['lastname']='Last name required';
                
    
            if(!$vars['username'] || strlen($vars['username'])<2)
    
    Jared Hancock's avatar
    Jared Hancock committed
                $errors['username']='Username required';
            elseif(($uid=Staff::getIdByUsername($vars['username'])) && $uid!=$id)
                $errors['username']='Username already in-use';
            
            if(!$vars['email'] || !Validator::is_email($vars['email']))
                $errors['email']='Valid email required';
            elseif(Email::getIdByEmail($vars['email']))
                $errors['email']='Already in-use system email';
            elseif(($uid=Staff::getIdByEmail($vars['email'])) && $uid!=$id)
                $errors['email']='Email already in-use by another staff member';
    
            if($vars['phone'] && !Validator::is_phone($vars['phone']))
                $errors['phone']='Valid number required';
            
            if($vars['mobile'] && !Validator::is_phone($vars['mobile']))
                $errors['mobile']='Valid number required';
    
    
            if($vars['passwd1'] || $vars['passwd2'] || !$id) {
                if(!$vars['passwd1'] && !$id) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                    $errors['passwd1']='Temp. password required';
                    $errors['temppasswd']='Required';
    
                } elseif($vars['passwd1'] && strlen($vars['passwd1'])<6) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                    $errors['passwd1']='Must be at least 6 characters';
    
                } elseif($vars['passwd1'] && strcmp($vars['passwd1'], $vars['passwd2'])) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                    $errors['passwd2']='Password(s) do not match';
                }
            }
            
            if(!$vars['dept_id'])
                $errors['dept_id']='Department required';
                
            if(!$vars['group_id'])
                $errors['group_id']='Group required';
    
            if(!$vars['timezone_id'])
                $errors['timezone_id']='Time zone required';
    
            if($errors) return false;
    
                
    
            $sql='SET updated=NOW() '
                .' ,isadmin='.db_input($vars['isadmin'])
                .' ,isactive='.db_input($vars['isactive'])
                .' ,isvisible='.db_input(isset($vars['isvisible'])?1:0)
                .' ,onvacation='.db_input(isset($vars['onvacation'])?1:0)
                .' ,assigned_only='.db_input(isset($vars['assigned_only'])?1:0)
                .' ,dept_id='.db_input($vars['dept_id'])
                .' ,group_id='.db_input($vars['group_id'])
                .' ,timezone_id='.db_input($vars['timezone_id'])
    
                .' ,daylight_saving='.db_input(isset($vars['daylight_saving'])?1:0)
    
                .' ,username='.db_input($vars['username'])
                .' ,firstname='.db_input($vars['firstname'])
                .' ,lastname='.db_input($vars['lastname'])
                .' ,email='.db_input($vars['email'])
                .' ,phone="'.db_input(Format::phone($vars['phone']),false).'"'
                .' ,phone_ext='.db_input($vars['phone_ext'])
                .' ,mobile="'.db_input(Format::phone($vars['mobile']),false).'"'
                .' ,signature='.db_input($vars['signature'])
                .' ,notes='.db_input($vars['notes']);
    
    Jared Hancock's avatar
    Jared Hancock committed
                
            if($vars['passwd1'])
    
                $sql.=' ,passwd='.db_input(Passwd::hash($vars['passwd1']));
    
    Jared Hancock's avatar
    Jared Hancock committed
                    
            if(isset($vars['change_passwd']))
    
                $sql.=' ,change_passwd=1';
    
    Jared Hancock's avatar
    Jared Hancock committed
                
            if($id) {
                $sql='UPDATE '.STAFF_TABLE.' '.$sql.' WHERE staff_id='.db_input($id);
                if(db_query($sql) && db_affected_rows())
                    return true;
                    
                $errors['err']='Unable to update the user. Internal error occurred';
    
            } else {
                $sql='INSERT INTO '.STAFF_TABLE.' '.$sql.', created=NOW()';
    
    Jared Hancock's avatar
    Jared Hancock committed
                if(db_query($sql) && ($uid=db_insert_id()))
                    return $uid;
                    
                $errors['err']='Unable to create user. Internal error';
            }
    
            return false;
        }
    }
    ?>