]> git.llucax.com Git - mecon/samurai.git/blobdiff - lib/SAMURAI/Perfil.php
Funcionalidad terminada, salvo consultas. Solo falta ver bien si hay errores
[mecon/samurai.git] / lib / SAMURAI / Perfil.php
index a74a16fd8b8da7bdf6b5556f56b0f3d97c8edc6e..b5742f84a00b76ce33c0429502335a9b3df01f59 100644 (file)
@@ -26,8 +26,6 @@
 
 #require_once 'PEAR.php';
 
-
-
 // +X2C Class 208 :SAMURAI_Perfil
 /**
  * Clase para el manejo de los perfies.
@@ -313,10 +311,12 @@ class SAMURAI_Perfil {
     function _grabarDb() // ~X2C
     {
         //Obtengo el id del perfil de ser necesario
+        $nuevo = 0;
         if (!$this->getId()) { 
             //No existe el perfil. Lo cargo por primera vez.
             $idPerfil = $this->_db->nextId('perfil');
             $this->setId($idPerfil);       
+            $nuevo = 1;
         }        
        
         //GRABO EN PERM_PERFIL_SIST
@@ -326,7 +326,7 @@ class SAMURAI_Perfil {
         }
 
         //GRABO EN PERFIL
-        if (!$this->getId()) { 
+        if ($nuevo) { 
             $datos = array (
                         'id_perfil'   => $idPerfil,
                         'desc_perfil' => $this->getDescripcion(),
@@ -450,6 +450,7 @@ class SAMURAI_Perfil {
             //Reemplazo el filtro por ##?##
             $consulta = ereg_replace ('##FILTRO##', $filtro, $tmp2);
         }
+        $consulta.= $sql['obtener_id_perfiles4'];
         $dbh = $db->prepare($consulta);
         if ($id_sistema) { 
             $tmp[] = $id_sistema;
@@ -460,7 +461,7 @@ class SAMURAI_Perfil {
         }
         while ($re = $res->fetchrow(DB_FETCHMODE_ASSOC)) {
             array_push($rta,$re['id_perfil']);
-        }        
+        }
         $res->free();
         return $rta;
     }
@@ -585,11 +586,13 @@ class SAMURAI_Perfil {
         while ($re  = $res->fetchRow(DB_FETCHMODE_ASSOC)) {
             $perm[$re['id_perfil']][] = $re['id_permiso'].'##'.$re['observaciones'];
         }
-        foreach ($perm as $p) {
+        foreach ($perm as $key => $p) {
             $rta1 = array_diff($p, $this->getPermisos());
             $rta2 = array_diff($this->getPermisos(), $p);
             if (!$rta1 && !$rta2) {
-                return new PEAR_Error("Ya existe un perfil con esos mismos permisos");
+            echo 1;
+                $perf = new SAMURAI_Perfil($this->_db, $key);
+                return new PEAR_Error("El perfil \"".$perf->getDescripcion()."\" contiene los mismos permisos.");
             }
         }
 
@@ -626,4 +629,4 @@ class SAMURAI_Perfil {
 
 } // -X2C Class :SAMURAI_Perfil
 
-?>
+?>
\ No newline at end of file