Documentos de Académico
Documentos de Profesional
Documentos de Cultura
programación ABAP.
Algunos métodos de búsqueda de BADIS en SAP y aprenda la manera de
implementarlas
No importa cuánto abarca un software de gestión, las necesidades particulares de cada cliente y
los requisitos de los distintos escenarios de negocios, puede generar una necesidad de
"customización" del software que excede la parametrización. Sin embargo, en un sistema de
envergadura y misión crítica, esto no debería llevarse a cabo de cualquier manera. En el caso
particular de SAP, es sabido que no se permite modificar el código fuente de un programa ABAP
standard.
Por ello, SAP proporciona recursos e instrumentos que permiten intromisiones "controladas" al
código, a través del concepto de ampliaciones o Enhancements. La idea es expandir la
funcionalidad dentro del sistema SAP para atender las necesidades adicionales del cliente, sin
modificar el código fuente del programa standard.
Se describirá qué es una BADI y luego mediante un ejemplo práctico, se detallarán los distintos
métodos para buscar BADI’s en el sistema y se implementará una de ellas.
1
Las BADI's poseen una arquitectura Multicapa (SAP, partners, soluciones de clientes,
localizaciones, soluciones específicas para industrias, etc), a diferencia de los User Exits
que son doble capa únicamente (SAP y soluciones de cliente).
Se usan para ampliar menúes, código fuente y pantallas de transacciones standards
Las BADI’s contienen dos vistas: la definición y la implementación.
La definición se realiza mediante la transacción SE18. En ella se deben especificar los siguientes
puntos:
Definición de la interfaz: métodos y parámetros.
Tipo de implementación: simple (sólo una implementación activa) o múltiple (más de una
implementación activa).
Para implementar o ver las distintas implementaciones de una BADI dada, utilizar la transacción
SE19.
Método 1:
Las BADIS se encuentran registradas en las tablas SXS_INTER, SXC_EXIT, SXC_CLASS y SXC_ATTR.
SAP accede a dichas tablas mediante las vistas V_EXT_IMP y V_EXT_ACT. En cada llamada
existente a una BADI, el sistema pasa por las tablas antes mencionadas. Por lo tanto, un método
para encontrar la BADI que necesitamos se basa en el uso de la transacción ST05 (Performance
Analysis).
2
El nombre de la BADI se encuentra a continuación del prefijo IF_EX_. Por ejemplo, si el nombre de
la interfase es IF_EX_ADDR_LANGU_TO_VERS, la BADI se llama ADDR_LANGU_TO_VERS.
Método 2:
Desde la transacción SE80, fijar un break-point en el método “ACT_IMPS_PER_FLT_VAL” de la
clase “CL_BADI_FLT_DATA_TRANS_AND_DB” justo después del “SELECT” encabezado con el
comentario “read BADI attributes”.
Luego ejecutar la transacción que se desea analizar. Por cada parada en el break-point del
debugger, examinar los campos “exit_name” e “internal”.
Método 3:
Desde la transacción SE24 (Class Builder) colocar un break-point en el CALL METHOD
cl_exithandler=>get_class_name_by_interface que está dentro del método GET_INSTANCE de la
clase CL_EXITHANDLER .
Luego, ejecutar la transacción o programa a verificar. En la variable exit_name se muestran los
nombres de las BADI's que implementa el programa. Este método puede resultar engorroso
porque detiene muchas veces la ejecución, pero ésto asegura que si una BADI existe se detendrá
en ese punto. Lo que se está haciendo es poner un BREAK-POINT en el momento en que SAP
verifica si una definición de BADI tiene alguna implementación activa; por lo tanto, aunque no
exista ninguna implementación activa para esa BADI particular, el método detectará que existe
una BADI en ese punto. Para ver si esa BADI está implementada o no, ir a la Transacción SE18 con
el nombre de la BADI obtenida en la variable exit_name e ir a la opción de
menú Implementaciones → Resumen.
Método 4:
Obtener el paquete (Clase de desarrollo) de la transacción que se desea analizar mediante
la transacción SE93. En la transacción SE18, en la búsqueda ampliada, buscar filtrando por el
paquete anteriormente encontrado y el sistema devolverá todas las BADI’s relacionadas a ese
paquete.
III) Implementando una BADI
En el siguiente caso práctico, se implementará una BADI que permita mostrar un mensaje cuando
se estén modificando los datos de dirección de un banco determinado, mediante la transacción
FI02.
3
4
5
Esta tabla está habilitada porque en la BADI se definió que se debe hacer con una definición de
filtros, es decir, el ckeckbox Filter-Dependen está seleccionado.
c. Finalmente Guardar .
4. Ingresar el código fuente solicitado. Para ello ir a la solapa INTERFACE, y hacer doble click sobre
el método IS_ACTIVE_FOR_COUNTRY.
6
Aparecerá la siguiente pantalla, donde se ingresará el siguiente código fuente:
7
1. Acceder a la transacción FI02 e ingresar el país y el código del banco. Por ejemplo,
AR(Argentina) y 001. Luego presionar ENTER.
8
9
Ampliaciones: ¿Qué diferencia a las BADIS de los CUSTOMER EXITS y otros
métodos?
requisitos de los distintos escenarios de negocios, puede generar una necesidad de "customización" del
software que excede la parametrización. Sin embargo, en un sistema de envergadura y misión crítica, ésto no
debería llevarse a cabo de cualquier manera. En el caso particular de SAP, es sabido que no se permite
Por ello, SAP proporciona recursos e instrumentos que permiten intromisiones "controladas" al código, a
través del concepto de ampliaciones o Enhancements. La idea es expandir la funcionalidad dentro del sistema
SAP para atender las necesidades adicionales del cliente, sin modificar el código fuente del programa
standard.
Las sucesivas versiones de SAP fueron incoporando nuevos y mejores instrumentos para llevar a cabo esta
tarea.
USER EXITS
La primera generación de ampliaciones se hacía a través de los USER EXITS.
Inicialmente los user-exits en ABAP eran el modo más usual de realizar ampliaciones en SAP. Los USER
EXITS son como subrutinas vacías dentro de un programa estándar en las cuales se puede agregar código.
(El nombre de las mismas comienza con USEREXIT). Este método utiliza módulos de función mediante los
cuales se puede ingresar código ABAP. El sistema provee las funciones donde los user-exits son llamados y
se cuenta con una interfaz definida y un programa Include. Es en este programa Include donde se agrega el
código requerido.
Los user exits NO están definidos dentro de unproyecto de ampliación, directamente se modifica el código
estándar.
que hay que tocar programas includes de SAP, para lo cual se necesita clave de modificación de objeto
transacción CMOD.
10
Permiten ampliar código fuente (function module exit), menúes (menu exit) y pantallas estándares (screen
ampliaciones que fueron desarrolladas para el módulo de Contabilidad Financiera (FI), que permiten agregar
componentes adicionales en los programas estándares por medio de funciones (FUNCTION MODULES). Una
característica común de las BTE, es que son independientes de mandante a diferencia de las ampliaciones
denominadas “Customer Exits”. (Ver Tip BTE (Business transaction events V4.0))
BADIS
Luego, con la versión 4.6C, y de la mano de la orientación a objetos, apareció la tercera generación de
recursos de ampliación, a través de las BADIS. Las BADI’s (Bussiness Add-ins) son las nuevas técnicas de
ampliación del código estándar de SAP basadas en programación ABAP orientada a objetos. Usan instancias
de ABAP Objects. Se invocan con CALL METHOD. Se crean con la transacción SE18 y se implementan con
El Enhancement Framework es una nueva tecnología que brinda todas las técnicas de ampliación bajo un
mismo techo.
Dentro de este Framework se diferencian las ampliaciones de tipo implícito, predefinidas y provistas por SAP
en el código fuente, y las ampliaciones de tipo explícito que pueden implementarse en cualquier parte del
código fuente a excepción de algunas áreas restringidas por SAP, a través de los ENHANCEMENT-POINTS
11
de función mediante los cuales se puede ingresar código ABAP. El sistema provee las funciones donde los user-exits son
llamados y se cuenta con una interfaz definida y un programa Include. Es en éste programa Include donde se agrega el
El problema principal de esta solución es que sólo es posible una implementación simple. Esto significa que si el
Para resolver esta limitación SAP provee la utilización de BADI’s que soportan múltiples implementaciones. De esta forma se pueden
crear varias instancias del mismo objeto bajo el concepto de la orientación a objetos.
SAP brinda un nuevo framework para el desarrollo de ampliaciones conocido como Enhancement Framework. Esta nueva opción esta
Página 2 de 6
II. Tipos de enhancements para ampliación de código fuente
12
Las ampliaciones de código fuente ABAP (source code enhancement/source code plug-in) es una de las tecnologías
disponibles dentro del Enhancement Framework. Esta técnica se almacena en un programa de tipo include y no es parte del
código fuente original.
Las ampliaciones de este tipo permiten ampliar la funcionalidad de transacciones estandar sin modificaciones en el código
fuente.
1. Las ampliaciones de tipo implícito son ampliaciones predefinidas provistas por SAP en el código fuente. Mediante la
opción: Enhancement Operations -> Show implicit Enhancement Options aparecerán resaltadas las líneas de código
relacionadas con la ampliación. Las podemos encontrar en los siguientes lugares:
- Principio y final de un Include
- Principio y final de un Método, módulo de Función, Rutina
- Al final de una estructura
- Al final de las sección privada, protegida y publica de clases locales
2. Las ampliaciones de tipo explícito pueden implementarse en cualquier parte del código fuente a excepción de algunas
áreas restringidas por SAP. Para este tipo de ampliaciones existen dos formas:
- ENHANCEMENT-POINT: permiten agregar código extra en un programa fuente. Pueden ser estáticos (agregar nuevas
declaraciones) o dinámicos (agregar código con alguna funcionalidad extra).
- ENHANCEMENT-SECTION: es posible reemplazar parte del código existente. Puede ser estático (modificar declaraciones)
o dinámica (reemplazar la funcionalidad estándar)
Página 3 de 6
Como ejemplo vamos a utilizar el reporte RFBVBIC_0 que lee un archivo, compara y actualiza los datos bancarios proporcionados. La
13
intención es agregar un nuevo select-option para filtrar la información por el campo Sucursal.
- La ampliación a agregar es de tipo ENHANCEMENT-POINT ya que sólo se agregará un parámetro en la pantalla de selección.
14
- Se ingresa el nombre del ENHANCEMENT POINT y del ENHANCEMENT SPOT que deberán crearse.
Página 4 de 6
- Posicionar el cursor sobre la sentencia ENHANCEMENT-POINT y luego ir con el botón derecho del mouse
15
· En el siguiente cuadro de diálogo creamos la implementación correspondiente.
· Luego de este paso, en el programa aparecerán las sentencias ENHANCEMENT – ENDENHANCEMENT donde se debe agregar el
código nuevo.
16
· Por último, se activa el Enhancement
Página 5 de 6
17
· Seleccionar el código a reemplazar y luego con el botón derecho del mouse posicionarse en: Enhancements -> Create
· Posicionar el cursor sobre la sentencia ENHANCEMENT-SECTION y luego ir con el botón derecho del mouse a: Enhancement
18
· Luego de este paso, en el programa aparecerán las sentencias ENHANCEMENT – ENDENHANCEMENT donde se debe agregar el
código nuevo.
estándar.
· Lo único que se agrega en el programa estándar son estos Enhancements. La implementación de los mismos es Z, por consiguiente
19
· Solo puede haber una implementación activa para un 'ENHANCEMENT-SECTION'.
http://www.teknodatips.com.ar/sap-netweaver/118-ampliaciones-enhancements-a-programas-abap-en-erp-
60.html?showall=1&limitstart=
Teknodata
20