[198] | 1 | <?php |
---|
| 2 | /***************************************************************************\ |
---|
| 3 | Plugin : magusine |
---|
| 4 | Licence : GPL |
---|
| 5 | Auteurs : Stéphane Noël, Philippe Vanderlinden |
---|
| 6 | Infos : http://www.spip-contrib.net/Le-plugin-Magusine |
---|
| 7 | http://www.magunews.net/spip.php?rubrique645 |
---|
| 8 | |
---|
| 9 | $LastChangedRevision: 12345 $ |
---|
| 10 | $LastChangedBy: bubu $ |
---|
| 11 | $LastChangedDate: 2008-03-21 15:50:47 +0100 (ven, 21 mar 2008) $ |
---|
| 12 | \***************************************************************************/ |
---|
| 13 | |
---|
| 14 | function arty_install($action){ |
---|
| 15 | switch ($action) |
---|
| 16 | { // La base est deja cree ? |
---|
| 17 | case 'test': |
---|
| 18 | // Verifier que le champ id_mon_plugin est present... |
---|
| 19 | include_spip('base/abstract_sql'); |
---|
| 20 | $desc = sql_showtable("spip_arty_themeassoc", false, '', true); |
---|
| 21 | return (isset($desc['field']['id'])); |
---|
| 22 | break; |
---|
| 23 | // Installer la base |
---|
| 24 | case 'install': |
---|
| 25 | include_spip('base/create'); // definir la fonction |
---|
| 26 | include_spip('base/tables_magusine'); // definir sa structure |
---|
| 27 | creer_base(); |
---|
| 28 | // entre les gabarits dans la db |
---|
| 29 | demarre_magusine(); |
---|
| 30 | break; |
---|
| 31 | // Supprimer la base |
---|
| 32 | case 'uninstall': |
---|
| 33 | // liste des tables à supprimer |
---|
| 34 | spip_query("DROP TABLE spip_arty_themeassoc"); |
---|
| 35 | break; |
---|
| 36 | } |
---|
| 37 | } |
---|
| 38 | |
---|
| 39 | function demarre_magusine() { |
---|
| 40 | include_spip('inc/xml-parser'); |
---|
| 41 | |
---|
| 42 | $resultat=spip_query("SELECT * FROM spip_arty_themeassoc WHERE type='rubrique' AND id = 0"); |
---|
| 43 | if(!spip_mysql_count($resultat)) { |
---|
| 44 | spip_query("INSERT INTO spip_arty_themeassoc (theme, id, type) VALUES ('emilio', 0, 'rubrique')"); |
---|
| 45 | } |
---|
| 46 | |
---|
| 47 | $gabarits=array(); |
---|
| 48 | $ignore_liste=array(".","..",".DS_Store"); |
---|
| 49 | $rep = _DIR_PLUGIN_ARTY."definitions-gabarits"; |
---|
| 50 | $handle = opendir($rep); |
---|
| 51 | while($fichier = readdir($handle)) { |
---|
| 52 | if (!in_array($fichier, $ignore_liste) && eregi('^[a-zA-Z0-9_-]*\.xml$',$fichier)) { |
---|
| 53 | |
---|
| 54 | $p =& new xmlParser(); |
---|
| 55 | $p->parse(_DIR_PLUGIN_ARTY.'definitions-gabarits/'.$fichier); |
---|
| 56 | |
---|
| 57 | foreach($p->output[0]['child'] as $ordre => $bloc) { |
---|
| 58 | |
---|
| 59 | $resultat = spip_query("SELECT * FROM spip_arty_gabarit_ordre WHERE nom='".$bloc['content']."' AND gabarit='".addslashes(ereg_replace("\.xml$", "", $fichier))."'"); |
---|
| 60 | |
---|
| 61 | if (!spip_mysql_count($resultat)) { |
---|
| 62 | spip_query("INSERT INTO spip_arty_gabarit_ordre (nom, ordre, conteneur ,gabarit, param) VALUES ('".$bloc['content']."', $ordre, ".addslashes($bloc['attrs']['STATUT'])." , '".addslashes(ereg_replace("\.xml$", "", $fichier))."', '".addslashes($bloc['attrs']['PARAMDEFAUT'])."')"); |
---|
| 63 | } |
---|
| 64 | } |
---|
| 65 | } |
---|
| 66 | } |
---|
| 67 | } |
---|
| 68 | |
---|
| 69 | |
---|
| 70 | ?> |
---|
| 71 | |
---|