Design of the sample
When you start the sample, it displays a screen map that has fields for:
- Name of the queue
- User request (valid actions are: inquire, allow, or inhibit)
- Current status of put operations for the queue
- Current status of get operations for the queue
The first two fields are for user input. The last two fields are filled by the application: they show the word INHIBITED or the word ALLOWED.
The application validates the values that you enter in the first two fields. It checks that the queue name starts with the characters CSQ4SAMP and that you entered one of the three valid requests in the Action field. The application converts all your input to uppercase, so we cannot use any queues with names that contain lowercase characters.
If you enter inquire in the Action field, the flow through the program logic is:
- Open the queue using the MQOPEN call with the MQOO_INQUIRE option
- Call MQINQ using the selectors MQIA_INHIBIT_GET and MQIA_INHIBIT_PUT
- Close the queue using the MQCLOSE call
- Analyze the attributes that are returned in the IntAttrs parameter of the MQINQ call and move the words INHIBITED or ALLOWED, as appropriate, to the relevant screen fields
If you enter inhibit in the Action field, the flow through the program logic is:
- Open the queue using the MQOPEN call with the MQOO_SET option
- Call MQSET using the selectors MQIA_INHIBIT_GET and MQIA_INHIBIT_PUT, and with the values MQQA_GET_INHIBITED and MQQA_PUT_INHIBITED in the IntAttrs parameter
- Close the queue using the MQCLOSE call
- Move the word INHIBITED to the relevant screen fields
If you enter allow in the Action field, the application performs similar processing to that for an inhibit request. The only differences are the settings of the attributes and the words displayed on the screen.
When the application opens the queue, it uses the default connection handle to the queue manager. (CICS establishes a connection to the queue manager when you start your CICS system.) The application can trap the following errors at this stage:
- The application is not connected to the queue manager
- The queue does not exist
- The user is not authorized to access the queue
- The application is not authorized to open the queue
For other MQI errors, the application displays the completion and reason codes.
Parent topic:
The Queue Attributes sample
fg18390_