SPIP - Contrib

[ar] [en] [es] [fr] [it]



Accueil du site > Auteurs et Authentification > Restriction de l’accés aux contenus > Accés restreint par groupes

Le plugin accés restreint par groupes

dimanche 22 octobre 2006, par Coyote, cy_altern. Dernier ajout vendredi 9 mai 2008


le plugin accés par groupes permet de restreindre l’accès à des rubriques et leurs contenus en gérant des groupes d’utilisateurs autorisés. A la différence du plugin "accés restreint", le filtrage est appliqué aussi bien dans l’espace privé que l’espace public.

Voir en ligne : Un tutoriel pour la prise en main du plugin accès par groupes

[plugins incompatibles]

  • acces restreint
  • barre typo enrichie (en revanche le plugin barre typo écologique est compatible)

[problèmes avec les sites ayant une arborescence complexe et/ou de nombreux groupes]
pour éviter de doublonner, voir ce forum concernant les problèmes actuels de acces_groupe et ses développements futurs


Historique

Ce plugin reprend la contrib Créer des groupes, limiter l’accès aux rubriques et aux articles... (version 0.7 réservée aux versions 1.8 de spip) dont il constitue la version 1.0. Ce plugin est compatible avec la version 1.9.2 de spip. Il n’a pas été complètement testé avec la version SVN de spip 1.9.3. (Une version compatible spip 1.9.1 est disponible également mais elle n’est plus maintenue).

[Mises à jour]

  • la version [1.0.1] remplace la version 1.0 pour permettre d’assurer le filtrage des articles en mode "révision". Voir ce forum pour plus de détails.
    Il est vivement conseillé de procéder à la mise à niveau des plugins v1.0, la mise à jour des fichiers n’entraînera pas de modification de vos groupes et restrictions existant.
  • passage à la version [1.0.2] qui permet l’utilisation du critère tout_voir et du filtre accesgroupes_visualise pour permettre l’affichage d’une liste de toutes les rubriques/articles/brèves y compris les restreintes.
  • passage à la version [1.0.3] compatible spip 1.9.2.
  • passage à la version [1.0.31] qui corrige un certain nombre de bogues.

But :

Un des besoins fréquent lorsque l’on gère un site sous SPIP est de pouvoir restreindre l’accès à des rubriques afin qu’elles ne soient accessible qu’à certains utilisateurs. De façon complémentaire, pour permettre une gestion de ces accès restreints complète, simple et ergonomique, il s’avère indispensable que les utilisateurs "autorisés" soient gérés par groupes.

Cette contrib répond à ce besoin en essayant d’offrir le maximum de possibilités tant dans la gestion des utilisateurs autorisés que dans les restrictions d’accès, le tout sans avoir à intervenir sur les squelettes utilisés.

Pour permettre de réaliser des contenus totalement protégés, les restrictions d’accès doivent pouvoir s’appliquer aussi bien à l’espace privé qu’à l’espace public.

Pour les utilisateurs de la contrib (v0.7 ou v0.61), les nouveautés de cette version 1.0 (plugin) sont signalées par un : [v1.0]

Ce plugin permet :

  • de créer des groupes d’auteurs : ces groupes peuvent êtres constitués d’utilisateurs, d’autres groupes (sous-groupes) ou de statuts (c’est à dire que tous les utilisateurs d’un statut donné appartiennent à ce groupe). Cette organisation génère elle-même d’autres contraintes techniques à gérer : ainsi il ne doit pas être possible d’inclure le groupe "pére" dans le groupe "fils" si celui-ci contient déja "fils" (sinon on risque la boucle infinie lors de la routine de contrôle d’accès).
  • de limiter l’accès à certaines rubriques "rubriques restreintes" aux groupes créés : cette limitation d’accès peut s’appliquer soit dans la partie publique ET dans la partie privée, soit à l’une OU l’autre de ces parties séparément.

Les rubriques "à accès restreint" sont gérées automatiquement : dès qu’au moins un groupe contrôle une rubrique, cette dernière devient alors à "accès restreint" et elle est inaccessible pour les lecteurs n’appartenant pas à ce groupe. Inversement, si aucun groupe ne "contrôle" une rubrique, elle est accessible par tous les internautes.

Le fonctionnement du système de restriction d’accès est conçu de manière à ce que toutes les sous-rubriques d’une rubrique à accès restreint soient elles aussi restreintes : principe "d’héritage des restrictions".

[v1.0] Ce plugin permet également qu’un admin général puisse créer des groupes en ayant la possibilité d’en "déléguer" ensuite la gestion à un admin restreint, ce qui correspond à une sorte de "changement de propriétaire" d’un groupe.

Un exemple de situation à gérer :

Pour mieux cerner le fonctionnement, voici le cahier des charges auquel cette contrib tente de répondre :

  • un SPIP est installé sur le site d’un établissement scolaire (disons un lycée) pour permettre la publication de contenus élaborés par les profs et/ou les élèves.
  • Ce SPIP comprend une rubrique par discipline (Anglais, Lettres, SVT...), tous les profs d’une discipline sont administrateurs de la rubrique de leur discipline afin qu’il puissent gérer/modérer les publications des élèves dans celle-ci. Tous les élèves sont rédacteurs dans ce SPIP, les parents peuvent avoir un compte visiteur.
  • On souhaite que les profs d’une discipline puissent, s’ils le veulent, créer des sous-rubriques à accès réservé selon leurs besoins. Par exemple une sous-rubrique "travail en cours" dans laquelle ils pourront mettre au point ensemble les sujets de leurs prochains devoirs ou les corrections de ceux-ci. Il semble évident qu’il ne faut PAS que les élèves (comptes auteurs) aient un accès à cette sous-rubrique que ce soit dans la partie publique ou la partie privée !
  • On veut également qu’il soit possible d’avoir des rubriques à accès réservé uniquement aux profs (comptes admins restreints) pour qu’ils puissent publier des infos qui ne concernent pas les élèves (documents administratif, comptes-rendus de réunions syndicales, préparation de projets pluridisciplinaires...).
  • Il doit également être possible d’avoir des rubriques dans lesquelles les profs peuvent préparer des documents (par exemple les comptes-rendus des conseils de classe) qui seront accessibles une fois publiés (donc accès non-restreint dans la partie publique) mais confidentiels tant qu’ils sont en mode "en cours de rédaction" ou "proposé à l’évaluation" (donc accès restreint dans la partie privée).
  • Il faudra aussi une rubrique dont l’accès est réservé à tous les utilisateurs inscrits dans l’établissement (profs = admins restreints + élèves = auteurs + parents = visiteurs) dans laquelle on mettra, par exemple, les emplois du temps qui ne seront donc pas visibles par les "extérieurs" à l’établissement.
  • Enfin, il doit également être possible de créer des rubriques réservées :
    • aux élèves d’une classe (un groupe "classe"),
    • à plusieurs élèves et quelques profs, par ex le groupe "club informatique"
    • aux profs de 2 ou 3 disciplines (par ex" profs de sciences", cad les profs de SVT + Physique/Chimie + Maths). On obtient donc un groupe de groupes
    • ...
  • l’administrateur général du spip doit également pouvoir créer des groupes dont il déléguera ensuite la gestion aux admins de rubriques
  • avec comme circonstance aggravante que les admins généraux doient pouvoir "s’inviter" dans n’importe quel groupe pour consulter le contenu des rubriques à accès réservé.

Installation du plugin acces groupes :

[v1.0] Comme tous les plugins : récupérez le dernier zip à jour de cette contrib sur http://zone.spip.org/files/spip-zone/ ou sur le miroir http://miroirspip.ventre.name/build..., décompactez le et placez le dossier "acces_groupes" obtenu dans votre répertoire /plugins (à créer à la racine de votre spip si nécessaire), rendez vous sur l’interface de gestion des plugins (menu Configuration > Gestion des plugins), cochez le plugin "acces_groupes" et validez.

Icone d'accès à l'interface de gestion du plugin acces_groupes Vous devriez voir apparaître une icone supplémentaire dans le menu "auteur" pour les administrateurs (de rubriques et généraux) (merci à Litteul Kevin pour son icone nettement plus "classe" que mes pauvres bidouillages...)

Du point de vue de la base de données, ce plugin installe 3 tables supplémentaires : spip_accesgroupes_auteurs, spip_accesgroupes_acces et spip_accesgroupes_groupes, sachant que grâce au nouveau système de gestion des requètes MySQL par le core de spip 1.9 ("SPIP est grand et ses codeurs sont mes prophètes !"), le préfixe ’spip’ sera automatiquement remplacé par le préfixe des tables que vous avez défini dans votre fichier /ecrire/mes_options.php (variable $table_prefix) si vous gérez plusieurs spip avec une seule base de données.

[*ATTENTION !!!*]

  • ce plugin n’est PAS compatible avec le plugin "acces restreint" puisqu’il surcharge les mêmes fonctions que lui pour le filtrage des BOUCLES (affichage de l’espace public) : si celui-ci est actif, vous devez d’ABORD le désactiver (la vérification n’est pas gérée par le plugin) !!!
  • Si vous procédez à une mise à jour depuis une version antérieure dans le cas ou votre spip serait passé de la version 1.8 (où vous utilisiez la version 0.7 ou 0.61 de la contrib originale) à la 1.9, vous devez d’ABORD procéder à la mise à jour des tables utilisées. Pour cela connectez vous sur le script /plugins/acces_groupes/maj_tables.php qui permet de "patcher" les tables à partir de celles de la version 0.7 ou 0.61. Ce script est extrèmement sommaire [1] et vous demandera de saisir les paramètres de connexion à votre base de données MySQL pour éviter que n’importe qui puisse le lancer. Une fois ce script joué, vous pouvez effacer le fichier maj_tables.php.

4. Fonctionnement obtenu lorsque l’on intègre ce plugin :

  • pour un internaute qui n’est pas authentifié toutes les rubriques restreintes (ce qui inclus les sous rubriques, les articles, les brèves, les liens ...) seront [v1.0] invisibles à ce visiteur dans la partie publique.
  • pour un visiteur authentifié, seules les rubriques restreintes auxquelles il n’a pas accès (via son appartenance à un groupe ou son statut) seront invisibles.
  • pour les auteurs authentifié : idem les visiteurs pour la partie publique, Message obtenu lors de l'accès à une rubrique restreinte dans l'espace privéen revanche pour la partie privée, les rubriques à accès restreint sont (pour l’instant !) visibles mais non accessibles.
  • pour les administrateurs de rubriques ("admin restreint") : idem les auteurs SAUF pour les rubriques dont ils sont administrateurs. Pour ces rubriques, ils ont un accès dans la partie publique et la partie privée MEME s’ils n’appartiennent pas à un groupe autorisé à l’accès. Il paraissait en effet logique qu’un admin de rubrique ait forcément accès aux rubriques dont il à la gestion. Il peut également créer des groupes (ou utiliser des groupes existants) pour limiter l’accès aux rubriques qu’il administre et à leurs sous-rubriques. Il ne peut modifier que les groupes et sous-groupes qu’il a créé (= dont il est le "propriétaire").
  • pour les administrateurs généraux ("admin général"), idem les auteurs mais ils peuvent accéder au gestionnaire de groupes pour modifier n’importe quel groupe et donc s’ajouter aux utilisateurs autorisés. Un admin général peut ainsi visiter/modérer une rubrique à accès restreint MAIS il deviendra alors visible dans la liste des utilisateurs autorisés, ce qui permet au "propriétaire" d’une rubrique restreinte (admin restreint) de savoir que l’admin général s’est "invité" dans sa rubrique.

Concernant l’intégration des statuts dans un groupe :

l’idée est la suivante : TOUS les utilisateurs du statut sélectionné sont membres du groupe. Cela implique qu’ils ont donc TOUS accès aux rubriques réservés à ce groupe.

Par exemple si un admin choisit de faire un groupe "tous les admins restreints" dans lequel il intègre le statut "Administrateurs" et qu’il donne l’accès à ce groupe pour la rubrique "le coin des admins", on aura comme résultat que tous les admins du SPIP (restreints ou généraux) peuvent accéder à cette rubrique mais que ni les visiteurs ni les auteurs ne pourront la visiter. Mais si l’administrateur le souhaite, il peut également intégrer l’auteur Toto dans ce groupe afin de lui permettre d’accéder aussi à cette rubrique.

L’interface de gestion des groupes et des rubriques restreintes :

Interface d'administration

  • Pour rendre les chose plus faciles à apréhender (l’imbrication groupes/sous-groupe peut devenir complexe, les restrictions des rubriques multiples...), l’interface de gestion des groupes (exec=accesgroupes_admin) intègre :
    • l’affichage de la liste des groupes et des rubriques qu’ils contrôlent
    • l’arborescence des groupes/sous-groupes.
  • Configuration de l'accès restreint pour une rubrique Chaque rubrique à accès restreint peut être configurée pour que la restriction porte soit sur la partie privée, soit sur la partie publique, soit sur les 2 (privé + public). Il est possible (pour un admin général ou pour un admin de rubrique dans une rubrique qu’il administre) de configurer une restriction d’accès sur une sous-rubrique d’une rubrique elle-même déja restreinte. Néanmoins, le principe "d’héritage des restrictions" d’une rubrique sur ses sous-rubriques impose les règles suivantes :
    • rubrique parent restreinte "privé + public" => sous-rubrique restreinte obligatoirement "privé + public"
    • rubrique parent restreinte "privé" uniquement => sous-rubrique restreinte "privé" ou "privé + public"
    • rubrique parent restreinte "public" uniquement => sous-rubrique restreinte "public" ou "privé + public"
  • Un groupe dont l'admin restreint est "propriétaire" Les administrateurs de rubriques ne peuvent modifier QUE les groupes qu’ils ont eux-même créés (= propriétaires). Cela permet de rester cohérent avec le fonctionnement de l’administration des rubriques : ils ne peuvent interdire l’accès qu’a l’intérieur de leurs rubriques. Ils peuvent utiliser des groupes créés par d’autres admins mais ne peuvent les modifier.
  • Changer de propriétaire un groupe[v1.0] Pour simplifier la vie des admins de rubriques, un admin général peut créer un groupe, lui attribuer des rubriques en accès restreint puis transférer la "propriété" de ce groupe à un admin de rubrique : celui-ci pourra alors gérer ce groupe comme s’il l’avait créé lui même.
  • JPEG - 13.7 ko
    Configurer la possibilité d’une demande d’intégration au groupe

Chaque groupe peut être configuré pour permettre aux utilisateurs n’ayant pas le droit d’accès à une rubrique d’envoyer un message au propriétaire du groupe demandant leur intégration dans celui-ci. Cette situation va se rencontrer principalement dans l’espace privé (les rubriques restreintes étant visibles dans les listes de rubriques/sous-rubriques) mais également dans l’espace public pour un utilisateur qui suivrait un lien vers une rubrique protégée (si le squelette le prévoit, cf "Type de filtrage et squelette" ci-dessous). Le formulaire de demande d'inscription à un groupeCe paramètre permet d’afficher un formulaire de demande d’inscription dans le groupe lorsque l’utilisateur ne peut accéder à une rubrique. Ce message sera consultable par le propriétaire du groupe (si c’est un admin de rubrique) ou par n’importe quel admin général (si le groupe est créé par un admin général) dans la messagerie de l’interface privée, il comporte un lien direct vers l’interface de gestion du groupe concerné. Un auteur ayant demandé à être intégré à un groupe Les auteurs en attente d’intégration sont listés dans cette interface et peuvent être intégrés ou rejetés en un clic.
[v1.0] Lorsque le propriétaire du groupe aura rejeté ou accepté la demande d’inscription de l’auteur, le message de demande sera automatiquement effacé.

Type de filtrage et squelette :

[v1.0] Etant donné que ce plugin filtre directement les BOUCLES qui génèrent le contenu de l’espace public rendant invisibles celles qui sont restreintes pour un utilisateur non-authentifié, vous avez le choix entre 2 types de filtrages :

  • Un filtrage fort : pas d’indication qu’un contenu existe mais qu’il n’est pas accessible (page 404 si un utilisateur non-autorisé essaye d’accéder directement au contenu d’une rubrique restreinte, par ex en suivant un lien ou un signet de son bookmark). Si vous ne souhaitez pas modifier votre squelette, c’est cette solution qui sera retenue par défaut.

Pour rendre les choses plus ergonomiques, vous devriez donc avoir un lien ’S’identifier’ générique sur tout le site, qui permet aux personnes habilitées de se connecter pour accéder au contenu. Pour cela utilisez par exemple la balise #LOGIN_PUBLIC (cf cet article de spip-contrib pour plus d’infos).

  • Formulaire d'identificationUn filtrage avec information : si l’internaute essaye d’accéder au contenu d’une rubrique restreinte alors il se retrouve sur une page l’informant qu’il est nécessaire de s’identifier pour accéder au contenu. Si une fois connecté il ne fait pas partie des utilisateurs autorisés, alors il aura éventuellement le formulaire de demande d’intégration au groupe (selon la config du groupe, cf paragraphe précédent). formulaire de demande d'inscription (partie publique)Pour obtenir ce fonctionnement vous disposez des filtres "accesgroupes_article_restreint", "accesgroupes_rubrique_restreinte" et "accesgroupes_breve_restreinte" qui vous permettent d’intégrer dans vos squelettes des pages "article.html", "rubrique.html" ou "breve.html" le formulaire de #LOGIN_PUBLIC (si l’utilisateur n’est pas connecté) ou (selon config) le formulaire de demande d’accés.

Pour réaliser cette intégration dans ces pages, il vous suffit de rajouter aux BOUCLES principales de ces pages le code suivant (exemple pour la page article.html) :

  1.  
  2. <!-- fin du fichier = fin de la boucle générale de la page -- >
  3. </BOUCLE_article_principal>
  4.  
  5. <!-- code à rajouter -- >
  6. [(#ID_ARTICLE|accesgroupes_article_restreint|?{' ',''})<INCLURE{fond=inc_accesgroupes_login}{skel=#CHEMIN{inc_accesgroupes_login}}>]
  7.  
  8. <//B_article_principal>
  9.  

Comme le montre le code ci-dessus, vous ajoutez donc à la BOUCLE_article_principal (celle qui englobe TOUTE la page) une condition en cas de retour vide (cad en principe affichage de la page 404 : "page non trouvée") qui permet d’INCLURE le fichier inc_accesgroupes_login.html (situé à la racine du répertoire /plugins/acces_groupes) dans le cas où l’absence de page est due à une restriction d’accès et non pas à une page vraiment absente.

La page inc_accesgroupes_login.html livrée avec le plugin est (volontairement) dépouillée, ce qui vous laisse la possibilité de la "customiser" selon vos goûts et votre charte graphique.

Fonctionnement du plugin :

Les filtrages des parties publiques et privée reposent sur 2 principes différents (pour l(instant !) :

  • Pour la partie privée, peu de modifications par rapport aux versions précédentes de cette contrib : on vérifie dans les pages de gestion des articles (exec=articles et exec=articles_edit) , rubriques (exec=naviguer et exec=rubriques_edit) et breves (exec=breves_voir et exec=breves_edit) si l’élément dont on affiche la page id_article=xxx par ex) fait partie d’une rubrique à accès restreint (en fonction de l’id_auteur et de son appartenance aux groupes/statuts) et si c’est le cas on envoie le message de restriction d’accès : jusque là rien de bien compliqué...
  • [v1.0] Pour la partie publique les choses se compliquent puisqu’il faut gérer le cache... Et pour "rendre à César ce qui appartient à César" il me faut ici remercier Cedric Morin pour son système de filtrage mis au point pour le plugin "accès retreint" qui permet de surcharger directement les requêtes SQL des BOUCLES de spip. Cela permet donc d’exclure des résultats renvoyés par la base de données tous les éléments appartenant à une rubrique à laquelle l’utilisateur n’a pas accès (soit il n’est pas connecté, soit il ne fait pas partie d’un groupe autorisé). Ce code est bien évidemment adapté au fonctionnement par groupe (alors que le plugin "accès restreint fonctionne par zones) mais reste le même dans son principe de filtrage. Je cite donc textuellement l’explication donnée par l’inventeur de ce système cf doc du plugin Accès restreint :

"L’intérêt de cette démarche, c’est qu’elle fonctionne sur toutes les boucles, donc tout le site se trouve instantanément sécurisé sans aucune modification de squelette. Il n’y a pas de risque d’oublier un morceau.

Ce plugin nous garantie l’absence de fuite liée a de nouvelles fonctionnalités de SPIP (comme les modèles de 1.9.1 qui seraient une belle faille pour ceux qui sécuriseraient du contenu au moyen des squelettes).

Le principe même de fonctionnement du plugin acces-restreint est de ’supprimer’ du résultat des boucles tout ce que le visiteur n’a pas le droit de voir. Ainsi les zones à accès réservées sont invisibles pour qui n’y est pas habilité.

N’ayez donc aucune crainte en ce qui concerne les robots, les moteurs de recherche, ou les fichiers de backend. Le filtre est infaillible.

Ce principe de fonctionnement permet au plugin de filtrer le contenu publié sans modification du squelette. Cela permet aussi d’avoir des menus (liste de rubriques) cohérents avec le contenu effectivement accessible. Bref c’est un parti pris, qui fait son efficacité même."

Donc vous pouvez dormir sur vos deux oreilles : pas de fuites possibles !

Du point de vue du cache, pour minimiser son volume tout en obligeant le recalcul des pages selon les droits de l’utilisateur, (et en utilisant un principe toujours pompé sur le plugin accès restreint !), il sera créé un fichier de cache par combinaison de rubriques interdites : donc si un utilisateur affiche une page, celle-ci sera tirée du cache correspondant au groupe de rubriques auxquelles il a accès, ainsi là également, pas de risque d’indiscrétions.

Outils à disposition pour les squelettes :

[v1.0.2]Selon le type de site utilisant ce plugin il peut apparaître le besoin de vouloir afficher une liste intégrale des rubriques (ou articles, brèves) c’est à dire y compris les éléments à accès restreint qui sont normalement invisibles. La version [1.0.2] intègre donc le critère tout_voir qui permet de réaliser cela [2].

JPEG - 2.8 ko
Résultat du filtre "accesgroupes_visualise"

De façon complémentaire, si on utilise ce critère il est utile de pouvoir "marquer" par une icone les titres des éléments à accès restreints : le filtre |accesgroupes_visualise, utilisable sur les #BALISEs des boucles ARTICLES, RUBRIQUES ou BREVES, permet d’ajouter une icone (par défaut cadenas-24.gif) devant la balise si l’élément fait partie d’une rubrique à accès restreint.

Exemple typique d’utilisation de ce critère et du filtre : modification du fichier inc-rubriques.html qui fait le menu latéral des rubrique de la dist :

  1.  
  2. <B_rubriques>
  3. <div class="rubriques">
  4.    <h2 class="menu-titre"><:rubriques:></h2>
  5.    <ul>
  6.      <BOUCLE_rubriques(RUBRIQUES) {racine} {par num titre, titre}{tout_voir}>
  7.      <li>
  8.        <a href="#URL_RUBRIQUE"[ class="(#EXPOSE)"]>[(#TITRE|couper{80}|accesgroupes_visualise{#ID_RUBRIQUE})]</a>
  9.        <B_sous_rubriques>
  10.           <ul>
  11.             <BOUCLE_sous_rubriques(RUBRIQUES) {id_parent} {par num titre, titre}{tout_voir}>
  12.             <BOUCLE_test_expose(RUBRIQUES) {id_enfant}{tout_voir}>#EXPOSE{' '}</BOUCLE_test_expose_total>
  13.             <li><a href="#URL_RUBRIQUE"[ class="(#EXPOSE)"]>[(#TITRE|couper{80}|accesgroupes_visualise{#ID_RUBRIQUE})]</a>
  14.               <BOUCLE_re(BOUCLE_sous_rubriques){tout_voir}></BOUCLE_re>
  15.             </li>
  16.             </B_test_expose>
  17.             </BOUCLE_sous_rubriques>
  18.           </ul>
  19.        </B_sous_rubriques>
  20.      </li>
  21.      </BOUCLE_rubriques>
  22.    </ul>
  23. </div>
  24. </B_rubriques>
  25.  

Remarque : le paramètre #ID_RUBRIQUE du filtre accesgroupes_visualise est obligatoire !

Si l’image (cadenas) utilisée ne vous plait pas, ce filtre vous offre la possibilité de choisir un autre fichier image en passant le nom de ce fichier en second paramètre du filtre. Exemple pour utiliser le fichier cadenas-petit.png placée dans le répertoire /img de votre dossier de squelette :

  1.  
  2. [(#TITRE|couper{80}|accesgroupes_visualise{#ID_RUBRIQUE, #CHEMIN{img/cadenas-petit.png}})]
  3.  

Ce qu’il reste à faire :

  • Ainsi que je le mentionne par 2 fois plus haut, l’idée pour la suite des développements est de réaliser un filtrage complet de l’espace privé afin que, comme pour l’espace public, un utilisateur ne voit que les rubriques auxquelles il à accès. Cela concernerait donc la liste des rubriques affichées dans la page d’accueil de /ecrire, les sous-rubriques affichées dans /exec=naviguer, les rubriques et articles affichés dans /exec=articles_tous, le navigateur rapide de rubriques du bandeau et surtout le mini-navigateur ajax de choix de la rubrique lors de la création d’un article ou d’une sous-rubrique (afin d’empécher un auteur de créer un article dans une rubrique à laquelle il n’a pas accès, ce qui, dans cette version, l’empèche ensuite d’y accéder dès qu’il l’a enregistré une fois).
  • comme suggéré dans ce message du forum, la prochaine version devrait intégrer des groupes basés sur l’adresse IP du poste connecté (groupe = plages d’adresses IP)
    Cela permettra de gérer des restrictions d’accès différents selon que l’accès au spip se fait depuis l’intranet ou internet ou selon le sous-réseaux de l’intranet etc...

Pour cette partie, soyez patients : on y travaille !

  • comme suggéré par le forum public de la version précédente de cette contrib on pourrait aussi imaginer :
    • que les restrictions d’accès puissent s’appliquer au niveau des articles (et pas seulement au niveau des rubriques)
    • que les groupes puissent êtres récupérés à partir d’un LDAP

Pour ces 2 points, on y travaille PAS mais toutes les bonnes volontées sont les bienvenues... et comme pour beaucoup d’autres plugins, afin de faciliter le developpement collaboratif, vous trouverez l’ensemble des fichiers en cours sur le SVN de spip-zone !

  • et, bien sûr, toutes les traductions du fichier de langue sont également les bienvenues (le fichier accesgroupes_en.php livré avec cette version est super incomplet...)

P.-S.

Historique des versions :

  • V0.1 - 16 juillet 2005
    version initiale avec gestion multilingue
  • v0.2 - 02 août 2005
    maj pour compatibilité avec MySQL 3.23 la table jpk_auteurs_groupes devient jpk_groupes_auteurs correction affichage des titres de rubriques typo()
  • v0.3 - 07 août 2005
    Ajout d’un bouton pour la suppression d’un groupe inactif Correction du test d’accès, utilisation du login au lieu de l’id_auteur
  • v0.4 - non diffusée
  • v0.5 - publiée avec un exemple de protection des articles dans l’espace /ecrire/ Attention, les fichiers ont été renommés !!!
  • v0.61 - intégration des sous-groupes et des status comme membres possibles des groupes, installateur automatique des tables dans la base de donnée de spip, préfixage des tables jpk_, "explorateurs" de groupes dans l’interface de gestion.
  • v0.7 : version finalisée pour SPIP < 1.9. Correction du bogue de la modification / suppression d’un groupe, possibilité de séparation privé / public, possibilité de demande d’inscription dans un groupe par formulaire. Passage en BOUCLE de la restriction de l’espace public + filtre + critère pour configurer les squelettes.
  • v 1.0 : passage en plugin pour spip 1.9
    Filtrage des éléments à accès restreint directement dans les requètes SQL des boucles par surcharge des fonctions du core. Gestion du cache en fonction des combinaisons de rubriques restreintes pour éviter les mauvaises surprises. Possibilité de modifier le propriétaire d’un groupe par les admins généraux. Amélioration du traitement des messages de demande d’accès. Marquage des groupes désactivés dans l’interface admin.
  • v 1.0.1 : filtrage des articles en mode "révision" (?exec=articles_versions)
  • v 1.0.2 : implémentation du critère tout_voir et du filtre accesgroupes_visualise

Notes

[1] NB : c’est la dernière fois que je fais l’effort d’assurer la compatibilité avec les versions de cette contrib pour les spip 1.8 !

[2] tout_voir est lui aussi un dérivé du plugin acces_restreint : encore une fois, merci Cedric !


Répondre à cet article

  • Bonjour,

    Comment faire pour que les articles en zone à accès restreint par groupe ne se retrouvent pas dans la liste des nouveautés du site gérée par SPIP et envoyée régulièrement ?

    J’utilise le plug in avec beespip. L’utilisation du mot clef "exclu actualité" ne résoud pas le problème. Un paliatif consiste à changer la date de l’article (l’année par exemple) mais cela n’est pas très propre...

    Répondre à ce message

    • De quelle liste des nouveautés parles-tu ? De la liste des derniers articles publiés lorsque tu as l’option "Annonce des nouveautés" activée dans la page "Interactivité" de la configuration du site ?
      Si c’est le cas, cette fonctionnalité n’est effectivement pas prise en compte dans le fonctionnement du plugin.

      Alors soit tu code l’ajout de cette fontionnalité, soit tu continue à bidouiller avec les dates : la zone est ouverte à tous, c’est toi qui choisit la solution que tu préfère !

      Répondre à ce message

    Retour au début des forums

  • Développement de l’accès restreint aux articles

    12 mai 2008 18:25, par Aurélien

    Bonsoir,

    Je viens d’installer ce super plugin qui me sera très utile et je salue le développement qui as dut être bien complexe.

    J’ai vu dans votre roadmap que vous ne travaillez pas sur la restriction niveau articles, hors cela m’intéresse énormément, je voudrais savoir si vous l’avez intégrer dans votre développement futur ou si ce n’était toujours pas d’actualité et si c’est le cas est ce difficile de le mettre en oeuvre ?

    Je veux bien m’en occuper mais n’ayant qu’une connaissance limitée du PHP, de MySQL mais surtout du système SPIP (encore un peu flou pour ma part) j’ai peur de ne pas y arriver si cela est trop complexe !

    Merci d’avance.

    Répondre à ce message

    • Développement de l’accès restreint aux articles 13 mai 2008 01:52, par cy_altern

      Pour l’instant on en est pas du tout là : voir le point sur la situation fait dans ce forum : http://www.spip-contrib.net/Acces-r....
      Le problème est que si tu bosse sur la version actuelle, il y a tellement de truc qui vont changer que ça risque d’être à refaire...

      Ceci dit, si tu es malgré tout motivé, la zone est ouverte à tous : si tu fais une version qui intègre cette fonctionnalité sans régression des autres, ça sera toujours un point de départ pour l’intégrer dans la fusion accès_restreint/accès_groupes.

      Répondre à ce message

      • Développement de l’accès restreint aux articles 13 mai 2008 17:08, par aurelien

        Merci de ta réponse.

        Je vais essayer de m’y coller car j’en ai vraiment besoin, et j’ai pas envie de faire un fouillis impossible à créer des rubriques pour chaque article que je veux protéger.

        Allez soyons fou je vais tenter de mettre les mains dans le cambouis...

         ;)

        Répondre à ce message

    Retour au début des forums

  • Je n’arrive pas à supprimer un sous-groupes inclus dans un groupe. quand je clique sur "Retirer le sous-groupe", J’ai message "Vous devez choisir un groupe".

    Je suis sous SPIP 192 est acces rectreint par groupe 103. Merci de votre aide

    Kos

    Répondre à ce message

    • OK, c’était un micro-bogue dans l’URL du lien de suppression. Corrigé par la version 1.0.31.
      si tu veux éviter de mettre à jour tout le plugin, il te suffit de mettre à jour uniquement les fichiers plugin.xml et /exec/accesgroupes_admin.php

      Merci pour la remontée de bogue !

      Répondre à ce message

    Retour au début des forums

  • bonjour Voici mon problème Il y a des rubriques dans le portail. Dès lors qu’on s’authentifie, on a accès à certains rubriques et pas à d’autres. Le problème est que malgré les bonnes declarations, les nouveaux users ne voient pas une rubrique. Donc à comparer leur profil avec ceux qui ont bien accès, je me suis rendu compte qu’il y a un champ ( attribut) ldap qui leur manquait. Si je leur ajoute cette dernière, ils ont accès à la rubrique. Mais le problème, c’est que mon responsable ne veut plus de ce champ car il ne doit plus exister. Donc je deduis donc qu’il y forcement un test sur ce champ. Moi je souhaiterais orienter le test sur un autre champ. Je crois que mon prédécesseur à supprimer le champ dans le formulaire de déclaration des users sans modifier son code.

    Pouvez vous m’aider ??

    Merci d’avance

    Répondre à ce message

    • [Urgent] Aide - Le plugin accés restreint par groupes 29 avril 2008 12:12, par cy_altern

      de ce que je comprend de ta "description" du problème (qui reste assez incomplète/peu claire), il semblerait que ton système de contrôle d’accès ne soit pas basé sur ce plugin, ou sur une version modifiée pour gérer LDAP.
      Peux tu vérifier dans le gestionnaire de plugins de ton spip (.../ecrire/ ?exec=admin_plugin) que le plugin accès_groupes est installé et activé ?
      Si oui, précise l’organisation des groupes et des rubriques qu’ils contrôlent pour qu’on ait plus d’infos sur la nature du problème.

      Répondre à ce message

      • Bonjour, Merci de me repondre. Je confirme que le plugin est bien installé et activé. Dans la partie rubrique gérées par les groupes de l’espace privé, j’ai Projet -> 3 espace equipe. et d’autres....

        La rubrique qui pose problème c’est " Espace equipe". Ma question : Comment permettre aux user de voir cette rubrique ???.

        Car auparavant mon responsable m’a dit que tout marchais bien. C’est à dire que les user declaré en tant qu’appartenant au groupe "TMA" inclut dans projet doivent voir la rubrique "espace equipe"

        Je reste à votre dispo pour apporter toutes autres précision

        Répondre à ce message

        • [Urgent] Aide - Le plugin accés restreint par groupes 29 avril 2008 16:58, par cy_altern

          il faut donc que tu vérifie :

          • que le sous-groupe "TMA" est bien inclut dans le groupe "Projet"
          • que le groupe "Projet" contrôle effectivement la rubrique "Espace équipe"
          • que les utilisateurs qui doivent accéder à la rubrique "Espace équipe" sont bien tous inclus soit dans le groupe "TMA" soit dans le groupe "Projet"

          Si ces vérifications sont OK, il te faut savoir aussi que lorsque tu viens d’ajouter des utilisateurs à un groupe, les modifications d’affichage pour leur compte nécessitent que les pages soient recalculées (sinon, spip te sert les pages du cache c’est à dire avant que les modifications aient été faites...).
          Un moyen simple pour vérifier que ce n’est pas ce problème que tu rencontre consiste à vider le cache via l’interface d’administration chaque fois que tu as modifié les groupes.

          Enfin si le problème persiste et qu’il est résolu via une modification du LDAP cela veut dire que tu as une version "bidouillée" de ce plugin pour assurer le support du LDAP et dans ce cas je ne peux rien pour toi (si ce n’est te demander de m’envoyer ta version pour une éventuelle intégration de cette fonctionnalité dans une prochaine version du plugin...)

          Répondre à ce message

          • Bonjour,

            *) Dans la partie privée : "Arborescence des sous groupes", j’ai bien le groupe TMA et le groupe projet. Pour le groupe projet, j’ai bien le Groupe TMA qui y appartient.

            *) Dans "Rubrique gérées par groupes", "Espace equipe" appartient bien au groupe "projet " et j’ai "Management" qui appartient à "TMA". Or "Management" est la première sous rubrique de la rubrique "Espace equipe" Est ce normal ???

            *) C’est dans le formulaire d’ajout de nouvel user qu’on sélectionne l’entité dans laquelle appartient l’user. Apparement, autrefois, en plus de sélectionner l’entité auquel appartient l’user, il y avait un champ "pôle". Si la valeur est "TMA", alors l’user à accès à la rubrique "espace equipe". une fois le formulaire validé, il ecrit dans la base ldap et dans les tables spip

            Mon prédécesseur à supprimer ce champ car il y a une certaine redondance de l’information. je m’explique : Certaines entités auxquels appartient un user sont tous inclus dans TMA. Il a donc supprimé le champ "pole" dans le formulaire et a oublié de mettre à jour son programme. D’où quand on déclare les users il ne voient pas la rubrique "espace equipe" malgré leur appartenance aux bonnes entités.

            Comment puis procéder pour corriger ???

            Merci d’avance pour votre aide

            Répondre à ce message

            • *) Dans "Rubrique gérées par groupes", "Espace equipe" appartient bien au groupe "projet " et j’ai "Management" qui appartient à "TMA". Or "Management" est la première sous rubrique de la rubrique "Espace equipe" Est ce normal ???

              C’est possible, "normal" ça dépend de ce que tu veux avoir comme niveaux d’accès aux rubriques. Cette configuration groupes/rubriques signifie que :

              • tous les utilisateurs de TMA ont accès à l’ensemble de la rubrique "Espace equipe" y compris la rubrique "Management"
              • les membres du groupe "Projet" ont accès à la rubrique "Espace équipe" mais pas à la sous-rubrique "Management".

              C’est dans le formulaire d’ajout de nouvel user qu’on sélectionne l’entité dans laquelle appartient l’user. Apparement, autrefois, en plus de sélectionner l’entité auquel appartient l’user, il y avait un champ "pôle".

              Ce plugin n’a jamais eu de champ "pôle" : ta version est "bidouillé" => sur cette fonctionnalité, tu dois te débrouiller avec l’auteur de la bidouille...

              Si la valeur est "TMA", alors l’user à accès à la rubrique "espace equipe"

              Ca c’est obligatoirement le cas vu ton architecture : tout utilisateur du groupe "TMA" fait partie du groupe "Projet" (puisque "TMA" est inclu dans "Projet") et à accès à l’ensemble de la rubrique "Espace équipe".

              une fois le formulaire validé, il ecrit dans la base ldap et dans les tables spip

              Non, ce plugin n’a jamais proposé de fonctionnalité de modification de LDAP... Idem : si ta version le propose, tu dois te débrouiller avec l’auteur de cette "bidouille" (et par la même occasion lui demander si il ne veut pas la proposer sur spip-zone que d’autres puissent en profiter...)

              Répondre à ce message

    Retour au début des forums

  • Mauvaise compréhension ou bug ?

    27 novembre 2007 11:43, par eniope

    Bonsoir, Je vous décrit ce qui m’arrive avec ce plugin et un spip 192b avec lequel je fais des tests pour développer un site communautaire.

    J’ai une rubrique secteur qui a 6 rubriques enfants. La rubrique parent(secteur) et donc les 6 enfants sont en accès restreint, par héritage, par un groupe composé d’un administrateur. L’une des 6 enfants est en accès restreint par un groupe composé d’un rédacteur. Celui ci, lors de la rédaction d’article, ne peut pas choisir de rubrique dans laquelle mettre l’article car le champ destiné à cela est totalement vide. Pas même la rubrique que son groupe contrôle. Après, lors de l’enregistrement, on sort de l’administration et on est renvoyé à la page d’accueil.

    Est ce un bug ou simplement une mauvaise utilisation de ma part du plugin ?

    merci d’avance pour vos retours !

    Répondre à ce message

    • Mauvaise compréhension ou bug ? 30 mars 2008 11:29

      Bonjour, j’ai aussi le même type de problème ( c.a.d. qu’un rédacteur pourtant déclaré dans un groupe ne peut pas rédiger un article car le nom de la rubrique, sous "Nouvel Article", dans laquelle il est autorisé à rédiger n’apparaît pas ) mais uniquement chez mon hébergeur (Free) car en local ça marche très bien !?!?!?

      Please help me :)

      Répondre à ce message

    Retour au début des forums

  • problèmes constatés avec acces_groupe

    29 février 2008 09:33, par cy_altern

    pour éviter de doublonner, voir ce forum concernant les problèmes actuels de acces_groupe et ses développements futurs

    Répondre à ce message

    Retour au début des forums

  • Le plugin accés restreint par groupes

    7 janvier 2008 17:00, par François Daniel Giezendanner

    Ce plugin est génial mais nous avons malheureusement constaté que dans certaines circonstances il se révèle trop lent !

    Dans un premier temps nous avions privilégié le plugin « Accès Restreints par groupes » par rapport au plugin « Accès Restreints ». Malheureusement, dans un site où nous avons défini de nombreux rédacteurs, administrateurs et visiteurs ainsi que de nombreux espaces restreints, le site est devenu extrêmement lent, au point de devenir inutilisable. Après moult essais, nous avons identifié que le plugin « Accès Restreints par groupes » était la cause de cette lenteur.

    Nous avons alors été obligé de l’abandonner et d’adopter le plugin « Accès Restreints » avec lequel nous n’observons pas de ralentissement du site.

    C’est fort dommage car ce plugin nous plaisait beaucoup !

    Meilleurs messages

    FDG

    Répondre à ce message

    • Le plugin accés restreint par groupes 27 janvier 2008 22:20, par Laurent

      Bonjour, Notre site pour un établissement scolaire (en cours de test en conditions réelles) utilise aussi le super plugin "accès restreints par groupes"qui correspond exactement à nos besoins. Il regroupe une centaine d’auteurs et environ 1300 visiteurs et montre lui aussi des gros problèmes de lenteurs. A la lecture de votre message il semblerait logique que ce plugin soit la cause des ralentissements mais comment en être sûr ? Et pensez-vous qu’il y a un moyen de réduire sensiblement ces ralentissements ?

      stlouis-stemrie.fr

      Répondre à ce message

      • Le plugin accés restreint par groupes 28 janvier 2008 17:57, par François Daniel Giezendanner

        Bonjour,

        Il suffit de "débrancher le plugin "Accès restreints par groupes" et d’essayer le site sans restriction d’accès, il devrait soudainement aller beaucoup plus vite (auparavant, prenez la précaution de sauver votre base de données !). Vous pouvez ensuite rebrancher le plugin et retrouver la lenteur qu’il impose.

        Pour suppléer à ce défaut, utilisez le plugin "Accès restreints" et créez des login / mot-de-passe génériques.

        Meilleurs messages

        FDG

        Répondre à ce message

    Retour au début des forums

  • Bonjour. Dans l’introduction, l’avertissement indique que ce plug-in n’est pas compatible avec Spip 1.9.2. Or, je vois de nombreux messages de personnes l’ayant installé sous SPIP 1.9.2. Cela signifie-t-il qu’il est désormais compatible ? Je suis toujours en 1.9.1 et je comptais mettre à jour ma version de SPIP. J’aimerais donc savoir si cela risque d’être source de problèmes. Bien cordialement, Patrick

    Répondre à ce message

    Retour au début des forums

  • Un grand grand grand merci ;; ;

    20 décembre 2007 22:52, par gigi

    Nom d’une pipe, ce login est génial, j’ai un site compliqué à mettre en place, avec des tas de gens qui ont des droits restreints, croisés, limités, enfin, voyez le genre. Alors ce plugin, quel soulagement !

    Ceci étant, j’ai abusivement donné des droits aux administrateurs sur une rubrique que je veux réservée à un public choisi. Comment les virer, les administrateurs ? (dans "statuts inclus dans ce groupe). Il faut que je les rétrograde ? Vont pas être contents !

    S’il faut les rétrograder un par un, on le fera...

    Mais en tout cas, merci infiniment !

    Répondre à ce message

    Retour au début des forums

  • Message d’erreur...

    29 novembre 2007 17:53, par Christophe Danaux

    Bonjour,

    Je viens d’activer le plugin et quand je clique sur le bouton "Accès restreint par groupes" dans l’admin privée, j’ai une page blanche avec ce message

    Parse error: syntax error, unexpected ';' in /home/elevages/www/plugins/acces_groupes/exec/accesgroupes_admin.php on line 55

    Répondre à ce message

    • Pareil 30 novembre 2007 12:05

      idem même message help

      Répondre à ce message

    • Message d’erreur... 30 novembre 2007 15:12, par yjbenigni

      Hello

      il semblerait que les deux lignes (52 et 53) du fichier accesgroupes_admin.php :

      $string = preg_replace ...

      ont été abimées ...

      en regardant le site http://php.net (suite au message : correction d’un bug :)

      Le plugin accés restreint par groupes : affichage des auteurs 20 novembre 2007 14:02

      on remaque un assez grosse différence ..

      ex :

      $string = preg_replace( R &#x([0-9a-f]+) ; ei R, Rchr(hexdec( \\1 )) R, $string) ; $string = preg_replace( R &#([0-9]+) ; e R, Rchr( \\1 ) R, $string) ;

      or sur le site :

      $string = preg_replace(’ &#x([0-9a-f]+) ; ei’, ’chr(hexdec("\\1"))’, $string) ; $string = preg_replace(’ &#([0-9]+) ; e’, ’chr("\\1")’, $string) ;

      dans vi d’ailleur la colorisation syntaxique ne s’en sort pas ...

      aprés modification des deux lignes tout a l’air OK. A verifier par les pros de l’accés restreint, perso j’en suis qu’a l’install du plugin.

      page du site php.net :

      http://fr3.php.net/manual/fr/function.html-entity-decode.php

      Merci à tous pour votre boulot il est super.

      YJB

      Répondre à ce message

    • Message d’erreur... 30 novembre 2007 15:17, par yjbenigni

      Désolé pour les sauts de lignes ... fichier : accesgroupes_admin.php lignes 52 et 53

      remplacement de :

      $string = preg_replace( R &#x([0-9a-f]+) ; ei R, Rchr(hexdec( \\1 )) R, $string) ;

      $string = preg_replace( R &#([0-9]+) ; e R, Rchr( \\1 ) R, $string) ;

      par

      $string = preg_replace(’ &#x([0-9a-f]+) ; ei’, ’chr(hexdec("\\1"))’, $string) ;

      $string = preg_replace(’ &#([0-9]+) ; e’, ’chr("\\1")’, $string) ;

      voila c’est plus clair ...

      Répondre à ce message

      • ben non ça marche pas 3 décembre 2007 15:07, par a-lex

        bonjour les gens, j’ai bien corrigé ces deux lignes (52 53) comme le disait yjbenigni, mais çA ne veux pas fonctionner, je reste avec ce message d’erreur :

        Parse error : syntax error, unexpected ’ ;’ in /home/www/8e3557253356b2d42280d58ca189ae77/web/plugins/acces_groupes/e xec/accesgroupes_admin.php on line 55

        bref, si quelqu’un a la réponse

        Répondre à ce message

    Retour au début des forums

0 | 25 | 50 | 75 | 100 | 125 | 150 | 175 | 200 |...