1 | <?php |
---|
2 | |
---|
3 | class data_utils extends data |
---|
4 | { |
---|
5 | |
---|
6 | # ---------------------------------------------------------------------------------------- |
---|
7 | # fonction de modification de champ generique |
---|
8 | # |
---|
9 | |
---|
10 | function get($table, $champ, $where_champ, $where_valeur) |
---|
11 | { $value = ""; |
---|
12 | try |
---|
13 | { $query = |
---|
14 | "SELECT `".$champ."` as res" |
---|
15 | ." FROM #--".$table |
---|
16 | ." WHERE ".$where_champ."=".$this->eq($where_valeur) |
---|
17 | ." LIMIT 1"; |
---|
18 | $rst = $this->sql->query($query); |
---|
19 | if($v_rst = $this->sql->fetch_assoc($rst)) $value = $v_rst["res"]; |
---|
20 | } |
---|
21 | catch(Exception $_e) { $value = false; } |
---|
22 | return $value; |
---|
23 | } |
---|
24 | |
---|
25 | function set($table, $champ, $valeur, $where_champ, $where_valeur) |
---|
26 | { try |
---|
27 | { $query = |
---|
28 | "UPDATE #--".$table |
---|
29 | ." SET `".$champ."`=".$this->eq($valeur) |
---|
30 | ." WHERE `".$where_champ."`=".$this->eq($where_valeur) |
---|
31 | ." LIMIT 1"; |
---|
32 | $this->sql->query($query); |
---|
33 | } |
---|
34 | catch(Exception $_e) { return false; } |
---|
35 | return true; |
---|
36 | } |
---|
37 | |
---|
38 | # ---------------------------------------------------------------------------------------- |
---|
39 | # |
---|
40 | # ci-dessous |
---|
41 | # |
---|
42 | # - utils : des fonctions courantes dans le traitement des données |
---|
43 | # (dates, echapement des simples quotes...) |
---|
44 | # |
---|
45 | # - fonctions de base : des squelettes de fonctions pour l'accÚs en base |
---|
46 | # (liste, ajout, modification...) |
---|
47 | # |
---|
48 | # ---------------------------------------------------------------------------------------- |
---|
49 | |
---|
50 | # ---------------------------------------------------------------------------------------- |
---|
51 | # utils |
---|
52 | # |
---|
53 | |
---|
54 | function html($content) |
---|
55 | { return str_replace |
---|
56 | ( array(">", "<", """), |
---|
57 | array(">", "<", "\""), |
---|
58 | $content |
---|
59 | ); |
---|
60 | } |
---|
61 | |
---|
62 | function encode_email($email) |
---|
63 | { return |
---|
64 | "<a href=\"".$this->ascii_entities("mailto:".$email)."\">" |
---|
65 | .$this->ascii_entities($email) |
---|
66 | ."</a>"; |
---|
67 | } |
---|
68 | |
---|
69 | function ascii_entities($content) |
---|
70 | { $entities = ""; |
---|
71 | $n = 0; |
---|
72 | while($n < strlen($content)) |
---|
73 | { $entities .= "&#".ord($content[$n]).";"; |
---|
74 | $n++; |
---|
75 | } |
---|
76 | return $entities; |
---|
77 | } |
---|
78 | |
---|
79 | function resume($content, $max) |
---|
80 | { $resume = ""; |
---|
81 | $v_content = explode(" ", $content); |
---|
82 | for($n = 0; $n < $max; $n++) $resume .= $v_content[$n]." "; |
---|
83 | return $resume; |
---|
84 | } |
---|
85 | |
---|
86 | function eq($content) { return (isset($content) ? "'".str_replace("'", "\'", $content)."'" : "NULL"); } |
---|
87 | |
---|
88 | function frenchdate($i) |
---|
89 | { if(ereg("([0-9]{2,4})-([0-9]{1,2})-([0-9]{1,2})", $i, $regs)) $i = $regs[3]."-".$regs[2]."-".$regs[1]; |
---|
90 | return $i; |
---|
91 | } |
---|
92 | |
---|
93 | function englishdate($i) |
---|
94 | { if(ereg("([0-9]{1,2})-([0-9]{1,2})-([0-9]{2,4})", $i, $regs)) $i = $regs[3]."-".$regs[2]."-".$regs[1]; |
---|
95 | return $i; |
---|
96 | } |
---|
97 | |
---|
98 | function unix_time($mysql_timestamp) |
---|
99 | { if |
---|
100 | ( preg_match('/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/', $mysql_timestamp, $pieces) |
---|
101 | || preg_match('/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/', $mysql_timestamp, $pieces) |
---|
102 | ) |
---|
103 | { $unix_time = mktime($pieces[4], $pieces[5], $pieces[6], $pieces[2], $pieces[3], $pieces[1]); |
---|
104 | } |
---|
105 | elseif |
---|
106 | ( preg_match('/\d{4}\-\d{2}\-\d{2} \d{2}:\d{2}:\d{2}/', $mysql_timestamp) |
---|
107 | || preg_match('/\d{2}\-\d{2}\-\d{2} \d{2}:\d{2}:\d{2}/', $mysql_timestamp) |
---|
108 | || preg_match('/\d{4}\-\d{2}\-\d{2}/', $mysql_timestamp) |
---|
109 | || preg_match('/\d{2}\-\d{2}\-\d{2}/', $mysql_timestamp) |
---|
110 | ) |
---|
111 | { $unix_time = strtotime($mysql_timestamp); |
---|
112 | } |
---|
113 | elseif |
---|
114 | ( preg_match('/(\d{4})(\d{2})(\d{2})/', $mysql_timestamp, $pieces) |
---|
115 | || preg_match('/(\d{2})(\d{2})(\d{2})/', $mysql_timestamp, $pieces) |
---|
116 | ) |
---|
117 | { $unix_time = mktime(0, 0, 0, $pieces[2], $pieces[3], $pieces[1]); |
---|
118 | } |
---|
119 | return $unix_time; |
---|
120 | } |
---|
121 | |
---|
122 | function str_to_hex($str) |
---|
123 | { $hex = ""; |
---|
124 | $n = 0; |
---|
125 | while($n < strlen($str)) |
---|
126 | { $hex_char = dechex(ord($str[$n])); |
---|
127 | if(strlen($hex_char) == 1) $hex_char = "0".$hex_char; |
---|
128 | $hex .= $hex_char; |
---|
129 | $n++; |
---|
130 | } |
---|
131 | return $hex; |
---|
132 | } |
---|
133 | |
---|
134 | function is_email($email) |
---|
135 | { $atom = '[-a-z0-9!#$%&\'*+\\/=?^_`{|}~]'; |
---|
136 | $domain = '([a-z0-9]([-a-z0-9]*[a-z0-9]+)?)'; |
---|
137 | return preg_match |
---|
138 | ( '/^'.$atom.'+'.'(\.'.$atom.'+)*'.'@'.'('.$domain.'{1,63}\.)+'.$domain.'{2,63}$/i', |
---|
139 | $email |
---|
140 | ); |
---|
141 | } |
---|
142 | |
---|
143 | # ---------------------------------------------------------------------------------------- |
---|
144 | # fonctions de base |
---|
145 | # |
---|
146 | |
---|
147 | function list_() |
---|
148 | { $list = array(); |
---|
149 | try |
---|
150 | { $query = "SELECT * FROM #--table"; |
---|
151 | $rst = $this->sql->query($query); |
---|
152 | while($v_rst = $this->sql->fetch_assoc($rst)) $list[$v_rst["id"]] = $v_rst; |
---|
153 | $this->sql->free_result($rst); |
---|
154 | } |
---|
155 | catch(Exception $_e) { $list = false; } |
---|
156 | return $list; |
---|
157 | } |
---|
158 | |
---|
159 | function add_($value) |
---|
160 | { try |
---|
161 | { $query = |
---|
162 | "INSERT INTO #--table(value) VALUES" |
---|
163 | ."( ".$this->eq($value) |
---|
164 | .")"; |
---|
165 | $this->sql->query($query); |
---|
166 | } |
---|
167 | catch(Exception $_e) { return false; } |
---|
168 | return true; |
---|
169 | } |
---|
170 | |
---|
171 | function set_($id, $value) |
---|
172 | { try |
---|
173 | { $query = |
---|
174 | "UPDATE #--table SET" |
---|
175 | ." value=".$this->eq($value) |
---|
176 | ." WHERE id=".$this->eq($id); |
---|
177 | $this->sql->query($query); |
---|
178 | } |
---|
179 | catch(Exception $_e) { return false; } |
---|
180 | return true; |
---|
181 | } |
---|
182 | |
---|
183 | function del_($id) |
---|
184 | { try |
---|
185 | { $query = "DELETE FROM #--table WHERE id=".$this->eq($id); |
---|
186 | $this->sql->query($query); |
---|
187 | } |
---|
188 | catch(Exception $_e) { return false; } |
---|
189 | return true; |
---|
190 | } |
---|
191 | |
---|
192 | } |
---|
193 | |
---|
194 | ?> |
---|