コード例 #1
0
 /**
  * Método construtor que lê os acessos liberados para o usuário logado
  */
 public function __construct()
 {
     try {
         $definicoes = definicao::pegarDefinicao();
         $controleDeAcesso = $definicoes->xpath('//controleDeAcesso');
         $this->menuLiberado = isset($controleDeAcesso[0]) && strval($controleDeAcesso[0]['liberado']) == 'sim' ? true : false;
         if (!$this->menuLiberado) {
             $nUsuario = sessaoSistema::pegar('usuario');
             $nAcesso = new NAcesso();
             $this->acessosLiberados = array_flip($nAcesso->lerAcessosPorUsuario($nUsuario)->gerarVetorDeAtributo('nmAcesso'));
         }
         return true;
     } catch (erro $e) {
         return false;
     }
 }
コード例 #2
0
 /**
  * Método criado para efetuar a validação de acesso a um controle do sistema
  * @param string nome do controle acessado
  */
 public static function validarAcesso($controleAcessado)
 {
     try {
         $definicoes = definicao::pegarDefinicao();
         if (strval($definicoes->controleDeAcesso['liberado']) == 'sim') {
             return true;
         }
         switch (true) {
             case !sessaoSistema::tem('usuario'):
                 throw new erroAcesso('Acesso não permitido, usuário não registrado!');
             default:
                 $nUsuario = sessaoSistema::pegar('usuario');
                 $nUsuario->carregarPerfis();
                 $nAcesso = new NAcesso();
                 $colecao = $nAcesso->lerAcessosPorUsuario($nUsuario, $controleAcessado);
                 if (!$colecao->contarItens()) {
                     throw new erroAcesso('Acesso Não Permitido!');
                 }
         }
         return true;
     } catch (erro $e) {
         throw $e;
     }
 }