]> git.llucax.com Git - mecon/samurai.git/blobdiff - sistema/www/perfiles/perfiles-abm.php
Consultas terminadas. Falta que sotton lo apruebe
[mecon/samurai.git] / sistema / www / perfiles / perfiles-abm.php
index 42dcacbd576eade8b130614555db4676ebcccc03..bb8d0bb289d27b99c209075c031a20a7372ee5c5 100644 (file)
@@ -19,6 +19,9 @@
 //
 // $Id$
 // 
 //
 // $Id$
 // 
+//VERIFICO SI SE TIENE ACCESO A LA PAGINA{{{
+$SAMURAI_PERM->chequear(SAMURAI_PERM_PERFIL_ALTA,SAMURAI_PERM_PERFIL_BAJA,SAMURAI_PERM_PERFIL_MODIF, SAMURAI_PERM_DEVELOPER);
+//}}}
 
 // REQUIRE_ONCE {{{
     require_once 'MECON/HTML/QuickForm.php';
 
 // REQUIRE_ONCE {{{
     require_once 'MECON/HTML/QuickForm.php';
@@ -27,6 +30,7 @@
     require_once 'SAMURAI/Perfil.php';
     require_once 'SAMURAI/Permiso.php';
     require_once 'SAMURAI/Sistema.php';
     require_once 'SAMURAI/Perfil.php';
     require_once 'SAMURAI/Permiso.php';
     require_once 'SAMURAI/Sistema.php';
+    require_once 'MECON/HTML/Image.php';
 // }}}
 //CREO LOS OBJETO NECESARIOS {{{
     if (@$_GET['id_perfil']) {
 // }}}
 //CREO LOS OBJETO NECESARIOS {{{
     if (@$_GET['id_perfil']) {
     }
     $FORM = new MECON_HTML_QuickForm ('perfiles_abm','post','perfiles-abm');
     $SISTEMA = new SAMURAI_Sistema ($DB, $_SESSION['samurai']['id_sistema']);
     }
     $FORM = new MECON_HTML_QuickForm ('perfiles_abm','post','perfiles-abm');
     $SISTEMA = new SAMURAI_Sistema ($DB, $_SESSION['samurai']['id_sistema']);
-    $PERFIL = new SAMURAI_Perfil ($DB, $id_perfil);
+    $PERFIL = new SAMURAI_Perfil ($DB, $id_perfil,
+            $_SESSION['samurai']['id_sistema']);
 
     if ($PERFIL->getResponsable()) {
         $responsable = $PERFIL->getResponsable();
     }
     else {
 
     if ($PERFIL->getResponsable()) {
         $responsable = $PERFIL->getResponsable();
     }
     else {
-        $responsable = $_SESSION['samurai']['login'];
+        $responsable = $_SESSION['usuario'];
     }
     
     if (!@$_GET['id_perfil']) {
     }
     
     if (!@$_GET['id_perfil']) {
     }
 // }}}
 //AGREGO LOS ELEMENTOS DEL FORM {{{
     }
 // }}}
 //AGREGO LOS ELEMENTOS DEL FORM {{{
-    $FORM->addElement ('header', 'cabecera', 'ABM Perfiles');
-    $FORM->addElement ('hidden', 'id_perfil', $id_perfil);
-    $FORM->addElement ('hidden', 'desc_ant'   , $descripcion);
-    $FORM->addElement ('static', 'desc_perfil', 'Descripcion', $descripcion);
-    $FORM->addElement ('select', 'permisos'   , 'Permisos'   , $PERMISOS, array('size' => '5', 'multiple' => 'true'));
-    $FORM->addElement ('select', 'tipo_perfil', 'Tipo Perfil', array('E' => 'Externo', 'I' => 'Interno', 'D' => 'Dios'), array ('size' => '1'));
-    $FORM->addElement ('hidden', 'responsable', $responsable);
-    $group[] = HTML_QuickForm::createElement('submit', 'aceptar' , 'Grabar');
-    $group[] = HTML_QuickForm::createElement('submit', 'cancelar', 'Cancelar', array ('onClick' => 'javascript:history.go(-1);return true;'));
-    $FORM->addGroup($group,'botones');
+    if (@$PERMISOS) {
+        $FORM->addElement ('header', 'cabecera', 'ABM Perfiles');
+        $FORM->addElement ('hidden', 'id_perfil', $id_perfil);
+        $FORM->addElement ('hidden', 'desc_ant'   , $descripcion);
+        $FORM->addElement ('static', 'desc_perfil', 'Descripcion', $descripcion);
+        $FORM->addElement ('select', 'permisos'   , 'Permisos'   , $PERMISOS, array('size' => '5', 'multiple' => 'true'));
+        if ($SAMURAI_PERM->tiene(SAMURAI_PERM_PERFIL_TIPO)) {
+            $FORM->addElement ('select', 'tipo_perfil', 'Tipo Perfil', array('E' => 'Externo', 'I' => 'Interno', 'D' => 'Dios'), array ('size' => '1'));
+        }
+        $FORM->addElement ('hidden', 'responsable', $responsable);
+        $group[] = HTML_QuickForm::createElement('submit', 'aceptar' , 'Grabar');
+        $group[] = HTML_QuickForm::createElement('submit', 'cancelar', 'Cancelar', array ('onClick' => 'javascript:window.location=\'perfiles\';return false;'));
+        $FORM->addGroup($group,'botones');
+    }
+    else {
+        $ERROR = new MECON_HTML_Error('El sistema no posee permisos asociados.');
+    }
 // }}}
 //AGREGO LAS REGLAS DE VALIDACION {{{
     $FORM->addRule ('permisos', 'Se debe seleccionar al menos un permiso', 'required');
 // }}}
 //CARGO LOS DATOS SI YA EXISTEN EN BASE {{{
 // }}}
 //AGREGO LAS REGLAS DE VALIDACION {{{
     $FORM->addRule ('permisos', 'Se debe seleccionar al menos un permiso', 'required');
 // }}}
 //CARGO LOS DATOS SI YA EXISTEN EN BASE {{{
-// TODO Terminar de armar la parte de modificacion y eliminacion
     if (isset($_GET['accion']) && $_GET['accion'] != '') {
         //MODIFICACION
         $id_perfil    =& $FORM->getElement  ('id_perfil'  );
         $desc_perfil  =& $FORM->getElement  ('desc_perfil');
         $permisos     =& $FORM->getElement  ('permisos'   );
     if (isset($_GET['accion']) && $_GET['accion'] != '') {
         //MODIFICACION
         $id_perfil    =& $FORM->getElement  ('id_perfil'  );
         $desc_perfil  =& $FORM->getElement  ('desc_perfil');
         $permisos     =& $FORM->getElement  ('permisos'   );
-        $tipo_perfil  =& $FORM->getElement  ('tipo_perfil');
+        
+        if ($SAMURAI_PERM->tiene(SAMURAI_PERM_PERFIL_TIPO)) {
+            $tipo_perfil  =& $FORM->getElement  ('tipo_perfil');
+        }
         $responsable  =& $FORM->getElement  ('responsable');
         $group        =& $FORM->getElement  ('botones'    );
         $group        =& $group->getElements('aceptar'    );
         $aceptar      =& $group[0];
 
         $permisos->setSelected($PERFIL->getPermisos());
         $responsable  =& $FORM->getElement  ('responsable');
         $group        =& $FORM->getElement  ('botones'    );
         $group        =& $group->getElements('aceptar'    );
         $aceptar      =& $group[0];
 
         $permisos->setSelected($PERFIL->getPermisos());
-        $tipo_perfil->setSelected($PERFIL->getTipo());
+        
+        if ($SAMURAI_PERM->tiene(SAMURAI_PERM_PERFIL_TIPO)) {
+            $tipo_perfil->setSelected($PERFIL->getTipo());
+        }
 
         if ($PERFIL->getResponsable() != '') {
             $responsable->setValue($PERFIL->getResponsable());
 
         if ($PERFIL->getResponsable() != '') {
             $responsable->setValue($PERFIL->getResponsable());
         //ELIMINACION -> modifico el valor del boton
         if ($_GET['accion'] == 'e') {
             $aceptar->setValue('Eliminar');
         //ELIMINACION -> modifico el valor del boton
         if ($_GET['accion'] == 'e') {
             $aceptar->setValue('Eliminar');
+            $aceptar->updateAttributes(array ('onClick' => 'javascript:if (confirm(\'¿Esta Seguro?\')) return true;return false;'));
             $FORM->freeze();
         }
     }
             $FORM->freeze();
         }
     }
             $id_perfil    =& $FORM->getElement  ('id_perfil'  );
             $desc_perfil  =& $FORM->getElement  ('desc_perfil');
             $permisos     =& $FORM->getElement  ('permisos'   );
             $id_perfil    =& $FORM->getElement  ('id_perfil'  );
             $desc_perfil  =& $FORM->getElement  ('desc_perfil');
             $permisos     =& $FORM->getElement  ('permisos'   );
-            $tipo_perfil  =& $FORM->getElement  ('tipo_perfil');
-            $tipo_perfil_tmp  =  $tipo_perfil->getSelected();
+            
+            if ($SAMURAI_PERM->tiene(SAMURAI_PERM_PERFIL_TIPO)) {
+                $tipo_perfil  =& $FORM->getElement  ('tipo_perfil');
+                $tipo_perfil_tmp  =  $tipo_perfil->getSelected();
+            }
             $responsable  =& $FORM->getElement  ('responsable');
             $group        =& $FORM->getElement  ('botones'    );
             $group        =& $group->getElements('aceptar'    );
             $responsable  =& $FORM->getElement  ('responsable');
             $group        =& $FORM->getElement  ('botones'    );
             $group        =& $group->getElements('aceptar'    );
             $PERFIL->setDescripcion($desc_perfil->_text     );
             $PERFIL->setResponsable($responsable->getValue());
             $PERFIL->setPermisos   ($permisos->getSelected()); //Le asigno al perfil los permisos seleccionados
             $PERFIL->setDescripcion($desc_perfil->_text     );
             $PERFIL->setResponsable($responsable->getValue());
             $PERFIL->setPermisos   ($permisos->getSelected()); //Le asigno al perfil los permisos seleccionados
-            $PERFIL->setTipo       ($tipo_perfil_tmp['0']   );
+            
+            if ($SAMURAI_PERM->tiene(SAMURAI_PERM_PERFIL_TIPO)) {
+                $PERFIL->setTipo       ($tipo_perfil_tmp['0']   );
+            }
             
             //Grabo y verifico si se produjo algun error
             $res = $PERFIL->guardarDatos($aceptar->getValue());
             
             //Grabo y verifico si se produjo algun error
             $res = $PERFIL->guardarDatos($aceptar->getValue());
     }
 // }}}
 //DIBUJO LA PAGINA {{{
     }
 // }}}
 //DIBUJO LA PAGINA {{{
-    $TABLA3 = new Tabla ('cellspacing=0');
-    $row   = array ('<b>SISTEMA: '.$SISTEMA->getNombre().'</b>');
-    $TABLA3->addRow($row,'titulo align=left');    
+    $imagen = new MECON_HTML_Image('/MECON/images/vinetas_flecha_doble.gif');
+    $row    = array ($imagen->toHtml().'&nbsp;<b>SISTEMA: '.$SISTEMA->getNombre().'</b>');
+    $TABLA3 = new MECON_HTML_Tabla ('cellspacing=0');
+    $TABLA3->addRow($row,'align=left');    
 
 
-    $MARCO = new Marco ('../../conf/confSecciones.php');
     $MARCO->addTitle('ABM Perfil');
     $MARCO->addBody($TABLA3);
     if (isset($ERROR)) {
     $MARCO->addTitle('ABM Perfil');
     $MARCO->addBody($TABLA3);
     if (isset($ERROR)) {