You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
240 lines
6.4 KiB
240 lines
6.4 KiB
<?php |
|
|
|
/***************************************************************************\ |
|
* SPIP, Systeme de publication pour l'internet * |
|
* * |
|
* Copyright (c) 2001-2020 * |
|
* Arnaud Martin, Antoine Pitrou, Philippe Riviere, Emmanuel Saint-James * |
|
* * |
|
* Ce programme est un logiciel libre distribue sous licence GNU/GPL. * |
|
* Pour plus de details voir le fichier COPYING.txt ou l'aide en ligne. * |
|
\***************************************************************************/ |
|
|
|
/** |
|
* Utilisations de pipelines |
|
* |
|
* @package SPIP\Organiseur\Pipelines |
|
**/ |
|
|
|
if (!defined('_ECRIRE_INC_VERSION')) { |
|
return; |
|
} |
|
|
|
|
|
/** |
|
* Lister les tables à ne pas inclure dans un export de BDD |
|
* |
|
* Ici se ramener à tester l'admin restreint est un abus |
|
* car cela présume qu'un admin restreint ne peut pas faire de sauvegarde |
|
* complète, alors que l'intention est d'exclure les messages |
|
* des sauvegardes partielles que peuvent réaliser les admin restreint |
|
* |
|
* @todo *a revoir* |
|
* @pipeline lister_tables_noexport |
|
* |
|
* @param array $EXPORT_tables_noexport |
|
* @return array |
|
*/ |
|
function organiseur_lister_tables_noexport($EXPORT_tables_noexport) { |
|
if (!$GLOBALS['connect_toutes_rubriques']) { |
|
$EXPORT_tables_noexport[] = 'spip_messages'; |
|
#$EXPORT_tables_noexport[]='spip_auteurs_liens'; // where objet='message' |
|
} |
|
|
|
return $EXPORT_tables_noexport; |
|
} |
|
|
|
/** |
|
* Optimiser les liens morts dans la base de donnees |
|
* |
|
* @pipeline optimiser_base_disparus |
|
* |
|
* @param array $flux |
|
* @return array |
|
*/ |
|
function organiseur_optimiser_base_disparus($flux) { |
|
// |
|
// Messages prives |
|
// |
|
|
|
# supprimer les messages lies a un auteur disparu |
|
$res = sql_select( |
|
'M.id_message AS id', |
|
'spip_messages AS M |
|
LEFT JOIN spip_auteurs AS A |
|
ON A.id_auteur=M.id_auteur', |
|
'A.id_auteur IS NULL' |
|
); |
|
|
|
$flux['data'] += optimiser_sansref('spip_messages', 'id_message', $res); |
|
|
|
return $flux; |
|
} |
|
|
|
/** |
|
* Generer les alertes message recu a destination de l'auteur |
|
* concerne par l'appel |
|
* |
|
* @pipeline alertes_auteur |
|
* |
|
* @param array $flux |
|
* @return array |
|
*/ |
|
function organiseur_alertes_auteur($flux) { |
|
|
|
$id_auteur = $flux['args']['id_auteur']; |
|
|
|
$result_messages = sql_allfetsel( |
|
'M.id_message', |
|
"spip_messages AS M LEFT JOIN spip_auteurs_liens AS L ON (L.objet='message' AND L.id_objet=M.id_message)", |
|
'L.id_auteur=' . intval($id_auteur) . " AND L.vu='non' AND M.statut='publie' AND M.type='normal'" |
|
); |
|
$total_messages = count($result_messages); |
|
if ($total_messages == 1) { |
|
$row = reset($result_messages); |
|
$id_message = $row['id_message']; |
|
$flux['data'][] = "<a href='" . generer_url_ecrire( |
|
'message', |
|
"id_message=$id_message" |
|
) . "'>" . _T('organiseur:info_1_message_nonlu') . '</a>'; |
|
} elseif ($total_messages > 1) { |
|
$flux['data'][] = "<a href='" . generer_url_ecrire('messages') . "'>" . _T( |
|
'organiseur:info_nb_messages_nonlus', |
|
array('nb' => $total_messages) |
|
) . '</a>'; |
|
} |
|
|
|
return $flux; |
|
} |
|
|
|
/** |
|
* Afficher les interventions et objets en lien |
|
* avec un auteur (sur sa page) |
|
* |
|
* @pipeline affiche_auteurs_interventions |
|
* |
|
* @param array $flux |
|
* @return array |
|
*/ |
|
function organiseur_affiche_auteurs_interventions($flux) { |
|
|
|
if ($id_auteur = intval($flux['args']['id_auteur'])) { |
|
include_spip('inc/message_select'); |
|
// Messages de l'auteur et discussions en cours |
|
if ($GLOBALS['meta']['messagerie_agenda'] != 'non' |
|
and $id_auteur != $GLOBALS['visiteur_session']['id_auteur'] |
|
and autoriser('repondre', 'message', '', $id_auteur) |
|
) { |
|
$flux['data'] .= recuperer_fond( |
|
'prive/squelettes/inclure/organiseur-interventions', |
|
array('id_auteur' => $id_auteur) |
|
); |
|
} |
|
} |
|
|
|
return $flux; |
|
} |
|
|
|
/** |
|
* Déclarer les metas de configuration de l'agenda/messagerie |
|
* |
|
* @pipeline configurer_liste_metas |
|
* @param array $metas |
|
* Couples nom de la méta => valeur par défaut |
|
* @return array |
|
* Couples nom de la méta => valeur par défaut |
|
*/ |
|
function organiseur_configurer_liste_metas($metas) { |
|
$metas['messagerie_agenda'] = 'oui'; |
|
|
|
return $metas; |
|
} |
|
|
|
/** |
|
* Insérer la css de l'agenda dans l'espace privé (hum) |
|
* |
|
* @pipeline header_prive |
|
* @param string $head |
|
* @return string |
|
*/ |
|
function organiseur_header_prive($head) { |
|
// CSS calendrier |
|
if ($GLOBALS['meta']['messagerie_agenda'] != 'non') { |
|
$head .= '<link rel="stylesheet" type="text/css" href="' |
|
. url_absolue(find_in_path('calendrier.css')) . '" />' . "\n"; |
|
} |
|
|
|
return $head; |
|
} |
|
|
|
/** |
|
* Afficher agenda, messages et annonces sur la page d'accueil |
|
* |
|
* @pipeline affiche_droite |
|
* @param array $flux |
|
* @return array |
|
*/ |
|
function organiseur_affiche_droite($flux) { |
|
if ($flux['args']['exec'] == 'accueil') { |
|
$flux['data'] .= recuperer_fond( |
|
'prive/squelettes/inclure/organiseur-rappels', |
|
array( |
|
'id_auteur' => $GLOBALS['visiteur_session']['id_auteur'], |
|
'last' => $GLOBALS['visiteur_session']['quand'], |
|
) |
|
); |
|
} |
|
|
|
return $flux; |
|
} |
|
|
|
/** |
|
* Afficher le formulaire de configuration sur la page concernée |
|
* |
|
* @pipeline affiche_milieu |
|
* @param array $flux |
|
* @return array |
|
*/ |
|
function organiseur_affiche_milieu($flux) { |
|
if ($flux['args']['exec'] == 'configurer_interactions') { |
|
$c = recuperer_fond('prive/squelettes/inclure/configurer_messagerie', array()); |
|
if ($p = strpos($flux['data'], '<!--contenu_prive-->')) { |
|
$flux['data'] = substr_replace($flux['data'], $c, $p, 0); |
|
} else { |
|
$flux['data'] .= $c; |
|
} |
|
} |
|
|
|
return $flux; |
|
} |
|
|
|
/** |
|
* Diffuser un message qui passe en publie (== a envoyer) |
|
* |
|
* @pipeline post_edition |
|
* @param array $flux |
|
* @return array |
|
*/ |
|
function organiseur_post_edition($flux) { |
|
|
|
if (isset($flux['args']['table']) |
|
and $flux['args']['table'] == 'spip_messages' |
|
and $flux['args']['action'] == 'instituer' |
|
and $flux['data']['statut'] == 'publie' |
|
and $flux['args']['statut_ancien'] != 'publie' |
|
) { |
|
$id_message = $flux['args']['id_objet']; |
|
$row = sql_fetsel('destinataires,id_auteur,titre,texte', 'spip_messages', 'id_message=' . intval($id_message)); |
|
if ($row) { |
|
include_spip('inc/messages'); |
|
list($auteurs_dest, $email_dests) = messagerie_destiner(explode(',', $row['destinataires'])); |
|
|
|
// diffuser le message en interne |
|
messagerie_diffuser_message($id_message, $auteurs_dest); |
|
// diffuser le message en externe |
|
messagerie_mailer_message($id_message, $email_dests); |
|
} |
|
} |
|
|
|
return $flux; |
|
}
|
|
|