Removed many global variables from config.default.php to GL Setup, Company Setup...
[fa-stable.git] / includes / current_user.inc
index 591524f4626e6b5ad899add3804b23567df97e7f..26b288a1e884463a22dd677521f04f205c041a25 100644 (file)
@@ -18,10 +18,11 @@ if (!defined('TB_PREF')) {
 
 class current_user
 {
-       var $user;
+       var $user = 0;
        var $loginname;
        var $username;
        var $name;
+       var $email;
        var $company; // user's company
        var $pos;
        var $access;
@@ -53,17 +54,20 @@ class current_user
 
        function set_company($company)
        {
-               $this->company = $company;
+               $this->company = (int)$company;
        }
 
        function login($company, $loginname, $password)
        {
-               global $security_areas, $security_groups, $security_headings, $path_to_root;
-               
+               global $security_areas, $security_groups, $security_headings, $path_to_root, $dflt_lang, $login_delay;
+
                $this->set_company($company);
            $this->logged = false;
 
-               set_global_connection();
+               set_global_connection($company);
+               $lang = &$_SESSION['language'];
+               $lang->set_language($_SESSION['language']->code);
+               db_set_encoding($_SESSION['language']->encoding);
 
                // Use external authentication source if any.
                // Keep in mind you need to have user data set for $loginname
@@ -73,9 +77,18 @@ class current_user
                if (!isset($Auth_Result))       // if not used: standard method
                        $Auth_Result = get_user_auth($loginname, md5($password));
 
+               if ($login_delay > 0)
+                       write_login_filelog($loginname, $Auth_Result);
+
                if ($Auth_Result)
                {
                        $myrow = get_user_by_login($loginname);
+                       if ($myrow['language'] != $dflt_lang)
+                       {        // refresh language and user data
+                               $lang->set_language($myrow['language']);
+                               db_set_encoding($_SESSION['language']->encoding);
+                               $myrow = get_user_by_login($loginname);
+                       }
 
                        $this->old_db = isset($myrow["full_access"]);
                        if (! @$myrow["inactive"]) {
@@ -118,6 +131,7 @@ class current_user
                    $this->username = $this->loginname;
                    $this->prefs = new user_prefs($myrow);
                    $this->user = @$myrow["id"];
+                $this->email = @$myrow["email"];
                        update_user_visitdate($this->username);
                        $this->logged = true;
                                $this->last_act = time();
@@ -127,6 +141,32 @@ class current_user
                return $this->logged;
        }
 
+       function reset_password($company, $email) {
+               global $app_title;
+
+               $this->set_company($company);
+               $this->logged = false;
+
+               set_global_connection();
+
+               $myrow = get_user_by_email($email);
+
+               if ($myrow['id'] != "") {
+
+                       $bytes = openssl_random_pseudo_bytes(8, $cstrong);
+                       $password   = base64_encode($bytes);
+
+                       $hash = md5($password);
+
+                       update_user_password($myrow['id'], $myrow['user_id'], $hash);
+
+                       mail($myrow['email'], _("New password for")." ".$app_title, $password);
+
+                       return true;
+               }
+               return false;
+    }
+
        function check_user_access()
        {
                global $security_groups;
@@ -137,20 +177,20 @@ class current_user
                        return !isset($security_groups) && is_array($this->role_set);
        }
 
-       function can_access($page_level)
+       function can_access($sec_area)
        {
                global $security_groups, $security_areas;
                if (isset($security_groups)) {
-                       return $this->company == 0 &&
+                       return is_admin_company() &&
                                in_array(20, $security_groups[$this->access]);
                }
 
-               if ($page_level === 'SA_OPEN') 
+               if ($sec_area === 'SA_OPEN') 
                        return true;
-               if ($page_level === 'SA_DENIED' || $page_level === '') 
+               if ($sec_area === 'SA_DENIED' || $sec_area === '') 
                        return false;
 
-               $code = $security_areas[$page_level][0];
+               $code = $security_areas[$sec_area][0];
 
                // only first registered company has site admin privileges
                return $code && in_array($code, $this->role_set)
@@ -162,6 +202,74 @@ class current_user
                return $this->can_access($page_level);
        }
 
+       function check_application_access($waapp)
+       {
+               if (!$this->hide_inaccessible_menu_items())
+               {
+                       return true;
+               }
+
+               foreach ($waapp->modules as $module)
+               {
+                       if ($this->check_module_access($module))
+                       {
+                               return true;
+                       }
+               }
+
+               return false;
+
+       }
+
+       function check_module_access($module)
+       {
+
+               if (!$this->hide_inaccessible_menu_items())
+               {
+                       return true;
+               }
+
+               if (sizeof($module->lappfunctions) > 0)
+               {
+                       foreach ($module->lappfunctions as $appfunction)
+                       {
+                               if ($appfunction->label != "" && $this->can_access_page($appfunction->access))
+                               {
+                                       return true;
+                               }
+                       }
+               }
+
+               if (sizeof($module->rappfunctions) > 0)
+               {
+                       foreach ($module->rappfunctions as $appfunction)
+                       {
+                               if ($appfunction->label != "" && $this->can_access_page($appfunction->access))
+                               {
+                                       return true;
+                               }
+                       }
+               }
+
+               return false;
+
+       }
+
+       function hide_inaccessible_menu_items()
+       {
+               global $hide_inaccessible_menu_items;
+
+               if (!isset($hide_inaccessible_menu_items) || $hide_inaccessible_menu_items == 0)
+               {
+                       return false;
+               }
+
+               else
+               {
+                       return true;
+               }
+       }
+
        function set_db_connection($id = -1)
        {
                return set_global_connection($id);
@@ -211,6 +319,20 @@ function number_format2($number, $decimals=0)
        return $decimals==='max' ? rtrim($num, '0') : $num;
 
 }
+
+/* price/float comparision helper to be used in any suspicious place for zero values? 
+usage:
+if (!floatcmp($value1, $value2)) 
+       compare value is 0
+*/
+
+define('FLOAT_COMP_DELTA', 0.004);
+
+function floatcmp($a, $b)
+{
+    return $a - $b > FLOAT_COMP_DELTA ? 1 : ($b - $a > FLOAT_COMP_DELTA ? -1 : 0);
+}
+
 //
 //     Current ui mode.
 //
@@ -420,6 +542,31 @@ function user_startup_tab()
        return $_SESSION["wa_current_user"]->prefs->start_up_tab();
 }
 
+function user_transaction_days()
+{
+    return $_SESSION["wa_current_user"]->prefs->transaction_days();
+}
+
+function user_save_report_selections()
+{
+    return $_SESSION["wa_current_user"]->prefs->save_report_selections();
+}
+
+function user_use_date_picker()
+{
+    return $_SESSION["wa_current_user"]->prefs->use_date_picker();
+}
+
+function user_def_print_destination()
+{
+    return $_SESSION["wa_current_user"]->prefs->def_print_destination();
+}
+
+function user_def_print_orientation()
+{
+    return $_SESSION["wa_current_user"]->prefs->def_print_orientation();
+}
+
 function user_check_access($sec_area)
 {
        return $_SESSION["wa_current_user"]->can_access($sec_area);
@@ -531,6 +678,14 @@ function array_search_key($needle, $haystack, $valuekey=null)
        return @$keys[0];
 }
 
+// Recalculate report columns if orientation is landscape.
+function recalculate_cols(&$cols)
+{
+       $factor = (user_pagesize() == "A4" ? 1.4 : 1.3);
+       foreach($cols as $key => $col)
+               $cols[$key] = intval($col * $factor); 
+}
+
 function flush_dir($path, $wipe = false) 
 {
        $dir = opendir($path);
@@ -562,4 +717,9 @@ function company_path($comp=null)
                        . '/'.$comp;
 }
 
+function is_admin_company()
+{
+       return $this->company == 0;
+}
+
 ?>
\ No newline at end of file