Processing the message retrieved by the CAM on z/OS
A message retrieved by the Credit Application Manager (CAM) can be one of four types. The way in which the CAM processes a message depends on its type.
A message retrieved by the CAM can be one of four types:- An inquiry message
- A reply message
- A propagation message
- An unexpected or unwanted message
The CAM processes these messages as follows:
- Inquiry message
- Inquiry messages come from the user interface program. It creates an inquiry message for each
loan request.
For all loan requests, the CAM requests the average balance of the customer's checking account. It does this by putting a request message on alias queue CSQ4SAMP.B2.OUTPUT.ALIAS. This queue name resolves to queue CSQ4SAMP.B3.MESSAGES, which is processed by the checking-account program, CSQ4CVB3. When the CAM puts a message on this alias queue, it specifies the appropriate CSQ4SAMP.B2.REPLY.n queue for the reply-to queue. An alias queue is used here so that program CSQ4CVB3 can easily be replaced by another program that processes a base queue of a different name. To do this, you redefine the alias queue so that its name resolves to the new queue. Also, you could assign differing access authorities to the alias queue and to the base queue.
If a user requests a loan that is larger than 10000 units, the CAM initiates checks on other databases as well. It does this by putting a request message on queue CSQ4SAMP.B4.MESSAGES, which is processed by the distribution program, CSQ4CVB4. The process serving this queue propagates the message to queues served by programs that have access to other records such as credit card history, savings accounts, and mortgage payments. The data from these programs is returned to the reply-to queue specified in the put operation. Additionally, a propagation message is sent to the reply-to queue by this program to specify how many propagation messages have been sent.
In a business environment, the distribution program would probably reformat the data provided to match the format required by each of the other types of bank account.
Any of the queues referred to can be on a remote system.
For each inquiry message, the CAM initiates an entry in the memory-resident Inquiry Record Table (IRT). This record contains:- The MsgId of the inquiry message
- In the ReplyExp field, the number of responses expected (equal to the number of messages sent)
- In the ReplyRec field, the number of replies received (zero at this stage)
- In the PropsOut field, an indication of whether a propagation message is expected
The CAM copies the inquiry message onto the waiting queue with:
- Priority set to 3
- CorrelId set to the MsgId of the inquiry message
- The other message-descriptor fields set to those of the inquiry message
- Propagation message
- A propagation message contains the number of queues to which the distribution program has
forwarded the inquiry. The message is processed as follows:
- Add to the ReplyExp field of the appropriate record in the IRT the number of messages sent. This information is in the message.
- Increment by 1 the ReplyRec field of the record in the IRT.
- Decrement by 1 the PropsOut field of the record in the IRT.
- Copy the message onto the waiting queue. The CAM sets the Priority to 2 and the other fields of the message descriptor to those of the propagation message.
- Reply message
- A reply message contains the response to one of the requests to the checking-account program or
to one of the agency-query programs. Reply messages are processed as follows:
- Increment by 1 the ReplyRec field of the record in the IRT.
- Copy the message onto the waiting queue with Priority set to 1 and the other fields of the message descriptor set to those of the reply message.
- If ReplyRec = ReplyExp, and PropsOut = 0, set the MsgComplete flag.
- Other messages
- The application does not expect other messages. However, the application might receive messages
broadcast by the system, or reply messages with a unknown CorrelIds.
The CAM puts these messages on queue CSQ4SAMP.DEAD.QUEUE, where they can be examined. If this put operation fails, the message is lost and the program continues. For more information about the design of this part of the program, see How the sample handles unexpected messages.
Parent topic: Credit application manager (CSQ4CVB2) on z/OS