Verfeinern der ZugriffskontrollePräzise Zugangsbeschränkung
Die grundlegende ACL, wie sie im vorherigen
Kapitel definiert ist, zeigt wie verschiedene Rechte für die gesamte ACL (alle
Ressourcen) vergeben werden können. In der Praxis tendieren Zugangsbeschränkungen jedoch
eher dahin, Ausnahmen und verschiedene Stufen von Komplexität zu haben.
Zend_Acl erlaubt einem, diese Verfeinerungen auf einfache und
flexible Weise zu bewerkstelligen.
Für das Beispiel CMS wurde ermittelt, dass, während die 'staff' Gruppe die Bedürfnisse
der überwiegenden Mehrheit der Benutzer abdeckt, es den Bedarf für eine neue 'marketing'
Gruppe gibt, die Zugriff auf den Newsletter und die neuesten Nachrichten im CMS
benötigen. Die Gruppe ist ziemlich unabhängig und wird die Möglichkeit haben, sowohl
Newsletter als auch die neuesten Nachrichten zu veröffentlichen und zu archivieren.
Zusätzlich wurde angefordert, dass es der 'staff' Gruppe erlaubt sein soll, die
Nachrichten ansehen, aber nicht die neuesten Nachrichen überarbeiten zu können.
Letztendlich soll es für jeden (Administratoren eingeschlossen) unmöglich sein, irgend
eine Bekanntmachung zu archivieren, da diese sowieso nur eine Lebensdauer von 1 bis 2
Tagen haben.
Zuerst überarbeiten wir die Rollenregistrierung, um die Änderungen wider zu spiegeln.
Wir haben ermittelt, dass die 'marketing' Gruppe die selben grundlegenden Rechte wie
'staff' hat, also definieren wir 'marketing' so, dass die Genehmigungen von 'staff'
geerbt werden:
addRole(new Zend_Acl_Role('marketing'), 'staff');
]]>
Als nächstes ist zu beachten, dass sich die obige Zugangsbeschränkung auf bestimmte
Ressourcen bezieht (z.B. "newsletter", "lastest news", "announcement news"). Nun fügen
wir die Ressourcen hinzu:
add(new Zend_Acl_Resource('newsletter'));
// Nachrichten
$acl->add(new Zend_Acl_Resource('news'));
// Neueste Nachrichten
$acl->add(new Zend_Acl_Resource('latest'), 'news');
// Bekanntmachungen
$acl->add(new Zend_Acl_Resource('announcement'), 'news');
]]>
Nun ist es nur eine Frage der Definition für diese spezifischeren Regeln auf die
Zielbereiche der ACL:
allow('marketing',
array('newsletter', 'latest'),
array('publish', 'archive'));
// Staff (und Marketing durch die Vererbung), wird die Erlaubnis verweigert,
// die neuesten Nachrichten überarbeiten zu können
$acl->deny('staff', 'latest', 'revise');
// Jedem (inklusive der Administratoren) wird die Erlaubnis verweigert,
// Bekanntmachungsnachricht zu archivieren
$acl->deny(null, 'announcement', 'archive');
]]>
Wir können nun die ACL abfragen hinsichtlich der letzten Änderungen
isAllowed('staff', 'newsletter', 'publish') ?
"allowed" : "denied";
// verweigert
echo $acl->isAllowed('marketing', 'newsletter', 'publish') ?
"allowed" : "denied";
// erlaubt
echo $acl->isAllowed('staff', 'latest', 'publish') ?
"allowed" : "denied";
// verweigert
echo $acl->isAllowed('marketing', 'latest', 'publish') ?
"allowed" : "denied";
// erlaubt
echo $acl->isAllowed('marketing', 'latest', 'archive') ?
"allowed" : "denied";
// erlaubt
echo $acl->isAllowed('marketing', 'latest', 'revise') ?
"allowed" : "denied";
// verweigert
echo $acl->isAllowed('editor', 'announcement', 'archive') ?
"allowed" : "denied";
// verweigert
echo $acl->isAllowed('administrator', 'announcement', 'archive') ?
"allowed" : "denied";
// verweigert
]]>Zugangsbeschränkungen entfernen
Um eine oder mehrere Zugangsregel von der ACL zu entfernen, verwendet man einfach die
vorhandenen removeAllow() oder removeDeny() Methoden. Wie bei
allow() und deny() kann man den null Wert
übergeben, um die Anwendung auf alle Rollen, Ressourcen und / oder Rechte anzuzeigen:
removeDeny('staff', 'latest', 'revise');
echo $acl->isAllowed('marketing', 'latest', 'revise') ?
"allowed" : "denied";
// erlaubt
// Entferne die Erlaubnis für das Marketing, Newsletter veröffentlichen und
// archivieren zu können
$acl->removeAllow('marketing',
'newsletter',
array('publish', 'archive'));
echo $acl->isAllowed('marketing', 'newsletter', 'publish') ?
"allowed" : "denied";
// verweigert
echo $acl->isAllowed('marketing', 'newsletter', 'archive') ?
"allowed" : "denied";
// verweigert
]]>
Rechte können schrittweise wie oben angezeigt verändert werden, aber ein
null Wert für die Rechte überschreibt solche schrittweisen Änderungen:
allow('marketing', 'latest');
echo $acl->isAllowed('marketing', 'latest', 'publish') ?
"allowed" : "denied";
// erlaubt
echo $acl->isAllowed('marketing', 'latest', 'archive') ?
"allowed" : "denied";
// erlaubt
echo $acl->isAllowed('marketing', 'latest', 'anything') ?
"allowed" : "denied";
// erlaubt
]]>