/** * @abstract Metodo que fara a persistencia no banco */ public function salvar($grava_historico = true) { # Verifica se tem acesso a salvar //if($this->_login->temPermissao($_GET[ACAO],Sistema_Login::SALVAR)){ $temp = $this->_dados; # Verifica se utiliza chave # incremental pelo sistema if (isset($_POST['acaoform'])) { $alterar = $_POST['acaoform'] == "alterar" ? true : false; } else { $alterar = $this->_dados[$this->_chavepk] > 0 ? true : false; unset($temp[$this->_chavepk]); } if (!$this->_msg->temErro()) { # Verifica se tem valor para chave primaria # UPDATE if ($alterar) { unset($temp[$this->_chavepk]); foreach ($temp as $k => $v) { $sets[] = sprintf(" %s = %s ", $k, $v); } $set = implode(",", $sets); $sql = sprintf("UPDATE %s SET %s WHERE %s=%d", $this->_tabela, $set, $this->_chavepk, $this->_dados[$this->_chavepk]); $id = Sistema_Conecta::Execute($sql); if ($id > 0) { if ($grava_historico) { # Grava no Histórico $hist = new Sistema_Historico($_SESSION['ACT_ATUAL']); $hist->setHistorico(Sistema_Historico::$OP_ALTERAR, $this->_dados[$this->_chavepk], $this->_tabela); } $this->_msg->setSucesso("Dados alterados com sucesso"); return array("id" => array("campoid" => $this->_chavepk, "valorid" => $this->_dados[$this->_chavepk])); } else { $this->_msg->setErro("Não foi possível alterar os dados"); return null; } } else { # INSERT $temp1 = array_keys($temp); $campos = implode(",", $temp1); $valores = implode(",", $temp); $sql = sprintf("INSERT INTO %s (%s) VALUES (%s)", $this->_tabela, $campos, $valores); $id = Sistema_Conecta::Execute($sql); if ($id > 0) { if ($grava_historico) { # Grava no Histórico $hist = new Sistema_Historico($_SESSION['ACT_ATUAL']); $hist->setHistorico(Sistema_Historico::$OP_INSERIR, $id, $this->_tabela); } $this->_msg->setSucesso("Dados inseridos com sucesso"); return array("id" => array("campoid" => $this->_chavepk, "valorid" => $id)); } else { $this->_msg->setErro("Não foi possível inserir os dados"); return null; } } } //}else{ //$this->_msg->setErro("Você não tem permissão para alterar ou inserir neste formulário"); //} }
/** * @abstract Metodo que irá salvar as permissoes * @param $post * @return unknown_type */ public function salvar($post) { $arr_campos = array("prm_salvar" => 1, "prm_exibir" => 1, "prm_inativa" => 1); $dados = $this->trataDados($post); # Exclui todos os registros anteriores $del = sprintf("DELETE FROM permissoes WHERE grp_cod=%d", $dados['grp_cod']); if (Sistema_Conecta::Execute($del)) { if (is_array($dados['acoes'])) { # percorre cada acao foreach ($dados['acoes'] as $acao_cod => $vetor) { $temp_campos = $arr_campos; $obj = new Classe_Permissoes(); $ds['grp_cod'] = $dados['grp_cod']; $ds['acao_cod'] = $acao_cod; # percorre cada campo foreach ($vetor as $campo => $valor) { $ds[$campo] = $valor; unset($temp_campos[$campo]); } # cria os campos nao selecionados como false if (is_array($temp_campos)) { foreach ($temp_campos as $v => $vv) { $ds[$v] = 0; } } $obj->setDados($ds); $obj->salvar(false); unset($obj); } # Grava no Histórico $hist = new Sistema_Historico($_SESSION['ACT_ATUAL']); $hist->setHistorico(Sistema_Historico::$OP_ALTERAR, $dados['grp_cod'], 'permissoes'); } } }