| Oracle® Application Integration Architecture Oracle Financial Management Integration Pack Implementation Guide for Oracle Transportation Management and Oracle E-Business Suite Release 3.1 Part Number E50313-01 | 
 | 
| 
 | PDF · Mobi · ePub | 
This chapter provides an overview of currency exchange rates process integration and discusses business process flows, assumptions and constraints, Oracle E-Business Suite (Oracle EBS) and Oracle Transportation Management (OTM) interfaces, core Oracle Application Integration Architecture (Oracle AIA) components, and integration services.
This chapter includes the following sections:
Currency exchange rate is the reference information used in the translation of monetary values from one currency to another. The exchange rate expresses the value of one currency in terms of another. The process integration for currency exchange rates enables you to use Oracle EBS Financials as an accounting engine and OTM for invoices and bills transactions.
The process integration for currency exchange rates between Oracle EBS and OTM supports these integration flows:
Initial load of currency exchange rates: Extracts and loads the initial currency exchange rates from Oracle EBS to OTM.
Incremental updates of currency exchange rates: Enables the synchronization of incremental creation and updates of the currency exchange rates from Oracle EBS to OTM.
This integration is not a point-to-point integration between Oracle EBS General Ledger and OTM. An Oracle AIA layer serves as an intermediate thin layer of application between Oracle EBS General Ledger (GL) and OTM. As a part of the currency exchange rates integration, Oracle EBS GL sends the currency exchange rates to the Oracle AIA layer and the Oracle AIA layer delivers the information to OTM. This Oracle AIA layer performs message filtering, message transformation, and message routing.
Figure 2-1 illustrates the integration of currency exchange rates.
The purpose of this flow is to load the existing currency exchange rates from Oracle EBS into OTM by triggering the CurrencyExchangeListEbizJMSProducer service.
Note:
Contact your Oracle Service-Oriented Architecture (Oracle SOA) Administrator to obtain the end point of the CurrencyExchangeListEbizJMSProducer web service.
The service expects the inputs listed in Table 2-1.
Table 2-1 Parameters for Loading Currency Rates
| Fields | Value | 
|---|---|
| from_currency | xsd:string | 
| to_currency | xsd:string | 
| from_date | xsd:date | 
| to_date | xsd:date | 
| conversion_rate_type | xsd:string | 
The from_date field is mandatory. If the to_date is not specified it takes the current date as the TO_DATE. The valid date format is YYYY-MM-DD (2008-02-09). The rest of the fields are optional. You can use those fields to limit the rates, which are required to be loaded from Oracle E-Business Suite to OTM. Use the appropriate date range based on the load of data and performance of the server.
Figure 2-2 illustrates the initial loading of currency exchange rates.
When you initiate the initial load of currency exchange rates process, these events occur:
Oracle E-Business Suite invokes the CurrencyExchangeListEbizJMSProducer whenever a currency exchange rate is created or loaded into Oracle E-Business Suite.
The CurrencyExchangeListEbizJMSProducer extracts all the currency exchange rates from the Oracle E-Business Suite database based on the dates provided in the Business Process Execution Language (BPEL) console and moves the currency exchange rates into the AIA_EbizCurrencyExchangeJMSQueue.
The CurrencyExchangeListEbizJMSConsumer service picks up the message from the AIA_EbizCurrencyExchangeJMSQueue and invokes the SyncCurrencyExchangeListEbizReqABCSImpl, which transforms the message into the SyncCurrencyExchangeListEBM. Then, the SyncCurrencyExchangeListEBM invokes the CurrencyExchangeEBS.
The CurrencyExchangeEBS receives the SyncCurrencyExchangeListEBM and invokes the SyncCurrencyExchangeListLogisticsProvABCSImpl.
The SyncCurrencyExchangeListLogisticsProvABCSImpl receives the SyncCurrencyExchangeListEBM and transforms it into the CurrencyExchangeOTMABM.
The LogisticsWebService is invoked with this transformed application business message (ABM) and the instance asynchronously waits for a transmission report from OTM. If the transaction is successful, then the cross-reference values are populated for OTM columns for each of the currency exchange IDs listed in the SyncCurrencyExchangeListEBM; otherwise it invokes the AIAAsyncErrorHandlingBPELProcess with an error message.
The currency exchange rates that are created or updated in the Oracle EBS must be updated in the OTM.
Figure 2-3 shows the incremental updates for currency exchange rates:
In the Oracle E-Business Suite user interface, the user updates or adds new currency exchange rates, which triggers and event that automatically invokes the SyncCurrencyExchangeListEbizAdapter. This adapter invokes the CurrencyExchangeListEbizJMSProducer, which queries the Oracle E-Business Suite database for currency exchanges rates and drops the message in AIA_EbizCurrencyExchangeJMSQueue.
The CurrencyExchangeListEbizJMSConsumer service picks up the message from the AIA_EbizCurrencyExchangeJMSQueue and invokes the SyncCurrencyExchangeListEbizReqABCSImpl, which transforms the message into the SyncCurrencyExchangeListEBM, and the SyncCurrencyExchangeListEBM invokes the CurrencyExchangeEBS.
The CurrencyExchangeEBS receives the SyncCurrencyExchangeListEBM and invokes the SyncCurrencyExchangeListLogisticsProvABCSImpl.
The SyncCurrencyExchangeListLogisticsProvABCSImpl receives the SyncCurrencyExchangeListEBM and transforms it into the CurrencyExchangeListOTMABM.
The LogisticsWebService is invoked with this transformed application business message (ABM), and the instance asynchronously waits for a transmission report from OTM. If the transaction is successful then the cross-reference values are populated for OTM columns for each of the currency exchange IDs listed in the SyncCurrencyExchangeListEBM; otherwise it invokes the AIAAsyncErrorHandlingBPELProcess with an error message.
These are the solution assumptions and constraints:
The Oracle EBS is responsible for adding and maintaining the currency exchange rates and types. Oracle EBS is the currency exchange rate master and all data from the Oracle EBS is synchronized to OTM.
The currency rate types and currency codes are different in Oracle EBS and OTM applications. The domain value maps (DVMs) are set up and maintained manually by both Oracle EBS and OTM in the Oracle AIA layer to have a common value.
Oracle EBS currency precision limit is limited to four digits (Example: $120.0001). OTM precision length must be setup at four digits to avoid rounding errors.
The currency exchange rates in OTM are synchronized to the public domain and this is changed by a property in the Oracle AIA configuration file.
For the currency exchange rates integration flow, these are the Oracle EBS interfaces:
Oracle EBS General Ledger (GL) exposes a business event called oracle.apps.gl.CurrencyConversionRates.dailyRate.specify as an interface to subscribe to the creation and updates of currency exchange rates.
Oracle EBS also provides an API called the GET_CUR_CONV_RATES interface in the GL_EXCH_RATES_SYNC_PKG that helps to retrieve the complete information of exchange rates.
For more information about Oracle EBS web services and documentation prior to Release 12.1.3, see the library on Oracle Technology Network: http://www.oracle.com/technetwork/documentation/applications-167706.html?. For Oracle E-Business Suite documentation for R12.1.3 and beyond, see this library: http://download.oracle.com/docs/cd/E18727_01/index.htm.
OTM provides an interface through a web service to connect to its application. This connectivity is established as a partner link in the provider service. Once invoked, the logistics web service immediately returns an acknowledgment with a transmission number. Once the processing is complete, it sends a transmission report back indicating the success or the failure. The application business message (ABM) details can be seen in the GLOG xsd with the ExchangeRate element.
For more information about the Logistics Service, see Oracle Transportation Management Integration Guide.
The currency exchange rate integration flow uses these components:
CurrencyExchangeEBO
SyncCurrencyExchangeListEBM
CurrencyExchangeEBS
The core enterprise business object (EBO) and enterprise business message (EBM) XSD files can be located by EBO within the $AIA_HOME/AIAMetaData/AIAComponents/EnterpriseObjectLibrary/Core/EBO/ parent folder.
The core enterprise business services (EBS) web services definition language (WSDL) files can be located by EBO within the $AIA_HOME/AIAMetaData/AIAComponents/EnterpriseBusinessServiceLibrary/Core/EBO/ parent folder.
For detailed documentation of individual EBOs and EBMs, click AIA Reference Doc link on EBO and EBM detail pages in the Oracle Enterprise Repository.
For more information about using the Oracle Enterprise Repository and configuring it to provide the AIA Reference Doc link, see Oracle Fusion Middleware Developer's Guide for Oracle Application Integration Architecture Foundation Pack, "Configuring and Using Oracle Enterprise Repository as the Oracle AIA SOA Repository."
EBOs can be extended, for instance, to add new data elements. These extensions are protected, and remain intact after a patch or an upgrade.
For more information, see Oracle Fusion Middleware Developer's Guide for Oracle Application Integration Architecture Foundation Pack, "Extensibility for AIA Artifacts".
These are the services involved in the currency exchange rate integration:
SyncCurrencyExchangeListEbizAdapter
CurrencyExchangeListEbizJMSProducer
CurrencyExchangeListEbizJMSConsumer
SyncCurrencyExchangeListEbizReqABCSImpl
CurrencyExchangeEBS
SyncCurrencyExchangeListLogisticsProvABCSImpl
CurrencyExchangeResponseEBS
This service is used for incremental changes. This service listens to the oracle.apps.gl.CurrencyConversionRates.dailyRate.specify business event and invokes the CurrencyExchangeListEbizJMSProducer, which then queries the Oracle E-Business Suite database for currency exchange rates with the Event ID.
The CurrencyExchangeEbizJMSProducer service is a Business Process Execution Language (BPEL) process. The Oracle E-Business application invokes this service when either is a new currency exchange rate is created, or an existing currency exchange rate is updated.
This service is also used when doing an initial load of the exchange rates from Oracle E-Business Suite. It takes the From and To date and the From and To Currency as inputs. These inputs can come from the event or are directly provided in an initial load. The database adapter reads all the currency exchange rates from the Oracle E-Business Suite database based on the dates entered. If the To_Date is not provided, it assumes today's date. Based on the From_Date, To_Date from the input and a property (NoOfDays) from the AIAConfigurationFile, the Oracle E-Business Suite API (get_cur_conv_rates) is called to obtain the currency exchange rates. Then, the Currency Exchange Rates are dropped in the AIA_EbizCurrencyExchangeJMSQueue. The NoOfDays property in the CURRENCYEXCHANGE module must be specified to determine the cursor size in which the exchange rates are retrieved. Based on the processing capabilities of the system, an appropriate value must be provided for this property.
The CurrencyExchangeListEbizJMSConsumer is a mediator service. It has a JMS adapter called CurrencyExchangeListEbizJMSConsumer. This adapter listens to the AIA_EbizCurrencyExchangeJMSQueue and picks up the messages for which JMSCorrelationID is SyncEbizCurrencyExchange. This invokes the SyncCurrencyExchangeListEbizReqABCSImpl with the CurrencyExchangeListEbizABM.
The SyncCurrencyExchangeListEbizReqABCSImpl is a Business Process Execution Language (BPEL) process, which receives the CurrencyExchangeListEbizABM from the CurrencyExchangeListEbizJMSConsumer and transforms the message into the SyncCurrencyExchangeListEBM.
These domain value map (DVM) lookups are used by this service:
CURRENCY_CODE: domain value mapping for currency codes.
CURRENCYEXCHANGE_CONVERSIONTYPECODE: domain value mapping for currency type codes.
CURRENCYEXCHANGE_STATUSCODE: domain value mapping for status code of currency exchange rates.
In addition, this service populates the EBM header variable and cross-reference table and invokes the CurrencyExchangeEBS.
The CurrencyExchangeEBS is an enterprise business service that exposes all the enterprise operations related to the currency exchange like create currency exchange, update currency exchange, and so on. This integration uses the SyncCurrencyExchangeList operation.
This enterprise business service routes the request to the appropriate provider like the SyncCurrencyExchangeListLogisticsProvABCSImpl or the Composite Application Validation System (CAVS), based on the filter condition and operations. Updates and creates are done using the synchronize action. No transformations are done in this service. OTM determines whether this synchronize currency exchange rate message is for create or an update action.
For more information about this enterprise business service (EBS), see Oracle Fusion Middleware Developer's Guide for Oracle Application Integration Architecture Foundation Pack, "Designing and Developing Enterprise Business Services" and Oracle Fusion Middleware Concepts and Technologies Guide for Oracle Application Integration Architecture Foundation Pack, "Understanding Enterprise Business Services"
The SyncCurrencyExchangeListLogisticsProvABCSImpl is a Business Process Execution Language (BPEL) process, which receives the SyncCurrencyExchangeListEBM, transforms the message into the CurrencyExchangeListOTMABM, invokes the LogisticsWebService with the SyncCurrencyExchangeListEBM and waits for the transmission report from the LogisticsWebService. If the transmission report specifies the transaction is successful, it populates the cross-reference values otherwise it invokes the AIAAsyncErrorHandlingBPEL process to generate the error messages.
These DVM lookups are used by this service:
CURRENCY_CODE: domain value mapping for currency codes.
CURRENCYEXCHANGE_CONVERSIONTYPECODE: domain value mapping for currency type codes.
The CurrencyExchangeResponseEBS is the enterprise business service (EBS) used to route all currency exchange response related actions to the requesting application like create currency-exchange rates, update currency-exchange rates, delete currency-exchange rates, and synchronize currency-exchange-list rates.