Select Feed Plus User Manual
Select Feed Plus User Manual
On startup gensfp either
(a) opens a port to a Reuters Select Feed Plus server, establishes an on-line session or
(b) connects to an SSL compliant data source.
Once connected, both versions send a set of RIC requests (read from a file). The returned data are read and, for each data record received, a Genesis Script is executed to format and send the required field values to a target Bank system.
Gensfp runs on any hardware and operating system that
supports an ANSI C compiler.
The parameters for gensfp are as follows:
tcid a four or less character code (usually "RSFP")
which will be used to ID associated logfiles
and data record files
script_ext the 3 character
filename extension of the set of scripts that will be
associated with this SFP client.
once If this argument is the
string "once" gensfp will issue all RIC requests as
"oneshot" (current value only (type-340 records)) i.e. no
update (type-316) records. Once all the requested RIC responses
have been gathered, gensfp is automatically shut
down.
max_secs t The number
of seconds that gensfp will wait for RICS from the
Reuters feed before automatically shutting itself down. If not
all the RICS have arrived within this time, gensfp will
re-request the late RICS and remain active for some additional
time to allow these RICS to be delivered.
setenv MRG_ECMD (uniq -6 | mail -S \"Critical Softek Message\" salist)
Each line in the <TCID>.msg file is timestamped and
its process-origin is identified. <TCID>.msg is deleted
each time after the command in MRG_ECMD is executed.
To prevent short-term error conditions from producing
orphaned notifications a 45 second delay is
implemented for new batches of error notifications.
MRG_SCREXT Script extension specifier, usually set as an argument to gensfp
MRG_ONCE If this variable has the value "once" or "ONCE", gensfp will keep track of which and how many RICS have been requested and will exit once all the requests have been satisfied.
MRG_MAXSECS The number of seconds that gensfp will wait for RICS from the Reuters feed before automatically shutting itself down. If not all the RICS have arrived within this time, gensfp will re-request the late RICS and remain active for some additional time to allow these RICS to be delivered.
MRG_ECMD The command to be used to process critical (information and error) messages (including all arguments to run the command) is taken from this variable. The command must take its input from the "standard input" stream.
MRG_MSGDIR The directory where transitory work files will be stored. Both critical messages and conversation details (Reuters only) make a temporary appearance in this directory.
MRG_LOGDIR The directory that will be used to store the logfiles generated by this program.
MRG_DLSDIR The directory that will be used to store the RIC Data received by this program.
SEN_LCKDIR see System Startup
SEN_EXE see System Startup
SEN_EXECDIR see System Startup
If gensfp is left running overnight, a new logfile is automatically created as soon as necessary after midnight.
Each record in this file comprises 3 parts as follows:
- a timestamp on a line by itself (together with the word "Start RIC" and the name of the RIC).
- the fields of the record (each field begins a new line and starts with the Reuters field identifier (a number) followed by a colon (':') character and then followed by the field data.) If the field data contains newline characters, these are also output,
- the timestamp in 1. repeated (together with the word "End RIC" and the name of the RIC).
The file <tcid><mmdd>.msg contains one line for each critical message. Each line comprises four sections:
- <application name>
- [<DateTime>]
- <a critical message>
- #<a critical message number>. Error numbers produced by ctksi are in the 120,000 to 129,999 range.
For Example:
cicsfp [Wed Sep 29 12:02:24 1999] RIC RZDET= does not
exist #121302
<machinename>:<portname>
Where <portname> is the number of a port, or the name of a port (found in /etc/services) that, on the machine named <machinename>, should be serving RIC data in the proper format. If necessary, numbers may be used instead of names for both the above data items. e.g.
192.168.2.1:6500
would be a legal designation for a Reuters Select Feed Plus server. Gensfp is a client to these RIC-data servers. Gensfp is itself a server for two ports whose details are also given in the ipmerge.ini file. When gensfp reads a line of the form:
_OUTPUT_:<portname>
or
_CONTROL_:<portname>
gensfp configures the port whose number is may be
derived by looking up <portname> in /etc/services (or
whose number is <portname>) to deliver RIC data.
Gensfp executes limited control commands sent to it
(e.g., via telnet) on the port tagged with the token
_CONTROL_.
Lines, in the file ipmerge.ini, starting with the "hash"
character (#) are ignored (they are comments or temporarily
disabled configuration lines). Both _OUTPUT_ and _CONTROL_
configuration lines must be present, although they may
appear anywhere in ipmerge.ini.
Gensfp uses a special form of the _OUTPUT_ designator to
indicate that the output should be processed through script
files. The special form is:
_OUTPUT_:_SCRIPT_
Message Type
Name of Script File
340 (Current Value on request)
sfp340.<ext>
316 (Asynchronous Data Update)
sfp316.<ext>
4 (News Item)
sfp4.<ext>
407 (Status Response)
sfp407.<ext>
These additional script files are invoked under the following conditions:
Condition
Name of Script File
gensfp startup
startup.<ext>
gensfp shutdown
shutdown.<ext>
"r" typed at intractive console
operator.<ext>
optionyearThe single character in the workarea is interpreted as an "Option Year Code". The resulting 4-character year is loaded back into the workarea. The initially loaded code should be taken from the last character of an Option RIC.optionmonthindex
The single character in the workarea is interpreted as an "Option Month Specifier". The resulting 1-based month index is loaded back into the workarea. This transform automatically distinguishes between "call" or "put" option codes. The initially loaded character should be loaded from the character before last of an Option RIC.expiremonthindex
The single character in the workarea is interpreted as an "Option Expiry Month". The resulting 1-based month index is loaded back into the workarea. The initially loaded character should be taken from the character before last of the relevant RIC, perhaps using the sequence:save:2
loadric:
transform:lastchars
save:1,1
transform:substr
ifn:transform:expiremonthindex
goto:baddataoptioncallorput
The single character in the workarea is interpreted as an "Option Month Specifier " and then converted into the upper-case word "CALL" or "PUT" depending on which type of instrument this "Month Specifier" would represent.swapperiod
The RIC in the workarea is decoded to establish its "swap-period". First a RIC delimiter (character in the set [!=.*>:+-,\]) is located, the preceeding character is checked and must be 'Y', the decimal digits preceeding the 'Y' are collected and the string " year" is appended. The resulting string (e.g. "10 year") is loaded back into the workarea. If the initial string (RIC), that is loaded into the workarea, is not of the appropriate form (a swap RIC designator), this transform will fail (see the if script-statement). For example:USDAM3L15Y=ICAPin the workarea would be replaced with "15 year".
firstxperiod
The RIC in the workarea is decoded to establish its first time period. The magnitude of the period is isolated and set apart from its period-type by a space. For example:USD3MX1Y=TTKLin the workarea would be replaced with "3 M".
secondxperiod
The RIC in the workarea is decoded to establish its first time period. The magnitude of the period is isolated and set apart from its period-type by a space. For example:USD3MX1Y=TTKLin the workarea would be replaced with "1 Y".
cashinstrument
swapinstrument
futureinstrument
numslash2tab
FxOptionVol
AddDotToOptionPrice
On the NT, an executable binary called ExecIt is provided. Since it takes no arguments, given a suitable program wrapper (not provided) ExecIt may be run as an NT service. Alternatively, ExecIt may be configured to start up on user log-in. ExecIt is configured via the following environment variables:
SEN_LCKDIR
SEN_EXE
SEN_EXECDIR
When ExecIt detects a file "softek.lck" in the directory
pointed at by the conents of the SEN_LCKDIR environment
variable, ExecIt executes the command, whose name is
given by the contents of the SEN_EXE environment variable,
found in the directory pointed at by the contents of the
SEN_EXECDIR environment variable, (phew!!).
The usual target, on the NT, for
ExecIt is a ".cmd" script e.g.
::run all ric directories one after the other
echo off
cd c:\Softek\cicsfp\production
cd ric_fx
del *.log *.rcs *.inp
C:\softek\bin\sed < %SEN_LCKDIR%\..\softek_input\ric_fx.txt > rics.ini -e s/\012/\015/
..\..\debug\cicsfp FX cic once 30
copy *.log %SEN_LCKDIR%\..\log
copy *.rcs %SEN_LCKDIR%\..\log
copy *.inp %SEN_LCKDIR%\..\softek_output
cd ..
del %SEN_LCKDIR%\softek.lck
exit
Note that the ".cmd" script deletes the "softek.lck" file
once it has finished processing, thereby providing a signal
back to a remote host (that is hosting the "lock" directory)
that the data gathering task has finished.
Number of Rics requested
Number of Rics retrieved
Number of Rics in error (broken down into)Number rejected,
Number not-permissioned,
Number not-found,
Number of data(script)-errorsNumber of Rics not received in time
- q or Q quit the program gracefully
- r or R run the script-file named operator.<ext>
- k or K list on the controlling window a status line concerning each of the ports specified in the ipmerge.ini file. Information is given about any valid sockets associated with these ports and their states (readable (r), writeable (w), or exception (x)).
- eof gensfp enters Daemon Mode (see above).
Interactive Mode is intended for use as a debugging aid,
since all messages will appear on the screen as they are
output. The use of Interactive Mode is strongly discouraged in
production since simple keyboard entry may be used to shut the
process down.
On UNIX operating systems, SIGPIPE is caught and its passage is noted in the logfile.