X-Git-Url: https://git.llucax.com/mecon/samurai.git/blobdiff_plain/0b3baffebc472d0116c7259abb3d64abf64674ae..3f60841680d8a7c6396a4cbc7d70a043770ec172:/sistema/www/perfiles/perfiles-abm.php
diff --git a/sistema/www/perfiles/perfiles-abm.php b/sistema/www/perfiles/perfiles-abm.php
index 42dcacb..bb8d0bb 100644
--- a/sistema/www/perfiles/perfiles-abm.php
+++ b/sistema/www/perfiles/perfiles-abm.php
@@ -19,6 +19,9 @@
//
// $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';
@@ -27,6 +30,7 @@
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']) {
@@ -40,13 +44,14 @@
}
$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 {
- $responsable = $_SESSION['samurai']['login'];
+ $responsable = $_SESSION['usuario'];
}
if (!@$_GET['id_perfil']) {
@@ -69,35 +74,47 @@
}
// }}}
//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 {{{
-// 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' );
- $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());
- $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());
@@ -109,6 +126,7 @@
//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();
}
}
@@ -125,8 +143,11 @@
$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' );
@@ -135,7 +156,10 @@
$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());
@@ -154,11 +178,11 @@
}
// }}}
//DIBUJO LA PAGINA {{{
- $TABLA3 = new Tabla ('cellspacing=0');
- $row = array ('SISTEMA: '.$SISTEMA->getNombre().'');
- $TABLA3->addRow($row,'titulo align=left');
+ $imagen = new MECON_HTML_Image('/MECON/images/vinetas_flecha_doble.gif');
+ $row = array ($imagen->toHtml().' SISTEMA: '.$SISTEMA->getNombre().'');
+ $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)) {