✒️ABAP Las Ampliaciones: los User Exits y los Customer Exits
ABAP Las Ampliaciones: los User Exits y los Customer Exits
Ampliaciones : user exist y customer exists
Ampliación: Son diferentes herramientas que presenta SAP para realizar mejoras, modificaciones o añadidos a un programa estándar del sistema. En algunos casos, se puede validar campos de alguna dynpro en particular, añadir campos a una pantalla con código que permita tratar esos datos nuevos, añadir una nueva opción dentro de un menú o añadir campos a tablas estándares. Las ampliaciones se generan y codifican en módulos aparte del código estándar, con lo cual no se necesita modificarlo, manteniendo la funcionalidad original y el buen funcionamiento.
Ventajas ampliación:
- Permiten modificar ciertos programas para adaptarlos a necesidades particulares de la empresa, añadiendo nuevas características a las existentes.
- Permiten realizar mejoras a un programa sin modificar el código original del mismo, manteniendo el buen funcionamiento y las características que tenía.
- Los cambios toman efecto con solo transportar los nuevos objetos.
Desventajas ampliación:
- No siempre se pueden hacer todas las modificaciones de manera satisfactoria, ya que la mayoría de las ampliaciones están preparadas para una determinada tarea y momento dentro de la ejecución de un programa
- No todos los programas estándares están preparados para añadir todos los tipos de ampliaciones.
Tipos de ampliaciones mas importantes:
- User exits
- Customer exists o exists de cliente
- Keyword exits
- Field exits o exists de campo
- Estructuras append
- Badis
- Enhancements
- Menú exits
User exits: Es una subrutina definida dentro de un programa estándar que está hueca, sin código, para que el usuario ponga su propio código fuente que le permita realizar tareas específicas que no están previstas por SAP. Son las primeras ampliaciones introducidas por SAP. Son propias del módulo SAP SD de ventas y distribución. No existen en otros módulos. Están implementados en la forma de subrutinas. Todos los user exit están nombrados como “USEREXIT_XXXXX”. El principal problema que representan está en encontrar el user exit correcto. Una vez que se encuentra, se deberá verificar que el mismo sirva para el propósito indicado. El código ABAP que se insertará dentro del user exit puede colocarse dentro de un include que comenzará con la letra Z o sino suelto. Para añadir o modificar código existente dentro de un user exit, no es necesaria la clave de acceso de SAP. Por ejemplo, en el programa estándar “MV45AFZZ” se encuentra el siguiente user exit que es utilizado por la transacción VA02 cada vez que lee un documento.
NOTA: Los user exits son huecos que genera SAP en el sistema estándar. Estos huecos están ubicados en lugares determinados del sistema. Es importante dejar claro que no es posible generar nuevos huecos, sino que se tiene que trabajar con los existentes. Si no se encuentra un user exit que se ajuste a los requisitos, entonces habrá que buscar otra alternativa de solución dentro de las demás soluciones de ampliaciones posibles que ofrece SAP en su sistema.
VA02: tx para modificar pedidos de venta
Customer exits o exit del cliente: es un punto dentro de un programa donde se puede llamar a un programa propio. Se ejecutan desde un programa estándar haciendo una invocación a un módulo de función. Algunos programas estándares tiene dentro de su código, llamadas a módulos de funciones que pueden ser modificados por el programador. Los customer exit (exit de cliente) son llamados dentro de los programas a través de un número. Este número es la terminación del nombre del módulo de función que está asociado al programa. En la tabla MODSAP se encuentran todos los módulos de función que se utilizan en los exits de cliente. Los módulos de función tienen una nomenclatura estándar. Por ejemplo, “EXIT_SAPMV45A_003”. La llamada a un exit de un módulo de función es implementada de la siguiente forma en un programa estándar: CALL CUSTOMER-FUNCTION <3 dígitos>. Cada uno de estos módulos es llamado por el proceso estándar en ciertos momentos y tienen por defecto algunos parámetros que son los disponibles dentro de la ampliación.
TABLA MODSAP: La tabla base de datos estándar MODSAP almacena todas la ampliaciones existentes en el sistema SAP. De cada ampliación se guarda: el nombre de la ampliación, el tipo de componente que puede ser "E" para Exit de funciones, "S" para Imágenes, "T" para Tablas y "C" para Código GUI y finalmente el nombre del objeto SAP (Programa, módulo de función, etc) que se modifica.
Ventajas customer exits o exit del cliente:
- Es una buena herramienta para añadir funcionalidad nueva a un programa estándar, como puede ser una validación o la ejecución de rutinas de control sin modificar el código original.
- Para transportar y activar los customer exit es suficiente con el include nuevo únicamente, sin tocar el programa original.
Desventajas de customer exits o exit del cliente:
- No siempre se ajusta el customer exit a las necesidades del programador ya que los objetos que importa o exporta son fijos y pueden no tener todos objetos que se requieren.
- No existe una búsqueda de customer exit por programa con una aclaración amplia de su utilización, para buscarlos hay que realizar una búsqueda de la cadena “CALL CUSTOMER-FUNCTION”, dentro del programa de control estándar y su funcionamiento se prueba sin saber exactamente si es el correcto para lo que se quiere hacer.
Transacciones para trabajar con Customer exits o exit del cliente:
- SMOD: Administra ampliaciones
- CMOD: Gestión de proyectos de ampliación.
Pasos para realizar un customer exit: Acceder a la transacción SMOD y completar el nombre de la ampliación que contiene el módulo de función a utilizar por el costumer exit. Si no se conoce el nombre aún, hay que ir a la transacción SE16, con la tabla MODSAP, en el campo MEMBER completar con el nombre del módulo de función a buscar y el campo NAME dirá la ampliación que la contiene. Si no se conoce el módulo de función especifico, se debe buscar en el código del programa estándar, las llamadas a funciones de usuario, que estarán indicadas por “CALL CUSTOMER-FUNCTION ‘001’”, donde el número del final puede ir cambiando si presenta más de una llamada, es decir, varios customer exit. Cuando ya se tiene el nombre presionar en Visualizar -> componentes. Aquí se pueden ver los objestos y tablas que pueden modificarse. En la solapa "Cód.fte" se encuentra el include Z que se utiliza para agragar el código del usuario (el las últimas versiones empieza por ZX). Si el include no existe se pedirá una o"den de transporte. Una vez creado se pude generar el código ABAP utilizando los objetos "Import, Modific y Tablas". Una vez terminad la codificiación la ampliación debe activarse en incluirse en un proyecto mediante la transacción CMOD. Un proyecto de ampliación asocia "n" ampliaciones. Su activación o desactivación afecta a todas las ampliaciones asociadas. Para crear un proyecto: tx CMOD -> nombre del poryecto (debe empezar con Z) y Crear -> Asignación de ampliación -> Introducir las ampliaciones y picar en "Componentes" para visulizarlos -> presionamos activación para activar los componentes exit (también se puede desactivar). Si el exit no está activo la llamada a la función no tendrá efecto.
Como probar un custormer exit: Lo más efectivo será crear un proyecto de ampliación, asignar la ampliación, activarla y luego colocar un breakpoint en el módulo de funciones, para determinar los datos con los que se dispone en ese momento y el punto exacto del proceso en donde se encuentra.
 
 
 
Sobre el autor
Publicación académica de Felipe Estepa Quintero, en su ámbito de estudios para la Carrera Consultor ABAP.
Felipe Estepa Quintero
Profesión: Tecnologo en Gestion Logistica - Colombia - Legajo: QH16V
✒️Autor de: 118 Publicaciones Académicas
🎓Egresado de los módulos:
Disponibilidad Laboral: FullTime
Certificación Académica de Felipe Estepa