CREATE OR REPLACE PACKAGE xx_gl_je_cnv_pkb AUTHID CURRENT_USER AS
--Version Draft 1a
/******************************************************************************************************************
* Package Name : xx_gl_je_cnv_pkb *
* Purpose : This program checks for pre-requisites, validates the GL JE data in the staging table. If *
* all the records are through the validations, then populate the standard interface *
* to create the journal information in base tables. *
* *
* *
* Procedures : *
* --------------------- *
* main : Main procedure registered as the executable file name, which *
* calls the other procedures *
* *
* validate_setups : Validate Certain prerequisite setups in Oracle Apps *
* *
* validate_records : Validate and update records in staging table *
* *
* process_records : Populate the standard interface tables *
* *
* Tables Accessed : *
* Access Type-------- (I - Insert, S - Select, U - Update, D - Delete) *
* *
* xx_gl_je_cnv : S,I,U,D
* xx_gl_int_preint : S,I,U *
* gl_interface : I,U *
* *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
********************************************************************************************************************/
/*-----------------------------------------------------------
Public Constant Declaration Section
------------------------------------------------------------*/
--
g_program_type xx_emf_message_headers.program_type%TYPE := 'CONC_PRGM';
--
/*-----------------------------------------------------------
Global Variable Declaration Section
-------------------------------------------------------------*/
g_debug_level NUMBER := 50;
-- 50 is default, that is all messages(logged at level 10,20..50)
-- would be visible
g_retention_period NUMBER := 30;
-- This is the number of days for which error records are going
-- to be retained in the EMF tables
g_err_col1_width NUMBER := 10;
-- These 8 should add up to 100 for best display, you can use
-- as many columns as you want, adding up to 100, leaving the rest as 0.
g_err_col2_width NUMBER := 30;
g_err_col3_width NUMBER := 10;
g_err_col4_width NUMBER := 10;
g_err_col5_width NUMBER := 10;
g_err_col6_width NUMBER := 20;
g_err_col7_width NUMBER := 10;
g_err_col8_width NUMBER := 0;
TYPE process_set_id_rec IS RECORD (process_set_id NUMBER);
TYPE process_set_id_tbl IS TABLE OF process_set_id_rec INDEX BY BINARY_INTEGER;
/*-----------------------------------------------------------
Public Constant Declaration Section
------------------------------------------------------------*/
PROCEDURE main( x_errbuf OUT VARCHAR2
, x_retcode OUT VARCHAR2
, p_run_mode IN VARCHAR2
);
g_rec_ins_exception EXCEPTION;
END xx_gl_je_cnv_pkb;
/
SHOW ERROR;
=======================================================================================================================
CREATE OR REPLACE PACKAGE BODY xx_gl_je_cnv_pkb AS
--Version Draft 1a
/*****************************************************************************************************************
* Package Name : xx_gl_je_cnv_pkb *
* Purpose : This program checks for pre-requisites, validates the GL JE data in the staging table. If *
* all the records are through the validations, then populate the standard interface *
* to create the journal information in base tables. *
* *
* Procedures : *
* --------------------- *
* main : Main procedure registered as the executable file name, which *
* calls the other procedures *
* *
* validate_setups : Validate Certain prerequisite setups in Oracle Apps *
* *
* validate_records : Validate and update records in staging table *
* *
* process_records : Populate the standard interface tables *
* *
* Tables Accessed : *
* Access Type----------------- (I - Insert, S - Select, U - Update, D - Delete) *
* *
* xx_gl_je_cnv : S,I,U,D
* xx_gl_je_cont_rec_cnv : S,I,U,D
* xx_gl_int_preint : S,I,U *
* gl_interface : I,U *
* *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
**********************************************************************************************************************/
l_set_of_books_id gl_sets_of_books.set_of_books_id%TYPE ;
l_batch_source gl_je_sources_tl.je_source_name%TYPE := 'Transfer' ;
l_je_category gl_je_categories_tl.user_je_category_name%TYPE := 'Transfer' ;
--stores ERROR/WARNING/SUCCESS
l_error_flag VARCHAR2 (1) := 'N' ;
l_header_id xx_emf_message_headers.header_id%TYPE ;
--EMF ID
l_return_value NUMBER := NULL ;
l_output_message VARCHAR2 (1000) ;
l_error_msg VARCHAR2(2000) ;
l_request_id xx_emf_message_headers.request_id%TYPE:= fnd_profile.VALUE ('CONC_REQUEST_ID');
l_process_status NUMBER ;
l_standard_request_id fnd_concurrent_requests.request_id%TYPE:= 0 ;
l_completed BOOLEAN ;
l_phase VARCHAR2 (200) ;
l_vstatus VARCHAR2 (200) ;
l_dev_phase VARCHAR2 (200) ;
l_dev_status VARCHAR2 (200) ;
l_message VARCHAR2 (2000) ;
l_appl_id fnd_concurrent_requests.responsibility_application_id%TYPE ;
l_resp_id fnd_concurrent_requests.responsibility_id%TYPE ;
l_user_id fnd_concurrent_requests.requested_by%TYPE ;
l_error_recs NUMBER;
PROCEDURE validate_setups(l_header_id IN NUMBER) ;
PROCEDURE validate_records ( l_total_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_total_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER
, p_run_mode IN VARCHAR2
);
PROCEDURE process_records ( l_processed_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER
);
PROCEDURE main( x_errbuf OUT VARCHAR2
,x_retcode OUT VARCHAR2
,p_run_mode IN VARCHAR2
)
/******************************************************************************************************************
* Procedure Name : main *
* *
* Description : Calls validate_setups,validate_records, process_records Procedures *
* *
* Called From : Concurrent Program *
* *
* Parameters Type Description *
* ----------------------------------------------------------------------------- *
* x_errbuf OUT Standard Error Buffer *
* x_retcode OUT Standard Error Code *
* *
* Tables Accessed *
* ----------------- *
* xx_gl_je_cnv : S,I,U,D *
* xx_gl_int_preint : S,I,U,D *
* gl_interface : S,I,U *
* *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Original Code *
*******************************************************************************************************************/
IS
l_package_name xx_emf_message_headers.program_name%TYPE := 'XX_GL_JE_CNV_PKB';
l_program_name xx_emf_message_headers.program_name%TYPE
:= l_package_name
|| '.'
|| 'MAIN';
l_ricewid xx_emf_message_headers.ricew_id%TYPE
:= 'GL_CNV_01';
--Object Name
l_error_rec xx_emf_message_details%ROWTYPE;
--used for EMF error header
l_messages_rec xx_emf_message_details%ROWTYPE;
--used for EMF messages
l_null_rec xx_emf_message_details%ROWTYPE := NULL;
--used for EMF messages
--stores number returned by EMF API's
l_err_width_rec xx_emf.output_rec_type;
--record type variable for assigning width to error section
l_processed_recs NUMBER := 0;
--stores total records for summary report
l_successful_recs NUMBER := 0;
--stores total successful records for summary report
l_error_recs NUMBER := 0;
--stores total error records for the summary report
l_status xx_emf_message_headers.status%TYPE;
l_error_cat_flag VARCHAR2 (1) := 'N';
--Flag to capture error (Y=ERROR/N=SUCCESS)
l_warning_flag VARCHAR2 (1);
--Flag to capture warning ('W')
l_total_gl_je_rec_cnt PLS_INTEGER ;
l_valid_gl_je_rec_cnt PLS_INTEGER ;
l_error_gl_je_rec_cnt PLS_INTEGER ;
l_total_gl_je_pre_rec_cnt PLS_INTEGER ;
l_valid_gl_je_pre_rec_cnt PLS_INTEGER ;
l_error_gl_je_pre_rec_cnt PLS_INTEGER ;
l_processed_gl_je_rec_cnt PLS_INTEGER ;
e_emf_initialize_error EXCEPTION;
--Stop the program if EMF initialization fails
e_emf_initialize_detail_error EXCEPTION;
--Stop the program with EMF error header insertion fails
e_cntrl_fail EXCEPTION;
BEGIN
/*----------------------------------------------------------------------------------------------------
Initialize Trace
Purpose : Set the program environment for Tracing
-----------------------------------------------------------------------------------------------------*/
xx_trace.set_program_environment (p_program_name => l_program_name);
/*----------------------------------------------------------------------------------------------------
Initialize EMF Section
Purpose : EMF is initialized so that error can be logged.
-----------------------------------------------------------------------------------------------------*/
xx_trace.vl ('Entering Program '
|| l_program_name);
--Call to EMF insert_program_start
l_header_id := xx_emf.insert_program_start( p_program_name => l_program_name
, p_program_type => g_program_type
, p_ricew_id => l_ricewid
, p_request_id => l_request_id
);
IF (l_header_id <= 1) THEN --Header id should be greater than 1
RAISE e_emf_initialize_error;
--Raise Exception to Stop the program if EMF initialization fails
END IF;
--
xx_trace.l ('EMF initialized, header_id :'
|| TO_CHAR (l_header_id));
/*----------------------------------------------------------------------------------------------------
Insert EMF Header
Purpose : To tag the Error labels to EMF columns
-----------------------------------------------------------------------------------------------------*/
l_error_rec.header_id := l_header_id;
--
-- Identifier to locate an error.
--
l_error_rec.identifier1 := 'Error Code'; --First Error Header
l_error_rec.identifier2 := 'Error Message'; --Second Error Header
l_error_rec.identifier3 := 'Record ID'; --Third Error Header
l_error_rec.identifier4 := 'Line Number'; --Fourth Error Header
l_error_rec.identifier5 := 'Description'; --Fifth Error Header
--
l_return_value := xx_emf.insert_error_headers (p_error_rec => l_error_rec);
IF l_return_value = 1 THEN --(1 indicates Error and 0 indicates Success)
--Raise Exception to Stop the program with 'ERROR' status if EMF error header initilaization fails
RAISE e_emf_initialize_detail_error;
END IF;
--
xx_trace.l ('EMF Error Header inserted');
l_return_value := NULL;
/*---------------------------------------------------------------------------------------------------
Call To Purge Program xx_emf.purge_ricewid_dated_messages
Purpose : DELETE EMF error records for this RICE object based on retention period.
----------------------------------------------------------------------------------------------------*/
l_return_value :=
xx_emf.purge_ricewid_dated_messages ( l_ricewid
, (SYSDATE
- g_retention_period)
);
--
IF l_return_value = 1 THEN
--
l_warning_flag := 'W';
xx_trace.l ('Failed to purge old EMF records');
--
END IF;
--Call procedure to validate setups
validate_setups(l_header_id);
IF (l_error_flag <> 'N') THEN
x_retcode := 2;
RETURN;
ELSE
--Call procedure to validate invoice lines and line distributions data
validate_records ( l_total_gl_je_rec_cnt
, l_valid_gl_je_rec_cnt
, l_error_gl_je_rec_cnt
, l_total_gl_je_pre_rec_cnt
, l_valid_gl_je_pre_rec_cnt
, l_error_gl_je_pre_rec_cnt
, l_header_id
, p_run_mode
);
process_records ( l_processed_gl_je_rec_cnt
, l_header_id
);
BEGIN
DELETE xx_gl_int_preint
WHERE status ='PR';
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
COMMIT;
END IF;
/*----------------------------------------------------------------------------
Call Insert Summary Count
Purpose: Display a summary of records processed, successful and in error
----------------------------------------------------------------------------*/
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_rec_cnt
, p_successful_recs => l_valid_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_pre_rec_cnt
, p_successful_recs => l_processed_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_pre_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
--
/*-----------------------------------------------------------------------------------------
Call flush PL/SQL table section
Purpose : Flush data from pl/sql table isrespective of the count.
Special Logic : record's message group is passed as 'ALL' and rest all columns are null
-------------------------------------------------------------------------------------------*/
xx_emf.call_store_message (p_message_group => 'ALL'
, p_header_id => l_header_id
, p_debug_value => 20
, p_global_debug => g_debug_level
, p_identifier1 => 'Flushing Data into EMF'
, p_process_status => l_return_value
, p_error_message => l_output_message
);
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to print EMF messages on the output');
END IF;
--
l_messages_rec := l_null_rec;
l_return_value := NULL;
/*----------------------------------------------------------------------------
Set display width for output
Purpose: Call to set EMF error and report section column widths
--------------------------------------------------------------------------*/
l_err_width_rec.identifier1 := TO_CHAR (g_err_col1_width);
l_err_width_rec.identifier2 := TO_CHAR (g_err_col2_width);
l_err_width_rec.identifier3 := TO_CHAR (g_err_col3_width);
l_err_width_rec.identifier4 := TO_CHAR (g_err_col4_width);
l_err_width_rec.identifier5 := TO_CHAR (g_err_col5_width);
l_err_width_rec.identifier6 := TO_CHAR (g_err_col6_width);
l_err_width_rec.identifier7 := TO_CHAR (g_err_col7_width);
l_err_width_rec.identifier8 := TO_CHAR (g_err_col8_width);
--
/*----------------------------------------------------------------
Call to xx_emf.display_output_messages
Purpose--Call to generate output file (Errors/Messages)
--------------------------------------------------------------*/
l_err_width_rec.header_id := l_header_id;
l_return_value :=
xx_emf.display_output_messages (p_header_id => l_header_id
, p_err_width_rec => l_err_width_rec
);
fnd_file.put_line(fnd_file.log,'Return Value :'||l_return_value);
IF l_return_value = 1
THEN
l_error_flag := 'Y';
xx_trace.l ('Failed to display output messages');
END IF;
--
l_return_value := NULL;
/*---------------------------------------------------
Call ToEMF Update_program_status in EMF tables
-----------------------------------------------------*/
IF l_error_flag = 'Y'
THEN --ERROR
l_warning_flag := ''; --error status supercedes warning
l_status := 'ERROR';
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
--
IF l_return_value = 1
THEN
xx_trace.l ('Failed to update program status');
l_return_value := NULL;
END IF;
ELSIF l_warning_flag = 'W'
THEN
l_status := 'WARNING';
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
--
IF l_return_value = 1
THEN
xx_trace.l ('Failed to update program status');
l_return_value := NULL;
END IF;
ELSIF l_error_flag = 'N'
THEN
l_status := 'SUCCESS';
l_return_value := NULL;
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
--
IF l_return_value = 1
THEN
xx_trace.l ('Failed to update program status for Success');
END IF;
COMMIT;
END IF;
EXCEPTION --Main Exception
WHEN g_rec_ins_exception THEN
x_retcode := 2;
ROLLBACK;
RETURN;
--Call emf_initialize_error if EMF header fails
WHEN e_emf_initialize_error
THEN
xx_trace.l ('Failed to initialize EMF');
--Call emf_initialize_detail_error if EMF error/report detail fails
WHEN e_emf_initialize_detail_error
THEN
l_status := 'ERROR';
l_return_value := xx_emf.update_program_status (l_header_id, l_status);
xx_trace.l ('Failed to insert EMF error header');
--Main Exception Block
WHEN OTHERS
THEN
null;
--Write to error
l_error_flag := 'Y';
xx_emf.call_store_message (p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 40
--High level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00004'
, p_identifier2 => 'Exception in Main.'
|| SQLERRM
, p_process_status => l_return_value
, p_error_message => l_output_message
);
--
l_messages_rec := l_null_rec;
l_return_value := NULL;
/*-------------------------------------------------------------------------------------
Call To Insert Summary Count
------------------------------------------------------------------------------------*/
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_rec_cnt
, p_successful_recs => l_valid_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_pre_rec_cnt
, p_successful_recs => l_processed_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_pre_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
/*-----------------------------------------------------------------------------------------
Call flush PL/SQL table section
Purpose : Flush data from pl/sql table isrespective of the count.
Special Logic : record's message group is passed as 'ALL' and rest all columns are null
-------------------------------------------------------------------------------------------*/
xx_emf.call_store_message (p_message_group => 'ALL'
, p_header_id => l_header_id
, p_debug_value => 20
--Low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'Flushing Data into EMF'
, p_process_status => l_return_value
, p_error_message => l_output_message
);
IF l_return_value = 1
THEN
l_return_value := NULL;
xx_trace.h ('Unable to call EMF error log');
l_return_value :=
xx_emf.update_program_status (l_header_id, l_status);
END IF;
l_return_value := NULL;
/*----------------------------------------------------------------------------
Purpose: Call to set EMF error and report section column widths
--------------------------------------------------------------------------*/
l_err_width_rec.identifier1 := TO_CHAR (g_err_col1_width);
l_err_width_rec.identifier2 := TO_CHAR (g_err_col2_width);
l_err_width_rec.identifier3 := TO_CHAR (g_err_col3_width);
l_err_width_rec.identifier4 := TO_CHAR (g_err_col4_width);
l_err_width_rec.identifier5 := TO_CHAR (g_err_col5_width);
l_err_width_rec.identifier6 := TO_CHAR (g_err_col6_width);
l_err_width_rec.identifier7 := TO_CHAR (g_err_col7_width);
l_err_width_rec.identifier8 := TO_CHAR (g_err_col8_width);
/*----------------------------------------------------------------
Purpose--Call to generate output file (Errors/Messages)
--------------------------------------------------------------*/
l_err_width_rec.header_id := l_header_id;
l_return_value :=
xx_emf.display_output_messages (p_header_id => l_header_id
, p_err_width_rec => l_err_width_rec
);
IF l_return_value = 1
THEN
xx_trace.h ('Unable to display output messages');
END IF;
l_return_value := NULL;
/*-------------------------------------------------------------------
Call update program status
---------------------------------------------------------------------*/
l_status := 'ERROR';
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
IF l_return_value = 1
THEN
xx_trace.h ('Unable to update program status');
l_return_value := NULL;
END IF;
END main;
PROCEDURE validate_setups(l_header_id IN NUMBER)
IS
/****************************************************************************************************************
* Procedure Name : validate_setups *
* *
* Description : Procedure which does the setup validations *
* *
* Called From : main *
* *
* Parameters Type Description *
* ----------------------------------------------------------------------------- *
* NONE *
* *
* Tables Accessed *
* ----------------- *
* *
* ----------------- *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
* *
********************************************************************************************************************/
l_set_of_book_name gl_sets_of_books.name%TYPE:='Vision Operations (USA)' ;
-- l_currency_code fnd_currencies.currency_code%TYPE:= 'USD' ;
BEGIN
-------- Validate Set_of_books_id --------
BEGIN
SELECT set_of_books_id
INTO l_set_of_books_id
FROM gl_sets_of_books
WHERE name = l_set_of_book_name;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_error_flag := 'Y';
xx_trace.l ('Set of books ID is not defined .');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Set of books ID is not defined.'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => l_set_of_book_name
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
--l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||l_set_of_book_name);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||l_set_of_book_name
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
-------- Validate JE BATCH_SOURCE --------
BEGIN
SELECT je_source_name
INTO l_batch_source
FROM gl_je_sources_tl
WHERE je_source_name = l_batch_source
;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_error_flag := 'Y';
xx_trace.l ('JE Batch Source is not defined .');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'JE Batch Source is not defined.'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => l_batch_source
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
--l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||l_batch_source);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||l_batch_source
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
-------- Validate JE CATEGORIES --------
BEGIN
SELECT USER_JE_CATEGORY_NAME
INTO l_je_category
FROM gl_je_categories_tl
WHERE USER_JE_CATEGORY_NAME = l_je_category
;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_error_flag := 'Y';
xx_trace.l ('JE Category Name is not defined .');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'JE JE Category Name is not defined.'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => l_batch_source
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
--l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||l_je_category);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||l_je_category
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
END validate_setups;
-- procedure to validate the staging table data
PROCEDURE validate_records ( l_total_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_total_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER
, p_run_mode IN VARCHAR2
)
/**************************************************************************************************************** *
* Procedure Name : validate_records *
* *
* Description : validate the staging table data *
* *
* Called From : main *
* *
* Parameters Type Description *
* ----------------------------------------------------------------------------- *
* l_total_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER *
* l_valid_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER *
* l_error_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER *
* *
* Tables Accessed *
* ----------------- *
* xx_gl_je_cnv : S,I,U,D *
* xx_gl_je_cont_rec_cnv : S,I,U,D *
* xx_gl_int_preint : S,I,U *
* gl_interface : I,U *
* *
* *
*Change History *
* *
*Ver Date Author CR/BUG # Description *
*------ ----------- ----------------- --------------- --------------------------- *
*Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
*******************************************************************************************************************/
IS
l_conc_seg_cnt NUMBER := 0;
l_record_error_flag NUMBER ;
l_rec_id VARCHAR2(50) := NULL;
l_sum_rec NUMBER;
l_rec_count NUMBER;
l_org_id PLS_INTEGER := FND_GLOBAL.ORG_ID ;
l_currency_code fnd_currencies.currency_code%TYPE ;
l_set_of_books_id gl_sets_of_books.set_of_books_id%TYPE ;
l_process_status NUMBER := 0;
l_date DATE ;
l_error_message VARCHAR2(500):= NULL ;
l_first_day gl_period_statuses.start_date%TYPE ;
l_last_day gl_period_statuses.end_date%TYPE ;
l_closing_status VARCHAR2(20);
l_ccid_ext VARCHAR2(20) := NULL;
l_ccid NUMBER := NULL;
l_period_name gl_period_statuses.period_name%TYPE ;
--Cursor to fetch GL JE information from the staging table
CURSOR cur_gl_je IS
SELECT *
FROM xx_gl_je_cnv
WHERE status ='NW';
CURSOR cur_gl_je_vl IS
SELECT *
FROM xx_gl_je_cnv
WHERE status ='NW';
CURSOR cur_gl_je_preint IS
SELECT *
FROM xx_gl_int_preint
WHERE status ='IP';
BEGIN
l_total_gl_je_rec_cnt := 0;
l_valid_gl_je_rec_cnt := 0;
l_error_gl_je_rec_cnt := 0;
-- To get the line count from staging table
BEGIN
SELECT COUNT(1)
INTO l_sum_rec
FROM xx_gl_je_cnv
WHERE status ='NW'
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END ;
l_error_msg := NULL ;
BEGIN
SELECT rec_count
INTO l_rec_count
FROM xx_gl_je_cont_rec_cnv
WHERE STATUS ='NW' ;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xx_trace.l('No control record found in data file');
l_rec_count :=0;
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'No control record found in data file;'
, p_identifier3 => NULL
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END ;
l_error_msg := NULL ;
IF l_sum_rec <> l_rec_count AND p_run_mode = 'F' THEN
l_record_error_flag := 1;
xx_trace.l ('Gl JE record count is not equal to summary record;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Gl JE record is not equal to summary record;'
, p_identifier3 => NULL
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
BEGIN
UPDATE xx_gl_je_cnv
SET status = 'ER' ;
UPDATE xx_gl_je_cont_rec_cnv
SET status = 'ER' ;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
l_error_msg := NULL ;
ELSE
/*---------------------------------------------------------------------------------------------------
Read Staging Table Data and Perform Control Level Validations
---------------------------------------------------------------------------------------------------*/
--Run mode will decide if the conversion will be run in full run mode 'F' or Partial run mode 'P'.
--IF p_run_mode is 'F the coversion starts with control validation for records with Status 'NW'in staging table
--IF p_run_mode is 'P' the coversion starts with business validation for records with Status 'IP''
--in the pre-interface table. The errored out records of previous run can be fixed in the pre-interface table
--if required and then this program can be run in partial mode .
IF p_run_mode = 'F' THEN
FOR lcu_gl_je IN cur_gl_je
LOOP
l_record_error_flag := 0;
l_total_gl_je_rec_cnt := l_total_gl_je_rec_cnt + 1 ;
l_rec_id:= lcu_gl_je.recid ;
-- 1 Check if mandatory field Actual Flag has value
IF lcu_gl_je.actual_flag IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Actual Flag can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Actual Flag can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field transaction_date has value
IF lcu_gl_je.transaction_date IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Transaction Date can not null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Creation Date can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field GL segments has value
IF lcu_gl_je.segment1 IS NULL
OR lcu_gl_je.segment2 IS NULL
OR lcu_gl_je.segment3 IS NULL
OR lcu_gl_je.segment4 IS NULL
OR lcu_gl_je.segment5 IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Either of the GL segments can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Either of the GL segments can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more informa
--p_identifier8 => NULL -- Can be utilized for displaying more informa
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field Currency Conversion Type has value
IF lcu_gl_je.user_curr_conv_type IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Currency Conversion Type can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency Conversion Type can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field set_of_books_id has value
IF lcu_gl_je.set_of_books_id IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Set of books_id can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Set of books id can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field currency_code has value
IF lcu_gl_je.currency_code IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Currency code can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency code can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
--Updating transaction record in staging table as ER if error
BEGIN
UPDATE xx_gl_je_cnv
SET status = DECODE(l_record_error_flag,1,'ER','NW')
WHERE recid = lcu_gl_je.recid
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
l_error_msg := NULL ;
-- Incrementing record counts
IF l_record_error_flag = 1 THEN
l_error_gl_je_rec_cnt := l_error_gl_je_rec_cnt + 1;
ELSIF l_record_error_flag = 0 THEN
l_valid_gl_je_rec_cnt := l_valid_gl_je_rec_cnt + 1;
END IF;
END LOOP;
-- END IF;
-- END IF;
-- inserting data into pre interface tables
BEGIN
FOR lcu_gl_je_vl IN cur_gl_je_vl
LOOP
BEGIN
INSERT INTO xx_gl_int_preint(
status
, set_of_books_id
, accounting_date
, currency_code
, recid
, last_update_date
, last_updated_by
, creation_date
, created_by
, last_update_login
, actual_flag
, user_je_category_name
, user_je_source_name
, currency_conversion_date
, user_currency_conversion_type
, currency_conversion_rate
, segment1
, segment2
, segment3
, segment4
, segment5
, entered_dr
, entered_cr
, accounted_dr
, accounted_cr
-- , transaction_date
, reference1
, reference2
, reference3
, reference4
, reference5
, reference6
, reference7
, reference8
, reference9
, reference10
)
VALUES (
'IP'
, lcu_gl_je_vl.set_of_books_id
, TO_DATE(lcu_gl_je_vl.transaction_date,'MM/DD/YYYY')
, lcu_gl_je_vl.currency_code
, XX_GL_INT_PREINT_S.NEXTVAL
, lcu_gl_je_vl.last_update_date
, lcu_gl_je_vl.last_updated_by
, lcu_gl_je_vl.creation_date
, lcu_gl_je_vl.created_by
, lcu_gl_je_vl.last_update_login
, lcu_gl_je_vl.actual_flag
, l_je_category --lcu_gl_je_vl.user_je_category_name
, l_batch_source --lcu_gl_je_vl.user_je_source_name
, TO_DATE(lcu_gl_je_vl.currency_conv_date,'MM/DD/YYYY')
, lcu_gl_je_vl.user_curr_conv_type
, NULL
, lcu_gl_je_vl.segment1
, lcu_gl_je_vl.segment2
, lcu_gl_je_vl.segment3
, lcu_gl_je_vl.segment4
, lcu_gl_je_vl.segment5
, lcu_gl_je_vl.entered_dr
, lcu_gl_je_vl.entered_cr
, lcu_gl_je_vl.accounted_dr
, lcu_gl_je_vl.accounted_cr
-- , NULL --lcu_gl_je_vl.transaction_date
, lcu_gl_je_vl.reference1
, lcu_gl_je_vl.reference2
, lcu_gl_je_vl.reference3
, lcu_gl_je_vl.reference4
, lcu_gl_je_vl.reference5
, lcu_gl_je_vl.reference6
, lcu_gl_je_vl.reference7
, lcu_gl_je_vl.reference8
, lcu_gl_je_vl.reference9
, lcu_gl_je_vl.reference10
);
EXCEPTION
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l ('Error while inserting Invoice Line records to pre interface table ');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Error while inserting records to pre interface table .'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => SQLERRM
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
-- RAISE g_rec_ins_exception;
END;
--Updating record in staging table as ER if error
BEGIN
UPDATE xx_gl_je_cnv
SET status = DECODE(l_record_error_flag,1,'ER','NW')
WHERE recid = lcu_gl_je_vl.recid
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
l_error_msg := NULL ;
END LOOP;
END ;
END IF;
-- Validating the data in pre interface tables
BEGIN
l_total_gl_je_pre_rec_cnt :=0;
l_valid_gl_je_pre_rec_cnt :=0;
l_error_gl_je_pre_rec_cnt :=0;
FOR lcu_gl_je_preint IN cur_gl_je_preint
LOOP
l_total_gl_je_pre_rec_cnt := l_total_gl_je_pre_rec_cnt + 1;
l_rec_id:=lcu_gl_je_preint.recid;
l_record_error_flag := 0;
-------- Validate actual flag --------
IF lcu_gl_je_preint.actual_flag <>'A'
-- OR lcu_gl_je_preint.actual_flag <>'B'
-- OR lcu_gl_je_preint.actual_flag <>'E'
THEN
l_record_error_flag :=1;
xx_trace.l ('Actual Flag is not correct'||'-'||lcu_gl_je_preint.actual_flag);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Actual Flag is not correct'||'-'||lcu_gl_je_preint.actual_flag
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-------- Validate currency code --------
BEGIN
SELECT fc.currency_code
INTO l_currency_code
FROM fnd_currencies fc
WHERE currency_flag = 'Y'
AND enabled_flag = 'Y'
AND nvl(fc.end_date_active,sysdate)>= sysdate
AND fc.currency_code = lcu_gl_je_preint.currency_code;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xx_trace.l('Currency Code not defined'||'-'||lcu_gl_je_preint.currency_code);
l_record_error_flag := 1;
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency Code not defined'||'-'||lcu_gl_je_preint.currency_code
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_error_msg := SQLERRM||'-'||lcu_gl_je_preint.currency_code;
l_record_error_flag := 1;
xx_trace.l(l_error_msg);
END;
-------- Validate set of books ID --------
BEGIN
SELECT set_of_books_id
INTO l_set_of_books_id
FROM gl_sets_of_books
WHERE set_of_books_id = lcu_gl_je_preint.set_of_books_id;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xx_trace.l('Set of books ID not defined'||'-'||lcu_gl_je_preint.set_of_books_id);
l_record_error_flag := 1;
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Set of books ID not defined'||'-'||lcu_gl_je_preint.set_of_books_id
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||lcu_gl_je_preint.set_of_books_id );
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||lcu_gl_je_preint.set_of_books_id
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END ;
-------- Validate currency converson type --------
IF lcu_gl_je_preint.user_currency_conversion_type <> 'Corporate'
-- OR lcu_gl_je_preint.user_currency_conversion_type <> 'User'
-- OR lcu_gl_je_preint.user_currency_conversion_type <> 'Spot'
THEN
l_record_error_flag := 1;
xx_trace.l ('Currency Conversion Type is not defined'||' '||lcu_gl_je_preint.user_currency_conversion_type);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency Conversion Type is not defined'||' '||lcu_gl_je_preint.user_currency_conversion_type
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- Check whether period is open for the transaction date or not
BEGIN
SELECT period_name, closing_status
INTO l_period_name, l_closing_status
FROM gl_period_statuses
WHERE application_id = 101
AND TO_DATE(TO_CHAR(lcu_gl_je_preint.accounting_date,'MM/DD/YYYY'),'MM/DD/YYYY') BETWEEN start_date AND end_date
AND set_of_books_id = lcu_gl_je_preint.set_of_books_id;
IF l_closing_status <> 'O' THEN
l_record_error_flag := 1;
xx_trace.l ('Period'||'-'||l_period_name ||' '||'is not opened');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Period'||'-'||l_period_name ||' '||'is not opened'
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_record_error_flag := 1;
xx_trace.l ('Period'||'-'||l_period_name ||' '||'is not defined');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Period'||'-'||l_period_name ||' '||'is not defined'
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l (SQLERRM);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
l_process_status :=0;
l_error_message := NULL ;
END ;
-- check CCID for the gl segments
BEGIN
l_ccid_ext:= xx_common_validations_pkg.get_coa_ccid (
p_segment1 =>lcu_gl_je_preint.segment1
,p_segment2 =>lcu_gl_je_preint.segment2
,p_segment3 =>lcu_gl_je_preint.segment3
,p_segment4 =>lcu_gl_je_preint.segment4
,p_segment5 =>lcu_gl_je_preint.segment5
-- ,p_segment6 =>
-- ,p_segment7 =>
,p_process_status => l_process_status
,p_error_message => l_error_message
,p_ccid => l_ccid
);
IF l_ccid_ext <> 'VALID' THEN
l_record_error_flag := 1;
xx_trace.l (l_error_message);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => l_error_message
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
l_process_status :=0;
l_error_message := NULL ;
END ;
-- update pre interface table
BEGIN
UPDATE xx_gl_int_preint
SET status = DECODE(l_record_error_flag,1,'ER','IP')
WHERE recid = lcu_gl_je_preint.recid
;
EXCEPTION
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l (SQLERRM);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
--RAISE g_rec_ins_exception;
END;
IF l_record_error_flag = 1 THEN
l_error_gl_je_pre_rec_cnt := l_error_gl_je_pre_rec_cnt + 1;
ELSIF l_record_error_flag = 0 THEN
l_valid_gl_je_pre_rec_cnt := l_valid_gl_je_pre_rec_cnt + 1;
END IF;
END LOOP;
END ;
END IF;
END validate_records;
PROCEDURE process_records ( l_processed_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER)
/* ***********************************************************************************************************
* Procedure Name : process_records *
* Description : Process validated Invoice records *
* Called From : Concurrent Program *
* *
* Parameters Type Description *
* l_processed_gl_je_rec_cnt OUT To stote total processed invoice lines records *
* *
* Tables Accessed *
* ----------------- *
* xx_gl_je_cnv : S,I,U *
* xx_gl_je_cont_rec_cnv : S,I,U *
* xx_gl_int_preint : I,U *
* gl_interface : I,U *
* *
* *
* Change History *
* ----------------- *
* Version Date Author Description *
* --------- ------------- --------------- -------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
************************************************************************************************************* */
IS
l_record_error_flag NUMBER;
l_org_id PLS_INTEGER := FND_GLOBAL.ORG_ID;
int_date DATE;
l_interface_run_id NUMBER;
l_gl_application_name CONSTANT VARCHAR2(30):= 'SQLGL';
l_journal_imp_prog_name CONSTANT VARCHAR2(30):= 'GLLEZL';
--Cursor to fetch Invoice Line information from the staging table
CURSOR cur_valid_gl_je IS
SELECT *
FROM xx_gl_int_preint
WHERE status = 'IP'
;
CURSOR c_gl_iface_ctl IS
SELECT gl_journal_import_s.NEXTVAL interface_run_id
FROM DUAL;
BEGIN
l_processed_gl_je_rec_cnt := 0;
FOR lcu_valid_gl_je IN cur_valid_gl_je
LOOP
l_record_error_flag := 0;
BEGIN
INSERT INTO gl_interface(
status
, set_of_books_id
, accounting_date
, currency_code
, date_created
, created_by
, actual_flag
, user_je_category_name
, user_je_source_name
, currency_conversion_date
, encumbrance_type_id
, budget_version_id
, user_currency_conversion_type
, currency_conversion_rate
, segment1
, segment2
, segment3
, segment4
, segment5
, entered_dr
, entered_cr
, accounted_dr
, accounted_cr
, reference1
, reference2
, reference3
, reference4
, reference5
, reference6
, reference7
, reference8
, reference9
, reference10
)
VALUES (
'NEW'
, lcu_valid_gl_je.set_of_books_id
, lcu_valid_gl_je.accounting_date
, lcu_valid_gl_je.currency_code
, SYSDATE
, lcu_valid_gl_je.created_by
, lcu_valid_gl_je.actual_flag
, lcu_valid_gl_je.user_je_category_name
, lcu_valid_gl_je.user_je_source_name
, lcu_valid_gl_je.currency_conversion_date
, lcu_valid_gl_je.encumbrance_type_id
, lcu_valid_gl_je.budget_version_id
, lcu_valid_gl_je.user_currency_conversion_type
, NULL
, lcu_valid_gl_je.segment1
, lcu_valid_gl_je.segment2
, lcu_valid_gl_je.segment3
, lcu_valid_gl_je.segment4
, lcu_valid_gl_je.segment5
, lcu_valid_gl_je.entered_dr
, lcu_valid_gl_je.entered_cr
, lcu_valid_gl_je.accounted_dr
, lcu_valid_gl_je.accounted_cr
, lcu_valid_gl_je.reference1
, lcu_valid_gl_je.reference2
, lcu_valid_gl_je.reference3
, lcu_valid_gl_je.reference4
, lcu_valid_gl_je.reference5
, lcu_valid_gl_je.reference6
, lcu_valid_gl_je.reference7
, lcu_valid_gl_je.reference8
, lcu_valid_gl_je.reference9
, lcu_valid_gl_je.reference10
);
EXCEPTION
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l ('Error while inserting records into gl_interface');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Error while inserting records into gl_interface'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
--Updating records in pre interface table as ER if error in site processing else PR
IF l_record_error_flag = 0 THEN
l_processed_gl_je_rec_cnt := l_processed_gl_je_rec_cnt + 1 ;
BEGIN
UPDATE xx_gl_int_preint
SET status = DECODE(l_record_error_flag,1,'ER','PR')
WHERE recid =lcu_valid_gl_je.recid
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
END IF ;
END LOOP;
/*---------------------------------------------------------------------------------------
Launch Standard Concurrent Program - With WAIT/Call Oracle Standard APIs
----------------------------------------------------------------------------------------*/
BEGIN
xx_common_validations_pkg.init_apps_params
( p_request_id => l_request_id
, p_process_status => l_process_status
, p_error_message => l_output_message
);
IF l_processed_gl_je_rec_cnt > 0 THEN
-- This concurrent program is used for creating GL JE Header and Lines
FOR lcu_gl_iface_ctl IN c_gl_iface_ctl LOOP
l_interface_run_id := lcu_gl_iface_ctl.interface_run_id;
END LOOP;
BEGIN
INSERT INTO gl_interface_control
(je_source_name
,status
,interface_run_id
,GROUP_ID
,set_of_books_id
,packet_id
,interface_table_name
,processed_table_code
,request_id
)
VALUES (l_batch_source -- JE_SOURCE_NAME
,'S' -- STATUS
,l_interface_run_id -- INTERFACE_RUN_ID
,NULL -- GROUP_ID
,l_set_of_books_id -- SET_OF_BOOKs_ID
,NULL -- PACKET_ID
,'GL_INTERFACE' -- INTERFACE_TABLE_NAME
,NULL -- PROCESSED_TABLE_CODE
,NULL -- REQUEST_ID
);
EXCEPTION
WHEN OTHERS THEN
xx_trace.l (SQLERRM);
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
l_standard_request_id := fnd_request.submit_request
(
application => l_gl_application_name
,program => l_journal_imp_prog_name
,description => ''
,start_time => ''
,sub_request => FALSE
,argument1 => l_interface_run_id -- Interface Run ID
,argument2 => l_set_of_books_id -- Set of Books ID
,argument3 => 'N' -- Allow Suspence posting
,argument4 => NULL -- default date
,argument5 => NULL -- transaction flexfield
,argument6 => '' -- transaction type
,argument7 => '' -- bill to customer number (low)
,argument8 => CHR(0) -- bill to customer number (high)
,argument9 => '' -- bill to customer name (low)
,argument10 => '' -- bill to customer name (high)
,argument11 => '' -- gl date(low)
,argument12 => '' -- gl date (high)
,argument13 => '' -- ship date(low)
,argument14 => '' -- ship date(high)
,argument15 => '' -- transaction number(low)
,argument16 => '' -- transaction number(high)
,argument17 => '' -- sales order number (low)
,argument18 => '' -- sales order number (high)
,argument19 => '' -- invoice date (low)
,argument20 => '' -- invoice date (high)
,argument21 => '' -- ship to customer number (low)
,argument22 => '' -- ship to customer number (high)
,argument23 => '' -- ship to customer name (low)
,argument24 => '' -- ship to customer name (high)
,argument25 => 'Y' -- base due date on trx date
,argument26 => '' -- due date adjustment date
,argument27 => l_org_id -- org id
);
IF l_standard_request_id > 0 THEN
COMMIT;
ELSE
xx_emf.call_store_message
(p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 --Low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00004'
, p_identifier2 => 'Error in submitting concurrent request'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
l_phase := NULL ;
l_vstatus := NULL ;
l_dev_phase := NULL ;
l_dev_status := NULL ;
l_message := NULL ;
--Wait for the completion of the concurrent request (if submitted successfully)
l_completed := fnd_concurrent.wait_for_request
(request_id => l_standard_request_id
, INTERVAL => 60
, max_wait => 0
, phase => l_phase
, status => l_vstatus
, dev_phase => l_dev_phase
, dev_status => l_dev_status
, MESSAGE => l_message
);
xx_trace.l ('Request submitted with request id-'|| l_standard_request_id
);
ELSE
xx_emf.call_store_message
(p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 --Low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00004'
, p_identifier2 => 'No records To Process in Interface Table'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
END;
END ;
END;
/
SHOW ERROR;
EXIT;
--Version Draft 1a
/******************************************************************************************************************
* Package Name : xx_gl_je_cnv_pkb *
* Purpose : This program checks for pre-requisites, validates the GL JE data in the staging table. If *
* all the records are through the validations, then populate the standard interface *
* to create the journal information in base tables. *
* *
* *
* Procedures : *
* --------------------- *
* main : Main procedure registered as the executable file name, which *
* calls the other procedures *
* *
* validate_setups : Validate Certain prerequisite setups in Oracle Apps *
* *
* validate_records : Validate and update records in staging table *
* *
* process_records : Populate the standard interface tables *
* *
* Tables Accessed : *
* Access Type-------- (I - Insert, S - Select, U - Update, D - Delete) *
* *
* xx_gl_je_cnv : S,I,U,D
* xx_gl_int_preint : S,I,U *
* gl_interface : I,U *
* *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
********************************************************************************************************************/
/*-----------------------------------------------------------
Public Constant Declaration Section
------------------------------------------------------------*/
--
g_program_type xx_emf_message_headers.program_type%TYPE := 'CONC_PRGM';
--
/*-----------------------------------------------------------
Global Variable Declaration Section
-------------------------------------------------------------*/
g_debug_level NUMBER := 50;
-- 50 is default, that is all messages(logged at level 10,20..50)
-- would be visible
g_retention_period NUMBER := 30;
-- This is the number of days for which error records are going
-- to be retained in the EMF tables
g_err_col1_width NUMBER := 10;
-- These 8 should add up to 100 for best display, you can use
-- as many columns as you want, adding up to 100, leaving the rest as 0.
g_err_col2_width NUMBER := 30;
g_err_col3_width NUMBER := 10;
g_err_col4_width NUMBER := 10;
g_err_col5_width NUMBER := 10;
g_err_col6_width NUMBER := 20;
g_err_col7_width NUMBER := 10;
g_err_col8_width NUMBER := 0;
TYPE process_set_id_rec IS RECORD (process_set_id NUMBER);
TYPE process_set_id_tbl IS TABLE OF process_set_id_rec INDEX BY BINARY_INTEGER;
/*-----------------------------------------------------------
Public Constant Declaration Section
------------------------------------------------------------*/
PROCEDURE main( x_errbuf OUT VARCHAR2
, x_retcode OUT VARCHAR2
, p_run_mode IN VARCHAR2
);
g_rec_ins_exception EXCEPTION;
END xx_gl_je_cnv_pkb;
/
SHOW ERROR;
=======================================================================================================================
CREATE OR REPLACE PACKAGE BODY xx_gl_je_cnv_pkb AS
--Version Draft 1a
/*****************************************************************************************************************
* Package Name : xx_gl_je_cnv_pkb *
* Purpose : This program checks for pre-requisites, validates the GL JE data in the staging table. If *
* all the records are through the validations, then populate the standard interface *
* to create the journal information in base tables. *
* *
* Procedures : *
* --------------------- *
* main : Main procedure registered as the executable file name, which *
* calls the other procedures *
* *
* validate_setups : Validate Certain prerequisite setups in Oracle Apps *
* *
* validate_records : Validate and update records in staging table *
* *
* process_records : Populate the standard interface tables *
* *
* Tables Accessed : *
* Access Type----------------- (I - Insert, S - Select, U - Update, D - Delete) *
* *
* xx_gl_je_cnv : S,I,U,D
* xx_gl_je_cont_rec_cnv : S,I,U,D
* xx_gl_int_preint : S,I,U *
* gl_interface : I,U *
* *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
**********************************************************************************************************************/
l_set_of_books_id gl_sets_of_books.set_of_books_id%TYPE ;
l_batch_source gl_je_sources_tl.je_source_name%TYPE := 'Transfer' ;
l_je_category gl_je_categories_tl.user_je_category_name%TYPE := 'Transfer' ;
--stores ERROR/WARNING/SUCCESS
l_error_flag VARCHAR2 (1) := 'N' ;
l_header_id xx_emf_message_headers.header_id%TYPE ;
--EMF ID
l_return_value NUMBER := NULL ;
l_output_message VARCHAR2 (1000) ;
l_error_msg VARCHAR2(2000) ;
l_request_id xx_emf_message_headers.request_id%TYPE:= fnd_profile.VALUE ('CONC_REQUEST_ID');
l_process_status NUMBER ;
l_standard_request_id fnd_concurrent_requests.request_id%TYPE:= 0 ;
l_completed BOOLEAN ;
l_phase VARCHAR2 (200) ;
l_vstatus VARCHAR2 (200) ;
l_dev_phase VARCHAR2 (200) ;
l_dev_status VARCHAR2 (200) ;
l_message VARCHAR2 (2000) ;
l_appl_id fnd_concurrent_requests.responsibility_application_id%TYPE ;
l_resp_id fnd_concurrent_requests.responsibility_id%TYPE ;
l_user_id fnd_concurrent_requests.requested_by%TYPE ;
l_error_recs NUMBER;
PROCEDURE validate_setups(l_header_id IN NUMBER) ;
PROCEDURE validate_records ( l_total_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_total_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER
, p_run_mode IN VARCHAR2
);
PROCEDURE process_records ( l_processed_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER
);
PROCEDURE main( x_errbuf OUT VARCHAR2
,x_retcode OUT VARCHAR2
,p_run_mode IN VARCHAR2
)
/******************************************************************************************************************
* Procedure Name : main *
* *
* Description : Calls validate_setups,validate_records, process_records Procedures *
* *
* Called From : Concurrent Program *
* *
* Parameters Type Description *
* ----------------------------------------------------------------------------- *
* x_errbuf OUT Standard Error Buffer *
* x_retcode OUT Standard Error Code *
* *
* Tables Accessed *
* ----------------- *
* xx_gl_je_cnv : S,I,U,D *
* xx_gl_int_preint : S,I,U,D *
* gl_interface : S,I,U *
* *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Original Code *
*******************************************************************************************************************/
IS
l_package_name xx_emf_message_headers.program_name%TYPE := 'XX_GL_JE_CNV_PKB';
l_program_name xx_emf_message_headers.program_name%TYPE
:= l_package_name
|| '.'
|| 'MAIN';
l_ricewid xx_emf_message_headers.ricew_id%TYPE
:= 'GL_CNV_01';
--Object Name
l_error_rec xx_emf_message_details%ROWTYPE;
--used for EMF error header
l_messages_rec xx_emf_message_details%ROWTYPE;
--used for EMF messages
l_null_rec xx_emf_message_details%ROWTYPE := NULL;
--used for EMF messages
--stores number returned by EMF API's
l_err_width_rec xx_emf.output_rec_type;
--record type variable for assigning width to error section
l_processed_recs NUMBER := 0;
--stores total records for summary report
l_successful_recs NUMBER := 0;
--stores total successful records for summary report
l_error_recs NUMBER := 0;
--stores total error records for the summary report
l_status xx_emf_message_headers.status%TYPE;
l_error_cat_flag VARCHAR2 (1) := 'N';
--Flag to capture error (Y=ERROR/N=SUCCESS)
l_warning_flag VARCHAR2 (1);
--Flag to capture warning ('W')
l_total_gl_je_rec_cnt PLS_INTEGER ;
l_valid_gl_je_rec_cnt PLS_INTEGER ;
l_error_gl_je_rec_cnt PLS_INTEGER ;
l_total_gl_je_pre_rec_cnt PLS_INTEGER ;
l_valid_gl_je_pre_rec_cnt PLS_INTEGER ;
l_error_gl_je_pre_rec_cnt PLS_INTEGER ;
l_processed_gl_je_rec_cnt PLS_INTEGER ;
e_emf_initialize_error EXCEPTION;
--Stop the program if EMF initialization fails
e_emf_initialize_detail_error EXCEPTION;
--Stop the program with EMF error header insertion fails
e_cntrl_fail EXCEPTION;
BEGIN
/*----------------------------------------------------------------------------------------------------
Initialize Trace
Purpose : Set the program environment for Tracing
-----------------------------------------------------------------------------------------------------*/
xx_trace.set_program_environment (p_program_name => l_program_name);
/*----------------------------------------------------------------------------------------------------
Initialize EMF Section
Purpose : EMF is initialized so that error can be logged.
-----------------------------------------------------------------------------------------------------*/
xx_trace.vl ('Entering Program '
|| l_program_name);
--Call to EMF insert_program_start
l_header_id := xx_emf.insert_program_start( p_program_name => l_program_name
, p_program_type => g_program_type
, p_ricew_id => l_ricewid
, p_request_id => l_request_id
);
IF (l_header_id <= 1) THEN --Header id should be greater than 1
RAISE e_emf_initialize_error;
--Raise Exception to Stop the program if EMF initialization fails
END IF;
--
xx_trace.l ('EMF initialized, header_id :'
|| TO_CHAR (l_header_id));
/*----------------------------------------------------------------------------------------------------
Insert EMF Header
Purpose : To tag the Error labels to EMF columns
-----------------------------------------------------------------------------------------------------*/
l_error_rec.header_id := l_header_id;
--
-- Identifier to locate an error.
--
l_error_rec.identifier1 := 'Error Code'; --First Error Header
l_error_rec.identifier2 := 'Error Message'; --Second Error Header
l_error_rec.identifier3 := 'Record ID'; --Third Error Header
l_error_rec.identifier4 := 'Line Number'; --Fourth Error Header
l_error_rec.identifier5 := 'Description'; --Fifth Error Header
--
l_return_value := xx_emf.insert_error_headers (p_error_rec => l_error_rec);
IF l_return_value = 1 THEN --(1 indicates Error and 0 indicates Success)
--Raise Exception to Stop the program with 'ERROR' status if EMF error header initilaization fails
RAISE e_emf_initialize_detail_error;
END IF;
--
xx_trace.l ('EMF Error Header inserted');
l_return_value := NULL;
/*---------------------------------------------------------------------------------------------------
Call To Purge Program xx_emf.purge_ricewid_dated_messages
Purpose : DELETE EMF error records for this RICE object based on retention period.
----------------------------------------------------------------------------------------------------*/
l_return_value :=
xx_emf.purge_ricewid_dated_messages ( l_ricewid
, (SYSDATE
- g_retention_period)
);
--
IF l_return_value = 1 THEN
--
l_warning_flag := 'W';
xx_trace.l ('Failed to purge old EMF records');
--
END IF;
--Call procedure to validate setups
validate_setups(l_header_id);
IF (l_error_flag <> 'N') THEN
x_retcode := 2;
RETURN;
ELSE
--Call procedure to validate invoice lines and line distributions data
validate_records ( l_total_gl_je_rec_cnt
, l_valid_gl_je_rec_cnt
, l_error_gl_je_rec_cnt
, l_total_gl_je_pre_rec_cnt
, l_valid_gl_je_pre_rec_cnt
, l_error_gl_je_pre_rec_cnt
, l_header_id
, p_run_mode
);
process_records ( l_processed_gl_je_rec_cnt
, l_header_id
);
BEGIN
DELETE xx_gl_int_preint
WHERE status ='PR';
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
COMMIT;
END IF;
/*----------------------------------------------------------------------------
Call Insert Summary Count
Purpose: Display a summary of records processed, successful and in error
----------------------------------------------------------------------------*/
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_rec_cnt
, p_successful_recs => l_valid_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_pre_rec_cnt
, p_successful_recs => l_processed_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_pre_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
--
/*-----------------------------------------------------------------------------------------
Call flush PL/SQL table section
Purpose : Flush data from pl/sql table isrespective of the count.
Special Logic : record's message group is passed as 'ALL' and rest all columns are null
-------------------------------------------------------------------------------------------*/
xx_emf.call_store_message (p_message_group => 'ALL'
, p_header_id => l_header_id
, p_debug_value => 20
, p_global_debug => g_debug_level
, p_identifier1 => 'Flushing Data into EMF'
, p_process_status => l_return_value
, p_error_message => l_output_message
);
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to print EMF messages on the output');
END IF;
--
l_messages_rec := l_null_rec;
l_return_value := NULL;
/*----------------------------------------------------------------------------
Set display width for output
Purpose: Call to set EMF error and report section column widths
--------------------------------------------------------------------------*/
l_err_width_rec.identifier1 := TO_CHAR (g_err_col1_width);
l_err_width_rec.identifier2 := TO_CHAR (g_err_col2_width);
l_err_width_rec.identifier3 := TO_CHAR (g_err_col3_width);
l_err_width_rec.identifier4 := TO_CHAR (g_err_col4_width);
l_err_width_rec.identifier5 := TO_CHAR (g_err_col5_width);
l_err_width_rec.identifier6 := TO_CHAR (g_err_col6_width);
l_err_width_rec.identifier7 := TO_CHAR (g_err_col7_width);
l_err_width_rec.identifier8 := TO_CHAR (g_err_col8_width);
--
/*----------------------------------------------------------------
Call to xx_emf.display_output_messages
Purpose--Call to generate output file (Errors/Messages)
--------------------------------------------------------------*/
l_err_width_rec.header_id := l_header_id;
l_return_value :=
xx_emf.display_output_messages (p_header_id => l_header_id
, p_err_width_rec => l_err_width_rec
);
fnd_file.put_line(fnd_file.log,'Return Value :'||l_return_value);
IF l_return_value = 1
THEN
l_error_flag := 'Y';
xx_trace.l ('Failed to display output messages');
END IF;
--
l_return_value := NULL;
/*---------------------------------------------------
Call ToEMF Update_program_status in EMF tables
-----------------------------------------------------*/
IF l_error_flag = 'Y'
THEN --ERROR
l_warning_flag := ''; --error status supercedes warning
l_status := 'ERROR';
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
--
IF l_return_value = 1
THEN
xx_trace.l ('Failed to update program status');
l_return_value := NULL;
END IF;
ELSIF l_warning_flag = 'W'
THEN
l_status := 'WARNING';
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
--
IF l_return_value = 1
THEN
xx_trace.l ('Failed to update program status');
l_return_value := NULL;
END IF;
ELSIF l_error_flag = 'N'
THEN
l_status := 'SUCCESS';
l_return_value := NULL;
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
--
IF l_return_value = 1
THEN
xx_trace.l ('Failed to update program status for Success');
END IF;
COMMIT;
END IF;
EXCEPTION --Main Exception
WHEN g_rec_ins_exception THEN
x_retcode := 2;
ROLLBACK;
RETURN;
--Call emf_initialize_error if EMF header fails
WHEN e_emf_initialize_error
THEN
xx_trace.l ('Failed to initialize EMF');
--Call emf_initialize_detail_error if EMF error/report detail fails
WHEN e_emf_initialize_detail_error
THEN
l_status := 'ERROR';
l_return_value := xx_emf.update_program_status (l_header_id, l_status);
xx_trace.l ('Failed to insert EMF error header');
--Main Exception Block
WHEN OTHERS
THEN
null;
--Write to error
l_error_flag := 'Y';
xx_emf.call_store_message (p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 40
--High level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00004'
, p_identifier2 => 'Exception in Main.'
|| SQLERRM
, p_process_status => l_return_value
, p_error_message => l_output_message
);
--
l_messages_rec := l_null_rec;
l_return_value := NULL;
/*-------------------------------------------------------------------------------------
Call To Insert Summary Count
------------------------------------------------------------------------------------*/
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_rec_cnt
, p_successful_recs => l_valid_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
l_return_value := NULL;
--
l_return_value :=
xx_emf.insert_summary_counts (p_header_id => l_header_id
, p_display_name => l_program_name
, p_total_recs => l_total_gl_je_pre_rec_cnt
, p_successful_recs => l_processed_gl_je_rec_cnt
, p_error_recs => l_error_gl_je_pre_rec_cnt
);
--
IF l_return_value = 1
THEN
l_warning_flag := 'W';
xx_trace.l ('Failed to Insert Summary Count');
END IF;
/*-----------------------------------------------------------------------------------------
Call flush PL/SQL table section
Purpose : Flush data from pl/sql table isrespective of the count.
Special Logic : record's message group is passed as 'ALL' and rest all columns are null
-------------------------------------------------------------------------------------------*/
xx_emf.call_store_message (p_message_group => 'ALL'
, p_header_id => l_header_id
, p_debug_value => 20
--Low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'Flushing Data into EMF'
, p_process_status => l_return_value
, p_error_message => l_output_message
);
IF l_return_value = 1
THEN
l_return_value := NULL;
xx_trace.h ('Unable to call EMF error log');
l_return_value :=
xx_emf.update_program_status (l_header_id, l_status);
END IF;
l_return_value := NULL;
/*----------------------------------------------------------------------------
Purpose: Call to set EMF error and report section column widths
--------------------------------------------------------------------------*/
l_err_width_rec.identifier1 := TO_CHAR (g_err_col1_width);
l_err_width_rec.identifier2 := TO_CHAR (g_err_col2_width);
l_err_width_rec.identifier3 := TO_CHAR (g_err_col3_width);
l_err_width_rec.identifier4 := TO_CHAR (g_err_col4_width);
l_err_width_rec.identifier5 := TO_CHAR (g_err_col5_width);
l_err_width_rec.identifier6 := TO_CHAR (g_err_col6_width);
l_err_width_rec.identifier7 := TO_CHAR (g_err_col7_width);
l_err_width_rec.identifier8 := TO_CHAR (g_err_col8_width);
/*----------------------------------------------------------------
Purpose--Call to generate output file (Errors/Messages)
--------------------------------------------------------------*/
l_err_width_rec.header_id := l_header_id;
l_return_value :=
xx_emf.display_output_messages (p_header_id => l_header_id
, p_err_width_rec => l_err_width_rec
);
IF l_return_value = 1
THEN
xx_trace.h ('Unable to display output messages');
END IF;
l_return_value := NULL;
/*-------------------------------------------------------------------
Call update program status
---------------------------------------------------------------------*/
l_status := 'ERROR';
l_return_value :=
xx_emf.update_program_status (p_header_id => l_header_id
, p_status => l_status
);
IF l_return_value = 1
THEN
xx_trace.h ('Unable to update program status');
l_return_value := NULL;
END IF;
END main;
PROCEDURE validate_setups(l_header_id IN NUMBER)
IS
/****************************************************************************************************************
* Procedure Name : validate_setups *
* *
* Description : Procedure which does the setup validations *
* *
* Called From : main *
* *
* Parameters Type Description *
* ----------------------------------------------------------------------------- *
* NONE *
* *
* Tables Accessed *
* ----------------- *
* *
* ----------------- *
* Change History *
* *
* Ver Date Author CR/BUG # Description *
* ------ ----------- ----------------- --------------- --------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
* *
********************************************************************************************************************/
l_set_of_book_name gl_sets_of_books.name%TYPE:='Vision Operations (USA)' ;
-- l_currency_code fnd_currencies.currency_code%TYPE:= 'USD' ;
BEGIN
-------- Validate Set_of_books_id --------
BEGIN
SELECT set_of_books_id
INTO l_set_of_books_id
FROM gl_sets_of_books
WHERE name = l_set_of_book_name;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_error_flag := 'Y';
xx_trace.l ('Set of books ID is not defined .');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Set of books ID is not defined.'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => l_set_of_book_name
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
--l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||l_set_of_book_name);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||l_set_of_book_name
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
-------- Validate JE BATCH_SOURCE --------
BEGIN
SELECT je_source_name
INTO l_batch_source
FROM gl_je_sources_tl
WHERE je_source_name = l_batch_source
;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_error_flag := 'Y';
xx_trace.l ('JE Batch Source is not defined .');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'JE Batch Source is not defined.'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => l_batch_source
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
--l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||l_batch_source);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||l_batch_source
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
-------- Validate JE CATEGORIES --------
BEGIN
SELECT USER_JE_CATEGORY_NAME
INTO l_je_category
FROM gl_je_categories_tl
WHERE USER_JE_CATEGORY_NAME = l_je_category
;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_error_flag := 'Y';
xx_trace.l ('JE Category Name is not defined .');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'JE JE Category Name is not defined.'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => l_batch_source
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
--l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||l_je_category);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||l_je_category
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
END validate_setups;
-- procedure to validate the staging table data
PROCEDURE validate_records ( l_total_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_total_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_valid_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_error_gl_je_pre_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER
, p_run_mode IN VARCHAR2
)
/**************************************************************************************************************** *
* Procedure Name : validate_records *
* *
* Description : validate the staging table data *
* *
* Called From : main *
* *
* Parameters Type Description *
* ----------------------------------------------------------------------------- *
* l_total_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER *
* l_valid_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER *
* l_error_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER *
* *
* Tables Accessed *
* ----------------- *
* xx_gl_je_cnv : S,I,U,D *
* xx_gl_je_cont_rec_cnv : S,I,U,D *
* xx_gl_int_preint : S,I,U *
* gl_interface : I,U *
* *
* *
*Change History *
* *
*Ver Date Author CR/BUG # Description *
*------ ----------- ----------------- --------------- --------------------------- *
*Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
*******************************************************************************************************************/
IS
l_conc_seg_cnt NUMBER := 0;
l_record_error_flag NUMBER ;
l_rec_id VARCHAR2(50) := NULL;
l_sum_rec NUMBER;
l_rec_count NUMBER;
l_org_id PLS_INTEGER := FND_GLOBAL.ORG_ID ;
l_currency_code fnd_currencies.currency_code%TYPE ;
l_set_of_books_id gl_sets_of_books.set_of_books_id%TYPE ;
l_process_status NUMBER := 0;
l_date DATE ;
l_error_message VARCHAR2(500):= NULL ;
l_first_day gl_period_statuses.start_date%TYPE ;
l_last_day gl_period_statuses.end_date%TYPE ;
l_closing_status VARCHAR2(20);
l_ccid_ext VARCHAR2(20) := NULL;
l_ccid NUMBER := NULL;
l_period_name gl_period_statuses.period_name%TYPE ;
--Cursor to fetch GL JE information from the staging table
CURSOR cur_gl_je IS
SELECT *
FROM xx_gl_je_cnv
WHERE status ='NW';
CURSOR cur_gl_je_vl IS
SELECT *
FROM xx_gl_je_cnv
WHERE status ='NW';
CURSOR cur_gl_je_preint IS
SELECT *
FROM xx_gl_int_preint
WHERE status ='IP';
BEGIN
l_total_gl_je_rec_cnt := 0;
l_valid_gl_je_rec_cnt := 0;
l_error_gl_je_rec_cnt := 0;
-- To get the line count from staging table
BEGIN
SELECT COUNT(1)
INTO l_sum_rec
FROM xx_gl_je_cnv
WHERE status ='NW'
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END ;
l_error_msg := NULL ;
BEGIN
SELECT rec_count
INTO l_rec_count
FROM xx_gl_je_cont_rec_cnv
WHERE STATUS ='NW' ;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xx_trace.l('No control record found in data file');
l_rec_count :=0;
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'No control record found in data file;'
, p_identifier3 => NULL
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END ;
l_error_msg := NULL ;
IF l_sum_rec <> l_rec_count AND p_run_mode = 'F' THEN
l_record_error_flag := 1;
xx_trace.l ('Gl JE record count is not equal to summary record;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Gl JE record is not equal to summary record;'
, p_identifier3 => NULL
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
BEGIN
UPDATE xx_gl_je_cnv
SET status = 'ER' ;
UPDATE xx_gl_je_cont_rec_cnv
SET status = 'ER' ;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
l_error_msg := NULL ;
ELSE
/*---------------------------------------------------------------------------------------------------
Read Staging Table Data and Perform Control Level Validations
---------------------------------------------------------------------------------------------------*/
--Run mode will decide if the conversion will be run in full run mode 'F' or Partial run mode 'P'.
--IF p_run_mode is 'F the coversion starts with control validation for records with Status 'NW'in staging table
--IF p_run_mode is 'P' the coversion starts with business validation for records with Status 'IP''
--in the pre-interface table. The errored out records of previous run can be fixed in the pre-interface table
--if required and then this program can be run in partial mode .
IF p_run_mode = 'F' THEN
FOR lcu_gl_je IN cur_gl_je
LOOP
l_record_error_flag := 0;
l_total_gl_je_rec_cnt := l_total_gl_je_rec_cnt + 1 ;
l_rec_id:= lcu_gl_je.recid ;
-- 1 Check if mandatory field Actual Flag has value
IF lcu_gl_je.actual_flag IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Actual Flag can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Actual Flag can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field transaction_date has value
IF lcu_gl_je.transaction_date IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Transaction Date can not null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Creation Date can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field GL segments has value
IF lcu_gl_je.segment1 IS NULL
OR lcu_gl_je.segment2 IS NULL
OR lcu_gl_je.segment3 IS NULL
OR lcu_gl_je.segment4 IS NULL
OR lcu_gl_je.segment5 IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Either of the GL segments can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Either of the GL segments can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more informa
--p_identifier8 => NULL -- Can be utilized for displaying more informa
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field Currency Conversion Type has value
IF lcu_gl_je.user_curr_conv_type IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Currency Conversion Type can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency Conversion Type can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field set_of_books_id has value
IF lcu_gl_je.set_of_books_id IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Set of books_id can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Set of books id can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- 1 Check if mandatory field currency_code has value
IF lcu_gl_je.currency_code IS NULL THEN
l_record_error_flag := 1;
xx_trace.l ('Currency code can not be null ;');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency code can not be null.'
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
--Updating transaction record in staging table as ER if error
BEGIN
UPDATE xx_gl_je_cnv
SET status = DECODE(l_record_error_flag,1,'ER','NW')
WHERE recid = lcu_gl_je.recid
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
l_error_msg := NULL ;
-- Incrementing record counts
IF l_record_error_flag = 1 THEN
l_error_gl_je_rec_cnt := l_error_gl_je_rec_cnt + 1;
ELSIF l_record_error_flag = 0 THEN
l_valid_gl_je_rec_cnt := l_valid_gl_je_rec_cnt + 1;
END IF;
END LOOP;
-- END IF;
-- END IF;
-- inserting data into pre interface tables
BEGIN
FOR lcu_gl_je_vl IN cur_gl_je_vl
LOOP
BEGIN
INSERT INTO xx_gl_int_preint(
status
, set_of_books_id
, accounting_date
, currency_code
, recid
, last_update_date
, last_updated_by
, creation_date
, created_by
, last_update_login
, actual_flag
, user_je_category_name
, user_je_source_name
, currency_conversion_date
, user_currency_conversion_type
, currency_conversion_rate
, segment1
, segment2
, segment3
, segment4
, segment5
, entered_dr
, entered_cr
, accounted_dr
, accounted_cr
-- , transaction_date
, reference1
, reference2
, reference3
, reference4
, reference5
, reference6
, reference7
, reference8
, reference9
, reference10
)
VALUES (
'IP'
, lcu_gl_je_vl.set_of_books_id
, TO_DATE(lcu_gl_je_vl.transaction_date,'MM/DD/YYYY')
, lcu_gl_je_vl.currency_code
, XX_GL_INT_PREINT_S.NEXTVAL
, lcu_gl_je_vl.last_update_date
, lcu_gl_je_vl.last_updated_by
, lcu_gl_je_vl.creation_date
, lcu_gl_je_vl.created_by
, lcu_gl_je_vl.last_update_login
, lcu_gl_je_vl.actual_flag
, l_je_category --lcu_gl_je_vl.user_je_category_name
, l_batch_source --lcu_gl_je_vl.user_je_source_name
, TO_DATE(lcu_gl_je_vl.currency_conv_date,'MM/DD/YYYY')
, lcu_gl_je_vl.user_curr_conv_type
, NULL
, lcu_gl_je_vl.segment1
, lcu_gl_je_vl.segment2
, lcu_gl_je_vl.segment3
, lcu_gl_je_vl.segment4
, lcu_gl_je_vl.segment5
, lcu_gl_je_vl.entered_dr
, lcu_gl_je_vl.entered_cr
, lcu_gl_je_vl.accounted_dr
, lcu_gl_je_vl.accounted_cr
-- , NULL --lcu_gl_je_vl.transaction_date
, lcu_gl_je_vl.reference1
, lcu_gl_je_vl.reference2
, lcu_gl_je_vl.reference3
, lcu_gl_je_vl.reference4
, lcu_gl_je_vl.reference5
, lcu_gl_je_vl.reference6
, lcu_gl_je_vl.reference7
, lcu_gl_je_vl.reference8
, lcu_gl_je_vl.reference9
, lcu_gl_je_vl.reference10
);
EXCEPTION
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l ('Error while inserting Invoice Line records to pre interface table ');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Error while inserting records to pre interface table .'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => SQLERRM
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
-- RAISE g_rec_ins_exception;
END;
--Updating record in staging table as ER if error
BEGIN
UPDATE xx_gl_je_cnv
SET status = DECODE(l_record_error_flag,1,'ER','NW')
WHERE recid = lcu_gl_je_vl.recid
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
l_error_msg := NULL ;
END LOOP;
END ;
END IF;
-- Validating the data in pre interface tables
BEGIN
l_total_gl_je_pre_rec_cnt :=0;
l_valid_gl_je_pre_rec_cnt :=0;
l_error_gl_je_pre_rec_cnt :=0;
FOR lcu_gl_je_preint IN cur_gl_je_preint
LOOP
l_total_gl_je_pre_rec_cnt := l_total_gl_je_pre_rec_cnt + 1;
l_rec_id:=lcu_gl_je_preint.recid;
l_record_error_flag := 0;
-------- Validate actual flag --------
IF lcu_gl_je_preint.actual_flag <>'A'
-- OR lcu_gl_je_preint.actual_flag <>'B'
-- OR lcu_gl_je_preint.actual_flag <>'E'
THEN
l_record_error_flag :=1;
xx_trace.l ('Actual Flag is not correct'||'-'||lcu_gl_je_preint.actual_flag);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Actual Flag is not correct'||'-'||lcu_gl_je_preint.actual_flag
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-------- Validate currency code --------
BEGIN
SELECT fc.currency_code
INTO l_currency_code
FROM fnd_currencies fc
WHERE currency_flag = 'Y'
AND enabled_flag = 'Y'
AND nvl(fc.end_date_active,sysdate)>= sysdate
AND fc.currency_code = lcu_gl_je_preint.currency_code;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xx_trace.l('Currency Code not defined'||'-'||lcu_gl_je_preint.currency_code);
l_record_error_flag := 1;
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency Code not defined'||'-'||lcu_gl_je_preint.currency_code
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_error_msg := SQLERRM||'-'||lcu_gl_je_preint.currency_code;
l_record_error_flag := 1;
xx_trace.l(l_error_msg);
END;
-------- Validate set of books ID --------
BEGIN
SELECT set_of_books_id
INTO l_set_of_books_id
FROM gl_sets_of_books
WHERE set_of_books_id = lcu_gl_je_preint.set_of_books_id;
EXCEPTION
WHEN NO_DATA_FOUND THEN
xx_trace.l('Set of books ID not defined'||'-'||lcu_gl_je_preint.set_of_books_id);
l_record_error_flag := 1;
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Set of books ID not defined'||'-'||lcu_gl_je_preint.set_of_books_id
, p_identifier3 => l_rec_id
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l (SQLERRM||'-'||lcu_gl_je_preint.set_of_books_id );
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM||'-'||lcu_gl_je_preint.set_of_books_id
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END ;
-------- Validate currency converson type --------
IF lcu_gl_je_preint.user_currency_conversion_type <> 'Corporate'
-- OR lcu_gl_je_preint.user_currency_conversion_type <> 'User'
-- OR lcu_gl_je_preint.user_currency_conversion_type <> 'Spot'
THEN
l_record_error_flag := 1;
xx_trace.l ('Currency Conversion Type is not defined'||' '||lcu_gl_je_preint.user_currency_conversion_type);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Currency Conversion Type is not defined'||' '||lcu_gl_je_preint.user_currency_conversion_type
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
-- Check whether period is open for the transaction date or not
BEGIN
SELECT period_name, closing_status
INTO l_period_name, l_closing_status
FROM gl_period_statuses
WHERE application_id = 101
AND TO_DATE(TO_CHAR(lcu_gl_je_preint.accounting_date,'MM/DD/YYYY'),'MM/DD/YYYY') BETWEEN start_date AND end_date
AND set_of_books_id = lcu_gl_je_preint.set_of_books_id;
IF l_closing_status <> 'O' THEN
l_record_error_flag := 1;
xx_trace.l ('Period'||'-'||l_period_name ||' '||'is not opened');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Period'||'-'||l_period_name ||' '||'is not opened'
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
EXCEPTION
WHEN NO_DATA_FOUND THEN
l_record_error_flag := 1;
xx_trace.l ('Period'||'-'||l_period_name ||' '||'is not defined');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Period'||'-'||l_period_name ||' '||'is not defined'
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l (SQLERRM);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
l_process_status :=0;
l_error_message := NULL ;
END ;
-- check CCID for the gl segments
BEGIN
l_ccid_ext:= xx_common_validations_pkg.get_coa_ccid (
p_segment1 =>lcu_gl_je_preint.segment1
,p_segment2 =>lcu_gl_je_preint.segment2
,p_segment3 =>lcu_gl_je_preint.segment3
,p_segment4 =>lcu_gl_je_preint.segment4
,p_segment5 =>lcu_gl_je_preint.segment5
-- ,p_segment6 =>
-- ,p_segment7 =>
,p_process_status => l_process_status
,p_error_message => l_error_message
,p_ccid => l_ccid
);
IF l_ccid_ext <> 'VALID' THEN
l_record_error_flag := 1;
xx_trace.l (l_error_message);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => l_error_message
, p_identifier3 => l_rec_id
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
l_process_status :=0;
l_error_message := NULL ;
END ;
-- update pre interface table
BEGIN
UPDATE xx_gl_int_preint
SET status = DECODE(l_record_error_flag,1,'ER','IP')
WHERE recid = lcu_gl_je_preint.recid
;
EXCEPTION
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l (SQLERRM);
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
--RAISE g_rec_ins_exception;
END;
IF l_record_error_flag = 1 THEN
l_error_gl_je_pre_rec_cnt := l_error_gl_je_pre_rec_cnt + 1;
ELSIF l_record_error_flag = 0 THEN
l_valid_gl_je_pre_rec_cnt := l_valid_gl_je_pre_rec_cnt + 1;
END IF;
END LOOP;
END ;
END IF;
END validate_records;
PROCEDURE process_records ( l_processed_gl_je_rec_cnt OUT NOCOPY PLS_INTEGER
, l_header_id IN NUMBER)
/* ***********************************************************************************************************
* Procedure Name : process_records *
* Description : Process validated Invoice records *
* Called From : Concurrent Program *
* *
* Parameters Type Description *
* l_processed_gl_je_rec_cnt OUT To stote total processed invoice lines records *
* *
* Tables Accessed *
* ----------------- *
* xx_gl_je_cnv : S,I,U *
* xx_gl_je_cont_rec_cnv : S,I,U *
* xx_gl_int_preint : I,U *
* gl_interface : I,U *
* *
* *
* Change History *
* ----------------- *
* Version Date Author Description *
* --------- ------------- --------------- -------------------------- *
* Draft 1A 18-Dec-2015 Madhu Dhare Original Code *
************************************************************************************************************* */
IS
l_record_error_flag NUMBER;
l_org_id PLS_INTEGER := FND_GLOBAL.ORG_ID;
int_date DATE;
l_interface_run_id NUMBER;
l_gl_application_name CONSTANT VARCHAR2(30):= 'SQLGL';
l_journal_imp_prog_name CONSTANT VARCHAR2(30):= 'GLLEZL';
--Cursor to fetch Invoice Line information from the staging table
CURSOR cur_valid_gl_je IS
SELECT *
FROM xx_gl_int_preint
WHERE status = 'IP'
;
CURSOR c_gl_iface_ctl IS
SELECT gl_journal_import_s.NEXTVAL interface_run_id
FROM DUAL;
BEGIN
l_processed_gl_je_rec_cnt := 0;
FOR lcu_valid_gl_je IN cur_valid_gl_je
LOOP
l_record_error_flag := 0;
BEGIN
INSERT INTO gl_interface(
status
, set_of_books_id
, accounting_date
, currency_code
, date_created
, created_by
, actual_flag
, user_je_category_name
, user_je_source_name
, currency_conversion_date
, encumbrance_type_id
, budget_version_id
, user_currency_conversion_type
, currency_conversion_rate
, segment1
, segment2
, segment3
, segment4
, segment5
, entered_dr
, entered_cr
, accounted_dr
, accounted_cr
, reference1
, reference2
, reference3
, reference4
, reference5
, reference6
, reference7
, reference8
, reference9
, reference10
)
VALUES (
'NEW'
, lcu_valid_gl_je.set_of_books_id
, lcu_valid_gl_je.accounting_date
, lcu_valid_gl_je.currency_code
, SYSDATE
, lcu_valid_gl_je.created_by
, lcu_valid_gl_je.actual_flag
, lcu_valid_gl_je.user_je_category_name
, lcu_valid_gl_je.user_je_source_name
, lcu_valid_gl_je.currency_conversion_date
, lcu_valid_gl_je.encumbrance_type_id
, lcu_valid_gl_je.budget_version_id
, lcu_valid_gl_je.user_currency_conversion_type
, NULL
, lcu_valid_gl_je.segment1
, lcu_valid_gl_je.segment2
, lcu_valid_gl_je.segment3
, lcu_valid_gl_je.segment4
, lcu_valid_gl_je.segment5
, lcu_valid_gl_je.entered_dr
, lcu_valid_gl_je.entered_cr
, lcu_valid_gl_je.accounted_dr
, lcu_valid_gl_je.accounted_cr
, lcu_valid_gl_je.reference1
, lcu_valid_gl_je.reference2
, lcu_valid_gl_je.reference3
, lcu_valid_gl_je.reference4
, lcu_valid_gl_je.reference5
, lcu_valid_gl_je.reference6
, lcu_valid_gl_je.reference7
, lcu_valid_gl_je.reference8
, lcu_valid_gl_je.reference9
, lcu_valid_gl_je.reference10
);
EXCEPTION
WHEN OTHERS THEN
l_record_error_flag :=1;
xx_trace.l ('Error while inserting records into gl_interface');
--Write to Error
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => 'Error while inserting records into gl_interface'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
--Updating records in pre interface table as ER if error in site processing else PR
IF l_record_error_flag = 0 THEN
l_processed_gl_je_rec_cnt := l_processed_gl_je_rec_cnt + 1 ;
BEGIN
UPDATE xx_gl_int_preint
SET status = DECODE(l_record_error_flag,1,'ER','PR')
WHERE recid =lcu_valid_gl_je.recid
;
EXCEPTION
WHEN OTHERS THEN
l_error_msg := SQLERRM;
xx_trace.l(l_error_msg);
RAISE g_rec_ins_exception;
END;
END IF ;
END LOOP;
/*---------------------------------------------------------------------------------------
Launch Standard Concurrent Program - With WAIT/Call Oracle Standard APIs
----------------------------------------------------------------------------------------*/
BEGIN
xx_common_validations_pkg.init_apps_params
( p_request_id => l_request_id
, p_process_status => l_process_status
, p_error_message => l_output_message
);
IF l_processed_gl_je_rec_cnt > 0 THEN
-- This concurrent program is used for creating GL JE Header and Lines
FOR lcu_gl_iface_ctl IN c_gl_iface_ctl LOOP
l_interface_run_id := lcu_gl_iface_ctl.interface_run_id;
END LOOP;
BEGIN
INSERT INTO gl_interface_control
(je_source_name
,status
,interface_run_id
,GROUP_ID
,set_of_books_id
,packet_id
,interface_table_name
,processed_table_code
,request_id
)
VALUES (l_batch_source -- JE_SOURCE_NAME
,'S' -- STATUS
,l_interface_run_id -- INTERFACE_RUN_ID
,NULL -- GROUP_ID
,l_set_of_books_id -- SET_OF_BOOKs_ID
,NULL -- PACKET_ID
,'GL_INTERFACE' -- INTERFACE_TABLE_NAME
,NULL -- PROCESSED_TABLE_CODE
,NULL -- REQUEST_ID
);
EXCEPTION
WHEN OTHERS THEN
xx_trace.l (SQLERRM);
xx_emf.call_store_message
( p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 -- low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00001'
, p_identifier2 => SQLERRM
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_identifier4 => NULL
, p_identifier5 => NULL
, p_identifier6 => NULL
--p_identifier7 => NULL -- Can be utilized for displaying more information
--p_identifier8 => NULL -- Can be utilized for displaying more information
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END;
l_standard_request_id := fnd_request.submit_request
(
application => l_gl_application_name
,program => l_journal_imp_prog_name
,description => ''
,start_time => ''
,sub_request => FALSE
,argument1 => l_interface_run_id -- Interface Run ID
,argument2 => l_set_of_books_id -- Set of Books ID
,argument3 => 'N' -- Allow Suspence posting
,argument4 => NULL -- default date
,argument5 => NULL -- transaction flexfield
,argument6 => '' -- transaction type
,argument7 => '' -- bill to customer number (low)
,argument8 => CHR(0) -- bill to customer number (high)
,argument9 => '' -- bill to customer name (low)
,argument10 => '' -- bill to customer name (high)
,argument11 => '' -- gl date(low)
,argument12 => '' -- gl date (high)
,argument13 => '' -- ship date(low)
,argument14 => '' -- ship date(high)
,argument15 => '' -- transaction number(low)
,argument16 => '' -- transaction number(high)
,argument17 => '' -- sales order number (low)
,argument18 => '' -- sales order number (high)
,argument19 => '' -- invoice date (low)
,argument20 => '' -- invoice date (high)
,argument21 => '' -- ship to customer number (low)
,argument22 => '' -- ship to customer number (high)
,argument23 => '' -- ship to customer name (low)
,argument24 => '' -- ship to customer name (high)
,argument25 => 'Y' -- base due date on trx date
,argument26 => '' -- due date adjustment date
,argument27 => l_org_id -- org id
);
IF l_standard_request_id > 0 THEN
COMMIT;
ELSE
xx_emf.call_store_message
(p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 --Low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00004'
, p_identifier2 => 'Error in submitting concurrent request'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
l_phase := NULL ;
l_vstatus := NULL ;
l_dev_phase := NULL ;
l_dev_status := NULL ;
l_message := NULL ;
--Wait for the completion of the concurrent request (if submitted successfully)
l_completed := fnd_concurrent.wait_for_request
(request_id => l_standard_request_id
, INTERVAL => 60
, max_wait => 0
, phase => l_phase
, status => l_vstatus
, dev_phase => l_dev_phase
, dev_status => l_dev_status
, MESSAGE => l_message
);
xx_trace.l ('Request submitted with request id-'|| l_standard_request_id
);
ELSE
xx_emf.call_store_message
(p_message_group => 'ERR_DTL'
, p_header_id => l_header_id
, p_debug_value => 20 --Low level debugging
, p_global_debug => g_debug_level
, p_identifier1 => 'E-00004'
, p_identifier2 => 'No records To Process in Interface Table'
, p_identifier3 => NULL
-- Can be utilized to store record serial number
, p_process_status => l_return_value
, p_error_message => l_output_message
);
END IF;
END;
END ;
END;
/
SHOW ERROR;
EXIT;