Módulo de función RFC: consiste en una llamada a una función que existe en un sistema distinto al programa que la llama. Su principal objetivo es acceder a otros ambientes para obtener datos. La comunicación puede darse entre sistemas SAP o entre un sistema SAP y otro sistema que no sea SAP.
Para llamar a una función RFC se debe agregar la cláusula DESTINATION al momento de declarar la función.
DESTINATION: Claúsula ABAP que se utiliza en la declaración de módulos de función RFC para especificar un destino RFC.
La RFC llamada no existe en el sistema origen pero si debe existir en el sistema destino.
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 y SY-MSGV4.
Una función RFC se crea de la misma manera que se crea una función, accediendo a la transacción SE37 y se completan los mismos parámetros que completamos para crear una función a excepción de que se debe seleccionar en la solapa de atributos la opcion MODULO DE ACCESO REMOTO (REMOTE ENABLED MODULE).
Los parámetros que se crean en una función RFC no se pueden pasar por REFERENCIA, deben pasarse por valor. Esto se hace tildando el check TRANSPORTAR VALORES (PASS VALUE) para cada parámetro en las solapas IMPORT, EXPORT Y CHANGING.
También las funciones RFC pueden ser utilizadas como módulos de función normales, esto se logra utilizando la declaración CALL FUNCTION DESTINATION 'NONE' o utulizando la declaración de un módulo de función normal, sin el agregado de la cláusula DESTIANTION.
Tipos de RFC:
Sincrónicas: ambos sistemas deben estar disponibles al momento de la llamada de la función, se basan en una comunicación sincrónica. En general son las más usadas.
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. 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 pasados en la ejecucion. Para visualizar este LOG se usa la trasacción SM58. Cuando el programa que ejecuta la RFC ejecuta la sentencia COMMIT WORK entonces es cuando la llamada remota es enviada al sistema remoto para su ejecución.
UTILIZAREMOS EL TIPO DE RFC TRANSACCIONAL PARA CIERTOS CASOS ESPECIFICOS DE ACTUALIZACIONES DONDE NO SE REQUIERA QUE DICHAS ACTUALIZACIONES SE REALICEN EN FORMA INMEDIATA SINO RECIEN CUANDO EL PROGRAMA LLAMADOR EJECUTA UN COMMIT WORK.
Asincrónicas: el programa llamador, llama a la función RFC, e inmediatamente después termina su procesamiento. Luego la función RFC se ejecuta independientemente del programa llamador, para la creación se usa el sufijo STARTING NEW TASK.
NO ES POSIBLE DEBAGUEAR UNA LLAMADA A UNA RFC REMOTA DE OTRO SISTEMA, SI DESDE SISTEMA SAP A OTRO SISTEMA SAP.