X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=includes%2Fcurrent_user.inc;h=5430b1104c2eb1d59b1ae31df94f364a0901bf1b;hb=05ba2d82d4230a8ea991920515cdc2377fcacfd0;hp=9e5938eba5e2f1bc1092420b0860aa79683119f8;hpb=d67d5295b9342c011697ce4df325197e29898588;p=fa-stable.git diff --git a/includes/current_user.inc b/includes/current_user.inc index 9e5938eb..5430b110 100644 --- a/includes/current_user.inc +++ b/includes/current_user.inc @@ -1,28 +1,45 @@ . +***********************************************************************/ include_once($path_to_root . "/includes/prefs/userprefs.inc"); //-------------------------------------------------------------------------- -class current_user +class current_user { - + var $user; var $loginname; var $username; - var $name; + var $name; var $company; + var $pos; var $access; - + var $timeout; + var $last_act; + var $role_set = false; + var $logged; - + var $ui_mode = 0; + var $prefs; function current_user() { - $this->loginname = $username = $this->name = $this->company = ""; + global $def_coy; + + $this->loginname = $this->username = $this->name = ""; + $this->company = isset($def_coy)? $def_coy : 0; $this->logged = false; - $this->prefs = null; + $this->prefs = new user_prefs(); } function logged_in() @@ -37,42 +54,95 @@ class current_user function login($company, $loginname, $password) { + global $security_areas, $security_groups, $security_headings; + $this->set_company($company); + $this->logged = false; $Auth_Result = get_user_for_login($loginname, $password); if (db_num_rows($Auth_Result) > 0) { - $myrow = db_fetch($Auth_Result); - - $this->access = $myrow["full_access"]; + $myrow = db_fetch($Auth_Result); + $this->old_db = isset($myrow["full_access"]); + if (! @$myrow["inactive"]) { + if ($this->old_db) { + // Transition code: + // db was not yet upgraded after source update to v.2.2 + // give enough access for admin user to continue upgrade + if (!isset($security_groups) || !isset($security_headings)) { + echo "


"; + echo _('Before software upgrade you have to include old $security_groups and $security_headings arrays from old config.php file to the new one.'); + echo "

"; + exit; + } + $this->access = $myrow["full_access"]; + if (in_array(20, $security_groups[$this->access])) + // temporary access for admin users + $this->role_set[] = $security_areas['SA_SOFTWAREUPGRADE'][0]; + else { + echo "


"; + echo _('System is available for site admin only until full database upgrade'); + echo "

"; + exit; + } + } else { + $this->role_set = array(); + $this->access = $myrow["role_id"]; + // store area codes available for current user role + $role = get_security_role($this->access); + if (!$role) + return false; + foreach( $role['areas'] as $code ) + // filter only area codes for enabled security sections + if (in_array($code&~0xff, $role['sections'])) + $this->role_set[] = $code; + } $this->name = $myrow["real_name"]; + $this->pos = $myrow["pos"]; $this->loginname = $loginname; $this->username = $this->loginname; $this->prefs = new user_prefs($myrow); - - update_user_visitdate($loginname); - $this->logged = true; - - } - else - { - $this->logged = false; + $this->user = @$myrow["id"]; + update_user_visitdate($this->username); + $this->logged = true; + $this->last_act = time(); + $this->timeout = session_timeout(); + } } - return $this->logged; } function check_user_access() { global $security_groups; - return is_array($security_groups[$this->access]); + if ($this->old_db) { + // notification after upgrade from pre-2.2 version + return isset($security_groups) && is_array(@$security_groups[$this->access]); + } else + return !isset($security_groups) && is_array($this->role_set); + } + + function can_access($page_level) + { + global $security_groups, $security_areas; + + if (isset($security_groups)) { + return $this->company == 0 && + in_array(20, $security_groups[$this->access]); + } + + if ($page_level === 'SA_OPEN') + return true; + $code = $security_areas[$page_level][0]; + // only first registered company has site admin privileges + return $code && in_array($code, $this->role_set) + && ($this->company == 0 || ($code&~0xff != SS_SADMIN)); } function can_access_page($page_level) { - global $security_groups; - return isset($page_level) && in_array($page_level, $security_groups[$this->access]); + return $this->can_access($page_level); } function get_db_connection() @@ -86,51 +156,95 @@ class current_user $db = mysql_connect($connection["host"] , $connection["dbuser"], $connection["dbpassword"]); mysql_select_db($connection["dbname"],$db); - + if (!defined('TB_PREF')) define('TB_PREF', $connection["tbpref"]); - + return $db; } - function update_prefs($price_dec, $qty_dec, $exrate_dec, $percent_dec, $showgl, $showcodes, - $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, $show_hints) { - update_user_display_prefs($this->username, $price_dec, $qty_dec, $exrate_dec, $percent_dec, $showgl, - $showcodes, $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, $show_hints); + function update_prefs($price_dec, $qty_dec, $exrate_dec, $percent_dec, + $showgl, $showcodes, $date_format, $date_sep, $tho_sep, $dec_sep, + $theme, $pagesize, $show_hints, $profile, $rep_popup, $query_size, + $graphic_links, $lang, $stickydate, $startup_tab) { + update_user_display_prefs($this->user, $price_dec, + $qty_dec, $exrate_dec, $percent_dec, $showgl, $showcodes, + $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, + $show_hints, $profile, $rep_popup, $query_size, $graphic_links, $lang, $stickydate, $startup_tab); // re-read the prefs - $user = get_user($this->username); + $user = get_user($this->user); $this->prefs = new user_prefs($user); } } //-------------------------------------------------------------------------- -function number_format2($number, $decimals=0) +function round2($number, $decimals=0) +{ + $delta = ($number < 0 ? -.000001 : .000001); + return round($number+$delta, $decimals); +} + +function number_format2($number, $decimals=0) { global $thoseps, $decseps; $tsep = $thoseps[$_SESSION["wa_current_user"]->prefs->tho_sep()]; $dsep = $decseps[$_SESSION["wa_current_user"]->prefs->dec_sep()]; - return number_format($number, $decimals, $dsep, $tsep); + //return number_format($number, $decimals, $dsep, $tsep); + $delta = ($number < 0 ? -.000001 : .000001); + return number_format($number+$delta, $decimals, $dsep, $tsep); +} +// +// Current ui mode. +// +function fallback_mode() { + return $_SESSION["wa_current_user"]->ui_mode==0; } function price_format($number) { - return number_format2($number, + return number_format2($number, $_SESSION["wa_current_user"]->prefs->price_dec()); } -function qty_format($number) { - return number_format2($number, - $_SESSION["wa_current_user"]->prefs->qty_dec()); +function price_decimal_format($number, &$dec) +{ + $dec = user_price_dec(); + $str = strval($number); + $pos = strpos($str, '.'); + if ($pos !== false) + { + $len = strlen(substr($str, $pos + 1)); + if ($len > $dec) + $dec = $len; + } + return number_format2($number, $dec); } - +// 2008-06-15. Added extra parameter $stock_id and reference for $dec +//-------------------------------------------------------------------- +function qty_format($number, $stock_id=null, &$dec) { + $dec = get_qty_dec($stock_id); + return number_format2($number, $dec); +} +// and get_qty_dec +function get_qty_dec($stock_id=null) +{ + global $path_to_root; + include_once($path_to_root."/inventory/includes/db/items_units_db.inc"); + if ($stock_id != null) + $dec = get_unit_dec($stock_id); + if ($stock_id == null || $dec == -1 || $dec == null) + $dec = $_SESSION["wa_current_user"]->prefs->qty_dec(); + return $dec; +} +//------------------------------------------------------------------- function exrate_format($number) { - return number_format2($number, + return number_format2($number, $_SESSION["wa_current_user"]->prefs->exrate_dec()); } function percent_format($number) { - return number_format2($number, + return number_format2($number, $_SESSION["wa_current_user"]->prefs->percent_dec()); } @@ -143,7 +257,7 @@ function user_numeric($input) { str_replace($sep, '', $num); $sep = $decseps[user_dec_sep()]; if($sep!='.') $num = str_replace( $sep, '.', $num); - + if (!is_numeric($num)) return false; $num = (float)$num; @@ -153,112 +267,157 @@ function user_numeric($input) { return $num; } -function user_company() +function user_company() { return $_SESSION["wa_current_user"]->company; } -function user_language() +function user_pos() +{ + return $_SESSION["wa_current_user"]->pos; +} + +function user_language() { return $_SESSION["wa_current_user"]->prefs->language(); } -function user_qty_dec() +function user_qty_dec() { return $_SESSION["wa_current_user"]->prefs->qty_dec(); } -function user_price_dec() +function user_price_dec() { return $_SESSION["wa_current_user"]->prefs->price_dec(); } -function user_exrate_dec() +function user_exrate_dec() { return $_SESSION["wa_current_user"]->prefs->exrate_dec(); } -function user_percent_dec() +function user_percent_dec() { return $_SESSION["wa_current_user"]->prefs->percent_dec(); } -function user_show_gl_info() +function user_show_gl_info() { return $_SESSION["wa_current_user"]->prefs->show_gl_info(); } -function user_show_codes() +function user_show_codes() { return $_SESSION["wa_current_user"]->prefs->show_codes(); } -function user_date_format() +function user_date_format() { return $_SESSION["wa_current_user"]->prefs->date_format(); } -function user_date_display() +function user_date_display() { return $_SESSION["wa_current_user"]->prefs->date_display(); } -function user_date_sep() +function user_date_sep() { return $_SESSION["wa_current_user"]->prefs->date_sep(); } -function user_tho_sep() +function user_tho_sep() { return $_SESSION["wa_current_user"]->prefs->tho_sep(); } -function user_dec_sep() +function user_dec_sep() { return $_SESSION["wa_current_user"]->prefs->dec_sep(); } -function user_theme() +function user_theme() { return $_SESSION["wa_current_user"]->prefs->get_theme(); } -function user_pagesize() +function user_pagesize() { return $_SESSION["wa_current_user"]->prefs->get_pagesize(); } -function user_hints() +function user_hints() { return $_SESSION["wa_current_user"]->prefs->show_hints(); } +function user_print_profile() +{ + return $_SESSION["wa_current_user"]->prefs->print_profile(); +} + +function user_rep_popup() +{ + return $_SESSION["wa_current_user"]->prefs->rep_popup(); +} + +function user_query_size() +{ + return $_SESSION["wa_current_user"]->prefs->query_size(); +} + +function user_graphic_links() +{ + return $_SESSION["wa_current_user"]->prefs->graphic_links(); +} + +function sticky_doc_date() +{ + return $_SESSION["wa_current_user"]->prefs->sticky_date(); +} + +function user_startup_tab() +{ + return $_SESSION["wa_current_user"]->prefs->start_up_tab(); +} + function set_user_prefs($price_dec, $qty_dec, $exrate_dec, $percent_dec, $showgl, $showcodes, - $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, $show_hints) + $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, $show_hints, + $print_profile, $rep_popup, $query_size, $graphic_links, $lang, $stickydate, $startup_tab) { $_SESSION["wa_current_user"]->update_prefs($price_dec, $qty_dec, $exrate_dec, $percent_dec, $showgl, $showcodes, - $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, $show_hints); + $date_format, $date_sep, $tho_sep, $dec_sep, $theme, $pagesize, $show_hints, + $print_profile, $rep_popup, $query_size, $graphic_links, $lang, $stickydate, $startup_tab); } function add_user_js_data() { - global $path_to_root, $thoseps, $decseps; + global $path_to_root, $thoseps, $decseps, $date_system, $dateseps; $ts = $thoseps[user_tho_sep()]; $ds = $decseps[user_dec_sep()]; - - $js = "\n"; + . "pdec : " . user_price_dec() . "}\n"; add_js_source($js); } //-------------------------------------------------------------------------- +function session_timeout() +{ + $tout = @get_company_pref('login_tout'); // mask warning for db ver. 2.2 + return $tout ? $tout : ini_get('session.gc_maxlifetime'); +} ?> \ No newline at end of file