Leccion 4/9: Modulos de funcion RFC
1. MODULO DE FUNCION RFC
Consiste en llamar a una funcion que existe en un sistema distinto al del programa que le llama.
El objetivo principal de las RFC es acceder a otros ambientes para obtener datos.
La comunicacion puede darse entre sistemas SAP o entre un sistema SAP y otro que no sea SAP.
- Para llamara un función RFC se debe agregar la clausula DESTINATION al momento de declarar la función, como vemos en el siguiente ejemplo.
LA RFC LLAMADA NO EXISTE EN EL SISTEMA ORIGEN PERO SI DEBE EXISTIR EN EL SISTEMA DESTINO
Ejemplo de cuando Utilizar una RFC
- Si queremos leer un registro de un cliente del sistema o ambiente DCR, a través de un programa ABAP existente en el ambiente DTR, crearíamos una RFC den DCR que devuelva los registros de los clientes.
- Luego llamar a esta función en el ambiente DTR utilizando un destino que previamente hemos creado a través de la transacción SM59 como se vera mas adelante
NOTA: si se produjera un error en la ejecución de una RFC, los mensajes de error son devueltos por el sistema remoto y alojados en las variables del sistema SY-MSGID, SY-MSGTY, SY-MSGNO, SY-MSGV1, SY-MSGV2, SY-MSGV3 SY-MSGV4.
2. CREAR UNA FRC
Se crea de la misma manera que se crea una función.
1. Acceder a la transaccion SE37
2. completar los mismos parametros que completamos para crear una funcion a excepcion que se debe seleccionar en la solapa de "Atributos" la opcion "Modulo de Acceso remoto (Remote Enabled Module)"
NOTA: Los parámetros que se crean en una función RFC no se pueden pasar por REFERENCIA, deben pasarse por valor.
Esto se logra tildando el check "Transportar valores (Pass value) para cada parametro en las solapas IMPORT, EXPORT Y CHANGING.
Las funciones creadas como RFC también pueden ser utilizadas como módulos de función normales. Esto se logra de dos maneras diferentes.
Utilizando la declaración CALL FUNCTION DESTINATION 'NONE'.
Utilizando la declaración de un modulo de función normal, sin el agregado de la clausula DESTINATION
3. TIPOS DE RFC
Existen 3 tipos:
3.1 SINCRÓNICAS ambos sistemas deben estar disponibles al momento de la llamada de la función. Estas RFC están basadas en una comunicación sincrónica.
NOTA: Para nuestros desarrollos utilizaremos generalmente el tipo de RFC sincrónico.
3.2 TRANSACCIONALES los sistemas no necesitan estar disponibles al momento de la llamada a la función. Un único ID de transacción es generado y los programas llamados son almacenados en el sistema junto con los datos. para crear una RFC transaccional debo utilizar el sufijo IN BACKGROUND TASK ver gráfico 3.1 page 29 del texto guía.
En las RFC transaccionales, el sistema deja un log con el pedido de la llamada remota en las tablas estandar de SAP ARFCSSTATE y ARFCSDATA con todos los valores de los parametros basados en la ejecucion.
NOTA: Las tablas ARFCSSTATE y ARFCSDATA son tablas estándar del sistema SAP que almacenan información relacionada a la llamada de RFC transaccionales en el sistema.
para visualizar el log de errores de las RFC transaccionales que se ejecutaron en el sistema se usa la transacción SM58
NOTA: el tipo de RFC Transaccional utilizaremos para ciertos casos específicos de actualizaciones donde no se requiera que dichas actualizaciones se realicen en forma inmediata sino recién cuando el programa llamador ejecuta un COMMIT WORK.
3.3 ASINCRÓNICAS. El programa llamador, llama a la función RFC e inmediatamente después termina a su procesamiento. Luego la función RFC se ejecuta independientemente del programa llamador.
Para crear una RFC asincronica se debe utilizar el sufijo STARTING NEW TASK
Sintaxis:
CALL FUNCTION RemoteFunction SATARTING NEW TASK taskname
Destination ...
EXPORTING...
TABLES ...
EXCEPTIONS...