527b89ce3b90cfc7d80be2e21ecf7169c641be4b
[fa-stable.git] / admin / db / users_db.inc
1 <?php
2 /**********************************************************************
3     Copyright (C) FrontAccounting, LLC.
4         Released under the terms of the GNU General Public License, GPL, 
5         as published by the Free Software Foundation, either version 3 
6         of the License, or (at your option) any later version.
7     This program is distributed in the hope that it will be useful,
8     but WITHOUT ANY WARRANTY; without even the implied warranty of
9     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  
10     See the License here <http://www.gnu.org/licenses/gpl-3.0.html>.
11 ***********************************************************************/
12
13 function add_user($user_id, $real_name, $password, $phone, $email, $full_access, 
14         $language, $profile, $rep_popup, $pos)
15 {
16         $sql = "INSERT INTO ".TB_PREF."users (user_id, real_name, password"
17                 .", phone, email, full_access, language, pos, print_profile, rep_popup)
18                 VALUES (".db_escape($user_id).", 
19                 ".db_escape($real_name).", ".db_escape($password) .",".db_escape($phone).",
20                  ".db_escape($email).", $full_access, ".db_escape($language).",
21                  $pos,".db_escape($profile).",$rep_popup)";
22
23         db_query($sql, "could not add user for $user_id");
24 }
25
26 //-----------------------------------------------------------------------------------------------
27
28 function update_user_password($id, $user_id, $password)
29 {
30         $sql = "UPDATE ".TB_PREF."users SET password=".db_escape($password) . ",
31                 user_id = ".db_escape($user_id). " WHERE id=".db_escape($id);
32
33         db_query($sql, "could not update user password for $user_id");
34 }
35
36 //-----------------------------------------------------------------------------------------------
37
38 function update_user($id, $user_id, $real_name, $phone, $email, $full_access, 
39         $language, $profile, $rep_popup, $pos)
40 {
41         $sql = "UPDATE ".TB_PREF."users SET real_name=".db_escape($real_name).
42         ", phone=".db_escape($phone).",
43                 email=".db_escape($email).",
44                 full_access=$full_access,
45                 language=".db_escape($language).",
46                 print_profile=".db_escape($profile).",
47                 rep_popup=$rep_popup,
48                 pos=$pos,
49                 user_id = " . db_escape($user_id)
50                 . " WHERE id=" . db_escape($id);
51         db_query($sql, "could not update user for $user_id");
52 }
53
54 //-----------------------------------------------------------------------------------------------
55
56 function update_user_display_prefs($id, $price_dec, $qty_dec, $exrate_dec, 
57         $percent_dec, $showgl, $showcodes, $date_format, $date_sep, $tho_sep, 
58         $dec_sep, $theme, $pagesize, $show_hints, $profile, $rep_popup, $query_size, 
59         $graphic_links, $lang, $stickydate)
60 {
61         $sql = "UPDATE ".TB_PREF."users SET
62                 prices_dec=".db_escape($price_dec).",
63                 qty_dec=".db_escape($qty_dec).",
64                 rates_dec=".db_escape($exrate_dec).",
65                 percent_dec=".db_escape($percent_dec).",
66                 show_gl=".db_escape($showgl).",
67                 show_codes=".db_escape($showcodes).",
68                 date_format=".db_escape($date_format).",
69                 date_sep=".db_escape($date_sep).",
70                 tho_sep=".db_escape($tho_sep).",
71                 dec_sep=".db_escape($dec_sep).",
72                 theme=".db_escape($theme).",
73                 page_size=".db_escape($pagesize).",
74                 show_hints=$show_hints,
75                 print_profile=".db_escape($profile).",
76                 rep_popup=$rep_popup,
77                 query_size=$query_size,
78                 graphic_links=$graphic_links,
79                 language=".db_escape($lang).",
80                 sticky_doc_date=".db_escape($stickydate)."
81                 WHERE id = ".db_escape($id);
82
83         db_query($sql, "could not update user display prefs for $id");
84 }
85
86 //-----------------------------------------------------------------------------------------------
87
88
89 function get_users($all=false)
90 {
91         $sql = "SELECT * FROM ".TB_PREF."users";
92         if (!$all) $sql .= " WHERE !inactive";
93
94         return db_query($sql, "could not get users");
95 }
96
97 //-----------------------------------------------------------------------------------------------
98
99 function get_user($id)
100 {
101         $sql = "SELECT * FROM ".TB_PREF."users WHERE id=".db_escape($id);
102
103         $result = db_query($sql, "could not get user $id");
104
105         return db_fetch($result);
106 }
107
108 //-----------------------------------------------------------------------------------------------
109 //      This function is necessary for admin prefs update after upgrade from 2.1
110 //
111 function get_user_by_login($user_id)
112 {
113         $sql = "SELECT * FROM ".TB_PREF."users WHERE user_id=".db_escape($user_id);
114
115         $result = db_query($sql, "could not get user $user_id");
116
117         return db_fetch($result);
118 }
119
120 //-----------------------------------------------------------------------------------------------
121
122 function delete_user($id)
123 {
124         $sql="DELETE FROM ".TB_PREF."users WHERE id=".db_escape($id);
125
126         db_query($sql, "could not delete user $id");
127 }
128
129 //-----------------------------------------------------------------------------------------------
130
131 function get_user_for_login($user_id, $password)
132 {
133         set_global_connection();
134
135 // do not exclude inactive records or you lost access after source upgrade
136 // on sites using pre 2.2 database
137         $sql = "SELECT * FROM ".TB_PREF."users WHERE user_id = '$user_id' AND"
138                 ." password='$password'";
139
140         return db_query($sql, "could not get validate user login for $user_id");
141 }
142
143 //-----------------------------------------------------------------------------------------------
144
145 function update_user_visitdate($user_id)
146 {
147         $sql = "UPDATE ".TB_PREF."users SET last_visit_date='". date("Y-m-d H:i:s") ."'
148                 WHERE user_id=".db_escape($user_id);
149
150         db_query($sql, "could not update last visit date for user $user_id");
151 }
152
153 //-----------------------------------------------------------------------------------------------
154 function check_user_activity($id) 
155 {
156         $sql = "SELECT COUNT(*) FROM ".TB_PREF."audit_trail WHERE audit_trail.user="
157                 . db_escape($id);
158         $result = db_query($sql,"Cant check user activity");
159         $ret = db_fetch($result);
160
161         return $ret[0];
162 }
163 ?>