End of Day Troubleshooting
The End of Day Sequence is run in all properties at the end of their business day. This runs in different steps that are separated into the categories of postings, procedures, and reports.
Arrivals for Today. Allows you to check-in the Due In guests. If you choose not to check in the listed guests, they would become No Shows during the Roll the Business Date part of the End of Day Sequence.
Departures for Today. All the Due Out guests for that Business date are listed. You can either extend the stay of the guest or check out the guest. You cannot proceed without completing this operation.
Automatic Closure of Cashiers. When the END OF DAY > AUTO CLOSE CASHIERS application parameter is set to Y, this procedure automatically closes all cashiers that have not been closed without a user having to go through balancing each of the cashiers individually.
Note: If the CASHIERING > POSITIVE CASHIER DROP application parameter is set to Y, OPERA will not allow cashiers to be closed with a negative shift drop.
Weather. When the END OF DAY > WEATHER AND NOTES application parameter is set to Y, you can activate the Weather and Notes routine.
Roll the Business Date. This operation rolls the system to the next business date. When you start this step, it accepts the number of minutes to wait before making users log out of their opera sessions (as defined in application settings). OPERA broadcasts the message to all other users that the business date is going to be rolled. After waiting for the specified number of minutes, the End of Day Sequence will kill all the existing opera sessions and roll the business date. The users can then go back into the system and pick up the new date. The first process that End of Day Sequence runs after rolling the business date is the No Show procedure. This process should not take long to complete. During this process, users are not allowed to alter the reservations that are in the process of being No Showed. If there is an exception in the No Show procedure, a message appears that includes the exact step prior to when the exception occurred.
Posting Room and Tax. All the in-house guests for the selected Business Date will have room, tax, packages, and fixed charges posted based on their rate code.
Running Procedures. All the procedures would be run during this step. These populate the summary tables.
Printing Reports. Prints all End of Day Sequence reports. Reports are stored on the application server under the Export folder.
The following is the list of the mandatory End of Day Sequence procedures, followed by a list of the optional procedures.
Note: The procedures above are mandatory for the income audit as well. These procedures will be run twice if you use Income audit, once in the End of Day Sequence and once before the income audit.
Procedures below are not mandatory but can be configured to run in the End of Day Sequence. The mandatory procedures below are only run once in the End of Day Sequence even if you use Income Audit functionality.
Posting Room and Tax, Running Procedures and Printing Reports are submitted as jobs in the database. To know about the jobs, Support needs to be aware of two Database views, DBA_JOBS and DBA_JOBS_RUNNING.
The following two-step query gives information about what jobs are running.
SELECT J.JOB, J.WHAT, J.SCHEMA_USER, J.FAILURES, J.INSTANCE, r.sid
FROM DBA_JOBS j, dba_jobs_running r
where j.job = r.job
and j.instance in (select instance_number from v$instance where rownum < 2);
Next, select information about the session. You should issue the following statement.
Note: Replace the X below with proper sid value given in the statement above.
Select * from v$session where sid = <X>;
The following statuses are for information purposes only.
When the Posting Room and Tax procedure starts, the MANDATORY_PROCS_PROGRESS column in this table will be updated to PROGRESS for the business date for which the End of Day Sequence is running. This prevents the user from starting any other post room and tax process. If the user gets blocked,, Support needs to kill the job and update the value PROGRESS to ERROR for that business date. Caution is suggested while doing this, as updating of this value to anything other than ERROR could result in serious problems. All the updates should be followed with a Commit.
This table stores the information about each reservation, whether the Post Room and Tax, Posting Fixed Charges, Posting Packages, Posting Package Profit/Loss is complete.
This table stores the times of all the procedures and their running statuses. If a procedure fails, this would be again picked up by the End of Day Sequence until the status of those procedures turns to COMPLETE. The ITERATION column tells how many times the procedure has run to become COMPLETE. SYS_JOB_ID column is a unique value generated for each insert. The different statuses that a procedure can have are RUNNING (Currently running), FAILED (Failed), and COMPLETED (Successfully completed).
This would insert records, if the Post Room and Tax procedure encounters errors. If you want to see the errors generated by one procedure, you can issue the following statement after replacing the proper sys_job_id from the night_audit_jurnal table.
Select * from night_audit_jurnal_details where sys_job_id = 15840;
The purpose of this table is to determine what reports/procedures exist for a particular day. Initialization for a day is required to access proper information from this view.
The following statement is used if you want to initialize to a particular date. This would be useful if you want to run a procedure from SQL Navigator for a date in the past. FDH in this following statement is the property code. Substitute your property code for FDH and the date in question.
begin
pms_p.initialize('NA_REPORTS','NA_REPORTS','FDH', 10-jan- 2001);
end;
Logon to SYSSTAT and check the session for blocking locks that can be resolved. This may take a few minutes. If it does not get resolved, escalate the issue.
Identify the session in which the job is running. Issue the two-step statements above to get the SID and serial number. Issue the following statement to kill the session. When you perform the following steps, allow the system some time (510 minutes) to take care of the sessions clean up.
Begin
Dbms_job.remove(<job_no>);
END;
If the above statement does not resolve the problem, proceed to kill the session using the following statement (where 12 = SID and 12312 = serial#).
Alter system kill session 12,12312;
If you kill a job while the End of Day Sequence is posting room and tax and the user gets stopped, Support will need to kill the job and update the value ‘Progress’ to ‘Error’ for that business date. Caution is advised while doing this as the wrong updates of this value could result in serious problems and jeopardize the integrity of the property’s financial data. All the updates should be followed with a Commit.
If you kill a job while procedures are running, it would make the current procedure fail and the application would proceed with other procedures.
In OPERA V2.0 and higher, Support does not need to update the business date as the program recognizes if the process is already running, and it would go to the respective Action Status screens if the Post Room and Tax procedure is in progress, if Procedures are in progress, or if Reports are in progress.
At the beginning of the End of Day process, a validation checks that all of the necessary application settings are set up to successfully complete the End of Day. If any of the required application settings are not set up, a message appears listing the ones that must be set up in order to continue.
When initiating a Night Audit, if certain java components, IP Addresses, Virtual IP Address, etc., are not configured properly and user sessions cannot be disconnected, this will prevent the Night Audit from completing successfully. When this occurs, OPERA will display a message "Opera application is not configured properly for the Night Audit. Do you want to see the error?" Select Yes to display the error and details related to it and have the option to create and export file of these errors. Select No to continue with the Night Audit process.
During Auto Check in for Pseudo Rooms, this message appears: 'Auto Check In of Pseudo Rooms procedure is running. Please wait...', and any error is logged in the night audit journal table.
In the following statement, replace the resort and business_date with proper values. The result from the SQL statement in the TIMETAKEN column will be shown in seconds.
Select job_name, (end_time-start_time)*24*60*60 TIMETAKEN, to_char(START_time,HH24:MI:SS) st,
to_char(end_time,HH24:MI:SS) en, status
From night_Audit_jurnal
Where resort = PHGBP (replace the PHGBP with the property code of your resort).
And business_date = 25-apr-01 (replace 25-apr-01 with the business date for the End of Day Sequence being run).
Order by sys_job_id
This error indicates that you do not have write permissions to the directory. While reprinting the report OPERA creates one file in the specified directory. Make sure that the directory that you indicated allows you to create a file from your workstation.
Go to the DOS Command prompt and enter the following SQL statement:
ALTER SYSTEM FLUSH SHARED POOL
Following is a checklist to investigate the Setup and Configuration of the Application Server and Print Server:
These are the files that are required to be in the PrintServer directory for the printserver to start:
If the files are not there, perform the following steps:
Also make sure the following steps are completed and correct:
set CLASSPATH=d:\printserver
java HTMLServer operaprint.conf start (This is the command to start the printserver)
If not then a small test command can be tried from the command prompt. Type the following test command:
jre -cp "d:\printserver;d:\printserver\classes12.zip" PrintClient APARNAC http://pmsweb/webtemp/abc.txt
"\\NPLDOMNW2S003\LANIER211" 23 pms_dev pms_dev purdue:1521:ohopera OPERAM SUPERVISOR
Parameters Explanation for above test command:
Parameter |
Explanation |
-cp |
Sets the CLASSPATH on the fly. We can get to the runtimes directory using the registry key OPERARUNTIMES which we set as part of the installation. |
PrintClient |
The class file that contains the Main Method and opens the Socket communication. |
APARNAC |
Machine name where the Print Receiver END was started. For testing we can use the same machine or different ones. |
http://pmsweb/webtemp/abc.txt |
File name in URL form. This can be a txt file or a .pdf file. |
\\NPLDOMNW2S003\LANIER211 |
Printer device where the output will be sent. |
23 |
SID of the session of the user submitting the print job. |
pms_dev pms_dev |
Schema name and schema password from where user is printing. |
purdue:1521:ohopera |
Connect string to establish a connection with the Java program. Purdue is HostName, 1521 is Port No., and ohopera is the Oracle database name. |
OPERAM |
The application name of the hotel from which the user is printing. |
SUPERVISOR |
User ID of the person logged into the application. |
The last five parameters (23, pms_dev pms_dev, purdue:1521:ohopera, OPERAM, OPERA) are required to process the messages so Broadcast Messaging displays messages to the correct user.
This will insert messages into the message_bin table in pms_dev schema on ohopera.
The SQL statement below will show the messages that have been inserted with possible problems:
Select * from message_bin
All the logging messages into the database is done by the PrintClient.class file.
There are a few objects required for the Reports Queue Manager to accept a report request.
The RW_QUEUE_SERVER table needs to exist.
In SQL, check the contents of this table. At the SQL prompt, type desc rw_server_queue, and your screen should return the following information.
SQL> desc rw_server_queue
Name |
Null? |
Type |
JOB_TYPE |
|
VARCHAR2(2000) |
JOB_ID |
|
NUMBER |
JOB_NAME |
|
VARCHAR2(2000) |
STATUS_CODE |
|
NUMBER |
STATUS_MESSAGE |
|
VARCHAR2(2000) |
COMMAND_LINE |
|
VARCHAR2(2000) |
OWNER |
|
VARCHAR2(2000) |
DESTYPE |
|
VARCHAR2(2000) |
DESNAME |
|
VARCHAR2(2000) |
SERVER |
|
VARCHAR2(2000) |
QUEUED |
|
DATE |
STARTED |
|
DATE |
FINISHED |
|
DATE |
LAST_RUN |
|
DATE |
NEXT_RUN |
|
DATE |
REPEAT_INTERVAL |
|
NUMBER |
REPEAT_PATTERN |
|
NUMBER |
CACHE_KEY |
|
VARCHAR2(2000) |
CACHE_HIT |
|
NUMBER(1) |
The Status_Code field has values from 1-8, which correspond to the following:
For every report you run there will be one record in this table.
Locate the default.env file in the //applicationserver/forms90/server directory. This has to be set with the path for the JRE l exactly like the following example:
ORACLE_HOME=d:\opera\10gdev
PATH=d:\opera\10gdev;d:\opera\10gdev\jre11\bin
FORM90_PATH=d:\runtimes;d:\runtimes\gifs
CLASSPATH=d:\runtimes
OS=WINDOWS
If this is missing, your reports will not be sent to the printer. The report will run but since the path to the JRE is not set up, the output will not be sent to the printer.
End of Day Sequence Reports. These run during End of Day Sequence and get printed automatically based upon configuration of your End of Day Sequence.
End of Day Sequence Reprint. This happens when you go to NAREPRINT form and click on the Print button. The request that was completed during the End of Day Sequence will be changed to PENDING again. CCMAN will then pick them up, print the same output that was generated during End of Day Sequence, and run the same request command. The End of Day Sequence hard copy report and End of Day Sequence reprint of the same report will never be different.
End of Day Sequence Regenerate. This will regenerate the batch file, regenerate the parameters file .ctl and will rerun the report with those parameters. Any changes to data made after the original audit that affect this date will show up on a regenerated report.
Note: The End of Day Sequence reports will be stored on the application server under the Export folder. This directory should be on the application server in the path d:\micros\opera\export\schema name\opera1\audit.