This chapter contains the following sections:
After the robot has finished with all the entries in the enumeration-pool and has finished all outstanding processing, you can specify additional programs to execute by enabling the cmdHook parameter.
The cmdHook is provided as a way for you to extend the shutdown phase of the robot. For example, you might want the robot to send email after it completes one run, start another process, analyze its own log files, write a small report, and so on.
When the robot has finished all outstanding processing, it will call the executable specified in the cmdHook setting. If the onCompletion parameter is set to idle or quit, the script is called once before the robot shuts down or goes idle. If the parameter is set to loop, the script is called each time the robot restarts. See the log samples in Monitoring cmdHook Execution.
The cmdHook script can be written in any language (as a Perl or shell script, a C program, and so on). If you choose to use a C program, you’ll have to insert the cmdHook parameter in the robot.conf file manually, as the search engine Administration Interface does not scan binary executables.
The cmdHook script is run from the robot’s execution environment. This means your script will inherit any environment variables set by the robot and will not have access to environment variables that might be set by your search server or the administration server. The cmdHook script will be executed from webcontainer-base/portal. This is important to keep in mind if you are using any relative directory references.
There are two examples provided in PortalServer-base/samples/robot directory. They are a simple touch test (cmdHook0) and an email upon completion (cmdHook1) scripts.
At the default logging level, a log message is written in robot.log when the cmdHook is run.
For example, if the onCompletion parameter is set to idle, the robot.log output appears as follows:
| [12:45:57] Run cmd: /opt/SUNWps/bin/cmdHook1 [12:45:58] Complete cmd: /opt/SUNWps/cmdHook1 [12:45:58] Robot is idle.... . . . if the onCompletion parameter is set to shutdown, the robot.log output would look like: [12:45:57] Run cmd: /opt/SUNWps/bin/cmdHook1 [12:45:58] Complete cmd: /opt/SUNWps/bin/cmdHook1 [12:46:33] Workload complete. . . . if the onCompletion parameter is set to loop, the robot.log output would look like: [12:52:04] Run cmd: /opt/SUNWps/bin/cmdHook1 [12:52:05] Complete cmd: /opt/SUNWps/bin/cmdHook1 [12:52:05] Restart Robot. . . . if the onCompletion parameter is set to loop, there will be an additional entry in filter.log like this: [12:54:41] Filter log started - loop 15 | 
If you want your cmdHook script to display as an option on the search engine administration page, you should follow these guidelines:
Because the search engine Administration Interface does not scan binary files when it looks for cmdHook scripts, write your script in a run-time evaluated language instead of C or another compiled language.
Place the file in PortalServer-base/bin directory.
Name the file cmdHook, followed by an alphanumeric character-string, for example, cmdHook0, cmdHookAlpha, cmdHook12a.
Add a description string to the file and comment it so that it does not affect the execution of the script. For example, #description="My menu choice string".