source: spip-zone/_plugins_/couteau_suisse/outils/boites_privees.php @ 111531

Last change on this file since 111531 was 111531, checked in by patfr@…, 9 months ago

Autre notice indésirable

File size: 12.6 KB
Line 
1<?php
2
3// Doc : https://contrib.spip.net/Les-Boites-Privees
4
5if (!defined("_ECRIRE_INC_VERSION")) return;
6include_spip('inc/presentation');
7include_spip('inc/layer');
8
9// compatibilite SQL pour SPIP 1.92
10if(!defined('_SPIP19300')) {
11        include_spip('base/abstract_sql');
12        if(!function_exists('sql_select')) { function sql_select($s=array(),$f=array(),$w=array(),$g=array(),$o=array(),$l='',$h=array(),$sv='') {
13                return spip_abstract_select($s,$f,$w,$g,$o,$l,'',$h,'','',$sv); } }
14        if(!function_exists('sql_fetch')) { function sql_fetch($s) { return spip_fetch_array($s); } }
15        if(!function_exists('sql_update')) { function sql_update($t, $e, $w=array()) {
16                if(!is_array($t))$t=array($t); if(!is_array($e))$e=array($e); if(!is_array($w))$w=array($w);
17                $q=$r =''; foreach($e as $i=>$v) $e[$i] = "$i=$v";
18                return spip_query("UPDATE ".join(',',$t)." SET ".join(',',$e).(empty($w)?'':" WHERE ".join(' AND ',$w)));
19        } }
20}
21
22// cette fonction appelee automatiquement a chaque affichage de la page privee du Couteau Suisse renvoie un tableau
23function boites_privees_installe_dist(){
24        tri_auteurs_verifie_table(); // OPTIM : ne le faire qu'a l'activation de la lame ou de la boite ? upgrade de SPIP ?
25        return false;
26}
27
28function boites_privees_affiche_gauche($flux){
29        $exec = &$flux['args']['exec'];
30        if(defined('boites_privees_TRI_AUTEURS') && ($exec=='article' || $exec=='articles')) {
31                include_spip('outils/boites_privees_action_rapide');
32                $flux['data'] .= action_rapide_tri_auteurs($flux['args']['id_article']);
33        }
34        if(defined('boites_privees_URLS_PROPRES')) {
35                // fonction de SPIP >= 3.0
36                $e = function_exists('trouver_objet_exec')
37                        ?trouver_objet_exec($exec)
38                        :array('type'=>$exec, 'id_table_objet'=>$flux['args']['id_'.$exec]?'id_'.$exec:'');
39                if($e && strlen($e['type']) && strlen($e['id_table_objet']) && isset($flux['args'][$e['id_table_objet']]))
40                        $flux['data'] .= cs_urls_propres($e['type'], $flux['args'][$e['id_table_objet']]);
41                else switch($exec) {
42                        // SPIP>=3.0 : objets au singulier uniquement (autres 'case' pour compatibilite SPIP<3.0)
43                        case 'articles': $flux['data'] .= cs_urls_propres('article', $flux['args']['id_article']); break;
44                        case 'naviguer': $flux['data'] .= cs_urls_propres('rubrique', $flux['args']['id_rubrique']); break;
45                        case 'auteur_infos': case 'auteurs_edit': $flux['data'] .= cs_urls_propres('auteur', $flux['args']['id_auteur']); break;
46                        case 'breves_voir': $flux['data'] .= cs_urls_propres('breve', $flux['args']['id_breve']); break;
47                        case 'mots_edit': $flux['data'] .= cs_urls_propres('mot', $flux['args']['id_mot']); break;
48                        case 'site': case 'sites': $flux['data'] .= cs_urls_propres('syndic', $flux['args']['id_syndic']); break;
49                }
50        }
51        return cs_pipeline_boite_privee($flux, 'gauche');
52}
53
54function boites_privees_affiche_milieu($flux){
55        switch($flux['args']['exec']) {
56                // SPIP >= 3.0 : objets au singulier
57                case 'article': case 'articles': {
58                        // texte original au format spip
59                        if(defined('boites_privees_ARTICLES'))
60                                $flux['data'] .= cs_formatspip($flux['args']['id_article']);
61                        break;
62                }
63                default:
64                        break;
65        }
66        return cs_pipeline_boite_privee($flux, 'milieu');
67}
68
69function boites_privees_affiche_droite($flux) {
70        switch($flux['args']['exec']) {
71                case 'auteur':case 'auteurs':/* Pour SPIP < v3 : */case 'auteur_infos':case 'auteurs_edit': 
72                        $flux['data'] .= cs_infos_webmasters() . cs_infos_connection(); break;
73                case 'admin_couteau_suisse':
74                        $flux['data'] .= cs_boite_rss(); break;
75                default:
76                        break;
77        }
78        return cs_pipeline_boite_privee($flux, 'droite');
79}
80
81/*
82 fonction appelant une liste de fonctions qui permettent :
83 - d'ajouter facilement des boites privees perso
84 - voire de modifier les boites fournies par le plugin
85 par exemple :
86        $GLOBALS['boites_privees_gauche'][] = 'ma_boite_privee';
87        function ma_boite_privee($flux, $exec) {
88                return $flux . debut_boite_info(true) . 'Youpi !!' . fin_boite_info(true);
89        }
90*/
91function cs_pipeline_boite_privee(&$flux, $endroit) {
92        // liste de filtres
93        $globale = 'boites_privees_'.$endroit;
94        if(!(isset($GLOBALS[$globale]) && is_array($GLOBALS[$globale]))) return $flux;
95        $liste = array_unique($GLOBALS[$globale]);
96        foreach($liste as $f)
97                if (function_exists($f)) $flux['data'] = $f($flux['data'], $flux['args']['exec']);
98        return $flux;
99}
100
101// pipeline utilise sous SPIP>=2.1, histoire de respecter l'ordre de stockage des auteurs d'objets
102function boites_privees_pre_boucle($flux) {
103        if(!defined('boites_privees_TRI_AUTEURS') || $flux->type_requete!='auteurs' 
104                        || !count($L1 = $flux->join) || !count($w = &$flux->where)>1) return $flux;
105        // alias de la jointure
106        $L1 = array_keys($L1);
107        if(defined('_SPIP30000')) { 
108                if($w[0][0]=="'='" && $w[1][0]=="'='")
109                        // SPIP v3 : 2 liens (sur objet et id_objet)
110                        $flux->order[] = 'tri_auteurs_sqlfield('.$w[0][2].','.$w[1][2].','._q($L1[0]).','._q(@$flux->serveur).')';
111        } elseif($w[0][0]=="'='")
112                // SPIP v2.1 : 1 lien (sur id_article)
113                $flux->order[] = 'tri_auteurs_sqlfield('.$w[0][2].',\'article\','._q($L1[0]).','._q(@$flux->serveur).')';
114        return $flux;
115}
116
117// function listant les auteurs d'un objet, tries suivant le champ 'ordre'
118function tri_auteurs_sqlfield($id_objet, $type_objet, $alias, $serveur) {
119        static $res = array();
120        if(!isset($r[$i = "$id_objet,$type_objet,$serveur"])) {
121                $t = defined('_SPIP30000')
122                        ?sql_allfetsel('id_auteur','spip_auteurs_liens', "objet=$type_objet AND id_objet=$id_objet", '','ordre','','',$serveur)
123                        :sql_allfetsel('id_auteur','spip_auteurs_articles', "id_article=$id_objet", '','ordre','','',$serveur);
124                $r[$i] = count($t)>1?'FIELD('.$alias.'.id_auteur,'.join(array_map('reset', $t), ',').')':'';
125        }
126        return $r[$i];
127}
128
129// verifier que le champ 'ordre' est bien present dans la table des liens, sinon on le cree
130// cette fonction ($complet=true) permet egalement une mise a jour en cas de creation du champ 'ordre' sur un site existant
131function tri_auteurs_verifie_table($complet=false) {
132        global $metas_outils; 
133        if(!defined('_SPIP20100') || //!defined('boites_privees_TRI_AUTEURS')) return;
134                !isset($metas_outils['boites_privees']['actif']) || !$metas_outils['boites_privees']['actif']) return;
135
136        include_spip('base/abstract_sql');
137        $table = defined('_SPIP30000')?'spip_auteurs_liens':'spip_auteurs_articles';
138        $x = sql_showtable($table);
139        if($x = !isset($x['field']['ordre']))
140                sql_alter("TABLE $table ADD ordre INT NOT NULL DEFAULT '0'");
141        if($complet || $x) {
142                // mise a jour du champ 'ordre' pour les articles a plusieurs auteurs et n'ayant jamais ete tries grace a ce champ
143                if(defined('_SPIP30000')) {
144                        $q1 = sql_select('id_objet, COUNT(*) as nb', $table, "objet='article' AND ordre=0", 'id_objet', '','', "nb>1");
145                        while($r1 = sql_fetch($q1)) {
146                                $q2 = sql_select('id_auteur', $table, "objet='article' AND ordre=0 AND id_objet=".$r1['id_objet']);
147                                $j = $r1['nb'] + 999; $i = 0;
148                                while($r2 = sql_fetch($q2))
149                                        sql_update($table, array('ordre'=>$i++ - $j), 
150                                                "objet='article' AND ordre=0 AND id_objet=$r1[id_objet] AND id_auteur=".$r2['id_auteur']);
151                        }
152                } else {
153                        $q1 = sql_select('id_article, COUNT(*) as nb', $table, "ordre=0", 'id_article', '','', "nb>1");
154                        while($r1 = sql_fetch($q1)) {
155                                $q2 = sql_select('id_auteur', $table, "ordre=0 AND id_article=".$r1['id_article']);
156                                $j = $r1['nb'] + 999; $i = 0;
157                                while($r2 = sql_fetch($q2))
158                                        sql_update($table, array('ordre'=>$i++ - $j), 
159                                                "ordre=0 AND id_article=$r1[id_article] AND id_auteur=".$r2['id_auteur']);
160                        }
161                }
162        } // $complet
163}
164
165function cs_boite_rss() {
166        include_spip('inc/autoriser');
167        if (!defined('boites_privees_CS') || !autoriser('configurer','csinfosrss')) return '';
168        return debut_boite_info(true)
169                . '<p><b>'.couteauprive_T('rss_titre').'</b></p><div class="cs_boite_rss"><div><p>'.couteauprive_T('rss_attente').'</p><noscript>'.couteauprive_T('outil_inactif').' !</noscript></div></div>'
170                /*.'<div style="text-align: right; font-size: 87%;"><a title="'.couteauprive_T('rss_desactiver').'" href="'
171                .generer_url_ecrire(_request('exec'),'cmd=switch&outil=rss_couteau_suisse').'">'.couteauprive_T('supprimer_cadre').'</a></div>'*/
172                . fin_boite_info(true);
173}
174
175function cs_infos_webmasters() {
176        include_spip('inc/autoriser');
177        if (!defined('boites_privees_WEBMASTERS') || !autoriser('configurer','csinfoswebmasters')) return '';
178        include_spip('cout_define');
179        list($w) = get_liste_administrateurs();
180        return cs_cadre_depliable(_T('couteau:webmestres'), 'bp_infos_webmasters', 
181        "<p>".(strlen($w)?'&bull; '.str_replace(', ','<br/>&bull; ',$w):_T('couteau:variable_vide'))."</p>");
182}
183
184function cs_infos_connection() {
185        include_spip('inc/autoriser');
186        if (!defined('boites_privees_AUTEURS') || !autoriser('configurer','csinfosconnection')) return '';
187        include_spip('public/assembler');
188        return cs_cadre_depliable(_T('couteau:connections'), 'bp_infos_connection',
189                recuperer_fond('fonds/derniers_connectes'));
190}
191
192function cs_formatspip($id_article){
193        include_spip('public/assembler');
194        if(!$txt = recuperer_fond('fonds/format_spip', array('id_article'=>$id_article))) return '';
195        $txt = explode('@TITRE@=', $txt, 2);
196        // compatibilite avec SPIP 1.92
197        $compat = function_exists('bouton_block_depliable');
198        $bouton = $compat?bouton_block_depliable(cs_div_configuration().$txt[1], 'invisible', "formatspip")
199                :bouton_block_invisible("formatspip").cs_div_configuration().$txt[1];
200        $bloc = $compat?debut_block_depliable(false, "formatspip")
201                :debut_block_invisible("formatspip");
202        return debut_cadre_enfonce(cs_icone(24,'formatspip','png'), true, '', $bouton)
203                . $bloc . $txt[0] . fin_block()
204                . fin_cadre_enfonce(true);
205}
206
207function cs_urls_propres($type, $id) {
208        global $type_urls;
209        if(!$id) return '';
210        $res = "";
211        // SPIP >= 2.0
212        if(defined('_SPIP19300')) {
213                $url = generer_url_entite_absolue($id, $type, '', '', true);
214                $lien_public = "\n[<span>[". _T('couteau:urls_propres_lien'). "|{$url}->{$url}]</span>]\n\n";
215                $s = sql_select("url, date", "spip_urls", "id_objet=$id AND type='$type'", '', 'date DESC');
216                $now = date('Y-m-d H:i:s');
217                $info = ' ('._T('couteau:url_verrouillee').')';
218                while ($t = sql_fetch($s)) $res .= ($res?'<br />':'').'&bull;&nbsp;<html>'.$t['url'].($t['date']>$now?$info:'')."</html>\n";
219                if(!find_in_path($f = $type."."._EXTENSION_SQUELETTES))
220                        $lien_public .= '{{[!]}} {'._T('info_erreur_squelette2',array('fichier'=>$f))."}\n\n";
221        // SPIP 1.92
222        } else {
223                // impossible de calculer l'url publique d'ici.
224                $table = $type.($type=='syndic'?'':'s');
225                $r = spip_query("SELECT url_propre FROM spip_$table WHERE id_$type=$id");
226                if ($r && $r = spip_fetch_array($r) ) {
227                        if(!strlen($r=$r['url_propre'])) $r = couteauprive_T('variable_vide');
228                        $res .= "&bull;&nbsp;$r\n";
229                }
230                $lien_public = './?exec=action_rapide&arg=type_urls|URL_objet_191&format=iframe&type_objet='.$type.'&id_objet='.$id.'&script=foo';
231                $lien_public = '<iframe src="'.$lien_public.'" width="100%" style="border:none; height:4em;"></iframe>';
232        }
233
234        $format = in_array($type_urls, array('page', 'standard', 'html'))
235                ?_T('couteau:urls_propres_erreur')
236                :_T('couteau:urls_propres_objet');
237        $mem = $GLOBALS['class_spip_plus'];
238        $GLOBALS['class_spip_plus']=' class="spip"';
239        $res = propre(
240                _T('couteau:urls_propres_format', array(
241                        'format'=>$type_urls,
242                        'url'=>generer_url_ecrire('admin_couteau_suisse', 'cmd=descrip&outil=type_urls#cs_infos')
243                )). "\n\n"
244                . $format . "\n\n"
245                . '|{{'. _T('couteau:2pts', array(
246                        'objet'=>strtoupper(filtrer_entites(_T('couteau:objet_'.$type))).' '.$id
247                ))."}}|\n"
248                . "|$res|")
249                // bug SPIP ?
250                . propre($lien_public);
251        $GLOBALS['class_spip_plus'] = $mem;
252        return cs_cadre_depliable(_T('couteau:urls_propres_titre'), 'bp_urls_propres', $res);
253}
254
255function cs_div_configuration() {
256        include_spip('inc/autoriser');
257        if(!autoriser('configurer', 'cs')) return '';
258        $img = defined('_SPIP30000')?chemin_image('secteur-12.png'):_DIR_IMG_PACK.'secteur-12.gif';
259        return '<div style="float:right; top:4px; right:-4px; position:relative;" ><a title="'._T('couteau:configurer').'" href="'.generer_url_ecrire('admin_couteau_suisse','cmd=descrip&outil=boites_privees#cs_infos').'"><img alt="'._T('couteau:configurer').'" src="'.$img.'"/></a></div>';
260}
261
262function cs_cadre_depliable($titre, $id, $texte) {
263        // SPIP 1.92
264        if(!defined('_SPIP19300')) return debut_cadre_relief(cs_icone(24), true)
265                . cs_div_configuration()
266                . "<div class='verdana1' style='text-align: left;'>"
267                . block_parfois_visible($id, "<b>$titre</b>", $texte, 'text-align: center;')
268                . "</div>"
269                . fin_cadre_relief(true);
270        // SPIP >= 2.0
271        return cadre_depliable(cs_icone(24), cs_div_configuration()."<b>$titre</b>", false /*true = deplie*/, $texte, $id);
272}
273
274?>
Note: See TracBrowser for help on using the repository browser.