]> git.llucax.com Git - mecon/samurai.git/blobdiff - sistema/www/usuarios/usuarios-abm.php
Se reemplazan die() por trigger_error().
[mecon/samurai.git] / sistema / www / usuarios / usuarios-abm.php
index 9058576b1bf91dd69252087a7ff97f74af2a46e0..4cb553b3b451246adda05b71aa2faa8133ed06d0 100644 (file)
 //
 // $Id$
 // 
-
 //VERIFICO SI SE TIENE ACCESO A LA PAGINA{{{
-    if (!$SAMURAI_PERM->tiene(SAMURAI_DEVELOPER)) {
-//        header('Location: error')
-    }
+$SAMURAI_PERM->setSistema(SAMURAI_PERM);
+if (!$SAMURAI_PERM->tiene(SAMURAI_PERM_DEVELOPER)) {
+    $SAMURAI_PERM->setSistema($_SESSION['samurai']['id_sistema']);
+    $SAMURAI_PERM->chequear(SAMURAI_PERM_USUARIO_ALTA, SAMURAI_PERM_USUARIO_BAJA, SAMURAI_PERM_USUARIO_MODIF, SAMURAI_PERM_DEVELOPER);
+}
+$MARCO =& new MECON_Marco ('/var/www/sistemas/samurai/sistema/conf/confSecciones.php', $SAMURAI_PERM);
+//}}}
+
+//XXX OBTENGO LA ACCION {{{
+switch ($_REQUEST['accion']) {
+    case 'm':
+        $b_accion = 'Modificar';
+        $accion = 'm';
+        break;
+    case 'e':
+        $b_accion = 'Eliminar';
+        $accion = 'e';
+        break;
+    default:
+        $b_accion = 'Grabar';
+        $accion = '';
+        break;
+}
 //}}}
 //REQUIRE ONCE {{{
     //MECON {{{
     require_once 'SAMURAI/Usuario.php';
     require_once 'SAMURAI/Sistema.php';
     //}}}
-    require_once 'HTML/Image.php';
+    require_once 'MECON/HTML/Image.php';
 // }}}
 //VEO SI HAY QUE ELEGIR EN QUE SISTEMA TRABAJAR {{{
-if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
-    header('Location: ./../sel-sistema');    
+if (!@$_SESSION['samurai']['id_sistema']) {
+    header('Location: ./../sel-sistema?redirect=usuarios/usuarios');    
 }
 // }}}   
 //CREO LOS OBJETOS NECESARIOS {{{
@@ -52,10 +71,13 @@ if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
         $validar = 1;
         $login = null;
     }
+
+
     $TABLA   = new MECON_HTML_Tabla ('cellspacing=0');
     $FORM    = new MECON_HTML_QuickForm ('usuarios_abm','post','usuarios-abm');
+    $FORM->renderer->updateAttributes('width="400"');
     $SISTEMA = new SAMURAI_Sistema($DB, $_SESSION['samurai']['id_sistema']);
-    $USUARIO = new SAMURAI_Usuario($DB, $login);
+    $USUARIO = new SAMURAI_Usuario($DB, $login, $_SESSION['samurai']['id_sistema']);
 // }}}
 //OBTENGO LOS DATOS DE LA BASE {{{
     $tmps = SAMURAI_Perfil::getPerfiles($DB, null, $_SESSION['samurai']['id_sistema']);
@@ -64,7 +86,7 @@ if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
     }
 //}}}
 //AGREGO LOS DATOS A LAS TABLAS {{{
-    $imagen = new HTML_Image('/MECON/images/vinetas_flecha_doble.gif');
+    $imagen = new MECON_HTML_Image('/MECON/images/vinetas_flecha_doble.gif');
     $row    = array ($imagen->toHtml().'&nbsp;<b>SISTEMA: '.$SISTEMA->getNombre().'</b>');
     $TABLA->addRow($row,'align=left');    
 //}}}
@@ -80,8 +102,9 @@ if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
             $FORM->addElement ('text'  , 'login' , 'Login@Organismo' , array( 'value' => $login , 'size' => '20'));
         }
         $FORM->addElement ('select', 'perfiles'   , 'Perfiles', $PERFILES, array('size' => '5', 'multiple' => 'true'));
-        $FORM->addElement ('hidden', 'responsable', $_SESSION['samurai']['login']);
-        $group[] = HTML_QuickForm::createElement('submit', 'aceptar' , 'Grabar');
+        $FORM->addElement ('hidden', 'responsable', $_SESSION['usuario']);
+        $FORM->addElement ('hidden', 'accion', $accion);
+        $group[] = HTML_QuickForm::createElement('submit', 'aceptar', $b_accion);
         $group[] = HTML_QuickForm::createElement('submit', 'cancelar', 'Cancelar', array ('onClick' => 'javascript:window.location = \'usuarios\';return false;'));
         $FORM->addGroup($group,'botones');
     }
@@ -122,7 +145,7 @@ if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
         // VEO SI SE CANCELO {{{
         $botones = $FORM->getSubmitValue('botones');
         if (@$botones['cancelar']) {
-            header('Location: perfiles');
+            header('Location: usuarios');
         }
         // }}}
         else {
@@ -141,6 +164,7 @@ if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
                 $login3 = $login2->getValue();
             }
             $USUARIO->setLogin($login3);
+            
             $res  = $USUARIO->verificarLogin();
             if ($aceptar->getValue() == 'Grabar') {
                 $res2 = $USUARIO->verificarAsociacionExistente();
@@ -153,7 +177,7 @@ if (!@$_SESSION['samurai']['id_sistema'] || !@$_SESSION['samurai']['login']) {
             }
             else {
                 $USUARIO->setPerfiles($perfiles->getSelected());
-
+                
                 $res = $USUARIO->guardarDatos($aceptar->getValue());
 
                 if (PEAR::isError($res)) {