✒️ABAP Las Ampliaciones: los User Exits y los Customer Exits
ABAP Las Ampliaciones: los User Exits y los Customer Exits
Lección 1 - Ampliaciones: User Exits y Customer Exits
1 | ¿ Qué es una Ampliación ?
Son diferentes herramientas que presenta SAP para realizar mejoras, modificaciones o agregados a un programa estándar del sistema.
Algunos programas estándares están preparados como para agregarles funcionalidad nueva a la existente.
En algunos casos se puede validar campos de alguna dynpro en particular; agregar campos a una pantalla con código que permita
tratar esos datos nuevos; 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.
Las principales ventajas que presentan las ampliaciones son:
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.
Las principales desventajas que presentan las ampliaciones son:
No siempre se pueden hacer todas las modificaciones de manera satisfactoria,
No todos los programas estándares están preparados para agregar todos los tipos de ampliaciones.
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.
En SAP existen varios tipos de ampliaciones, que son utilizados de acuerdo al tipo de mejora o requerimiento que se quiera desarrollar,
cada una con sus particularidades que serán explicadas en detalle más adelante. Las más importantes son:
User Exits
Customer Exits o Exits de Cliente
KeyWord Exits
Field Exits o Exits de Campo
Estructuras Append
Badis
Enhancements
Menú Exits
2 | User Exits
Es una subrutina definida dentro de un programa estándar ABAP que está hueca, es decir sin código,
está allí 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 que introdujo SAP.
Son propias del módulo de SAP SD de Ventas y Distribución, no existen en otros módulos de SAP.
Están implementados en la forma de subrutinas.
Todos los User Exit están nombrados por SAP como USEREXIT_XXXXXXXX.
Imagen 2.1 - Nomenclatura de la declaración de los User Exit
El principal problema que presentan está en encontrar el User Exit correcto.
Una vez que lo encontramos deberemos verificar que el mismo sirva para nuestro propósito.
El código ABAP 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, 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.
El User Exit USEREXIT_READ_DOCUMENT
Transacción VA02
Utilizaremos la 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 esta utilizando para nuevas extensiones al código SAP.
En su lugar se utilizan el resto de los tipos de ampliaciones disponibles,
aunque vale tener en cuenta que los User Exits serán mantenidos por SAP en las nuevas versiones del sistema.
3 | Customer Exits
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 de función.
Algunos programas estándares tienen dentro de su código, llamadas a módulos de funciones que pueden ser modificados por el programador.
Los Customer Exit son llamados dentro de 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 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.
Imagen 3.1 - La tabla estándar MODSAP
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.
Los módulos de función tienen una nomenclatura estándar:
Imagen 3.2 - Nomenclatura de los módulos de función de los Customer exits
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 de SAP:
CALL CUSTOMER-FUNCTION <3 dígitos>
Imagen 3.3 - Ejemplo de la implementación de un exit en un programa estándar de SAP
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 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.
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 una 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.
Para trabajar con Customer Exits vamos a utilizar principalmente dos transacciones que son:
SMOD: para administrar las ampliaciones.
Imagen 3.4 - La transacción estándar SMOD
CMOD: para la gestión de proyectos de ampliaciones.
Imagen 3.5 - La transacción estándar CMOD
Transacciones SMOD y CMOD
Utilizaremos estas dos transacciones estándar para trabajar con los exits de cliente.
4 | Pasos para realizar un Customer Exit
Vamos a analizar los pasos necesarios para implementar un Customer Exit.
Primeramente vamos a dirigirnos a la transacción SMOD, que 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 por el Customer 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 (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 específico, debe buscarse 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 o exits de cliente.
Una vez que se tiene 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.
Imagen 4.1 - Introducimos el nombre de la ampliación en la transacción SMOD
En la siguiente pantalla presionamos el botón Componentes (o habiendo seleccionado la opción Componentes de la pantalla anterior)
y se visualizarán todos los módulos de funciones que contiene esta ampliación.
Imagen 4.2 - Presionamos el botón componentes
En este caso, para la ampliación V45A0003, existen dos módulos de función. Cada uno va a ser ejecutado en algún momento
determinado de la ejecución del programa al cual pertenecen, en este caso SAPMV45A.
Imagen 4.3 - Visualizamos los componentes de la ampliación
Una vez que ya se sabe qué modulo de función usar se debe hacer doble clic sobre el mismo y se derivará a otra pantalla,
en la cual se puede ver qué objetos importa y exporta esta función, como así también las tablas que importa y que pueden modificarse,
las cuales se utilizarán en el código fuente.
En la solapa Cód.fte. se encuentra un Include Z que se utiliza para agregar el código del usuario.
En las ultimas versiones de SAP el include comienza con ZX y si no se utilizo anteriormente deberemos crearlo ya que no existirá.
Si este Include no existe, al hacer doble clic sobre el mismo, se pedirá al usuario que le asigne una orden de transporte para poder generarlo.
Imagen 4.4 - El sistema nos informa que el include no existe
Una vez creado es posible generar código ABAP utilizando todos los objetos que figuren en la solapa de Import, Modific., y Tablas,
pudiendo devolver resultados modificando los objetos que se encuentran en las solapas Export, Modif. y Tablas.
Imagen 4.5 - Dentro del include vamos a introducir el código ABAP
Una vez terminada la codificación, 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 se desee.
Para agrupar, clasificar y controlar los Customer Exit crearemos un proyecto de ampliación.
Un proyecto de ampliación asocia n ampliaciones. Su activación o desactivación afecta a todas las ampliaciones asociadas.
La transacción para acceder a los proyectos de ampliación es la CMOD. Allí ingresamos el nombre del proyecto y presionamos Crear.
Imagen 4.6 - Introducimos el nombre del proyecto en la transacción CMOD
El nombre de los proyectos de ampliación debe estar dentro del rango permitido para los clientes, es decir debe comenzar con Z.
Ahora presionamos el botón Asignación ampliación para asignar las ampliaciones que vamos a incluir en el proyecto.
Imagen 4.7 - Presionamos el botón asignación ampliación
La pantalla de asignación de ampliaciones es la que vemos a continuación. Allí introducimos las ampliaciones
y presionamos el botón Componentes para visualizar los componentes de cada ampliación.
Imagen 4.8 - Introducimos la ampliación y presionamos el botón componentes
En la pantalla de componentes vamos a activar la ampliación presionando el botón de activación.
Cada uno de esos componentes son los Exit de la ampliación, es allí en donde se debe incorporar
el código de validación o proceso a controlar con la ampliación.
Imagen 4.9 - Visualizamos los componentes y activamos la ampliación
Una vez activado, el proyecto de ampliación pasará al color verde.
Imagen 4.10 - El color verde indica que el proyecto se encuentra activado
Podemos anular la activación del proyecto de ampliación presionando el botón para desactivar
Es importante recordar que si el Exit no está activo, la llamada a esta función no tendrá efecto alguno.
5 | ¿ Cómo probar un Customer Exit ?
Un punto complicado en la utilización de Customer Exits es ubicarlos y conocer el momento del proceso en el que ocurren los mismos.
Todo esto para determinar que datos y que particularmente, se puede realizar en ese momento.
Para realizar esta investigación, 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 disponemos en ese momento y el punto exacto del proceso en donde se encuentra.
 
 
 
Sobre el autor
Publicación académica de Alex Francisco Lemos Collazos, en su ámbito de estudios para la Carrera Consultor ABAP.
Alex Francisco Lemos Collazos
Profesión: Ingeniero en Sistemas - Colombia - Legajo: QS36A
✒️Autor de: 174 Publicaciones Académicas
🎓Cursando Actualmente: Master S/4HANA Material Management
🎓Egresado de los módulos:
- Máster Material Management en SAP S/4HANA LOGISTIC
- Carrera Consultor ABAP Nivel Avanzado
- Carrera Consultor ABAP Nivel Inicial
- Carrera Consultor en SAP SD Nivel Inicial