Subversion Repositories Applications.papyrus

Rev

Rev 2121 | Rev 2142 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
// +------------------------------------------------------------------------------------------------------+
// | PHP version 4.1                                                                                      |
// +------------------------------------------------------------------------------------------------------+
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
// +------------------------------------------------------------------------------------------------------+
// | This file is part of Papyrus.                                                                        |
// |                                                                                                      |
// | Foobar is free software; you can redistribute it and/or modify                                       |
// | it under the terms of the GNU General Public License as published by                                 |
// | the Free Software Foundation; either version 2 of the License, or                                    |
// | (at your option) any later version.                                                                  |
// |                                                                                                      |
// | Foobar is distributed in the hope that it will be useful,                                            |
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                        |
// | GNU General Public License for more details.                                                         |
// |                                                                                                      |
// | You should have received a copy of the GNU General Public License                                    |
// | along with Foobar; if not, write to the Free Software                                                |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
// +------------------------------------------------------------------------------------------------------+
// CVS : $Id: moteur_recherche.php,v 1.24 2008-10-21 15:24:50 aperonnet Exp $
/**
* Applette : moteur de recherche
*
* G�n�re un formulaire contenant une zone de saisie permettant de taper un texte � rechercher sur l'ensemble
* des sites g�r�s par Papyrus.
* Utilisation des biblioth�ques inclue par Papyrus :
* - Papyrus pap_meta.fonct.php
* - PEAR NET_URL
*
*@package Applette
*@subpackage Moteur_recherche
//Auteur original :
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
//Autres auteurs :
*@author        Aucun
*@copyright     Tela-Botanica 2000-2004
*@version       $Revision: 1.24 $ $Date: 2008-10-21 15:24:50 $
// +------------------------------------------------------------------------------------------------------+
*/


// pour utiliser Sphinx, cela désactive alors l'appel à $moteur->rechercherMotif()
// et utilise sphinx_search() (moteur_recherche_sphinx.php)
// TODO: un test avec mysql_connect() sur le SPHINX_DSN tel que défini dans moteur_recherche_sphinx.php
// pourrait être un plus.
define('USE_SPHINX', TRUE);
// XXX: PHP-5.4
if(!defined('ENT_HTML401')) {
        define('ENT_HTML401', ENT_COMPAT);
}

// +------------------------------------------------------------------------------------------------------+
// |                                            ENTETE du PROGRAMME                                       |
// +------------------------------------------------------------------------------------------------------+
$GLOBALS['_GEN_commun']['info_applette_nom_fonction'] = 'afficherMoteurRecherche';
$GLOBALS['_GEN_commun']['info_applette_balise'] =       '(?:<!-- '.$GLOBALS['_GEN_commun']['balise_prefixe'].'(MOTEUR_RECHERCHE) -->|'.
                                                                                                        '\{\{[[Mm]oteurRecherche'.
                                                                                                        '(?:\s*'.
                                                                                                                '(?:'.
                                                                                                                        '(url="[^"]*")|(sphinx="(?:0|1)")'.
                                                                                                                ')'.
                                                                                                        ')+'.
                                                                                                        '\s*\}\})';

// --------------------------------------------------------------------------------------------------------
//Utilisation de la biblioth�que Papyrus pap_meta.fonct.php inclue par Papyrus
//Utilisation de la biblioth�que PEAR NET_URL inclue par Papyrus
/** Inclusion du fichier de configuration de cette application.*/
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_configuration.inc.php';
/** Inclusion du fichier de configuration des Spip.*/
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_config_spip.inc.php';
/** Inclusion du fichier de configuration de l appli projet.*/
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_config_projet.inc.php';
/** Inclusion du fichier de configuration de l appli bazar.*/
require_once GEN_CHEMIN_APPLETTE.'moteur_recherche/configuration/more_config_bazar.inc.php';

// Inclusion des fichiers de traduction de l'appli ADME de Papyrus
if (file_exists(MORE_CHEMIN_LANGUE.'more_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) {
    /** Inclusion du fichier de traduction suite � la transaction avec le navigateur.*/
    require_once MORE_CHEMIN_LANGUE.'more_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php';
} else {
    /** Inclusion du fichier de traduction par d�faut.*/
    require_once MORE_CHEMIN_LANGUE.'more_langue_'.MORE_I18N_DEFAUT.'.inc.php';
}

// +------------------------------------------------------------------------------------------------------+
// |                                            CORPS du PROGRAMME                                        |
// +------------------------------------------------------------------------------------------------------+

if (isset($_POST['more_motif']) && !empty($_POST['more_motif'])) {
    // Initialisation de variable ext�rieures
    $GLOBALS['_VEI_']['usurpation'] = MORE_LG_USURPATION.htmlentities(stripslashes($_POST['more_motif']), ENT_COMPAT|ENT_HTML401, 'ISO8859-15');
    $GLOBALS['_PAPYRUS_']['general']['application_chemin'] = null;
    // Modification des meta de l'ent�te de la page
    GEN_modifierMetaHttpEquiv('Content-Type', 'text/html; charset=ISO-8859-15');
    GEN_modifierMetaHttpEquiv('Content-style-type', 'text/css');
    GEN_modifierMetaHttpEquiv('Content-script-type', 'text/javascript');
    GEN_modifierMetaHttpEquiv('Content-language', $GLOBALS['_GEN_commun']['i18n']);
    
    GEN_modifierMetaName('revisit-after', '15 days');
    GEN_modifierMetaName('robots', 'index,follow');
    GEN_modifierMetaName('author', 'Tela Botanica');
    GEN_modifierMetaName('keywords', 'Recherche, r�sultat.');
    GEN_modifierMetaName('description', 'Page de r�sultats du moteur de recherche de Papyrus.');
    
    GEN_viderMeta('dc');
}

// +------------------------------------------------------------------------------------------------------+
// |                                           LISTE de FONCTIONS                                         |
// +------------------------------------------------------------------------------------------------------+

/** Fonction afficherMoteurRecherche() - Fournit un formulaire de recherche.
*
* Renvoie un formulaire permettant de rechercher une chaine de caract�res dans les sites
* g�r�s par Papyrus.
* Necessite l'utilisation de Pear Net_URL par le programme appelant cette fonction.
*
* @param  array  tableau d'�ventuel arguments pr�sent dans la balise transmis � la fonction. 
* @param  array  tableau global de Papyrus.
* @return string  formulaire XHTML de recherche.
*/
function afficherMoteurRecherche($tab_applette_arguments, $_GEN_commun)
{
        //+----------------------------------------------------------------------------------------------------------------+
        // Gestion des arguments
        $options = array();
        $balise = $tab_applette_arguments[0];
    $tab_arguments = $tab_applette_arguments;
        unset($tab_arguments[0]);
    foreach($tab_arguments as $argument) {
        if (!empty($argument)) {
                $tab_parametres = explode('=', $argument, 2);
                $options[$tab_parametres[0]] = trim($tab_parametres[1], '"');
        }
    }

        // --------------------------------------------------------------------------------------------------------
    // Initialisation de variable de configuration.
    $liste_type_site = '102, 103';// Les id des types des sites pouvant appara�tre dans le s�lecteur
    $objet_pear_db =& $_GEN_commun['pear_db'];//objet Pear cr�� par DB contenant la connexion � la base de donn�es.
    $GLOBALS['_MOTEUR_RECHERCHE_']['bd']['papyrus'] =& $_GEN_commun['pear_db'];// Connexion � la BD de Papyrus
    $GLOBALS['_MOTEUR_RECHERCHE_']['variables'] = array();
    $code_site = $_GEN_commun['url_site'];// identifiant du site courant.
    $url = $_GEN_commun['url'];
    $sphinx = array_key_exists('sphinx', $options) && $options['sphinx'] ? true : false;
    $url_id_type_site = GEN_URL_ID_TYPE_SITE;
    $indent_origine = 12;// Indentation de d�part en nombre d'espace
    $indent_pas     = 4;// Pas d'indentation en nombre d'espace
    $retour = '';
    $retour_resultats = '';
    
    // --------------------------------------------------------------------------------------------------------
    // Lancement de la recherche si n�cessaire
    $aso_squelette = array('formulaire' => MORE_FORM_SQUELETTE);
    $_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif'] = '';
        
    //Greg : gestion d'une url personnalisée passée en paramètres url=""
    if (!isset($options['url']))        {
        $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['form_url'] = $url->getUrl();
    } else {
        $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['form_url'] = $options['url'];
    }
    
        $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['form_tab'] = MORE_FORM_MOTIF_TAB;
        $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['more_motif_base'] = MORE_LG_FORM_MOTIF_VALUE;
    if (!isset($_POST['more_motif']) || empty($_POST['more_motif'])) {
        $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['more_motif'] = MORE_LG_FORM_MOTIF_VALUE;
    } else {
        // Ajout du squelette de r�sultat
        $aso_squelette['resultat'] = MORE_RESULTAT_SQUELETTE;
                // Titre de la page
                $GLOBALS['_PAPYRUS_']['rendu']['TITRE_PAGE'] = MORE_LG_TITRE.htmlentities(stripslashes($_POST['more_motif']), ENT_COMPAT|ENT_HTML401, 'ISO8859-15');
                $_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif'] = $_POST['more_motif'];
                $GLOBALS['_MOTEUR_RECHERCHE_']['formulaire']['more_motif'] =  htmlentities(stripslashes($_POST['more_motif']), ENT_COMPAT|ENT_HTML401, 'ISO8859-15');
                
        /** Inclusion de la classe Recherche.*/
        require_once MORE_CHEMIN_BIBLIO.'more_recherche.class.php';
        /** Inclusion de la classe Recherche_Papyrus_Menu.*/
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_papyrus_menu.class.php';
        /** Inclusion de la classe Recherche_Spip_Article.*/
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_spip_article.class.php';
        /** Inclusion de la classe Recherche_Projet.*/
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_projet.class.php';
        /** inclusion de la classe Recheche Bazar. */
        require_once MORE_CHEMIN_BIBLIO.'more_recherche_bazar.class.php';
        $moteur = new More_Recherche($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
        
        $recherche_papyrus_menu = new More_Recherche_Papyrus_Menu($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
                $moteur->ajouterRecherche($recherche_papyrus_menu);
                
        if (!empty($GLOBALS['_MOTEUR_RECHERCHE_']['spip']))     {
                $recherche_spip_article = new More_Recherche_Spip_Article($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
                $moteur->ajouterRecherche($recherche_spip_article);     
        }
        
        if (!empty($GLOBALS['_MOTEUR_RECHERCHE_']['bazar'][0])) {
                $recherche_bazar = new More_Recherche_Bazar($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
                $moteur->ajouterRecherche($recherche_bazar);            
        }
        
        if (!empty($GLOBALS['_MOTEUR_RECHERCHE_']['projet']['url']))    {
                $recherche_projet = new More_Recherche_Projet($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
                $moteur->ajouterRecherche($recherche_projet);
        }

                $sphinx_connect = FALSE;
                if(USE_SPHINX && $sphinx) {
                        require_once("moteur_recherche_sphinx.php");
                        $sphinx_connect = @mysql_connect(SPHINX_DSN, NULL, NULL, TRUE);
                        if(!$sphinx_connect) error_log("sphinx: can't connect to " . SPHINX_DSN . ", traditionnal SQL fallback [moteur_recherche.php]");
                }
                if(!$sphinx_connect) {
                        // recherche traditionnelle
                        $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'] = $moteur->rechercherMotif();
                } else {
                        /* ce fichier/cette fonction peut-être réclamé plusieurs fois
                           car le motif du template '{{MoteurRecherche}}' est inclu récursivement,
                           (la première substitution fait réapparaître '{{MoteurRecherche}}')
                           Cela est lié au fonctionnement des sessions et diffère selon un espace de test
                           et la config' en production... */
                        // if(!isset($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'])) {
                                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'] = sphinx_search($_SESSION['_MOTEUR_RECHERCHE_']['rechercher']['more_motif']);
                        // }
                }

        //$GLOBALS['_DEBOGAGE_'] = '<pre>'.print_r($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'], true).'</pre>';
        $nbre_pages = count($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats']);
                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['nbre_pages'] = $nbre_pages;
                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['vide'] = MORE_LG_RESULTAT_VIDE;
        if ($nbre_pages <= 1) {
                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['titre'] = sprintf(MORE_LG_RESULTAT_TITRE, $nbre_pages);
        } else {
                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['titre'] = sprintf(MORE_LG_RESULTAT_TITRE_PLURIEL, $nbre_pages);
        }

                foreach ($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'] as $cle => $val) {
                        if (empty($val['url'])) {
                unset($GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]);
                        } else {
                                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]['score'] = trim($val['score']);
                                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]['date_creation'] = trim($val['date_creation']);
                                $GLOBALS['_MOTEUR_RECHERCHE_']['resultat']['resultats'][$cle]['description'] = trim($val['description']);
                        }
                }
        }

        // G�n�ration du contenu � partir des squelettes
        foreach ($aso_squelette as $squelette => $fichier) {
                // Extrait les variables et les ajoutes � l'espace de noms local
                extract($GLOBALS['_MOTEUR_RECHERCHE_'][$squelette]);
                // D�marre le buffer
                ob_start();
                // Inclusion du fichier
                include(MORE_CHEMIN_SQUELETTE.$fichier);
                // R�cup�rer le  contenu du buffer
                $retour = ob_get_contents();
                // Arr�te et d�truit le buffer
                ob_end_clean();
                // Retourne le contenu
                switch ($squelette) {
                        case 'resultat' :
                                // L'applette fournie un r�sultat qui �crase le contenu de la page courrante
                                $GLOBALS['_PAPYRUS_']['rendu']['CONTENU_NAVIGATION'] = '';
                                $GLOBALS['_PAPYRUS_']['rendu']['CONTENU_TETE'] = '';
                                $GLOBALS['_PAPYRUS_']['rendu']['CONTENU_CORPS'] = $retour;
                                $GLOBALS['_PAPYRUS_']['rendu']['CONTENU_PIED'] = '';
                                $GLOBALS['_GEN_commun']['info_menu'] = '';
                                break;
                        case 'formulaire' :
                                // L'applette est appel�e par d�faut
                                $retour_formulaire = $retour;
                                break;
                        default:
                                $e = "Squellette <$squelette> pour le moteur de recherche inconnu!";
                                trigger_error($e, E_USER_WARNING);
                }
        }
        return $retour_formulaire;
}

// +------------------------------------------------------------------------------------------------------+
// |                                            PIED du PROGRAMME                                         |
// +------------------------------------------------------------------------------------------------------+


/* +--Fin du code ----------------------------------------------------------------------------------------+
*
* $Log: not supported by cvs2svn $
* Revision 1.23  2008-08-26 15:31:16  alexandre_tb
* ajout du moteur de recherche dans l'appli projet
*
* Revision 1.22  2007-11-30 14:02:48  alexandre_tb
* Fusion avec la livraison
*
* Revision 1.21  2007-10-29 18:29:30  jp_milcent
* Ajout d'un pr�fixe devant les classes de l'applette pour �viter les conflits avec d'autres classes provenant des applis clientes.
*
* Revision 1.20  2007-06-15 12:27:39  jp_milcent
* Ajout de fonctionnalit�s Javascript au moteur de recherche.
*
* Revision 1.19  2007-01-02 18:49:22  jp_milcent
* Am�lioration de la gestion du motif.
* Ajout de la gestion des expressions compl�te via l'utilisation de guillemets.
*
* Revision 1.18  2006/12/12 13:53:54  jp_milcent
* Mise en place du nouveau format des balises d'applette.
*
* Revision 1.17  2006/12/01 16:33:40  florian
* Am�lioration de la gestion des applettes et compatibilit� avec le nouveau mode de gestion de l'inclusion des applettes.
*
* Revision 1.16  2006/11/20 09:36:59  jp_milcent
* Correction bogue z�ro r�sultat et ajout d'url simple pour indiquer la page de l'article.
*
* Revision 1.15  2006/11/14 16:10:13  jp_milcent
* Extraction du XHTML et utilisation de squelettes � la place.
* Possibilit� de configurer le squlette voulu via le fichier de conf.
*
* Revision 1.14  2006/10/10 13:28:14  jp_milcent
* Suppression d'une variable et utilisation de la constante PAP_URL
*
* Revision 1.13  2006/10/10 12:02:30  jp_milcent
* Suppression d'une biblioth�que Pear qu'il est inutile d'inclure.
* Ajout du chemin vers la bibliotheque Pear de Papyrus.
*
* Revision 1.12  2006/06/16 09:45:10  jp_milcent
* Correction bogue li� � la suppression de l'objet info_menu.
*
* Revision 1.11  2006/05/23 13:39:13  florian
* corection bug notice de jean pascal ;-)
*
* Revision 1.10  2006/05/19 10:04:55  jp_milcent
* Ajout d'un moteur de recherche analysant les articles des sites sous Spip.
*
* Revision 1.9  2006/04/28 12:41:49  florian
* corrections erreurs chemin
*
* Revision 1.8  2006/03/02 10:49:49  ddelon
* Fusion branche multilinguisme dans branche principale
*
* Revision 1.7.2.2  2005/12/27 15:56:00  ddelon
* Fusion Head vers multilinguisme (wikini double clic)
*
* Revision 1.7.2.1  2005/12/20 14:40:25  ddelon
* Fusion Head vers Livraison
*
* Revision 1.7  2005/09/27 09:07:32  ddelon
* size applette et squelettes
*
* Revision 1.6  2005/05/25 13:49:22  jpm
* Corection erreur pour la recherche dans le contenu.
*
* Revision 1.5  2005/05/19 12:46:12  jpm
* Correction bogue accesskey.
* Ajout d'un id � la liste.
* Arrondissement des score.
*
* Revision 1.4  2005/04/14 17:39:34  jpm
* Am�lioration du moteur de rechercher :
*  - pourcentage
*  - ajout d'info
*
* Revision 1.3  2005/02/22 19:27:21  jpm
* Changement de nom de variables.
* Suppression de l'attribut nam de la balise form via une m�thode de HTML_Common.
*
* Revision 1.2  2005/02/22 17:44:03  jpm
* Suppression de r�f�rence posant probl�me.
*
* Revision 1.1  2004/12/07 10:24:01  jpm
* Moteur de recherche version de d�part.
*
*
* +-- Fin du code ----------------------------------------------------------------------------------------+
*/
?>