Rev 609 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php
//
// Ce fichier ne sera execute qu'une fois
if (defined("_INC_CHAMP_SQUEL")) return;
define("_INC_CHAMP_SQUEL", "1");
function init_champs_squel() {
global $champs_valides;
global $champs_traitement, $champs_pretraitement, $champs_posttraitement;
global $rows_articles;
global $rows_signatures;
global $rows_syndication;
global $rows_syndic_articles;
global $rows_documents;
global $rows_types_documents;
global $rows_rubriques;
global $rows_forums;
global $rows_breves;
global $rows_auteurs;
global $rows_hierarchie;
global $rows_mots;
global $rows_groupes_mots;
global $tables_relations;
global $tables_code_contexte;
global $tables_doublons;
//
// Construire un tableau des tables de relations
//
$tables_relations = '';
$tables_relations['articles']['id_mot'] = 'spip_mots_articles';
$tables_relations['articles']['id_auteur'] = 'spip_auteurs_articles';
$tables_relations['articles']['id_document'] = 'spip_documents_articles';
$tables_relations['auteurs']['id_article'] = 'spip_auteurs_articles';
$tables_relations['breves']['id_mot'] = 'spip_mots_breves';
$tables_relations['breves']['id_document'] = 'spip_documents_breves';
$tables_relations['documents']['id_article'] = 'spip_documents_articles';
$tables_relations['documents']['id_rubrique'] = 'spip_documents_rubriques';
$tables_relations['documents']['id_breve'] = 'spip_documents_breves';
$tables_relations['forums']['id_mot'] = 'spip_mots_forum';
$tables_relations['mots']['id_article'] = 'spip_mots_articles';
$tables_relations['mots']['id_breve'] = 'spip_mots_breves';
$tables_relations['mots']['id_forum'] = 'spip_mots_forum';
$tables_relations['mots']['id_rubrique'] = 'spip_mots_rubriques';
$tables_relations['mots']['id_syndic'] = 'spip_mots_syndic';
$tables_relations['groupes_mots']['id_groupe'] = 'spip_mots';
$tables_relations['rubriques']['id_mot'] = 'spip_mots_rubriques';
$tables_relations['rubriques']['id_document'] = 'spip_documents_rubriques';
$tables_relations['syndication']['id_mot'] = 'spip_mots_syndic';
//
// Construire un tableau associatif des codes de champ utilisables
//
$c = array('NOM_SITE_SPIP', 'URL_SITE_SPIP', 'EMAIL_WEBMASTER',
'CHARSET', 'ID_ARTICLE', 'ID_RUBRIQUE', 'ID_BREVE', 'ID_FORUM',
'ID_PARENT', 'ID_SECTEUR', 'ID_DOCUMENT', 'ID_TYPE', 'ID_AUTEUR',
'ID_MOT', 'ID_SYNDIC_ARTICLE', 'ID_SYNDIC', 'ID_SIGNATURE',
'ID_GROUPE', 'ID_VIGNETTE', 'TITRE', 'SURTITRE', 'SOUSTITRE', 'DESCRIPTIF',
'CHAPO', 'TEXTE', 'PS', 'NOTES', 'INTRODUCTION', 'MESSAGE', 'DATE',
'DATE_REDAC', 'DATE_MODIF', 'DATE_NOUVEAUTES', 'INCLUS', 'LANG',
'LANG_LEFT', 'LANG_RIGHT', 'LANG_DIR', 'LESAUTEURS', 'EMAIL',
'NOM_SITE', 'LIEN_TITRE', 'URL_SITE', 'LIEN_URL', 'NOM', 'BIO',
'TYPE', 'PGP', 'FORMULAIRE_ECRIRE_AUTEUR', 'FORMULAIRE_FORUM',
'FORMULAIRE_SITE', 'PARAMETRES_FORUM', 'FORMULAIRE_RECHERCHE',
'RECHERCHE', 'FORMULAIRE_INSCRIPTION', 'FORMULAIRE_SIGNATURE',
'LOGO_MOT', 'LOGO_RUBRIQUE', 'LOGO_RUBRIQUE_NORMAL',
'LOGO_RUBRIQUE_SURVOL', 'LOGO_AUTEUR', 'LOGO_AUTEUR_NORMAL',
'LOGO_AUTEUR_SURVOL', 'LOGO_SITE', 'LOGO_BREVE',
'LOGO_BREVE_RUBRIQUE', 'LOGO_DOCUMENT', 'LOGO_ARTICLE',
'LOGO_ARTICLE_RUBRIQUE', 'LOGO_ARTICLE_NORMAL',
'LOGO_ARTICLE_SURVOL', 'URL_ARTICLE', 'URL_RUBRIQUE', 'URL_BREVE',
'URL_FORUM', 'URL_SYNDIC', 'URL_MOT', 'URL_DOCUMENT', 'URL_AUTEUR',
'EMBED_DOCUMENT', 'IP', 'VISITES', 'POPULARITE',
'POPULARITE_ABSOLUE', 'POPULARITE_MAX', 'POPULARITE_SITE', 'POINTS',
'COMPTEUR_BOUCLE', 'TOTAL_BOUCLE', 'PETITION', 'LARGEUR', 'HAUTEUR',
'TAILLE', 'EXTENSION', 'DEBUT_SURLIGNE', 'FIN_SURLIGNE',
'TYPE_DOCUMENT', 'EXTENSION_DOCUMENT', 'FORMULAIRE_ADMIN',
'LOGIN_PRIVE', 'LOGIN_PUBLIC', 'URL_LOGOUT', 'PUCE', 'EXTRA',
'EXPOSER', 'MENU_LANG', 'MENU_LANG_ECRIRE'
);
reset($c);
while (list(, $val) = each($c)) {
unset($champs_traitement[$val]);
unset($champs_pretraitement[$val]);
unset($champs_posttraitement[$val]);
$champs_valides[$val] = $val;
}
//
// Construire un tableau associatif des pre-traitements de champs
//
// Textes utilisateur : ajouter la securite anti-script
$c = array('NOM_SITE_SPIP', 'URL_SITE_SPIP', 'EMAIL_WEBMASTER', 'CHARSET',
'TITRE', 'SURTITRE', 'SOUSTITRE', 'DESCRIPTIF', 'CHAPO', 'TEXTE', 'PS',
'NOTES', 'INTRODUCTION', 'MESSAGE', 'LESAUTEURS', 'EMAIL', 'NOM_SITE',
'LIEN_TITRE', 'URL_SITE', 'LIEN_URL', 'NOM', 'IP', 'BIO',
'TYPE', 'PGP', 'RECHERCHE'
);
reset($c);
while (list(, $val) = each($c)) {
$champs_pretraitement[$val][] = 'trim';
$champs_posttraitement[$val][] = 'interdire_scripts';
}
$c = array('EXTRA');
reset($c);
while (list(, $val) = each($c)) {
$champs_posttraitement[$val][] = 'interdire_scripts';
}
// Textes courts : ajouter le traitement typographique
$c = array('NOM_SITE_SPIP', 'SURTITRE', 'TITRE', 'SOUSTITRE', 'NOM_SITE', 'LIEN_TITRE', 'NOM');
reset($c);
while (list(, $val) = each($c)) {
$champs_traitement[$val][] = 'typo';
}
// Chapo : ne pas l'afficher si article virtuel
$c = array('CHAPO');
reset($c);
while (list(, $val) = each($c)) {
$champs_traitement[$val][] = 'nettoyer_chapo';
}
// Textes longs : ajouter le traitement typographique + mise en forme
$c = array('DESCRIPTIF', 'CHAPO', 'TEXTE', 'PS', 'BIO', 'MESSAGE');
reset($c);
while (list(, $val) = each($c)) {
$champs_traitement[$val][] = 'traiter_raccourcis';
}
// Dates : ajouter le vidage des dates egales a 00-00-0000
$c = array('DATE', 'DATE_REDAC', 'DATE_MODIF', 'DATE_NOUVEAUTES');
reset($c);
while (list(, $val) = each($c)) {
$champs_traitement[$val][] = 'vider_date';
}
// URL_SITE : vider les url == 'http://'
$c = array('URL_SITE_SPIP', 'URL_SITE', 'LIEN_URL');
reset($c);
while (list(, $val) = each($c)) {
$champs_traitement[$val][] = 'vider_url';
}
// URLs : remplacer les & par &
$c = array('URL_SITE_SPIP', 'URL_SITE', 'LIEN_URL', 'PARAMETRES_FORUM',
'URL_ARTICLE', 'URL_RUBRIQUE', 'URL_BREVE', 'URL_FORUM', 'URL_SYNDIC',
'URL_MOT', 'URL_DOCUMENT');
reset($c);
while (list(, $val) = each($c)) {
$champs_traitement[$val][] = 'htmlspecialchars';
}
//
// Construire un tableau associatif des champs de chaque type
// avec l'intitule de la colonne mysql correspondante
//
$rows_articles = array(
'ID_ARTICLE' => 'id_article',
'ID_RUBRIQUE' => 'id_rubrique',
'ID_SECTEUR' => 'id_secteur',
'SURTITRE' => 'surtitre',
'TITRE' => 'titre',
'SOUSTITRE' => 'soustitre',
'DESCRIPTIF' => 'descriptif',
'CHAPO' => 'chapo',
'TEXTE' => 'texte',
'PS' => 'ps',
'LANG' => 'lang',
'DATE' => 'date',
'DATE_REDAC' => 'date_redac',
'NOM_SITE' => 'nom_site',
'URL_SITE' => 'url_site',
'DATE_MODIF' => 'date_modif',
'VISITES' => 'visites',
'POINTS' => 'points'
);
$rows_auteurs = array(
'ID_AUTEUR' => 'id_auteur',
'NOM' => 'nom',
'BIO' => 'bio',
'EMAIL' => 'email',
'NOM_SITE' => 'nom_site',
'URL_SITE' => 'url_site',
'PGP' => 'pgp',
'LANG' => 'lang',
'POINTS' => 'points'
);
$rows_breves = array(
'ID_BREVE' => 'id_breve',
'ID_RUBRIQUE' => 'id_rubrique',
'ID_SECTEUR' => 'id_rubrique',
'DATE' => 'date_heure',
'TITRE' => 'titre',
'TEXTE' => 'texte',
'LANG' => 'lang',
'NOM_SITE' => 'lien_titre',
'URL_SITE' => 'lien_url',
'LIEN_TITRE' => 'lien_titre',
'LIEN_URL' => 'lien_url',
'POINTS' => 'points'
);
$rows_forums = array(
'ID_FORUM' => 'id_forum',
'ID_PARENT' => 'id_parent',
'ID_BREVE' => 'id_breve',
'ID_RUBRIQUE' => 'id_rubrique',
'ID_ARTICLE' => 'id_article',
'TITRE' => 'titre',
'TEXTE' => 'texte',
'DATE' => 'date_heure',
'NOM' => 'auteur',
'EMAIL' => 'email_auteur',
'NOM_SITE' => 'nom_site',
'URL_SITE' => 'url_site',
'ID_AUTEUR' => 'id_auteur',
'IP' => 'ip'
);
$rows_documents = array(
'ID_DOCUMENT' => 'id_document',
'ID_VIGNETTE' => 'id_vignette',
'ID_TYPE' => 'id_type',
'ID_ARTICLE' => 'id_article',
'TITRE' => 'titre',
'DESCRIPTIF' => 'descriptif',
'DATE' => 'date',
'LARGEUR' => 'largeur',
'HAUTEUR' => 'hauteur',
'TAILLE' => 'taille',
'TYPE_DOCUMENT' => 'type_document',
'EXTENSION_DOCUMENT' => 'extension_document'
);
$rows_types_documents = array(
'ID_TYPE' => 'id_type',
'TITRE' => 'titre',
'DESCRIPTIF' => 'descriptif',
'EXTENSION' => 'extension'
);
$rows_mots = array(
'ID_MOT' => 'id_mot',
'TYPE' => 'type',
'TITRE' => 'titre',
'DESCRIPTIF' => 'descriptif',
'TEXTE' => 'texte',
'POINTS' => 'points',
'ID_GROUPE' => 'id_groupe'
);
$rows_groupes_mots = array(
'ID_GROUPE' => 'id_groupe',
'TITRE' => 'titre'
);
$rows_rubriques = array(
'ID_RUBRIQUE' => 'id_rubrique',
'ID_PARENT' => 'id_parent',
'ID_SECTEUR' => 'id_secteur',
'TITRE' => 'titre',
'DESCRIPTIF' => 'descriptif',
'TEXTE' => 'texte',
'LANG' => 'lang',
'DATE' => 'date',
'POINTS' => 'points'
);
$rows_hierarchie = $rows_rubriques;
$rows_signatures = array(
'ID_SIGNATURE' => 'id_signature',
'ID_ARTICLE' => 'id_article',
'DATE' => 'date_time',
'NOM' => 'nom_email',
'EMAIL' => 'ad_email',
'NOM_SITE' => 'nom_site',
'URL_SITE' => 'url_site',
'MESSAGE' => 'message'
);
$rows_syndication = array(
'ID_SYNDIC' => 'id_syndic',
'ID_RUBRIQUE' => 'id_rubrique',
'ID_SECTEUR' => 'id_secteur',
'NOM_SITE' => 'nom_site',
'URL_SITE' => 'url_site',
'URL_SYNDIC' => 'url_syndic',
'DESCRIPTIF' => 'descriptif',
'DATE' => 'date',
'POINTS' => 'points'
);
$rows_syndic_articles = array(
'ID_SYNDIC_ARTICLE' => 'id_syndic_article',
'ID_SYNDIC' => 'id_syndic',
'TITRE' => 'titre',
'URL_ARTICLE' => 'url',
'DATE' => 'date',
'LESAUTEURS' => 'lesauteurs',
'DESCRIPTIF' => 'descriptif',
'NOM_SITE' => 'nom_site',
'URL_SITE' => 'url_site'
);
$tables_code_contexte = array(
'articles' => '
$contexte["id_article"] = $row["id_article"];
$contexte["id_rubrique"] = $row["id_rubrique"];
$contexte["id_secteur"] = $row["id_secteur"];
$contexte["date"] = $row["date"];
$contexte["date_redac"] = $row["date_redac"];
$contexte["accepter_forum"] = $row["accepter_forum"];
$contexte["id_trad"] = $row["id_trad"];
',
'breves' => '
$contexte["id_breve"] = $row["id_breve"];
$contexte["id_rubrique"] = $row["id_rubrique"];
$contexte["id_secteur"] = $row["id_rubrique"];
$contexte["date"] = $row["date_heure"];
',
'rubriques' => '
$contexte["id_rubrique"] = $row["id_rubrique"];
$contexte["id_parent"] = $row["id_parent"];
$contexte["id_secteur"] = $row["id_secteur"];
$contexte["date"] = $row["date"];
',
'hierarchie' => '
$contexte["id_rubrique"] = $row["id_rubrique"];
$contexte["id_parent"] = $row["id_parent"];
$contexte["id_secteur"] = $row["id_secteur"];
$contexte["date"] = $row["date"];
',
'documents' => '
$contexte["id_document"] = $row["id_document"];
$contexte["id_vignette"] = $row["id_vignette"];
$contexte["id_type"] = $row["id_type"];
',
'types_documents' => '
$contexte["id_type"] = $row["id_type"];
',
'forums' => '
$contexte["id_forum"] = $row["id_forum"];
$contexte["id_rubrique"] = $row["id_rubrique"];
$contexte["id_article"] = $row["id_article"];
$contexte["id_breve"] = $row["id_breve"];
$contexte["id_syndic"] = $row["id_syndic"];
$contexte["id_parent"] = $row["id_parent"];
$contexte["id_auteur"] = $row["id_auteur"];
$contexte["date"] = $row["date_heure"];
',
'auteurs' => '
$contexte["id_auteur"] = $row["id_auteur"];
',
'signatures' => '
$contexte["id_signature"] = $row["id_signature"];
$contexte["date"] = $row["date_time"];
',
'mots' => '
$contexte["id_mot"] = $row["id_mot"];
$contexte["type"] = $row["type"];
$contexte["id_groupe"] = $row["id_groupe"];
',
'groupes_mots' => '
$contexte["id_groupe"] = $row["id_groupe"];
',
'syndication' => '
$contexte["id_syndic"] = $row["id_syndic"];
$contexte["id_rubrique"] = $row["id_rubrique"];
$contexte["id_secteur"] = $row["id_secteur"];
$contexte["url_site"] = $row["url_site"];
$contexte["date"] = $row["date"];
',
'syndic_articles' => '
$contexte["id_syndic"] = $row["id_syndic"];
$contexte["id_syndic_article"] = $row["id_syndic_article"];
$contexte["date"] = $row["date"];
'
);
$tables_doublons = array(
'articles' => "id_article",
'auteurs' => "id_auteur",
'breves' => "id_breve",
'documents' => "id_document",
'forums' => "id_forum",
'groupes_mots' => "id_groupe",
'hierarchie' => "id_rubrique",
'mots' => "id_mot",
'rubriques' => "id_rubrique",
'signatures' => "id_signature",
'syndication' => "id_syndic",
'syndic_articles' => "syndic_articles",
'types_documents' => "id_document"
);
}
init_champs_squel();
?>