예제 #1
0
 /**
  * @return array
  */
 protected function getAuthItemsFromApp()
 {
     $list = [];
     if (!is_dir($this->app->controllerPath)) {
         return $list;
     }
     $moduleAuthItemName = $this->className();
     foreach (FileHelper::findFiles($this->app->controllerPath, ['only' => ['*Controller.php']]) as $file) {
         $relativePath = basename($file);
         $controllerBaseClassName = substr($relativePath, 0, -4);
         // Removing .php
         $controllerName = substr($controllerBaseClassName, 0, -10);
         // Removing Controller
         $controllerClassName = ltrim($this->app->controllerNamespace . '\\' . $controllerBaseClassName);
         $ref = new \ReflectionClass($controllerClassName);
         if ($ref->isSubclassOf(Controller::class) || $ref->implementsInterface(AccessControlInterface::class)) {
             /** @var string $controllerClassName */
             $controllerAuthItemName = $controllerClassName;
             $controllerDescription = \Yii::t('admin/t', 'Access to the section "Application/{controller}"', ['controller' => $controllerName]);
             $controllerAuthItem = [$controllerAuthItemName => [$controllerDescription, Item::TYPE_PERMISSION, []]];
             $moduleAuthItem[$moduleAuthItemName][2][] = $controllerAuthItemName;
             $controllerInstance = $this->app->createControllerByID(Inflector::camel2id($controllerName));
             $actions = array_keys($controllerInstance->actions());
             $methods = $ref->getMethods(\ReflectionMethod::IS_PUBLIC);
             $actionsAuthItems = [];
             foreach (array_merge($actions, $methods) as $method) {
                 if (is_string($method)) {
                     $action = ucfirst($method);
                 } else {
                     /** @var \ReflectionMethod $method */
                     if (!preg_match('/^action([A-Z].*)$/', $method->getName(), $m)) {
                         continue;
                     }
                     $action = $m[1];
                 }
                 $actionAuthItemName = Rbac::operationName($controllerClassName, $action);
                 $actionDescription = \Yii::t('admin/t', 'Access to the action "Application/{controller}/{action}"', ['action' => $action, 'controller' => $controllerName]);
                 $actionsAuthItems[$actionAuthItemName] = [$actionDescription, Item::TYPE_PERMISSION, []];
                 $controllerAuthItem[$controllerAuthItemName][2][] = $actionAuthItemName;
             }
             $list = array_merge($list, $controllerAuthItem, $actionsAuthItems);
         }
     }
     return $list;
 }