It may not always be the case that Account codes will be created by user from the front end. There may be scenarios sometimes where we need to have programs that will be creating the code combinations.
Oracle has provided the API's that can be used to create code combinations , we will be discussing a couple of them here.
Pre-requisits
Now we will discuss the API's:
‘SQLGL’,
‘GL#’,
chart_of_accts_id,
concatenated_segments,
‘V’,
SYSDATE,
‘ALL’, NULL, NULL, NULL, NULL,
FALSE,FALSE, NULL, NULL, NULL);
Oracle has provided the API's that can be used to create code combinations , we will be discussing a couple of them here.
Pre-requisits
- When trying to create the code combinations via the API is that in the Key Flexfields setup , for the KFF defined for your Accounting segments the check box Allow Dynamic Inserts need to be enabled, then only will the code combination be created else the API will never create the accounting segments.
- User needs to do initialization
- The Accounting flex-filed Value sets need to be populated with the values being used in the account being created
Now we will discuss the API's:
- fnd_flex_ext.get_ccid , this API will take in the input parameters and return the code combination id of the account segment created. In case the API is not able to create the account segmewnts for any reason or in case of an error the API will return 0.
API syntax:
fnd_flex_ext.get_ccid
(application_short_name => 'SQLGL',
key_flex_code => 'GL#',
structure_number => p_chart_of_accounts_id,
validation_date => SYSDATE
concatenated_segments => allsegments
);
The API takes in all these parameters as input:
application_short_name : this is the short name of the General Ledger Application
key_flex_code : this is to be hardcoded as GL#
structure_number : this is to be the chart of account id in which the account
is to be created
validation_date : Pass SYSDATE
concatenated_segments : the account code segments in concatenated format
Once the API is run , if the account creation is successful then the CCID of the account is returned else the program will return 0.
2. FND_FLEX_KEYVAL.VALIDATE_SEG , the API will take in the input parameters based
on which the account code will be created , the API returns a BOOLEAN message of
TRUE : signifying success or FALSE : in case API was not successful
API syntax:
FND_FLEX_KEYVAL.VALIDATE_SEGS(
‘CREATE_COMBINATION’,‘SQLGL’,
‘GL#’,
chart_of_accts_id,
concatenated_segments,
‘V’,
SYSDATE,
‘ALL’, NULL, NULL, NULL, NULL,
FALSE,FALSE, NULL, NULL, NULL);
If the API is successful the the account segment will be created and the API will
return a status TRUE , in case any error occurs he the account code creation will
fail and the API will return a status FALSE, In case of any error the API will
populate the Error in the fnd_message queue.
The user will have to retrieve the error message from there to see the error
occurred:
occurred:
l_chr_error_msg := fnd_flex_keyval.error_message