For straight through processing of uploaded funds transfer contracts, you would need to maintain all the reference information that you would typically maintain for normal funds transfer contracts and a few other parameters which are specific to STP.
Refer the ‘Maintenance’ chapter of the Payment & Collections (PC) User Manual for details on mapping the SWIFT tags to the PC contract fields. Let us understand the processing of different messages for various types of transactions through few examples: Case 1: The following example illustrates the successful processing of MT103 in the system. SWIFT BIC alone or SWIFT BIC plus //CC + 9 digit Canadian Sort Code (no spaces) in Subfield 1. Leave BLANK, if NOSCCATT. Name and address of receiving branch plus //CC + 9 digit Canadian Sort Code.:58A Beneficiary Institution Use Option A:72 Sender to Receiver Information Use of Codes /REC/ or /BEN/ will result in a non straight-through message. When using a MT 199 template, the SWIFT Type is automatically chosen as a 199 Payment. You cannot change this field. This field is automatically generated by your computer; it indicates how the message was created. The status field displays the current status of the message.
This chapter contains the following sections
A product, in Oracle FLEXCUBE, is a service your bank offers to your customers. The different types of funds transfers that your bank supports could be thought of as products. You would need to maintain products for funds transfer contracts that are initiated through straight through processing. The preferences for such products would need to be defined in the same manner as you would for a normal funds transfer product.
The product maintenance is required for the system to interpret the incoming message and create the appropriate FT contract. Since the STP process invokes the FT upload process, the product becomes one of the most important fields to be derived for creation of the contract upload table.
For more information on setting up products and defining specific preferences and attributes for products used for processing funds transfer contracts, consult the Funds Transfer user manual.
For each of the customers or banks (i.e., BIC Codes), you must maintain details of settlement accounts and settlement preferences, which would be used for processing funds transfer contracts being initiated through straight through processing. You must maintain this information for the straight through processing feature, just as you would do for normal funds transfer contracts. These standard instructions would be used when the incoming message itself does not contain the account information for the debit and credit accounts. The actual pick-up of the account is based on the contents of the incoming message itself. Details of this process are described in the discussion of the logic of pick-up of debit and credit accounts.
For more information on the settlements service in Oracle FLEXCUBE, and defining specific settlement preferences and attributes for funds transfer contracts, consult the Funds Transfer user manual.
You will need to maintain the Bank Identifier Codes for the banks, just as you would do for normal funds transfer processing.
For more information on BIC Codes, consult the Funds Transfer user manual.
Advices and messages are generated at the specified events in the lifecycle of funds transfer contracts. You should maintain the different media through which these advices and messages would be generated (from and to your bank).
At your bank, you can only receive or route messages through a media that you have maintained in Oracle FLEXCUBE. These specifications can be made only at the main branch and will be applicable to all the branches of your bank.
You must maintain the media that would be used for generation of advices and messages relating to funds transfer contracts that have been initiated through straight through processing, in the Media Maintenance screen.
In the context of STP, the relevant media type for which STP function is supported would be SWIFT.
For more information about the Media Maintenance screen and the messaging system module, consult the Messaging System user manual.
As discussed earlier, all Incoming SWIFT and Non Swift Messages are routed through a messaging queue. You are therefore, required to maintain the different user queues to which incoming messages will be directed. Users with appropriate rights will be allowed to access a particular queue.
To invoke this screen, click on Messages in the Application Browser, select Queues and click on Detailed under it. You can invoke the ‘Message Queue Maintenance’ screen by typing ‘MSDQUEUE’ in the field at the top right corner of the Application tool bar and clicking the adjoining arrow button.
In this screen you can capture the following details for a queue:
Note
The codes of various SWIFT and Non SWIFT messages list in the grid is not applicable for the collection queue.
You can assign a message to more than one messaging queue. At the time of maintaining rules for a message (discussed in the subsequent sections of this document), you can select the appropriate queue for each rule from the list of queues to which the message is linked.
As and when an Incoming SWIFT and Non SWIFT Common Payment Gateway Messages satisfy a particular rule, the system will automatically route it to the relevant queue associated with the rule. The product and other associated details (maintained at the product mapping level, discussed later) defined for the branch; queue and message type combination will be made applicable to translate the Message into a normal FT Contract.
Select ‘Add’ from the Actions menu in the Application tool bar or click add icon to add a message to the queue being defined. To remove a message from the queue, Select ‘Delete’ from the Actions menu in the Application tool bar or click delete icon.
As mentioned earlier, the messages and advices that are sent to the customers of your bank can be transmitted through different media types. You will need to maintain the address details for each media type. In the STP context, the relevant media type would be SWIFT. You can maintain multiple addresses for each media type. The unique location specified for each address will help you to differentiate between one address of a customer and another for a given media type. These details are captured in the ‘Customer Address’ screen.
For more information about the Customer Address Maintenance consult the Messaging System User Manual.
The advices that are generated from your bank will have a definite format. In the Advice Format Maintenance screen you can specify formats and indicate the messages and advices that should use the formats you have defined.
By maintaining message formats you can ensure consistency across the branches of your bank.
Message formats are maintained at the bank level and will be applicable to all the branches of your bank.
For each message format, you can specify the following details:
For more information about message formats, refer to the chapter ‘Maintaining Advice Formats’ in the Messaging System User Manual.
You must also map the message types and queue combinations to the relevant funds transfer products / product types / instrument types that you create, for straight through processing. This can be specified in the Product Mapping Screen, for each branch.
For each product / product types / instrument type, you must specify the message types, with details such as whether the messages would be incoming or outgoing and whether a cover is required.
From the Application Browser, you can invoke the Product Mapping Detailed screen.
You can invoke the ‘Message Product Mapping Maintenance’ screen by typing ‘MSDPRMAP’ in the field at the top right corner of the Application tool bar and clicking the adjoining arrow button.
Through this screen, you can map a message type to a product / product type / instrument that you have created in Oracle FLEXCUBE thereby supporting creation of instrument transactions and mapping of message queues for instrument types.
In the Product mapping screen on indicating the branch and message type you can map a product / product type / instrument to the combination.
All messages belonging to the ‘type’ you have indicated will be enriched with attributes defined for the product to which it is mapped.
Queue
For a branch, message and product combination, you can also specify the messaging queue to which the messages should be routed. As discussed earlier, you can assign multiple queues to a message type. All the queues defined for a message is available in the option-list. Select the appropriate queue from the list.
At the time of maintaining rules for a message type, you will indicate the queue to which the message must be routed, if it satisfies the rule being defined. The STP process will then associate the payment message with the product (and other related details) mapped to the queue to which it is routed and will subsequently process the payment transaction.
Note
You can map a message type with different funds transfer products and maintain unique preferences for each branch, message and product combination. Depending on the message type, the appropriate product will be picked up for creating the FT contract.
Cover Required
Whether a cover is required or not is decided based on the settlement instructions maintained for the party to which the onward message is sent.
Based on whether a cover needs to be sent to the reimbursement bank along with the payment message the appropriate FT product is selected for creating an FT contract.
Direction Flag
Specify whether the message for which you are maintaining details will result in an incoming FT or an outgoing FT.
Depending on your specification here the appropriate product will be picked up by the upload process and an FT Contract will be generated automatically.
Product
The system displays the FT product for creating an FT contract. It is selected on the basis of the requirement to send a cover to the reimbursement bank along with the payment message.
For your branch, you can indicate how Oracle FLEXCUBE should handle S.W.I.F.T. messages that do not carry information on the ultimate beneficiary and Non SWIFT Common Payment Gateway. The options available for SWIFT Messages that do not carry beneficiary information are:
If you indicate Suspense, the transfer amount indicated in the MT100, MT 103 or MT 202 is posted to suspense GL of your bank. This is applicable only when the incoming message results in an incoming Funds Transfer. In other words, your bank should be the last stop in the transfer route.
When you receive adequate information on the beneficiary, you can transfer the funds posted to the suspense GL to the customer account by liquidating the transfer. If you indicate ‘Repair’, the message will not be processed, and will be placed in ‘Repair’ status.
The preference that you stated for your branch in the Product Mapping detailed screen is defaulted. You can change the default to suit the current upload session.
An incoming SWIFT payment message may contain information regarding parties involved in a funds transfer, in the ‘D’ format, i.e., names and addresses, instead of the appropriate BIC Codes (or the ‘A’ format).
You can maintain mappings, which translate the ‘D’ formats to ‘A’ formats (BIC codes), which the STP process can use while processing. These details are known as converter records. These are maintained in the ‘D to A Converter Maintenance’ screen invoked from the Application Browser.
You can invoke the ‘D to A Converter Maintenance’ screen by typing ‘ISDDACNV’ in the field at the top right corner of the Application tool bar and clicking the adjoining arrow button.
When an incoming SWIFT payment message contains party information in the form of names and addresses (D format), the STP function uses the converter records to derive the BICs (A format) for the parties involved in the funds transfer.
The STP function replaces the name and address information (D format) in the message with the corresponding BIC (A format), picked up from the converter record.
The name and address information contained in the incoming SWIFT message will be matched exactly, line for line, literally and without case sensitivity, with the address lines information in the converter record to fetch the corresponding BIC to be used by the STP function.
The STP function will not convert this information using the converter record, as it does not literally match, line for line, with the address details maintained in the converter record.
As a convenience feature, Oracle FLEXCUBE also allows you to Copy the ‘D’ field from an incoming message’ and ‘Paste’ it onto the Converter Record.
In addition to the core processing logic that has been built into the system for processing SWIFT and Non SWIFT Common Payment Gateway Payment Messages, Oracle FLEXCUBE also allows you to maintain certain rule based processing logic and status control on the Incoming Messages, based on the contents of specific fields of the message.
Just as you define custom fields (User Defined Fields - UDF) to be associated with the various Oracle FLEXCUBE Products and Function Ids (Maintenance screens), you can also maintain UDFs for each Incoming Message (MT 100, MT 103, MT 200, MT 202). Based on your requirement, you can specify the default values (derived from field logic) and validations for the UDF. The system will validate all the entries made to the field of an Incoming Message against the validations (rules) you define for a field. All unprocessed messages in the Incoming Message Browser will be assigned a status (Repair, Pending Cover Match or Suppress) depending on the rules that you maintain for each message.
You can define the STP related fields (UDFs) and assign values to it in the ‘User Defined Fields for SWIFT Messages’ invoked from the Application Browser.
You can invoke the ‘STP Rule Maintenance’ screen by typing ‘MSDRLSTP’ in the field at the top right corner of the Application tool bar and clicking the adjoining arrow button.
Message Type
Maintain UDFs for the following SWIFT Payment Messages:
Specify the message for which you want to define the Rule based on which the STP will process the same.
Field Name
Specify a unique name to identify a field that you define. The STP process will get the value of the field from the logic specified in the ‘Field Logic’ column and will validate the entries made to these fields based on certain pre-defined conditions. You can use a maximum of 16 characters to assign a name to the UDF being defined.
Field Type
The type of field that you can create can be of the following formats:
Field Logic
The value of the field (UDF) being defined for a message type is derived based on the logic that you specify here. The value derived thus is subsequently validated against the rules maintained for the UDF.
The tags and the syntax for using these in the ‘Field Logic’ are as follows:
TAGS | SYNTAX | Value of the Field |
---|---|---|
@SENDER | @VALUE:=@SENDER() | Sender of the Message |
@BIC | @VALUE:=@BIC('TAG') | BIC code of the tag contained within quotes, for example, @BIC(‘57’) |
@ACC | @VALUE:=@ACC('TAG') | Account number specified in the tag |
@TAGVALUE | @VALUE:=@TAGVALUE('TAG') | The value of the tag specified |
@AMT | @VALUE:=@AMT(3) | The amount in the field 32 |
@CCY | @VALUE:=@CCY(2) | The currency of the transfer |
@VALDT | @VALUE:=@VALDT(1) | The value date of the transfer |
@TRAILER | @VALUE:= @TRAILER | The trailer of the message |
@HEADER | @VALUE:= @HEADER(3); | To get the value of tag 119 in block 3 |
@CUST_TYPE | @VALUE:= @CUST_TYPE() | The value returned is ‘I’, ‘B’ or ’C’ ( ‘Individual’,’Bank’,’Corporate’ respectively) |
@VALDT | @VALUE:=@VALDT(1); |
Depending on the value of the UDF (obtained from the Field Logic), you can define additional conditions (or rules) to process the message. You can also specify a status for each condition. If a particular condition is satisfied, the system will automatically assign the corresponding status to the message.
To define the conditions for a message, click ‘Show Rule’ button in the ‘User Defined Fields for SWIFT Messages’ screen. The ‘Rule Maintenance’ screen is displayed.
If you expect user interaction for the Non Swift Message, choose ‘Waiting for Queue change’ as the Status.
The Message Type is defaulted from the previous screen.
Priority
For a particular message type, you can define multiple conditions to validate the UDF’s based on which the message is assigned a particular status. Each set of five conditions will be associated with a priority number. The system automatically assigns the next available priority number to the next set of five conditions. If a condition with a higher priority level is satisfied, the status associated with that condition is assigned to the message.
Select ‘Add’ from the Actions menu in the Application tool bar or click add icon to specify the next set of conditions. To remove a set of conditions, select ‘Delete’ from the Actions menu in the Application tool bar or click delete icon.
Conditions
Using the tags mentioned above, you can specify the following conditions for processing the Incoming SWIFT and Non SWIFT Messages:
Result
Select multiple conditions for validating the value (derived from the Field logic) of an UDF. Each condition can be assigned one of the following values:
Queue Name
Choose the queue, to which a message will be routed if a particular condition is satisfied. As discussed earlier, you can specify multiple queues for a message. All the queues maintained for a specific message will be available for selection in the form of an option-list. Select the appropriate ‘Queue Name’ from the list.
Status
Each condition that you define can be associated with a status. If a condition is satisfied, the status defined for that condition will be assigned to the Incoming Message. The following statuses are available for selection:
Repair Reason
In case you choose to assign the status as ‘Repair’, you can indicate the reason for repair. Select the appropriate error code from the option list.
Note
The ‘Repair Reason’ field is enabled only if you have chosen the status as ‘Repair’.
The repair reason that you can assign is in turn user definable, as explained below.
You can invoke the ‘Error Message Maintenance’ screen by typing ‘CSDERRMS’ in the field at the top right corner of the Application tool bar and clicking the adjoining arrow button.
In the Error Messages screen, you can maintain your own error codes and appropriate messages. These will be displayed during message upload if that particular condition (for which the error message is mapped) occurs.
You can specify the following details for an error message:
Specify the details pertaining to the branch for converting the old error code to a new one for a branch based on the Function Id.
Branch Code
Specify the code of the branch for which you want to map update the error code.
Old Error Code
Specify the old error code that needs to be replaced with the new one.
New Error Code
Specify the new error codes that with which you want to replace the old one.
Function Id
Specify the Function Id on the basis of which you want to replace the error code.
If you wish to defer processing of a message till receipt of a cover, based on certain criteria, then you can select the ‘Pending Cover Match’ status for that condition. If that condition is encountered, Oracle FLEXCUBE will update the message status to ‘Pending Cover Match’ and process the payment only after receipt of the cover.
When the system receives an MT103/MT202/MT200, it will process the message based on the STP Rule you have defined for the same.
Straight through processing of MT103 and MT202 can be performed based on the customer type and amount limit. You can maintain STP rules for a combination of customer type and transaction amount, based on which the transaction is either processed or moved to ‘Repair’ status.
If, as per the rule, the message moves to a queue which requires ‘Cover Matching’, it will be marked as ‘Pending Cover Match’. Subsequently, as mentioned above, when the Cover message is received, the system will process the original MT103/MT202 message.
If the Queue is mapped to a PC Product Category then a PC Contract will be created. The ‘PC Message Mapping’ screen will be used to map the message fields to the PC Contract fields.
While processing an incoming MT200, the system checks for the following:
If the BIC of the receiver and the AWI are same then the transaction is treated as the transaction ending with us. If this condition is not satisfied, the system will not upload this incoming message which would further result in the generation of outgoing MT205.
In case of an incoming MT103, if the beneficiary account is a Trust account, the system will put the transaction in ‘Unauthorized’ status even if the post upload status has been maintained as ‘Authorized’ in the STP preference. If field 70 is null in the incoming MT103 message for Trust account payment, the system will not process that payment. Instead, it will move the transaction in the repair queue. It will also raise the override message as ‘Project Details needs to be captured for the trust account transaction’.
You will have to manually unlock the transaction and capture project details for it. While saving the transaction, the system will check whether project details have been captured or not.
Note
Following maintenances are mandatory before initiating MT101 from interfaces. Function IDs to access the respective maintenance screens are given in brackets.
Accounting
By routing the transaction to the appropriate module & product, without manual intervention system will be capable to interrupt the following instruction codes and also book appropriate transactions
Transactions View
MT201 message is for Multiple Financial Institution Transfer for its Own Account. The Incoming MT201 message is processed in the same manner as MT203. The Incoming MT201 is split into individual MT200 messages and then these generated MT200 messages are processed as individual MT200.
Refer the ‘Maintenance’ chapter of the Payment & Collections (PC) User Manual for details on mapping the SWIFT tags to the PC contract fields.
Let us understand the processing of different messages for various types of transactions through few examples:
Case 1:
The following example illustrates the successful processing of MT103 in the system.
Assume Company A orders Bank A to pay Company B’s account in Bank B. The diagram depicts the transaction and message flow in the system.
Once the PC transaction is booked and if the product is an RTGS product, the system processes the transaction in the following sequence:
Thus, a payment initiated from Bank A is successfully processed in Bank B.
Case 2:
The following example illustrates the processing MT103 in case of insufficient Funds in Initiating Bank.
Assume Company A orders Bank A to pay Company B’s account in Bank B. The diagram below depicts the transaction and message flow in the system.
Once the PC transaction is booked and if the product is an RTGS product, the system processes the transaction.
When a payment initiated from Bank A is rejected by NBS for lack of funds, the message is processed in the following manner:
Case 3:
The following example illustrates the processing of MT103 message which is in Wait State.
Assume Company A orders Bank A to pay Company B’s account in Bank B. The diagram below depicts the transaction and message flow in the system.
Once the PC transaction is booked and if the product is an RTGS product, the system processes the transaction.
When a payment initiated from Bank A is in the wait status in NBS, the message is processed in the following manner:
Case 4:
The following example illustrates the MT195 check carried out for MT103 message in Wait State.
Assume Company A orders Bank A to pay Company B’s account in Bank B.
Let us assume the following:
Once the PC transaction is booked and if the product is an RTGS product, the system processes the transaction. When a payment initiated from Bank A is in the wait status in NBS and subsequent checking from the Bank on the status of the message, the processing for the message is done in the following sequence:
Case 5:
The following example illustrates the process in which MT192 request for cancellation of the MT103 in Wait State is handled in the system along with the approval of cancellation by NBS.
Assume Company A orders Bank A to pay Company B’s account in Bank B. The diagram below depicts the transaction and message flow in the system.
Let us assume the following:
Once the PC transaction is booked and if the product is an RTGS product, the system processes the transaction.
If you choose the ‘Suppressed’ status, the incoming message itself gets suppressed. The Oracle FLEXCUBE STP process will not pick up SWIFT Payment Messages with a Suppressed status for further processing.
If a message is in repair, you can pre-define two possible statuses to which the message would go after the message is manually repaired. These are indicated by the two check boxes viz.:
If ‘Cover Required’ flag is checked, the message would move to the ‘Pending Cover Match’ status after repair of the message, while if the ‘Suppress message’ flag is on, the payment (post-repair) would be processed normally, but the resultant outgoing messages would be suppressed.
After you specify the logic for deriving the value of an UDF, it will be validated by the system (on Save of the Rule maintenance). The system automatically generates a procedure based on the logic specified by you and if any checks fail, you can view the errors in the ‘Errors’ screen invoked from the ‘User Defined Fields for SWIFT Messages’ screen. The statement containing the error will be highlighted for easy identification. You can return to the previous screen and alter the statement so that the validations are carried out successfully.
Click ‘Error’ button to view the errors.
FT contracts can be uploaded onto Oracle FLEXCUBE from any external source. However, the details that come in the form of SWIFT messages are converted to data in the FT Upload tables by the Message Upload function, from where the FT Upload function picks them up for processing.
When you maintain details of a source, you can also specify characteristics for contracts coming into the FT Upload tables from the source. Besides defining the operations that can be performed on contracts uploaded from the source, you can also define the status that uploaded contracts should be marked with.
Upload sources can be maintained at the Head Office level and propagated to the branches of your bank.
The maintenance of upload sources helps to retrieve information for a given source.
The procedure for maintaining details of an upload source has been discussed under the head ‘Maintaining upload sources’, in the Batch Upload chapter of the Funds Transfer user manual
You can maintain preferences for contracts uploaded by the FT Upload process, to be applicable based on the branch that is initiating the upload. The following preferences can be set:
To set up the branch-level preferences, to be applicable for uploads, for a branch and message type combination, you can use the STP Branch Preferences screen.
You can invoke the ‘STP Preferences’ screen by typing ‘MSDSTPRF’ in the field at the top right corner of the Application tool bar and clicking the adjoining arrow button.
In this screen, you can maintain the preferences to be applicable for uploads initiated in:
Queue Name
Specify STP Preferences at a messaging Queue level for FT contracts uploaded from a source for a particular branch. The adjoining option list displays all valid queue names maintained in the system. You can choose the appropriate one.
If an account statement (MT 940/950) is identified as a Cover message for a corresponding payment message, then the system will pick the corresponding Payment message (MT 103/ 202) that was kept on hold for further processing.
When an MT 103/ 202 is received from any other banks apart from our correspondent banks, then as part of STP processing, the system moves the Payment message (MT 103/202) to a Cover matching queue with status as ‘Pending Cover Match’.
The messages corresponding to account statement (i.e.,) MT 940 / 950 will also be available in Incoming Browser using NR module.
If an MT 940 / 950 is received, the system will validate the following criteria to check if a corresponding credit entry in the account statement message can be considered as an acknowledgement of cover for a Payment message (MT 103/202).
Sub Field | Description | Format | Value | Applicable Values | |||||
---|---|---|---|---|---|---|---|---|---|
3 | (Debit/Credit Mark) | 2a | C | C, D, RD, RC | (C-Credit, D-Debit, RC – Reversal Credit, RD – Reversal Debit) | ||||
6 | (Transaction Type Identification Code) | 1!a3!c | S, 103/202 | N, S, F | (S - For entries related to SWIFT transfer instructions and subsequent charge messages | S - For entries related to payment and transfer instructions, including related charges messages, not sent through SWIFT | F - For entries being first advised by the statement (items originated by the account servicing institution) | In case of fund code – S, The three characters will indicate the message type of the SWIFT message causing the entry (for debit entries) or the message type of the SWIFT message used to advise the account owner (for credit entries) | In case of Fund code – N or F, it can contain any of the swift identified Transaction type codes. |
On receipt of above identified MT 940/ 950 message, the STP process matches the credit entries with the corresponding Payment message MT 103/202 that satisfies the following condition:
If the above condition is satisfied, then the system will pick the corresponding Payment message MT 103/202 from Pending Cover queue for further processing.
If a corresponding Cover message (or) funds are not received for a Payment Message (MT 103 / 202), you should manually do a force cover matching to proceed with further processing on MT 103 or manually return the Payment message due to funds not received.
This maintenance will be used to define following preferences applicable for uploads initiated in the branches:You can maintain the following preferences:
Branch | Message Type | Queue |
---|---|---|
Specific | Specific | Specific |
Specific | Specific | All |
Specific | All | Specific |
Specific | All | All |
All | Specific | Specific |
All | Specific | All |
All | All | Specific |
All | All | All |
Post Upload Status
The status of the contract on successful upload (Post Upload Status). This could be :
When no Beneficiary Found
How incoming funds transfers in respect of which the beneficiary is not found, are handled during upload. You can specify any of the following options:
On Error
How errors encountered in respect of contracts during upload, would be handled (On Error). You can specify any of the following options:
On Override
How overrides encountered in respect of contracts during upload, would be handled (On Error). You can specify any of the following options:
Note
This maintenance is part of the Reconciliation module of Oracle FLEXCUBE. This is used to map the nostro accounts in your Bank’s books to the actual account numbers in the books of you Correspondent Banks.
The procedure for maintaining details of External Accounts has been discussed in the Reconciliation Module user manual
The STP process (apart from the User defined Error Codes) also checks for various error conditions based on the contents of the message and their interpretation during the processing of the message., for instance limit checks, available balance checks, dormant account checks, etc. The actual result of the upload (whether it fails with an error or goes through with an override) depends on the configuration of the error codes.