Subversion Repositories Applications.papyrus

Rev

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

Rev Author Line No. Line
217 jpm 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
// +------------------------------------------------------------------------------------------------------+
1933 aperonnet 24
// CVS : $Id: moteur_recherche.php,v 1.24 2008-10-21 15:24:50 aperonnet Exp $
217 jpm 25
/**
26
* Applette : moteur de recherche
27
*
2056 gduche 28
* G�n�re un formulaire contenant une zone de saisie permettant de taper un texte � rechercher sur l'ensemble
29
* des sites g�r�s par Papyrus.
30
* Utilisation des biblioth�ques inclue par Papyrus :
339 jpm 31
* - Papyrus pap_meta.fonct.php
32
* - PEAR NET_URL
217 jpm 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-2004
1933 aperonnet 41
*@version       $Revision: 1.24 $ $Date: 2008-10-21 15:24:50 $
217 jpm 42
// +------------------------------------------------------------------------------------------------------+
43
*/
44
 
45
// +------------------------------------------------------------------------------------------------------+
46
// |                                            ENTETE du PROGRAMME                                       |
47
// +------------------------------------------------------------------------------------------------------+
339 jpm 48
$GLOBALS['_GEN_commun']['info_applette_nom_fonction'] = 'afficherMoteurRecherche';
1145 jp_milcent 49
$GLOBALS['_GEN_commun']['info_applette_balise'] = 	'(?:<!-- '.$GLOBALS['_GEN_commun']['balise_prefixe'].'(MOTEUR_RECHERCHE) -->|'.
2097 drzraf 50
													'\{\{[[Mm]oteurRecherche'.
51
													'(?:\s*'.
52
														'(?:'.
53
															'(url="[^"]*")|'.
54
														')'.
55
													')+'.
56
													'\s*\}\})';
217 jpm 57
 
58
// --------------------------------------------------------------------------------------------------------
2056 gduche 59
//Utilisation de la biblioth�que Papyrus pap_meta.fonct.php inclue par Papyrus
60
//Utilisation de la biblioth�que PEAR NET_URL inclue par Papyrus
217 jpm 61
/** Inclusion du fichier de configuration de cette application.*/
62
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_configuration.inc.php';
846 jp_milcent 63
/** Inclusion du fichier de configuration des Spip.*/
64
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_config_spip.inc.php';
1897 alexandre_ 65
/** Inclusion du fichier de configuration de l appli projet.*/
66
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_config_projet.inc.php';
1933 aperonnet 67
/** Inclusion du fichier de configuration de l appli bazar.*/
68
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_config_bazar.inc.php';
217 jpm 69
 
1090 florian 70
// Inclusion des fichiers de traduction de l'appli ADME de Papyrus
339 jpm 71
if (file_exists(MORE_CHEMIN_LANGUE.'more_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) {
2056 gduche 72
    /** Inclusion du fichier de traduction suite � la transaction avec le navigateur.*/
339 jpm 73
    require_once MORE_CHEMIN_LANGUE.'more_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php';
217 jpm 74
} else {
2056 gduche 75
    /** Inclusion du fichier de traduction par d�faut.*/
217 jpm 76
    require_once MORE_CHEMIN_LANGUE.'more_langue_'.MORE_I18N_DEFAUT.'.inc.php';
77
}
78
 
79
// +------------------------------------------------------------------------------------------------------+
80
// |                                            CORPS du PROGRAMME                                        |
81
// +------------------------------------------------------------------------------------------------------+
82
 
2109 drzraf 83
if (isset($_POST['more_motif']) && !empty($_POST['more_motif'])) {
2056 gduche 84
    // Initialisation de variable ext�rieures
2109 drzraf 85
    $GLOBALS['_VEI_']['usurpation'] = MORE_LG_USURPATION.htmlentities(stripslashes($_POST['more_motif']), ENT_COMPAT|ENT_HTML401, 'ISO8859-15');
217 jpm 86
    $GLOBALS['_PAPYRUS_']['general']['application_chemin'] = null;
2056 gduche 87
    // Modification des meta de l'ent�te de la page
846 jp_milcent 88
    GEN_modifierMetaHttpEquiv('Content-Type', 'text/html; charset=ISO-8859-15');
217 jpm 89
    GEN_modifierMetaHttpEquiv('Content-style-type', 'text/css');
90
    GEN_modifierMetaHttpEquiv('Content-script-type', 'text/javascript');
339 jpm 91
    GEN_modifierMetaHttpEquiv('Content-language', $GLOBALS['_GEN_commun']['i18n']);
217 jpm 92
 
93
    GEN_modifierMetaName('revisit-after', '15 days');
94
    GEN_modifierMetaName('robots', 'index,follow');
95
    GEN_modifierMetaName('author', 'Tela Botanica');
2056 gduche 96
    GEN_modifierMetaName('keywords', 'Recherche, r�sultat.');
97
    GEN_modifierMetaName('description', 'Page de r�sultats du moteur de recherche de Papyrus.');
217 jpm 98
 
99
    GEN_viderMeta('dc');
100
}
101
 
102
// +------------------------------------------------------------------------------------------------------+
103
// |                                           LISTE de FONCTIONS                                         |
104
// +------------------------------------------------------------------------------------------------------+
105
 
850 florian 106
/** Fonction afficherMoteurRecherche() - Fournit un formulaire de recherche.
217 jpm 107
*
2056 gduche 108
* Renvoie un formulaire permettant de rechercher une chaine de caract�res dans les sites
109
* g�r�s par Papyrus.
217 jpm 110
* Necessite l'utilisation de Pear Net_URL par le programme appelant cette fonction.
111
*
2056 gduche 112
* @param  array  tableau d'�ventuel arguments pr�sent dans la balise transmis � la fonction.
217 jpm 113
* @param  array  tableau global de Papyrus.
114
* @return string  formulaire XHTML de recherche.
115
*/
116
function afficherMoteurRecherche($tab_applette_arguments, $_GEN_commun)
117
{
2097 drzraf 118
	//+----------------------------------------------------------------------------------------------------------------+
119
	// Gestion des arguments
120
	$balise = $tab_applette_arguments[0];
121
    $tab_arguments = $tab_applette_arguments;
122
	unset($tab_arguments[0]);
123
    foreach($tab_arguments as $argument) {
2109 drzraf 124
    	if (!empty($argument)) {
2097 drzraf 125
	    	$tab_parametres = explode('=', $argument, 2);
126
	    	$options[$tab_parametres[0]] = trim($tab_parametres[1], '"');
127
    	}
128
    }
2109 drzraf 129
 
2097 drzraf 130
	// --------------------------------------------------------------------------------------------------------
217 jpm 131
    // Initialisation de variable de configuration.
2056 gduche 132
    $liste_type_site = '102, 103';// Les id des types des sites pouvant appara�tre dans le s�lecteur
133
    $objet_pear_db =& $_GEN_commun['pear_db'];//objet Pear cr�� par DB contenant la connexion � la base de donn�es.
134
    $GLOBALS['_MOTEUR_RECHERCHE_']['bd']['papyrus'] =& $_GEN_commun['pear_db'];// Connexion � la BD de Papyrus
1051 jp_milcent 135
    $GLOBALS['_MOTEUR_RECHERCHE_']['variables'] = array();
339 jpm 136
    $code_site = $_GEN_commun['url_site'];// identifiant du site courant.
217 jpm 137
    $url = $_GEN_commun['url'];
138
    $url_id_type_site = GEN_URL_ID_TYPE_SITE;
2056 gduche 139
    $indent_origine = 12;// Indentation de d�part en nombre d'espace
217 jpm 140
    $indent_pas     = 4;// Pas d'indentation en nombre d'espace
141
    $retour = '';
142
    $retour_resultats = '';
143
 
144
    // --------------------------------------------------------------------------------------------------------
2056 gduche 145
    // Lancement de la recherche si n�cessaire
1051 jp_milcent 146
    $aso_squelette = array('formulaire' => MORE_FORM_SQUELETTE);
217 jpm 147
    $_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif'] = '';
2097 drzraf 148
 
149
    //Greg : gestion d'une url personnalisée passée en paramètres url=""
150
    if (!isset($options['url']))	{
151
    	$GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['form_url'] = $url->getUrl();
152
    } else {
153
    	$GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['form_url'] = $options['url'];
154
    }
155
 
1051 jp_milcent 156
	$GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['form_tab'] = MORE_FORM_MOTIF_TAB;
1456 jp_milcent 157
	$GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['more_motif_base'] = MORE_LG_FORM_MOTIF_VALUE;
2109 drzraf 158
    if (!isset($_POST['more_motif']) || empty($_POST['more_motif'])) {
1051 jp_milcent 159
        $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['more_motif'] = MORE_LG_FORM_MOTIF_VALUE;
217 jpm 160
    } else {
2056 gduche 161
        // Ajout du squelette de r�sultat
1051 jp_milcent 162
        $aso_squelette['resultat'] = MORE_RESULTAT_SQUELETTE;
163
		// Titre de la page
2109 drzraf 164
		$GLOBALS['_PAPYRUS_']['rendu']['TITRE_PAGE'] = MORE_LG_TITRE.htmlentities(stripslashes($_POST['more_motif']), ENT_COMPAT|ENT_HTML401, 'ISO8859-15');
1183 jp_milcent 165
		$_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif'] = $_POST['more_motif'];
2109 drzraf 166
		$GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['more_motif'] =  htmlentities(stripslashes($_POST['more_motif']), ENT_COMPAT|ENT_HTML401, 'ISO8859-15');
1183 jp_milcent 167
 
217 jpm 168
        /** Inclusion de la classe Recherche.*/
169
        require_once MORE_CHEMIN_BIBLIO.'more_recherche.class.php';
846 jp_milcent 170
        /** Inclusion de la classe Recherche_Papyrus_Menu.*/
217 jpm 171
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_papyrus_menu.class.php';
846 jp_milcent 172
        /** Inclusion de la classe Recherche_Spip_Article.*/
173
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_spip_article.class.php';
1897 alexandre_ 174
        /** Inclusion de la classe Recherche_Projet.*/
175
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_projet.class.php';
1933 aperonnet 176
        /** inclusion de la classe Recheche Bazar. */
177
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_bazar.class.php';
1678 jp_milcent 178
        $moteur = new More_Recherche($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
2056 gduche 179
 
180
    	$recherche_papyrus_menu = new More_Recherche_Papyrus_Menu($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
181
		$moteur->ajouterRecherche($recherche_papyrus_menu);
182
 
183
        if (!empty($GLOBALS['_MOTEUR_RECHERCHE_']['spip']))	{
184
        	$recherche_spip_article = new More_Recherche_Spip_Article($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
185
        	$moteur->ajouterRecherche($recherche_spip_article);
186
        }
187
 
188
        if (!empty($GLOBALS['_MOTEUR_RECHERCHE_']['bazar'][0]))	{
189
        	$recherche_bazar = new More_Recherche_Bazar($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
190
        	$moteur->ajouterRecherche($recherche_bazar);
191
        }
192
 
2109 drzraf 193
        if (!empty($GLOBALS['_MOTEUR_RECHERCHE_']['projet']['url']))	{
2056 gduche 194
        	$recherche_projet = new More_Recherche_Projet($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
195
        	$moteur->ajouterRecherche($recherche_projet);
196
        }
2109 drzraf 197
 
198
		$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'] = $moteur->rechercherMotif();
199
 
1051 jp_milcent 200
        //$GLOBALS['_DEBOGAGE_'] = '<pre>'.print_r($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'], true).'</pre>';
201
        $nbre_pages = count($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats']);
1052 jp_milcent 202
		$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['nbre_pages'] = $nbre_pages;
1051 jp_milcent 203
		$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['vide'] = MORE_LG_RESULTAT_VIDE;
846 jp_milcent 204
        if ($nbre_pages <= 1) {
1051 jp_milcent 205
        	$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['titre'] = sprintf(MORE_LG_RESULTAT_TITRE, $nbre_pages);
846 jp_milcent 206
        } else {
1051 jp_milcent 207
        	$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['titre'] = sprintf(MORE_LG_RESULTAT_TITRE_PLURIEL, $nbre_pages);
846 jp_milcent 208
        }
2109 drzraf 209
 
1051 jp_milcent 210
		foreach ($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'] as $cle => $val) {
211
			if (empty($val['url'])) {
212
                unset($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]);
213
			} else {
214
				$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]['score'] = trim($val['score']);
215
				$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]['date_creation'] = trim($val['date_creation']);
216
				$GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]['description'] = trim($val['description']);
217
			}
218
		}
219
	}
220
 
2056 gduche 221
	// G�n�ration du contenu � partir des squelettes
1051 jp_milcent 222
	foreach ($aso_squelette as $squelette => $fichier) {
2056 gduche 223
		// Extrait les variables et les ajoutes � l'espace de noms local
1051 jp_milcent 224
		extract($GLOBALS['_MOTEUR_RECHERCHE_'][$squelette]);
2056 gduche 225
		// D�marre le buffer
1051 jp_milcent 226
		ob_start();
227
		// Inclusion du fichier
228
		include(MORE_CHEMIN_SQUELETTE.$fichier);
2056 gduche 229
		// R�cup�rer le  contenu du buffer
1051 jp_milcent 230
		$retour = ob_get_contents();
2056 gduche 231
		// Arr�te et d�truit le buffer
1051 jp_milcent 232
		ob_end_clean();
233
		// Retourne le contenu
234
		switch ($squelette) {
235
			case 'resultat' :
2056 gduche 236
				// L'applette fournie un r�sultat qui �crase le contenu de la page courrante
1051 jp_milcent 237
				$GLOBALS['_PAPYRUS_']['rendu']['CONTENU_NAVIGATION'] = '';
238
				$GLOBALS['_PAPYRUS_']['rendu']['CONTENU_TETE'] = '';
239
				$GLOBALS['_PAPYRUS_']['rendu']['CONTENU_CORPS'] = $retour;
240
				$GLOBALS['_PAPYRUS_']['rendu']['CONTENU_PIED'] = '';
241
				$GLOBALS['_GEN_commun']['info_menu'] = '';
242
				break;
243
			case 'formulaire' :
2056 gduche 244
				// L'applette est appel�e par d�faut
1051 jp_milcent 245
				$retour_formulaire = $retour;
246
				break;
247
			default:
248
				$e = "Squellette <$squelette> pour le moteur de recherche inconnu!";
249
				trigger_error($e, E_USER_WARNING);
250
		}
251
	}
252
	return $retour_formulaire;
217 jpm 253
}
254
 
255
// +------------------------------------------------------------------------------------------------------+
256
// |                                            PIED du PROGRAMME                                         |
257
// +------------------------------------------------------------------------------------------------------+
258
 
259
 
260
/* +--Fin du code ----------------------------------------------------------------------------------------+
261
*
262
* $Log: not supported by cvs2svn $
1933 aperonnet 263
* Revision 1.23  2008-08-26 15:31:16  alexandre_tb
264
* ajout du moteur de recherche dans l'appli projet
265
*
1897 alexandre_ 266
* Revision 1.22  2007-11-30 14:02:48  alexandre_tb
267
* Fusion avec la livraison
268
*
1736 alexandre_ 269
* Revision 1.21  2007-10-29 18:29:30  jp_milcent
2056 gduche 270
* Ajout d'un pr�fixe devant les classes de l'applette pour �viter les conflits avec d'autres classes provenant des applis clientes.
1736 alexandre_ 271
*
1678 jp_milcent 272
* Revision 1.20  2007-06-15 12:27:39  jp_milcent
2056 gduche 273
* Ajout de fonctionnalit�s Javascript au moteur de recherche.
1678 jp_milcent 274
*
1456 jp_milcent 275
* Revision 1.19  2007-01-02 18:49:22  jp_milcent
2056 gduche 276
* Am�lioration de la gestion du motif.
277
* Ajout de la gestion des expressions compl�te via l'utilisation de guillemets.
1456 jp_milcent 278
*
1183 jp_milcent 279
* Revision 1.18  2006/12/12 13:53:54  jp_milcent
280
* Mise en place du nouveau format des balises d'applette.
281
*
1145 jp_milcent 282
* Revision 1.17  2006/12/01 16:33:40  florian
2056 gduche 283
* Am�lioration de la gestion des applettes et compatibilit� avec le nouveau mode de gestion de l'inclusion des applettes.
1145 jp_milcent 284
*
1090 florian 285
* Revision 1.16  2006/11/20 09:36:59  jp_milcent
2056 gduche 286
* Correction bogue z�ro r�sultat et ajout d'url simple pour indiquer la page de l'article.
1090 florian 287
*
1052 jp_milcent 288
* Revision 1.15  2006/11/14 16:10:13  jp_milcent
2056 gduche 289
* Extraction du XHTML et utilisation de squelettes � la place.
290
* Possibilit� de configurer le squlette voulu via le fichier de conf.
1052 jp_milcent 291
*
1051 jp_milcent 292
* Revision 1.14  2006/10/10 13:28:14  jp_milcent
293
* Suppression d'une variable et utilisation de la constante PAP_URL
294
*
1027 jp_milcent 295
* Revision 1.13  2006/10/10 12:02:30  jp_milcent
2056 gduche 296
* Suppression d'une biblioth�que Pear qu'il est inutile d'inclure.
1027 jp_milcent 297
* Ajout du chemin vers la bibliotheque Pear de Papyrus.
298
*
1025 jp_milcent 299
* Revision 1.12  2006/06/16 09:45:10  jp_milcent
2056 gduche 300
* Correction bogue li� � la suppression de l'objet info_menu.
1025 jp_milcent 301
*
862 jp_milcent 302
* Revision 1.11  2006/05/23 13:39:13  florian
303
* corection bug notice de jean pascal ;-)
304
*
850 florian 305
* Revision 1.10  2006/05/19 10:04:55  jp_milcent
306
* Ajout d'un moteur de recherche analysant les articles des sites sous Spip.
307
*
846 jp_milcent 308
* Revision 1.9  2006/04/28 12:41:49  florian
309
* corrections erreurs chemin
310
*
832 florian 311
* Revision 1.8  2006/03/02 10:49:49  ddelon
312
* Fusion branche multilinguisme dans branche principale
313
*
754 ddelon 314
* Revision 1.7.2.2  2005/12/27 15:56:00  ddelon
315
* Fusion Head vers multilinguisme (wikini double clic)
316
*
317
* Revision 1.7.2.1  2005/12/20 14:40:25  ddelon
318
* Fusion Head vers Livraison
319
*
320
* Revision 1.7  2005/09/27 09:07:32  ddelon
321
* size applette et squelettes
322
*
467 ddelon 323
* Revision 1.6  2005/05/25 13:49:22  jpm
324
* Corection erreur pour la recherche dans le contenu.
325
*
373 jpm 326
* Revision 1.5  2005/05/19 12:46:12  jpm
327
* Correction bogue accesskey.
2056 gduche 328
* Ajout d'un id � la liste.
373 jpm 329
* Arrondissement des score.
330
*
368 jpm 331
* Revision 1.4  2005/04/14 17:39:34  jpm
2056 gduche 332
* Am�lioration du moteur de rechercher :
368 jpm 333
*  - pourcentage
334
*  - ajout d'info
335
*
339 jpm 336
* Revision 1.3  2005/02/22 19:27:21  jpm
337
* Changement de nom de variables.
2056 gduche 338
* Suppression de l'attribut nam de la balise form via une m�thode de HTML_Common.
339 jpm 339
*
272 jpm 340
* Revision 1.2  2005/02/22 17:44:03  jpm
2056 gduche 341
* Suppression de r�f�rence posant probl�me.
272 jpm 342
*
268 jpm 343
* Revision 1.1  2004/12/07 10:24:01  jpm
2056 gduche 344
* Moteur de recherche version de d�part.
217 jpm 345
*
268 jpm 346
*
217 jpm 347
* +-- Fin du code ----------------------------------------------------------------------------------------+
348
*/
349
?>