X-Git-Url: http://git.cyclocoop.org/?p=velocampus%2Fweb%2Fwww.git;a=blobdiff_plain;f=www%2Fecrire%2Fbase%2Fconnect_sql.php;fp=www%2Fecrire%2Fbase%2Fconnect_sql.php;h=6e5b8a48e59c6d1f830009c0ca834e4ac2a2e006;hp=0000000000000000000000000000000000000000;hb=80b4d3e85f78d402ed2e73f8f5d1bf4c19962eed;hpb=aaf970bf4cdaf76689ecc10609048e18d073820c diff --git a/www/ecrire/base/connect_sql.php b/www/ecrire/base/connect_sql.php new file mode 100644 index 0000000..6e5b8a4 --- /dev/null +++ b/www/ecrire/base/connect_sql.php @@ -0,0 +1,358 @@ + $auth); + } + $g['authentification'] = $auth; + $g['type'] = $type; + return $db_ok = $g; + } + // En cas d'indisponibilite du serveur, eviter de le bombarder + if (!defined('_ECRIRE_INSTALL')) { + @touch($f); + spip_log("Echec connexion serveur $type : host[$host] port[$port] login[$login] base[$db]", $type); + } +} + +// 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; + if (!$r = $f('valeur','spip_meta', "nom='charset_sql_connexion'")) + 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); +} + +// 1 interface de abstract_sql a demenager dans base/abstract_sql a terme + +// http://doc.spip.org/@_q +function _q ($a) { + return (is_numeric($a)) ? strval($a) : + (!is_array($a) ? ("'" . addslashes($a) . "'") + : join(",", array_map('_q', $a))); +} + +// Nommage bizarre des tables d'objets +// http://doc.spip.org/@table_objet +function table_objet($type) { + static $surnoms = null; + if (!$type) return; + if (!$surnoms){ + // passer dans un pipeline qui permet aux plugins de declarer leurs exceptions + $surnoms = pipeline('declarer_tables_objets_surnoms', + array( + 'article' => 'articles', + 'auteur' => 'auteurs', + 'breve' => 'breves', + 'document' => 'documents', + 'doc' => 'documents', # pour les modeles + 'img' => 'documents', + 'emb' => 'documents', + 'groupe_mots' => 'groupes_mots', # hum + 'groupe_mot' => 'groupes_mots', # hum + 'groupe' => 'groupes_mots', # hum (EXPOSE) + 'message' => 'messages', + 'mot' => 'mots', + 'petition' => 'petitions', + 'rubrique' => 'rubriques', + 'signature' => 'signatures', + 'syndic' => 'syndic', + 'site' => 'syndic', # hum hum + 'syndic_article' => 'syndic_articles', + 'type_document' => 'types_documents', # hum + 'extension' => 'types_documents' # hum + )); + } + return isset($surnoms[$type]) + ? $surnoms[$type] + : preg_replace(',ss$,', 's', $type."s"); +} + +// http://doc.spip.org/@table_objet_sql +function table_objet_sql($type) { + global $table_des_tables; + $nom = table_objet($type); + include_spip('public/interfaces'); + if (isset($table_des_tables[$nom])) { + $t = $table_des_tables[$nom]; + $nom = 'spip_' . $t; + } + return $nom ; +} + +// http://doc.spip.org/@id_table_objet +function id_table_objet($type,$serveur='') { + $type = preg_replace(',^spip_|s$,', '', $type); + if ($type == 'type') + return 'extension'; + else { + if (!$type) return; + $t = table_objet($type); + $trouver_table = charger_fonction('trouver_table', 'base'); + $desc = $trouver_table($t,$serveur); + return @$desc['key']["PRIMARY KEY"]; + } +} + +// http://doc.spip.org/@objet_type +function objet_type($table_objet){ + static $surnoms = null; + if (!$surnoms){ + // passer dans un pipeline qui permet aux plugins de declarer leurs exceptions + $surnoms = pipeline('declarer_type_surnoms', array()); + } + + // scenario de base + // le type est decline a partir du nom de la table en enlevant le prefixe eventuel + // et la marque du pluriel + $type = preg_replace(',^spip_|s$,', '', $table_objet); + if (isset($surnoms[$type])) + return $surnoms[$type]; + + // si le type redonne bien la table c'est bon + if ( (table_objet($type)==$table_objet) + OR (table_objet_sql($type)==$table_objet)) + return $type; + + // sinon on passe par la cle primaire id_xx pour trouver le type + // car le s a la fin est incertain + // notamment en cas de pluriel derogatoire + // id_jeu/spip_jeux id_journal/spip_journaux qui necessitent tout deux + // une declaration jeu => jeux, journal => journaux + // dans le pipeline declarer_tables_objets_surnoms + $trouver_table = charger_fonction('trouver_table', 'base'); + if ($desc = $trouver_table($table_objet) + AND isset($desc['key']["PRIMARY KEY"])){ + $primary = $desc['key']["PRIMARY KEY"]; + $primary = explode(',',$primary); + $primary = reset($primary); + $type = preg_replace(',^id_,', '', $primary); + } + // on a fait ce qu'on a pu + return $type; +} + +// 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)); + $tx = $xdesc['table']; + $ty = $ydesc['table']; + $ix = @$xdesc['key']["PRIMARY KEY"]; + $iy = @$ydesc['key']["PRIMARY KEY"]; + if ($table = $GLOBALS['tables_jointures'][$ty][$ix]) return $table; + if ($table = $GLOBALS['tables_jointures'][$tx][$iy]) return $table; + return ''; +} + +// 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; +} + +?>