Ver Mensaje Individual
  #5  
Antiguo 02-06-2005
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Reputación: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por Crandel
Deberías estar modificando los indices del menu en la tabla privilegios para cada usuario.
Sí claro, pero si se desea algo realmente dinamico tienes que guardar los permisos en algún lado ¿no? Con tu método, ¿de dónde tomas esta información? Hasta donde veo tendrías que ir menú por menú:

Código:
FOR EACH menu DO
  CASE usuario OF
    'hugo':
      CASE menu OF
        'clientes': menu.habilitar = TRUE;
        'facturas': menu.habiltar  TRUE;
        'usuarios': menu.habiltar  FALSE;
        ............
      ENDCASE

    'paco':
      CASE menu OF
        'clientes': menu.habilitar = TRUE;
        'facturas': menu.habiltar  FALSE;
        'usuarios': menu.habiltar  FALSE;
        ............
      ENDCASE

    'luis':
      CASE menu OF
        'clientes': menu.habilitar = FALSE;
        'facturas': menu.habiltar  TRUE;
        'usuarios': menu.habiltar  TRUE;
        ............
      ENDCASE
    ................................
ENDCASE
Es decir, una estructura condicional gigantezca y absoultamente dificil de mantener. ¿Qué pasa si el administrador necesita cambiar los permisos de un usuario? ¿Le pide al programador que cambie el código y recompile? Y agregar una opción tampoco la veo fácil; hay que aumentar un CASE por cada usuario. Y si se agrega un usuario habrá que aumentar un CASE por cada menú.

Complicado sí que lo es; más el desarrollo completo-que no expuse, pero se trata de lograr flexibilidad. Si el sistema es muy sencillo y estático cualquiera de las dos formas es buena excepto que con una tabla puedes agregar usuarios y asignar permisos sin necesidad de modificar el código.

Yo he usado la opción que describí sin mayores problemas- y eso porque se trató de un sistema sin mayores cambios en las opciones pero sí de usuarios.

Ahora, si además se va a tener un sistema cambiante la cuestión es más compleja.

Para empezar construiría el menú dinámicamente tomando los datos de la base. Además de la tabla depermisos se requieren las tablas de menús y submenús con los textos de cada uno. Pero además hay que asignarle algo al evento OnClick. Para ello usaría una fábrica (factory pattern) que, basada en el id del menú o submenú, me dé una clase de formulario (TFormClass) para así construir y mostrar el formulario adecuado. Suponiendo claro que los menús sólo abren formularios pero para no complicar la cosa dejémoslo así.

Claro que cada vez que se agregue una módulo al sistema habrá que programar, no hay manera de evitar esto , pero el nuevo módulo se programa aparte y se registra en la fábrica con lo que el código de construcción del menú no tiene que modificarse en lo absoluto.

// Saludos
Responder Con Cita