• Jeder User im Forum verpflichtet sich zur Akzeptanz und zur Einhaltung dieser Regeln:
    1. Umgangston
      Ein angemessener höflicher Umgangston, ohne Beleidigungen, Beschimpfungen und aggressive Postings ist für jedes Mitglied Pflicht.
    2. Beiträge
      Jedes Mitglied sollte sich bemühen nur sinnvolle Beiträge zum Thema zu posten. Dabei ist unbedingt vorher zu prüfen, ob das Thema vorher schon einmal diskutiert wurde und daher fortgesetzt werden kann
      • Suchfunktion benutzen!
      • offizielle Doku lesen!
    3. Haftung
      Jeder Beitragsersteller übernimmt die alleinige Verantwortung seiner Inhalte.
    4. Werbung
      Wir erlauben keine Beiträge, Signaturen, Private Nachrichten oder eMails an Benutzer, die Werbung enthalten. Ausgenommen
      sind Stellengesuche /-angebote, welche ausschließlich im Forum "Stellengesuche" veröffentlicht werden dürfen.
    5. Verstöße
      Regelwidrige Beiträge sollten dem Team gemeldet werden. Nach deren Überprüfung werden wir schnellstmöglich
      entsprechend handeln.
    6. Authorität
      Den Anweisungen der Team-Mitglieder (Administratoren und Moderatoren) sind in diesem Forum Folge zu leisten.
      Bei Fragen oder Beschwerden bitte an diese wenden.
    Wir möchten Euch darauf aufmerksam machen, dass es bei Verstößen gegen einen oder mehreren der oben genannten
    Punkte dem Team frei steht entsprechend zu handeln. Dies kann z.B. das Löschen eines Beitrags, das Ausschliessen bzw.
    Sperren von Mitgliedern oder aber lediglich eine Verwarnung sein.

    In diesem Zusammenhang sollte erwähnt werden, dass das Forum automatisch die IP-Adresse jedes Beitrag-Erstellers
    speichert. Bei schweren Vergehen, behalten wir es uns vor, die IP-Adresse zur Strafverfolgung weiterzugeben.
  • Willkommen im Zend Framework Forum

    ZF1 Zend Framework 1 + ZF2 Zend Framework 2

    Das Zend Framework Forum ist seit 2006 die erste Anlaufstelle für Zend Framework Entwickler in Deutschland. Mit über 70.000 Beiträgen und einer steigenden Nutzerzahl bietet das Forum hilfreiche Themen und ZF-Tutorials für professionelle Entwickler, fortgeschrittene Programmierer sowie Zend Framework Einsteiger.
    Wenn dies Dein erster Besuch in der Zend Framework Community ist, lies bitte zuerst die Hilfe - FAQ durch. Du musst Dich registrieren, bevor Du Beiträge verfassen kannst. Klicke oben auf 'Registrieren', um die Registrierung zu starten. Du kannst auch jetzt schon Beiträge lesen. Hier im Forum findest Du die Zend Framework Hilfe, die Du suchst!

    Grüße an alle Zend Framework Entwickler. Das Team vom Zend Framework Forum!

    Drupal Agentur

ACL für Navigation funktioniert bei bestimmter Rolle nicht

KnechtRootRecht

New member
Ich habe ein ganz komisches Problem, und zwar funktioniert die ACL für die Navigation bei einer bestimmten Rolle nicht.
Ich hab mir eine ganz simple ACL gebastelt, welche nur immer eine Rolle haben kann, die Rolle des angemeldeten Users.
Das funktioniert soweit auch perfekt, bei allen anderen Rollen, nur eben bei einer nicht. Dort werden mit keine Haupt/Untermenüpunkte sowie auch keine Breadcrumbs angezeigt.

PHP:
$oAcl = Zend_Registry::get('Acl');
$sRequestController = $oRequest->getControllerName();
$sRequestAction = $oRequest->getActionName();
       
if (!$oAcl->has($sRequestController)) {
    $oAcl->addResource(new Zend_Acl_Resource($sRequestController));
}

$oAcl->addRole(new Zend_Acl_Role($oRoleModel->getLabel()));

$aAllowed = array_merge_recursive($aAllowed, $aAllowedHiddenResources);
foreach ($aAllowed as $sController => $aPrivileges) {

     if (!$oAcl->has($sController)) {
         $oAcl->addResource(new Zend_Acl_Resource($sController));
     }
     $oAcl->allow($oRoleModel->getLabel(), $sController, $aPrivileges);
}

Zend_View_Helper_Navigation_HelperAbstract::setDefaultAcl($oAcl);
Zend_View_Helper_Navigation_HelperAbstract::setDefaultRole($oRoleModel->getLabel());
$aAllowed ist mit folgendem Befüllt:
Code:
Array
(
    [mobilebasedata] => Array
        (
            [0] => index
            [1] => mobilecards
            [2] => carduser
            [3] => devices
            [4] => tariff
            [5] => contract
        )

    [config] => Array
        (
            [0] => index
        )

    [usermanagement] => Array
        (
            [0] => index
            [1] => edit
        )

    [auth] => Array
        (
            [0] => login
            [1] => logout
            [2] => auth
            [3] => removeghost
        )

    [index] => Array
        (
            [0] => removeghost
            [1] => index
        )

    [invoice] => Array
        (
            [0] => itemizedbill
        )

    [error] => Array
        (
            [0] => noauth
            [1] => noparam
            [2] => noresource
            [3] => error
        )

    [adminlandline] => Array
        (
            [0] => options
        )

)
also für jeden Array-Key eine Resource und deren SubArray asl Privilegien.
Wie gesagt es funktioniert nur bei einer Rolle nicht, bei allen anderen schon. Es werden mir keine Navigationspunkte angezeigt.
Wenn ich aber per URL auf einen Kontroller navigiere, dann wird mir der Zugang verwehrt, was auch richtig ist. Warum zeigt mir dann die Naviagation gar keine Menüs an wenn ich aber doch explizit erlaube welchen Kontroller/Action der User sehen darf.
Das seltsame ist, bei allen anderen Rollen funktionert es. Die Rolle wird auch korrekt übergeben, Resourcen werden korrekt ins ACL eingetragen.
 
Zuletzt bearbeitet:

KnechtRootRecht

New member
So ich hab jetzt mal mein Navigationsplugin auf "routeStartup" und das ACL-Plugin auf PostDispatch.
jetzt wird mir der letzte Key aus dem Allowed-Array angezeigt im Menü, im Submenü werden die Punkte aufgelistet welche man als Privilegien auch sehen darf.

ICh kann auch per URL auf andere Kontroller zugreifen, dort werden mir auch die Submenüpunkte angezeigt, nur nicht die Hauptnavi.
Ist das ein Bug in dem View-Helper??

Im ACL-Object ist auch alles so wie es sein soll, kanns leider nicht anhängen da es zu groß ist.


Edit: was mit natürlich nicht aufgefallen ist, das der Parent des Menüpunktes nicht sichtbar war.... ganz klarer Fall von Fehler 40!

-- close --
 
Zuletzt bearbeitet:
Oben