Added development/bugtracking sql trail.
[fa-stable.git] / includes / db / connect_db.inc
1 <?php
2
3 set_global_connection();
4
5 function set_global_connection()
6 {
7         global $db;
8
9     if (isset($_SESSION["wa_current_user"]) && $_SESSION["wa_current_user"]->company !='')
10         $db = $_SESSION["wa_current_user"]->get_db_connection();
11     else
12         $db = null;
13 }
14
15 $db_duplicate_error_code = 1062;
16
17 //DB wrapper functions to change only once for whole application
18
19 function db_query($sql, $err_msg=null)
20 {
21         global $db, $show_sql, $sql_trail, $select_trail;
22
23         //echo "<br>$sql<br>";
24         if ($show_sql)
25         {
26                 echo "<font face=arial size=2 color=000099><b>SQL..</b></font>";
27                 echo "<pre>";
28                 echo $sql;
29                 echo "</pre>\n";
30         }
31         
32
33         $result = mysql_query($sql, $db);
34         if($sql_trail) {
35                 if ($select_trail || (strstr($sql, 'SELECT') === false)) {
36                         mysql_query(
37                         "INSERT INTO ".TB_PREF."sql_trail
38                                 (`sql`, `result`, `msg`)
39                                 VALUES(".db_escape($sql).",".($result ? 1 : 0).",
40                                 ".db_escape($err_msg).")", $db);
41                 }
42         }
43
44         if ($err_msg != null)
45           if (function_exists('xdebug_call_file'))
46                 check_db_error('<br>At file '.xdebug_call_file().':'.xdebug_call_line().':<br>'.$err_msg, $sql);
47           else
48                 check_db_error($err_msg, $sql);
49
50         return $result;
51 }
52
53 function db_fetch_row ($result)
54 {
55
56         return mysql_fetch_row($result);
57 }
58
59 function db_fetch_assoc ($result)
60 {
61
62         return mysql_fetch_assoc($result);
63 }
64
65 function db_fetch ($result)
66 {
67
68         return mysql_fetch_array($result);
69 }
70
71 function db_seek (&$result,$record)
72 {
73         mysql_data_seek($result, $record);
74 }
75
76 function db_free_result ($result)
77 {
78         if ($result)
79                 mysql_free_result($result);
80 }
81
82 function db_num_rows (&$result)
83 {
84         return mysql_num_rows($result);
85 }
86
87 function db_num_fields ($result)
88 {
89         return mysql_num_fields($result);
90 }
91
92 function db_escape($value = "", $nullify = false)
93 {
94         $value = @htmlspecialchars($value, ENT_COMPAT, $_SESSION['language']->encoding);
95
96         //reset default if second parameter is skipped
97         $nullify = ($nullify === null) ? (false) : ($nullify);
98
99         //check for null/unset/empty strings
100         if ((!isset($value)) || (is_null($value)) || ($value === "")) {
101                 $value = ($nullify) ? ("NULL") : ("''");
102         } else {
103                 if (is_string($value)) {
104                 //value is a string and should be quoted; determine best method based on available extensions
105                         if (function_exists('mysql_real_escape_string')) {
106                                 $value = "'" . mysql_real_escape_string($value) . "'";
107                         } else {
108                           $value = "'" . mysql_escape_string($value) . "'";
109                         }
110                 } else if (!is_numeric($value)) {
111                         //value is not a string nor numeric
112                         display_error("ERROR: incorrect data type send to sql query");
113                         echo '<br><br>';
114                         exit();
115                 }
116         }
117         return $value;
118 }
119
120 function db_error_no ()
121 {
122         global $db;
123         return mysql_errno($db);
124 }
125
126 function db_error_msg($conn)
127 {
128         return mysql_error($conn);
129 }
130
131 function db_insert_id()
132 {
133         global $db;
134         return mysql_insert_id($db);
135 }
136
137 function db_num_affected_rows()
138 {
139         global $db;
140         return mysql_affected_rows($db);
141 }
142
143 ?>