--- /dev/null
+<?php
+/**
+ * Plugin Acces Restreint 3.0 pour Spip 2.0
+ * Licence GPL (c) 2006-2008 Cedric Morin
+ *
+ */
+if (!defined("_ECRIRE_INC_VERSION")) return;
+
+/**
+ * editer une zone (action apres creation/modif de zone)
+ *
+ * @param int $arg
+ * @return array
+ */
+function action_editer_zone_dist($arg=null){
+
+ if (is_null($arg)){
+ $securiser_action = charger_fonction('securiser_action', 'inc');
+ $arg = $securiser_action();
+ }
+
+ // Envoi depuis le formulaire d'edition d'une zone
+ if (!$id_zone = intval($arg)) {
+ $id_zone = zone_inserer();
+ }
+
+ if (!$id_zone)
+ return array(0,''); // erreur
+
+ if (_request('droits_admin')){
+ zone_lier($id_zone,'auteur',$GLOBALS['visiteur_session']['id_auteur']);
+ }
+
+ $err = zone_modifier($id_zone);
+
+ return array($id_zone,$err);
+}
+
+
+/**
+ * Inserer une zone en base
+ *
+ * @return int
+ */
+function zone_inserer() {
+
+ include_spip('inc/autoriser');
+ if (!autoriser('creer','zone'))
+ return false;
+
+ $champs = array(
+ 'publique'=>'non',
+ 'privee'=>'non',
+ );
+
+ // Envoyer aux plugins
+ $champs = pipeline('pre_insertion',
+ array(
+ 'args' => array(
+ 'table' => 'spip_zones',
+ ),
+ 'data' => $champs
+ )
+ );
+ $id_zone = sql_insertq("spip_zones", $champs);
+ pipeline('post_insertion',
+ array(
+ 'args' => array(
+ 'table' => 'spip_zones',
+ 'id_objet' => $id_zone
+ ),
+ 'data' => $champs
+ )
+ );
+ return $id_zone;
+}
+
+
+/**
+ * Modifier une zone en base
+ * $c est un contenu (par defaut on prend le contenu via _request())
+ *
+ * @param int $id_zone
+ * @param array $set
+ * @return string|bool
+ */
+function zone_modifier ($id_zone, $set=null) {
+
+ include_spip('inc/modifier');
+ $c = collecter_requests(
+ // white list
+ array('titre', 'descriptif','publique', 'privee'),
+ // black list
+ array(),
+ // donnees eventuellement fournies
+ $set
+ );
+
+ // Si la zone est publiee, invalider les caches et demander sa reindexation
+ $invalideur = $indexation = '';
+ $t = sql_getfetsel("statut", "spip_zones", "id_zone=$id_zone");
+ if ($t == 'publie') {
+ $invalideur = "id='zone/$id_zone'";
+ $indexation = true;
+ }
+
+ if ($err = objet_modifier_champs('zone', $id_zone,
+ array(
+ 'nonvide' => array('titre' => _T('info_sans_titre')),
+ 'invalideur' => $invalideur,
+ 'indexation' => $indexation
+ ),
+ $c))
+ return $err;
+
+
+ zone_lier($id_zone, 'rubrique', _request('rubriques'),'set');
+ return $err;
+}
+
+
+/**
+ * Mettre a jour les liens objets/zones.
+ * si zones vaut '', associe toutes les zones a(aux) objets(s).
+ * $ids est une liste d'id.
+ * $type est le type de l'objet (rubrique, auteur).
+ * $operation = add/set/del pour ajouter, affecter uniquement, ou supprimer les objets listes dans ids.
+ *
+ * @param int|array $zones
+ * @param string $type
+ * @param int|array $ids
+ * @param string $operation
+ */
+function zone_lier($zones,$type,$ids,$operation = 'add'){
+ include_spip('inc/autoriser');
+ include_spip('action/editer_liens');
+ if (!$zones)
+ $zones="*";
+ if (!$ids)
+ $ids = array();
+ elseif (!is_array($ids))
+ $ids = array($ids);
+
+ if ($operation=='del'){
+ // on supprime les ids listes
+ objet_dissocier(array('zone'=>$zones),array($type=>$ids));
+ }
+ else {
+ // si c'est une affectation exhaustive, supprimer les existants qui ne sont pas dans ids
+ // si c'est un ajout, ne rien effacer
+ if ($operation=='set'){
+ objet_dissocier(array('zone'=>$zones),array($type=>array("NOT",$ids)));
+ }
+ foreach ($ids as $id) {
+ if (autoriser('affecterzones',$type,$id,null,array('id_zone'=>$zones))) {
+ objet_associer(array('zone'=>$zones),array($type=>$id));
+ }
+ }
+ }
+}
+
+
+
+/**
+ * Supprimer une zone
+ *
+ * @param int $id_zone
+ * @return int
+ */
+function zone_supprimer($id_zone){
+ include_spip('action/editer_liens');
+ objet_dissocier(array('zone'=>$id_zone),array('*'=>'*'));
+
+ // puis la zone
+ sql_delete("spip_zones", "id_zone=".intval($id_zone));
+
+ $id_zone = 0;
+ return $id_zone;
+}
+
+
+?>