Subversion Repositories Applications.papyrus

Rev

Rev 846 | Rev 1034 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
846 jp_milcent 1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This file is part of Papyrus.                                                                        |
9
// |                                                                                                      |
10
// | Foobar is free software; you can redistribute it and/or modify                                       |
11
// | it under the terms of the GNU General Public License as published by                                 |
12
// | the Free Software Foundation; either version 2 of the License, or                                    |
13
// | (at your option) any later version.                                                                  |
14
// |                                                                                                      |
15
// | Foobar is distributed in the hope that it will be useful,                                            |
16
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
17
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                        |
18
// | GNU General Public License for more details.                                                         |
19
// |                                                                                                      |
20
// | You should have received a copy of the GNU General Public License                                    |
21
// | along with Foobar; if not, write to the Free Software                                                |
22
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
23
// +------------------------------------------------------------------------------------------------------+
24
// CVS : $Id$
25
/**
26
* Classe permettant d'effectuer des recherches sur les informations des articles de Spip.
27
*
28
* Permet de rechercher et classer les articles en fonction d'une chaine.
29
* Utilisation des bibliothèques inclue par Papyrus :
30
* - Papyrus pap_meta.fonct.php
31
* - Papyrus pap_menu.fonct.php
32
* - Papyrus pap_url.class.php
33
*
34
*@package Applette
35
*@subpackage Moteur_Recherche
36
//Auteur original :
37
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
38
//Autres auteurs :
39
*@author        aucun
40
*@copyright     Tela-Botanica 2000-2006
41
*@version       $Revision$ $Date$
42
// +------------------------------------------------------------------------------------------------------+
43
*/
44
 
45
// +------------------------------------------------------------------------------------------------------+
46
// |                                            ENTETE du PROGRAMME                                       |
47
// +------------------------------------------------------------------------------------------------------+
48
///** Inclusion du fichier contenant les fonctions de manipulations des menus de Papyrus.*/
49
//require_once GEN_CHEMIN_BIBLIO.'pap_menu.fonct.php';
50
 
51
// +------------------------------------------------------------------------------------------------------+
52
// |                                            CORPS du PROGRAMME                                        |
53
// +------------------------------------------------------------------------------------------------------+
54
 
55
class Recherche_Spip_Article extends Recherche {
56
 
57
    // Constructeur
58
    function Recherche_Menu_Meta($motif) {
59
        $this->setMotif($motif);
60
    }
61
 
62
    // Accesseurs
63
    function getMotif() {
64
        return $this->motif;
65
    }
66
    function setMotif($motif) {
67
        $this->motif = $motif;
68
    }
69
 
70
    // Méthodes
71
    function rechercherMotif($motif) {
72
    	for ($i = 0; $i < count($GLOBALS['_MOTEUR_RECHERCHE_']['spip']); $i++ ) {
73
	        $db = DB::connect($GLOBALS['_MOTEUR_RECHERCHE_']['spip'][$i]['bdd_dsn']);
74
	        if (DB::isError($db)) {
75
	    		$msg_erreur_connection = 'Impossible de se connecter à la base de données Spip.';
76
	    		die(BOG_afficherErreurSql(__FILE__, __LINE__, $db->getMessage(), 'connexion à la base de données',$msg_erreur_connection));
77
			}
78
	        $prefixe = $GLOBALS['_MOTEUR_RECHERCHE_']['spip'][$i]['table_prefixe'];
79
	        $url_base = $GLOBALS['_MOTEUR_RECHERCHE_']['spip'][$i]['url'];
80
	        $tab_articles = $this->retournerArticles($db, $prefixe);
81
	        foreach ($tab_articles as $article_id => $Article) {
82
	            // Initialisation du tableau de résultat vide
83
	            $aso_resultat = array(  'poids' => 0, 'url' => '', 'titre' => '',
84
	                                    'hreflang' => '', 'accesskey' => '', 'title' => '',
85
	                                    'date_creation' => '', 'description' => '');
86
 
87
	            // Analyse du poids de cette page vis à vis des données
88
	            $tab_champs_a_visiter = array(  'surtitre', 'titre', 'soustitre', 'descriptif', 'chapo', 'texte', 'ps');
1032 jp_milcent 89
	            $tab_motif = explode(' ', $motif);
90
	            $bool_operateur_et = false;
846 jp_milcent 91
	            foreach ($tab_champs_a_visiter as $val) {
1032 jp_milcent 92
	                $compteur_mot = 0;
93
	                foreach ($tab_motif as $mot_motif) {
94
	                	$nbre_mot = $this->retournerOccurenceMotif($mot_motif, $Article->$val);
95
	                	if ($nbre_mot > 0) {
96
	                		$compteur_mot++;
97
	                	}
98
	                	$aso_resultat['poids'] += $nbre_mot;
99
	                }
100
	                if ($compteur_mot == count($tab_motif)) {
101
	                	$bool_operateur_et = true;
102
	                }
846 jp_milcent 103
	            }
104
 
1032 jp_milcent 105
	            if ($aso_resultat['poids'] > 0 && $bool_operateur_et == true) {
106
	                // Création de l'url
107
		            $var_recherche = str_replace(' ', '+', trim($motif));
108
		            $aso_resultat['url'] = $url_base.'article'.$article_id.'.html?var_recherche='.$var_recherche;
109
 
110
		            // Récupération du titre de la page
111
		            if (trim($Article->titre) != '') {
112
		                $aso_resultat['titre'] = htmlentities($Article->titre);
113
		            } else if (trim($Article->surtitre) != '') {
114
		                $aso_resultat['titre'] = htmlentities($Article->surtitre);
115
		            } else if (trim($Article->soustitre) != '') {
116
		                $aso_resultat['titre'] = htmlentities($Article->soustitre);
117
		            }
118
		            $aso_resultat['hreflang'] = htmlentities($Article->lang);
119
 
120
		            $aso_resultat['description'] = $this->couper($Article->texte, 450);
121
 
122
		            if (($jour = date('d', strtotime($Article->date)) ) != 0 ) {
123
		                $aso_resultat['date_creation'] .= '<span class="page_modification_jour"> '.$jour.'</span>'."\n";
124
		            }
125
		            if (($mois = $this->traduireMois(date('m', strtotime($Article->date))) ) != '' ) {
126
		                $aso_resultat['date_creation'] .= '<span class="page_modification_mois"> '.$mois.'</span>'."\n";
127
		            }
128
		            if (($annee = date('Y', strtotime($Article->date)) ) != 0 ) {
129
		                $aso_resultat['date_creation'] .= '<span class="page_modification_annee"> '.$annee.'</span>'."\n";
130
		            }
846 jp_milcent 131
	                $this->setResultat($aso_resultat);
132
	            }
133
	        }
134
    	}
135
        return $this->getResultats();
136
    }
137
 
138
    /** Renvoie un tableau contenant les infos sur les articles
139
	*
140
	* @param  mixed		une instance de la classse Pear DB.
141
	* @param  string	le préfixe pour les tables spip.
142
	* @return array		tableau contenant les articles.
143
	*/
144
	function retournerArticles(&$db, $prefixe = '')
145
	{
146
	    //----------------------------------------------------------------------------
147
	    // Recherche des informations sur le menu
148
	    $requete =  'SELECT * '.
149
	                'FROM '.$prefixe.'spip_articles '.
150
	                'WHERE statut = "publie"';
151
 
152
	    $resultat = $db->query($requete);
153
	    (DB::isError($resultat)) ? die(BOG_afficherErreurSql(__FILE__, __LINE__, $resultat->getMessage(), $requete)) : '';
154
 
155
	    //----------------------------------------------------------------------------
156
	    // Récupération des infos
157
	    $tab_retour = array();
158
	    while ($info_article = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
159
	        $tab_retour[$info_article->id_article] = $info_article;
160
	    }
161
	    $resultat->free();
162
 
163
	    return $tab_retour;
164
	}
165
 
166
	// Fichier : inc_texte.php3
167
	function couper($texte, $taille = 50)
168
	{
169
		$texte = substr($texte, 0, 400 + 2*$taille); /* eviter de travailler sur 10ko pour extraire 150 caracteres */
170
 
171
		// on utilise les \r pour passer entre les gouttes
172
		$texte = str_replace("\r\n", "\n", $texte);
173
		$texte = str_replace("\r", "\n", $texte);
174
 
175
		// sauts de ligne et paragraphes
176
		$texte = ereg_replace("\n\n+", "\r", $texte);
177
		$texte = ereg_replace("<(p|br)( [^>]*)?".">", "\r", $texte);
178
 
179
		// supprimer les traits, lignes etc
180
		$texte = ereg_replace("(^|\r|\n)(-[-#\*]*|_ )", "\r", $texte);
181
 
182
		// supprimer les tags
183
		$texte = $this->supprimer_tags($texte);
184
		$texte = trim(str_replace("\n"," ", $texte));
185
		$texte .= "\n";	// marquer la fin
186
 
187
		// travailler en accents charset
188
		// On supprime dans Papyrus car cela tire trop de fonctions...
189
		//$texte = $this->filtrer_entites($texte);
190
 
191
		// supprimer les liens
192
		$texte = ereg_replace("\[->([^]]*)\]","\\1", $texte); // liens sans texte
193
		$texte = ereg_replace("\[([^\[]*)->([^]]*)\]","\\1", $texte);
194
 
195
		// supprimer les notes
196
		$texte = ereg_replace("\[\[([^]]|\][^]])*\]\]", "", $texte);
197
 
198
		// supprimer les codes typos
199
		$texte = ereg_replace("[}{]", "", $texte);
200
 
201
		// supprimer les tableaux
202
		$texte = ereg_replace("(^|\r)\|.*\|\r", "\r", $texte);
203
 
204
		// couper au mot precedent
205
		$long = $this->spip_substr($texte, 0, max($taille-4,1));
206
		$court = ereg_replace("([^[:space:]][[:space:]]+)[^[:space:]]*\n?$", "\\1", $long);
207
		$points = '&nbsp;(...)';
208
 
209
		// trop court ? ne pas faire de (...)
210
		if (strlen($court) < max(0.75 * $taille,2)) {
211
			$points = '';
212
			$long = $this->spip_substr($texte, 0, $taille);
213
			$texte = ereg_replace("([^[:space:]][[:space:]]+)[^[:space:]]*$", "\\1", $long);
214
			// encore trop court ? couper au caractere
215
			if (strlen($texte) < 0.75 * $taille)
216
				$texte = $long;
217
		} else
218
			$texte = $court;
219
 
220
		if (strpos($texte, "\n"))	// la fin est encore la : c'est qu'on n'a pas de texte de suite
221
			$points = '';
222
 
223
		// remettre les paragraphes
224
		$texte = ereg_replace("\r+", "\n\n", $texte);
225
 
226
		// supprimer l'eventuelle entite finale mal coupee
227
		$texte = preg_replace('/&#?[a-z0-9]*$/', '', $texte);
228
 
229
		return trim($texte).$points;
230
	}
231
 
232
	// Gerer les outils mb_string
233
	// Fichier : inc_texte.php3
234
	function spip_substr($c, $start=0, $end='')
235
	{
236
		// methode substr normale
237
		if ($end) {
238
			return substr($c, $start, $end);
239
		} else {
240
			return substr($c, $start);
241
		}
242
	}
243
 
244
	// Suppression basique et brutale de tous les <...>
245
	// Fichier : inc_filtres.php3
246
	function supprimer_tags($texte, $rempl = "")
247
	{
248
		$texte = preg_replace(",<[^>]*>,U", $rempl, $texte);
249
		// ne pas oublier un < final non ferme
250
		$texte = str_replace('<', ' ', $texte);
251
		return $texte;
252
	}
253
 
254
}
255
 
256
/* +--Fin du code ----------------------------------------------------------------------------------------+
257
*
258
* $Log$
1032 jp_milcent 259
* Revision 1.1  2006/05/19 10:04:55  jp_milcent
260
* Ajout d'un moteur de recherche analysant les articles des sites sous Spip.
261
*
846 jp_milcent 262
*
263
* +-- Fin du code ----------------------------------------------------------------------------------------+
264
*/
265
?>