MQIIH - IMS information header
The MQIIH structure describes the header information for a message sent to
IMS across the IMS bridge.
For any IBM® MQ supported platform you can create and transmit a message
that includes the MQIIH structure, but only an IBM MQ for z/OS®
queue manager can use the IMS bridge. Therefore, for
the message to get to IMS from a non-z/OS queue manager, your queue manager network must include at
least one z/OS queue manager through which the message
can be routed.
Availability
All IBM MQ systems and IBM MQ clients.
Format name
MQFMT_IMS
Character set and encoding
Special conditions apply to the character set and encoding used for the MQIIH structure and
application message data:
- Applications that connect to the queue manager that owns the IMS bridge queue must provide an MQIIH structure that is in the character set and encoding of the queue manager. This is because data conversion of the MQIIH structure is not performed in this case.
- Applications that connect to other queue managers can provide an MQIIH structure that is in any of the supported character sets and encodings; the receiving message channel agent connected to the queue manager that owns the IMS bridge queue converts the MQIIH.
- The application message data following the MQIIH structure must be in the same character set and
encoding as the MQIIH structure. Do not use the
CodedCharSetIdandEncodingfields in the MQIIH structure to specify the character set and encoding of the application message data.You must provide a data-conversion exit to convert the application message data if the data is not one of the built-in formats supported by the queue manager.
Fields
Note: In the following table, the fields are grouped by usage rather than alphabetically.
| Field name and description | Name of constant | Initial value (if any) of constant |
|---|---|---|
| StrucId (structure identifier) | MQIIH_STRUC_ID | 'IIH¬' |
| Version (structure version number) | MQIIH_VERSION_1 | 1 |
| StrucLength (length of MQIIH structure) | MQIIH_LENGTH_1 | 84 |
| Encoding (reserved - see Character set and encoding) | None | 0 |
| CodedCharSetId (reserved - see Character set and encoding) | None | 0 |
| Format (MQ format name of data that follows MQIIH) | MQFMT_NONE | Blanks |
| Flags (flags) | MQIIH_NONE | 0 |
| LTermOverride (logical terminal override) | None | Blanks |
| MFSMapName (message format services map name) | None | Blanks |
| ReplyToFormat (MQ format name of reply message) | MQFMT_NONE | Blanks |
| Authenticator (RACF® password or passticket) | MQIAUT_NONE | Blanks |
| TranInstanceId (transaction instance identifier) | MQITII_NONE | Nulls |
| TranState (transaction state) | MQITS_NOT_IN_CONVERSATION | '¬' |
| CommitMode (commit mode) | MQICM_COMMIT_THEN_SEND | '0' |
| SecurityScope (security scope) | MQISS_CHECK | 'C' |
| Reserved (reserved) | None | '¬' |
|
Notes:
|
||
Language declarations
C declaration for MQIIH
typedef struct tagMQIIH MQIIH;
struct tagMQIIH {
MQCHAR4 StrucId; /* Structure identifier */
MQLONG Version; /* Structure version number */
MQLONG StrucLength; /* Length of MQIIH structure */
MQLONG Encoding; /* Reserved */
MQLONG CodedCharSetId; /* Reserved */
MQCHAR8 Format; /* MQ format name of data that follows
MQIIH */
MQLONG Flags; /* Flags */
MQCHAR8 LTermOverride; /* Logical terminal override */
MQCHAR8 MFSMapName; /* Message format services map name */
MQCHAR8 ReplyToFormat; /* MQ format name of reply message */
MQCHAR8 Authenticator; /* RACF password or passticket */
MQBYTE16 TranInstanceId; /* Transaction instance identifier */
MQCHAR TranState; /* Transaction state */
MQCHAR CommitMode; /* Commit mode */
MQCHAR SecurityScope; /* Security scope */
MQCHAR Reserved; /* Reserved */
};
COBOL declaration for MQIIH
** MQIIH structure
10 MQIIH.
** Structure identifier
15 MQIIH-STRUCID PIC X(4).
** Structure version number
15 MQIIH-VERSION PIC S9(9) BINARY.
** Length of MQIIH structure
15 MQIIH-STRUCLENGTH PIC S9(9) BINARY.
** Reserved
15 MQIIH-ENCODING PIC S9(9) BINARY.
** Reserved
15 MQIIH-CODEDCHARSETID PIC S9(9) BINARY.
** MQ format name of data that follows MQIIH
15 MQIIH-FORMAT PIC X(8).
** Flags
15 MQIIH-FLAGS PIC S9(9) BINARY.
** Logical terminal override
15 MQIIH-LTERMOVERRIDE PIC X(8).
** Message format services map name
15 MQIIH-MFSMAPNAME PIC X(8).
** MQ format name of reply message
15 MQIIH-REPLYTOFORMAT PIC X(8).
** RACF password or passticket
15 MQIIH-AUTHENTICATOR PIC X(8).
** Transaction instance identifier
15 MQIIH-TRANINSTANCEID PIC X(16).
** Transaction state
15 MQIIH-TRANSTATE PIC X.
** Commit mode
15 MQIIH-COMMITMODE PIC X.
** Security scope
15 MQIIH-SECURITYSCOPE PIC X.
** Reserved
15 MQIIH-RESERVED PIC X.
PL/I declaration for MQIIH
dcl
1 MQIIH based,
3 StrucId char(4), /* Structure identifier */
3 Version fixed bin(31), /* Structure version number */
3 StrucLength fixed bin(31), /* Length of MQIIH structure */
3 Encoding fixed bin(31), /* Reserved */
3 CodedCharSetId fixed bin(31), /* Reserved */
3 Format char(8), /* MQ format name of data that follows
MQIIH */
3 Flags fixed bin(31), /* Flags */
3 LTermOverride char(8), /* Logical terminal override */
3 MFSMapName char(8), /* Message format services map name */
3 ReplyToFormat char(8), /* MQ format name of reply message */
3 Authenticator char(8), /* RACF password or passticket */
3 TranInstanceId char(16), /* Transaction instance identifier */
3 TranState char(1), /* Transaction state */
3 CommitMode char(1), /* Commit mode */
3 SecurityScope char(1), /* Security scope */
3 Reserved char(1); /* Reserved */
High Level Assembler declaration for MQIIH
MQIIH DSECT
MQIIH_STRUCID DS CL4 Structure identifier
MQIIH_VERSION DS F Structure version number
MQIIH_STRUCLENGTH DS F Length of MQIIH structure
MQIIH_ENCODING DS F Reserved
MQIIH_CODEDCHARSETID DS F Reserved
MQIIH_FORMAT DS CL8 MQ format name of data that follows
* MQIIH
MQIIH_FLAGS DS F Flags
MQIIH_LTERMOVERRIDE DS CL8 Logical terminal override
MQIIH_MFSMAPNAME DS CL8 Message format services map name
MQIIH_REPLYTOFORMAT DS CL8 MQ format name of reply message
MQIIH_AUTHENTICATOR DS CL8 RACF password or passticket
MQIIH_TRANINSTANCEID DS XL16 Transaction instance identifier
MQIIH_TRANSTATE DS CL1 Transaction state
MQIIH_COMMITMODE DS CL1 Commit mode
MQIIH_SECURITYSCOPE DS CL1 Security scope
MQIIH_RESERVED DS CL1 Reserved
*
MQIIH_LENGTH EQU *-MQIIH
ORG MQIIH
MQIIH_AREA DS CL(MQIIH_LENGTH)
Visual Basic declaration for MQIIH
Type MQIIH
StrucId As String*4 'Structure identifier'
Version As Long 'Structure version number'
StrucLength As Long 'Length of MQIIH structure'
Encoding As Long 'Reserved'
CodedCharSetId As Long 'Reserved'
Format As String*8 'MQ format name of data that follows MQIIH'
Flags As Long 'Flags'
LTermOverride As String*8 'Logical terminal override'
MFSMapName As String*8 'Message format services map name'
ReplyToFormat As String*8 'MQ format name of reply message'
Authenticator As String*8 'RACF password or passticket'
TranInstanceId As MQBYTE16 'Transaction instance identifier'
TranState As String*1 'Transaction state'
CommitMode As String*1 'Commit mode'
SecurityScope As String*1 'Security scope'
Reserved As String*1 'Reserved'
End Type