$auth); } $g['authentification'] = $auth; $g['type'] = $type; return $db_ok = $g; } // En cas d'indisponibilite du serveur, eviter de le bombarder if ($f) { @touch($f); spip_log( "Echec connexion serveur $type : host[$host] port[$port] login[$login] base[$db]", $type.'.'._LOG_HS); } } // Premiere connexion au serveur principal: // retourner le charset donnee par la table principale // mais verifier que le fichier de connexion n'est pas trop vieux // Version courante = 0.7 // La version 0.7 indique un serveur d'authentification comme 8e arg // La version 0.6 indique le prefixe comme 7e arg // La version 0.5 indique le serveur comme 6e arg // // La version 0.0 (non numerotee) doit etre refaite par un admin // les autres fonctionnent toujours, meme si : // - la version 0.1 est moins performante que la 0.2 // - la 0.2 fait un include_ecrire('inc_db_mysql.php3'). // http://doc.spip.org/@spip_connect_main function spip_connect_main($connexion) { if ($GLOBALS['spip_connect_version']< 0.1 AND _DIR_RESTREINT){ include_spip('inc/headers'); redirige_url_ecrire('upgrade', 'reinstall=oui'); } if (!($f = $connexion['select'])) return false; // en cas d'erreur select retourne la requette (is_string=true donc) if (!$r = $f('valeur','spip_meta', "nom='charset_sql_connexion'") OR is_string($r)) return false; if (!($f = $connexion['fetch'])) return false; $r = $f($r); return ($r['valeur'] ? $r['valeur'] : -1); } // compatibilite function spip_connect_ldap($serveur='') { include_spip('auth/ldap'); return auth_ldap_connect($serveur); } // Echappement d'une valeur (num, string, array) sous forme de chaine PHP // pour un array(1,'a',"a'") renvoie la chaine "'1','a','a\''" // Usage sql un peu deprecie, a remplacer par sql_quote() // http://doc.spip.org/@_q function _q ($a) { return (is_numeric($a)) ? strval($a) : (!is_array($a) ? ("'" . addslashes($a) . "'") : join(",", array_map('_q', $a))); } // Recuperer le nom de la table de jointure xxxx sur l'objet yyyy // http://doc.spip.org/@table_jointure function table_jointure($x, $y) { $trouver_table = charger_fonction('trouver_table', 'base'); $xdesc = $trouver_table(table_objet($x)); $ydesc = $trouver_table(table_objet($y)); $ix = @$xdesc['key']["PRIMARY KEY"]; $iy = @$ydesc['key']["PRIMARY KEY"]; if ($table = $ydesc['tables_jointures'][$ix]) return $table; if ($table = $xdesc['tables_jointures'][$iy]) return $table; return ''; } /** * Echapper les textes entre ' ' ou " " d'une requete SQL * avant son pre-traitement * On renvoi la query sans textes et les textes separes, dans * leur ordre d'apparition dans la query * * @param string $query * @return array */ function query_echappe_textes($query){ static $codeEchappements = array("''"=>"\x1@##@\x1", "\'"=>"\x2@##@\x2", "\\\""=>"\x3@##@\x3"); $query = str_replace(array_keys($codeEchappements), array_values($codeEchappements), $query); if (preg_match_all("/((['])[^']*(\\2))|(([\"])[^\"]*(\\5))/S",$query,$textes)){ $textes = reset($textes); // indice 0 du match switch(count($textes)){ case 0:$replace=array();break; case 1:$replace=array('%1$s');break; case 2:$replace=array('%1$s','%2$s');break; case 3:$replace=array('%1$s','%2$s','%3$s');break; case 4:$replace=array('%1$s','%2$s','%3$s','%4$s');break; case 5:$replace=array('%1$s','%2$s','%3$s','%4$s','%5$s');break; default: $replace = range(1,count($textes)); $replace = '%'.implode('$s,%',$replace).'$s'; $replace = explode(',',$replace); break; } $query = str_replace($textes,$replace,$query); } else $textes = array(); return array($query, $textes); } /** * Reinjecter les textes d'une requete SQL a leur place initiale, * apres traitement de la requete * * @param string $query * @param array $textes * @return string */ function query_reinjecte_textes($query, $textes){ static $codeEchappements = array("''"=>"\x1@##@\x1", "\'"=>"\x2@##@\x2", "\\\""=>"\x3@##@\x3"); # debug de la substitution #if (($c1=substr_count($query,"%"))!=($c2=count($textes))){ # spip_log("$c1 ::". $query,"tradquery"._LOG_ERREUR); # spip_log("$c2 ::". var_export($textes,1),"tradquery"._LOG_ERREUR); # spip_log("ini ::". $qi,"tradquery"._LOG_ERREUR); #} switch (count($textes)){ case 0:break; case 1:$query=sprintf($query,$textes[0]);break; case 2:$query=sprintf($query,$textes[0],$textes[1]);break; case 3:$query=sprintf($query,$textes[0],$textes[1],$textes[2]);break; case 4:$query=sprintf($query,$textes[0],$textes[1],$textes[2],$textes[3]);break; case 5:$query=sprintf($query,$textes[0],$textes[1],$textes[2],$textes[3],$textes[4]);break; default: array_unshift($textes,$query); $query = call_user_func_array('sprintf',$textes); break; } $query = str_replace(array_values($codeEchappements), array_keys($codeEchappements), $query); return $query; } // Pour compatibilite. Ne plus utiliser. // http://doc.spip.org/@spip_query function spip_query($query, $serveur='') { global $spip_sql_version; $f = spip_connect_sql($spip_sql_version, 'query', $serveur, true); return function_exists($f) ? $f($query, $serveur) : false; } ?>