✒️ABAP Las Ampliaciones: los User Exits y los Customer Exits
ABAP Las Ampliaciones: los User Exits y los Customer Exits
1.- Qué es una ampliación.
Son diferentes herramientas que presenta SAP para realizar MEJORAS, MODIFICACIONES ó AGREGADOS a un programa estándar del sistema.
Algunos programas estándares estan preparados para agregarles funcionalidad nueva a la ya existente, se pueden validar campos de alguna dynpro, agregar campos a una pantalla y adaptar código para tratar esos nuevos datos, agregar una nueva opción dentro de un menú o agregar 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 de las ampliaciones:
- Permiten modificar ciertos programas para adaptarlos a necesidades particulares de la empresa, agregando 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 sólo transportar los nuevos objetos.
Desventajas de las ampliaciones:
- No siempre se pueden hacer todas las modificaciones de manera satisfactoría, ya que la mayoria 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 agregar todos los tipos de ampliaciones.
En SAP existen varios tipos de ampliaciones, que son utilizados de acuerdo al tipo de mejora o requerimiento que se quieran desarrollar:
- User Exits.
- Customer Exits o Exits de Cliente.
- Keyword Exits.
- Field Exits o Exits de Campo
- Estructuras Append
- Badis
- Enhancements
- Menú Exits
2.- USER EXIT.
- Primeras ampliaciones que introdujo SAP.
- Son propias del módulo de SAP SD(Sales and Distribution) de Ventas y Distribución, no existen en otros módulos de SAP
- Es una subrutina definida dentro de un programa estándar ABAP que está hueca, es decir sin código, esta allí para que el usuario ponga su propio código fuente que le permita realizar tareas especificas que no están previstas por SAP.
- Están implementados en la forma de subrutinas.
- Todos los User Exit están nombrados por SAP como USEREXIT_XXXXXXXX.
- El problema es en encontrar el User Exit correcto o que necesitamos,una vez encontrado debemos validarlo.
- El código que se insertará dentro del User Exit puede colocarse dentro de un INCLUDE que comenzará con Z o sino suelto.
- Para ingresar código ABAP o modificar el código existente dentro de un User Exit, no se necesita una clave de acceso de SAP.
Por ejemplo el programa estándar MV45AFZZ contiene el User Exit (USEREXIT_READ_DOCUMENT) que es utilizado por la transacción VA02 cada vez que lee un documento.
VA02: Transacción estándar VA02 para modificar los pedidos de ventas.
Ciertas aplicaciones del módulo SD todavía utilizan este tipo de ampliaciones pero esta práctica no se utilizando para nuevas extensiones al código SAP. En su lugar se utilizan el resto de los tipos de ampliaciones disponibles, vale tener en cuenta que los User Exits serán mantenidos por SAP en las nuevas versiones del sistema.
Audio Tip: Estos huecos estan ubicados en lugares determinados del sistema. Es IMPORTANTE mencionar dejar en claro, que no es posible generar nuevos huecos o User Exit, sino que debemos de trabajar únicamente con los ya existentes, sino encontramos un user exit que se ajuste a nuestro requerimiento, entonces deberemos de buscar otra alternativa de solución, dentro de las demás soluciones de ampliaciones posibles que ofrece SAP en su sistema.
3.- CUSTOMER EXIT.
También llamado Exit de Cliente es un punto dentro de un programa en donde se puede llamar a un programa propio.
- Se ejecutan desde un programa estándar haciendo una invocación a un módulo función(SE37 se crean funciones).
- Algunos programas estádares tienen dentro de sus código, llamadas a módulos de funciones que pueden ser modificados por el programnador.
- Los Customer Exit son llamados dentro los programas estándares a través de un número.
- Este número es la terminación del nombre del módulo de función que esta asociado al programa.
- En la tabla MODSAP se encuentran todos los módulos de función que se utilizan en los Exits de cliente,
MODSAP: Tabla estándar del sistema que almacena todas las ampliaciones existentes en SAP, de cada ampliación se guarda:
- Nombre de la ampliación SAP.
- Tipo de Componente: Que pueden ser "E"(para Exit de Funciones) "S"(para Imágenes) "T"(para Tablas) y "C"(Código GUI)
- Y el nombre del Objeto SAP: "Programa, módulo de función,etc."
Los módulos de función tienen una nomenclatura estándar: EXIT_<nombre del programa>_<número de función>.
Ejemplo: EXIT_SAPMV45A_003
La llamada a un EXIT de un Módulo de función es implementada: CALL CUSTOMER-FUNCTION <3 dígitos>.
Cada uno de estos módulos es llamado por el proceso estándar en ciertos momentos y ellos tienen por defecto algunos parámetros que son los disponibles dentro de la ampliación.
Las principales ventajas que presenta un Customer Exit son:
- El Customer Exit es una buena herramienta para agregar funcionalidad nueva a un programa estándar como puede ser un validación o la ejecución de rutinas de control sin modificar el código original.
- Para transportar y activar los Customer Exits es suficiente con el Include nuevo únicamente, sin tocar el programa original.
Las principales desventajas que presenta un Customer Exit son:
- 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 los 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 un búsqueda del string 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.
Utilizaremos principalmente estas 2 transacciones estándar, para trabajar con los EXITS de CLIENTE:
SMOD: para administrar las ampliaciones.
CMOD: para la gestión de proyectos de ampliaciones.
4.- Pasos para realizar un Customer Exit.
- Vamos a la transacción SMOD, es la que maneja las ampliaciones en SAP. En esta transacción se debe completar el nombre de la ampliación que contiene el módulo de función a utilizar.
- Para saber el nombre de la ampliación utilizamos la transacción SE16, con la tabla MODSAP, en el campo MEMBER completar con el nombre del módulo de función a buscar (Ejemplo: EXIT_SAPMV45A_003) y el campo NAME nos dirá la ampliación que la contiene.
- Si tampoco se conoce el módulo de función especifico, debe buscar en el código del programa estándar las llamadas a funciones del usuario, que están indicadas por CALL CUSTOMER-FUNCTION '001', el número del final puede cambiar si existen más de una llamada, es decir varios customer exits o exits de cliente.
- Una vez que tenemos el nombre de la ampliación, en este ejemplo V45A0003, lo colocamos en el campo AMpliación de la transacción SMOD y presionamos visualizar.
- Para ver los componentes de la ampliación, damos clic en componentes, parar nuestro ejemplo V45A0003, existen 2 módulos de funciones, dando doble clic sobre el que se desea utilizar podemos ver en el código los objetos que importa y exporta, las tablas que importa y que pueden modificarse, En esta misma solapa Cód.fte. se encuentra un Include Z que se utiliza para agregar el código del usuario.
- En general el código que escribiremos dentro de los EXITS será destinado a realizar validaciones de los campos de entrada, en caso de cumplirse una condición determinada, se emitira en pantalla un mensaje de error, que impedirá el normal funcionamiento de la transacción, caso contrario se continuará con el proceso normal
En las última versiones de SAP el include comienza con ZX y si no se utilizo anteriormente deberemos crearlo ya que no existirá.
Si el INCLUDE no existiera, al hacer doble clic sobre el mismo, se pedirá al usuario que se le asigne una orden de transporte.
- Una vez creado el Include se puede generar código con todos los objetos que figuren en la solapa de Import, Modific. y Tablas, pudiendo devolver resultados modificando los objetos que se encuentran en las pestañas Export, Modif y Tablas.
- Una vez programando el código, la ampliación debe activarse e incluirse en un proyecto. Los proyectos son creados en la transacción CMOD. Allí se debe generar un proyecto Z en el cual se incluirán las ampliaciones que queramos.
IMPORTANTE: Para agrupar,clasificar y controlar los Customer Exit crearemos un proyecto de ampliación con CMOD.
El nombre de los proyectos de ampliación debe estar dentro del rango permitido para los clientes, es decir debe contar con Z
Es importante recordar que si el Exit no está activo, la llamada a está función no tendrá efecto alguno.
5.- ¿ Como probar un Customer Exit.?
Lo dificil de utilizar un customer Exits es ubicarlos y conocer el momento del proceso en el que ocurren los mismos. Todo esto para saber que datos y que particularmente, se puede realizar en ese momento.
Para investigar esto los más efectivo será:
- Crear un proyecto de ampliación.
- Asignar la ampliación.
- Activar la ampliación.
- Colocar un Breakpoint.
El Breakpoint se debe colocar en el módulo de funciones, para determinar los datos con los que disponemos en ese momento y el punto exacto del proceso en donde se encuentra.
 
 
 
Sobre el autor
Publicación académica de Gustavo Alberto Ramirez Franco, en su ámbito de estudios para la Carrera Consultor ABAP.
Gustavo Alberto Ramirez Franco
Profesión: Ingeniero en Sistemas Computacionales - Mexico - Legajo: TA38Q
✒️Autor de: 38 Publicaciones Académicas
🎓Egresado de los módulos:
Certificación Académica de Gustavo Ramirez