当前位置: 首页>>代码示例>>PHP>>正文


PHP ACL::isAllowed方法代码示例

本文整理汇总了PHP中ACL::isAllowed方法的典型用法代码示例。如果您正苦于以下问题:PHP ACL::isAllowed方法的具体用法?PHP ACL::isAllowed怎么用?PHP ACL::isAllowed使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ACL的用法示例。


在下文中一共展示了ACL::isAllowed方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: checkAcl

 /**
  * @param MvcEvent $e
  */
 public function checkAcl(MvcEvent $e)
 {
     $route = $e->getRouteMatch();
     $controller = $route->getParam('controller');
     $action = $route->getParam('action');
     if (!$this->acl->isAllowed($controller, $action)) {
         $url = $e->getRouter()->assemble(array('controller' => 'index', 'action' => 'non-autorise'), array('name' => 'accueil'));
         /** @var Response $response */
         $response = $e->getResponse();
         $response->getHeaders()->addHeaderLine('Location', $url);
         $response->setStatusCode(302);
         $response->sendHeaders();
     }
 }
开发者ID:baptcomet,项目名称:weprono,代码行数:17,代码来源:Module.php

示例2: authenticate

 static function authenticate($resource = '', $permissions = '')
 {
     $ci =& get_instance();
     $ci->form_validation->set_rules('token', 'token', 'required');
     $validated = $ci->form_validation->run();
     if ($validated) {
         $token = $ci->input->post('token');
         $token = JWT::decode($token, $ci->config->item('jwt_key'));
         if ($token == false) {
             $output['status'] = false;
             $output['errors'] = '{"type": "unathenticated"}';
             if (array_key_exists('errors', $output)) {
                 $errors = explode("\n", $output['errors']);
                 foreach ($errors as $key => $error) {
                     $errors[$key] = json_decode($error);
                 }
                 $output['errors'] = $errors;
             }
             $ci->load->view('json', array('output' => $output));
         } else {
             $acl = new ACL();
             if (!empty($permissions) && !$acl->isAllowed($token->id, $resource, $permissions)) {
                 $token = false;
                 $output['status'] = false;
                 $output['errors'] = '{"type": "access"}';
                 if (array_key_exists('errors', $output)) {
                     $errors = explode("\n", $output['errors']);
                     foreach ($errors as $key => $error) {
                         $errors[$key] = json_decode($error);
                     }
                     $output['errors'] = $errors;
                 }
                 $ci->load->view('json', array('output' => $output));
                 return false;
             }
             return $token;
         }
     } else {
         $output['status'] = false;
         $output['errors'] = validation_errors();
         if (array_key_exists('errors', $output)) {
             $errors = explode("\n", $output['errors']);
             foreach ($errors as $key => $error) {
                 $errors[$key] = json_decode($error);
             }
             $output['errors'] = $errors;
         }
         $ci->load->view('json', array('output' => $output));
         return false;
     }
 }
开发者ID:ericariyanto,项目名称:angularjs-ci3,代码行数:51,代码来源:acl_helper.php


注:本文中的ACL::isAllowed方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。