400 likes | 659 Views
Capítulo 9 : Seguridad en z/OS. Objetivos. En este capítulo veremos como: Explicar los conceptos de seguridad e integridad Explicar RACF y su interfaz con el sistema operativo Autorizar un programa Discutir los conceptos de integridad Explicar la importancia del control de cambios
E N D
Objetivos • En este capítulo veremos como: • Explicar los conceptos de seguridad e integridad • Explicar RACF y su interfaz con el sistema operativo • Autorizar un programa • Discutir los conceptos de integridad • Explicar la importancia del control de cambios • Explicar el concepto de la evaluación de riesgos
Librerías autorizadas authorized program facility (APF) encripción SAF SVC PASSWORD firewall hacker page protection bit Resource Access Control Facility (RACF) política de seguridad separación de funciones Integridad del sistema user ID Términos clave
Introducción • Un dato o programa es el recurso más valioso de la instalación, y debe ser protegido • Hace tiempo, un dato estuvo seguro porque nadie conocía como acceder a él • Cada vez más gente se convirtió en experta en computación y capaz de usar herramientas simples, y los datos no protegidos se volvieron accesibles • La seguridad de los datos es ahora más importante que antes, incluída la prevención ante destrucción inadvertida
Porqué seguridad? • Cualquier sistema de seguridad debe permitir a usuarios autorizados el acceso a lo que necesiten, y prevenir el acceso no autorizado • Muchos datos críticos de las compañías están ahora en computadoras, y son fáciles de ‘robar’ si no están protegidos • El Servidor de Seguridad del z/OS provee una estructura de funciones para proteger los datos
RACF (Resource Access Control Facility) • RACF (parte del Servidor de Seguridad) y otros paquetes disponibles, son productos que proveen la estructura básica de seguridad en un mainframe z/OS • Identifica y autentica usuarios • Autoriza usarios para acceder a recursos protegidos • Registra y reporta intentos de accesos no autorizados • Controla el modo de acceso a los recursos
Identificación y verificación de usuarios • RACF usa un ‘userid’ y una ‘password’ de sistema encriptada para realizar la identificación y verificación de los usuarios • El ‘userid’ identifica la persona para el sistema • La ‘password’ verifica la identidad del usuario • La ‘password’ no debería ser trivial, y se pueden usar exits para forzar políticas centralizadas para su formato
Niveles de Protección • RACF trabaja en una estructura jerárquica • ALLOC permite creación y destrucción de un data set • CONTROL permite repro de un data set VSAM • WRITE permite actualización de datos • READ permite lectura de datos • NONE ningún acceso • Un permiso mayor, implica todos los que están por debajo de él
Protegiendo un dataset • Se crea un perfil (profile) de data set y se almacena en la database de RACF • Este le dará acceso a nivel de usuario o grupo • También se puede definir un acceso universal • El perfil puede ser específico o genérico, con o sin caractéres especiales (wild cards)
Display típico de un perfil de RACF INFORMATION FOR DATASET SYS1.*.** (G) LEVEL OWNER UNIVERSAL ACCESS WARNING ERASE ----- -------- ------------------------------ ------- ----- 00 SYS1 READ NO NO AUDITING -------- FAILURES(READ) NOTIFY -------- NO USER TO BE NOTIFIED YOUR ACCESS CREATION GROUP DATASET TYPE -------------------- -------------------------- ---------------------- ALTER SYS1 NON-VSAM
Lista de acceso de RACF para SYS1.*.** ID ACCESS -------- ------- SYS1 ALTER KARRAS ALTER WANDRER ALTER SCHUBER ALTER KURTKR UPDATE KURTKR2 UPDATE KURTKR3 NONE CICSRS1 ALTER CICSRS2 ALTER HEISIG UPDATE JUSTO UPDATE GERALD READ
Protegiendo recursos generales o comunes • Se pueden proteger muchos recursos del sistema • Volumenes de discos (DASD) • Cintas y cartuchos • Transacciones CICS o IMS • Datasets de Spool del JES • Comandos del sistema • Recursos de una aplicación • y mucho más • RACF es flexible, y se puede agregar mucho más
System Authorization Facility • SAF es parte del z/OS • Usa RACF si está presente • También puede usar rutinas exits (opcionales) • SAF es un servicio del sistema y es un punto focal para todos los productos que proveen control de recursos • SAF se invoca en un punto de control dentro del código del administrador de recursos
Estructura del RACF • Userid (usuario) • Group (grupo) • Cada userid pertenece como mínimo a un group • Las estructuras de ‘group’ se usan para acceso a los recursos • Resource (recurso) • Resource classes • Class descriptor table – usado para personalizar (customize)
Identificación del Usuario • RACF lo identifica en su logon • Son necesarios Userid y Password • Cada userid de RACF tiene una única password • La password está encriptada para que nadie la conoza, ni el administrador • Se revoca un Userid luego de una cantidad determinada de intentos de logon, cuando se ingresaron password inválidas
Registro (log) y Reporte: • RACF mantiene información estadística • RACF graba un registro de seguridad cuando detecta: • Intentos no autorizados para entrar al sistema • Acceso a recursos • Esto depende de las definiciones del recurso • Por ejemplo: AUDIT(ALL(UPDATE) registrará todas las actualizaciones al recurso • Ejecución de comandos
Administración de Seguridad • Interpreta la política de seguridad como: • Determinar cuáles funciones de RACF usar • Identificar el nivel de protección de RACF • Identificar cuáles datos proteger • Identificar la estructura administrativa y de usuarios
RACF compartir datos en sysplex y RRSF • Si varios sistemas comparten la database de RACF habrá problemas de contención • RACF propagará los comandos a través del sysplex • RACF puede usar un ‘coupling facility’ en un ‘parallel sysplex’ para mejorar la performance • Se puede usar RRSF para tener databases de RACF distribuidas y en línea
Programas autorizados • Tareas autorizadas ejecutando programas autorizados se les permite acceder a funciones sensitivas del sistema • Para evitar problemas de integridad, programas no autorizados sólo podrán usar funciones standard
Librerías Autorizadas • Una tarea (task) es ‘autorizada' cuando el progama en ejecución tiene las siguientes características: • Ejecuta en estado supervisor • Ejecuta en su PSW con clave (key) 0 a 7 • Todos los programas previos en la misma tarea fueron programas APF • El módulo fué cargado desde una librería APF
Problem Programs (Programas Problema) • A los programas normales se los conocen como ‘programas problema’, y ejecutan en estado problema (en oposición al estado supervisor) • Ejecutan con clave 8 (problema) en su PSW • Pueden o no estar en una librería APF
Librerías APF • Las librerías autorizadas se definen en la lista APF en SYS1.PARMLIB • SYS1.LINKLIB, SYS1.SVCLIB y SYS1.LPALIB son automáticamente autorizadas • Las librerías de instalación se definen en PROGxx • Por default, todas las librerías en LINKLIST son autorizadas, pero muchas instalaciones definen LNKAUTH=APFTAB
Autorizando un programa • El primero, y sólo el primero de los módulos de carga del programa, debe ser linkeditado con el código de autorización AC=1 • Ese y todos los módulos subsiguientes deben ser cargados desde una librería autorizada • Las librerías APF se deben proteger de manera que sólo los usuarios autorizados puedan almacenar programas en ellas
Librerías autorizadas • La lista APF se crea durante el IPL, usando las librerías incluídas en el miembro PROGxx de parmlib • Si se especifica una lista dinámica, se puede actualizar mediante un comando de operador
Un ejemplo de lista APF BROWSE SYS1.PARMLIB(PROGTT) - 01.01 Line 00000000 Col 001 080 Command ===> Scroll ===> PAGE *************************** Top of Data ******************************** APF FORMAT(DYNAMIC) APF ADD DSNAME(SYS1.VTAMLIB) VOLUME(******) APF ADD DSNAME(SYS1.SICELINK) VOLUME(******) APF ADD DSNAME(SYS1.LOCAL.VTAMLIB) VOLUME(TOTCAT) APF ADD DSNAME(ISP.SISPLOAD) VOLUME(*MCAT*) *************************** Bottom of Data *****************************
APF dinámica • Actualizar un miembro PROGxx y activarlo con el comando de operador SET PROG=xx • Use el comando SETPROG APF • El comando DISPLAY PROG,APF mostrará la lista actual
D PROG,APF D PROG,APF CSV450I 12.46.27 PROG,APF DISPLAY 027 FORMAT=DYNAMIC ENTRY VOLUME DSNAME 1 Z04RE1 SYS1.LINKLIB 2 Z04RE1 SYS1.SVCLIB 3 Z04RE1 ANF.SANFLOAD 4 Z04RE2 AOP.SAOPLOAD 5 Z04RE1 AOP.SAOPLOAD 6 Z04RE1 ARTURO.BFSLMOD 7 Z04RE1 ASMA.V1R2M0.SASMMOD1 8 TOTDBZ ASN.V7R1M0.SASNALNK 9 TOTDBZ ASN.V7R1M0.SASNLLNK 10 TOTDBZ ASN.V8R1M0.SASNLOAD 11 TOTPT1 ASNA.V5R1M0.SASNALNK 12 TOTPT1 ASNL.V5R1M0.SASNLLNK ……
Operator Console Security • A las consolas se les pueden asignar niveles de autorización en el miembro CONSOLxx de parmlib • Los comandos están agrupados en: • INFO comandos informativos • SYS comandos de control del sistema • IO comandos de I/O • CONS comandos de control de consola • MASTER comandos de consola maestra • Cada consola puede tener uno o más niveles de autorización
Consolas • Al menos una consola debe tener autoridad MASTER • En un sysplex las consolas son compartidas • Se puede requerir logon para las consolas usando RACF • Todas las consolas extendidas (MCS) podrían necesitar un logon
Roles de Seguridad • El system programmer configura el RACF • Los administradores del sistema implementan las políticas de seguridad • Los administradores de seguridad definen las políticas de seguridad • Es necesaria la separación de las tareas para prevenir el acceso no controlado
Resumen • z/OS Security Server • RACF • SAF • Programas Autorizados • Lista APF • Consola de seguridad