MQPD - Property descriptor
The MQPD is used to define the attributes of a property.
Overview
Purpose: The structure is an input/output parameter on the MQSETMP call and an output parameter on the MQINQMP call.
Character set and encoding: Data in MQPD must be in the character set of the application and encoding of the application (ENNAT).
Fields
The MQPD structure contains the following fields; the fields are described in alphabetical order:
- PDCT (10-digit signed integer)
-
This describes what message context the property belongs to.
When a queue manager receives a message containing an IBM MQ -defined property that the queue manager recognizes as being incorrect. the queue manager corrects the value of the PDCT field.
The following option can be specified:- PDUSC
- The property is associated with the user context.
No special authorization is required to be able to set a property associated with the user context using the MQSETMP call.
On a IBM WebSphere MQ Version 7.0 queue manager, a property associated with the user context is saved as described for OOSAVA. An MQPUT call with PMPASA specified, causes the property to be copied from the saved context into the new message.
If the option previously described is not required, the following option can be used:
- PDNOC
- The property is not associated with a message context.
An unrecognized value is rejected with a PDREA code of RC2482.
This is an input/output field to the MQSETMP call and an output field from the MQINQMP call. The initial value of this field is PDNOC.
- PDCPYOPT (10-digit signed integer)
-
This describes which type of messages the property should be copied into.
This is an output only field for recognized IBM MQ-defined properties; IBM MQ sets the appropriate value.
When a queue manager receives a message containing an IBM MQ-defined property that the queue manager recognizes as being incorrect. the queue manager corrects the value of the CopyOptions field.
We can specify one or more of these options. To specify more than one option, either add the values together (do not add the same constant more than once), or combine the values using the bitwise OR operation (if the programming language supports bit operations).- COPFOR
- This property is copied into a message being forwarded.
- COPPUB
- This property is copied into the message received by a subscriber when a message is being published.
- COPREP
- This property is copied into a reply message.
- COPRP
- This property is copied into a report message.
- COPALL
- This property is copied into all types of subsequent messages.
- COPNON
- This property is not copied into a message.
Default option: The following option can be specified to supply the default set of copy options:
- COPDEF
- This property is copied into a message being forwarded, into a report message, or into a message received by a subscriber when a message is being published.
This is equivalent to specifying the combination of options COPFOR, plus COPRP, plus COPPUB.
If none of the options described previously are required, use the following option:
- COPNON
- Use this value to indicate that no other copy options have been specified; programmatically no relationship exists between this property and subsequent messages. This is always returned for message descriptor properties.
This is an input/output field to the MQSETMP call and an output field from the MQINQMP call. The initial value of this field is COPDEF.
- PDOPT (10-digit signed integer)
-
The value must be:
- PDNONE
- No options specified
This is always an input field. The initial value of this field is PDNONE.
- PDSID (10-digit signed integer)
-
This is the structure identifier; the value must be:
- PSIDV
- Identifier for property descriptor structure.
This is always an input field. The initial value of this field is PSIDV.
- PDSUP (10-digit signed integer)
-
This field describes what level of support for the message property is required of the queue manager, in order for the message containing this property to be put to a queue. This applies only to IBM MQ-defined properties; support for all other properties is optional.
The field is automatically set to the correct value when the IBM MQ-defined property is known by the queue manager. If the property is not recognized, PDSUPO is assigned. When a queue manager receives a message containing an IBM MQ-defined property that the queue manager recognizes as being incorrect. the queue manager corrects the value of the PDSUP field.
When setting an IBM MQ-defined property using the MQSETMP call on a message handle where the CMNOVA option was set, PDSUP becomes an input field. This allows an application to put an IBM MQ-defined property, with the correct value, where the property is unsupported by the connected queue manager, but where the message is intended to be processed on another queue manager.
The value PDSUPO is always assigned to properties that are not IBM MQ-defined properties.
If a IBM WebSphere MQ Version 7.0 queue manager, that supports message properties, receives a property that contains an unrecognized PDSUP value, the property is treated as if:- PDSUPR was specified if any of the unrecognized values are contained in the PDRUM.
- PDSUPL was specified if any of the unrecognized values are contained in the PDAUXM
- PDSUPO was specified otherwise.
- PDSUPO
- The property is accepted by a queue manager even if it is not supported. The property can be discarded in order for the message to flow to a queue manager that does not support message properties. This value is also assigned to properties that are not IBM MQ-defined.
- PDSUPR
- Support for the property is required. The message is rejected by a queue manager that does not support the IBM MQ-defined property. The MQPUT or MQPUT1 call fails with completion code CCFAIL and reason code RC2490.
- PDSUPL
- The message is rejected by a queue manager that does not support the IBM MQ-defined property if the message is destined for a local queue. The MQPUT or MQPUT1 call fails with completion code CCFAIL and reason code RC2490.
The MQPUT or MQPUT1 call succeeds if the message is destined for a remote queue manager.
This is an output field on the MQINQMP call and an input field on the MQSETMP call if the message handle was created with the CMNOVA option set. The initial value of this field is PDSUPO.
- PDVER (10-digit signed integer)
-
This is the structure version number; the value must be:
PDVER1
Version-1 property descriptor structure.
The following constant specifies the version number of the current version:
PDVERC
Current version of property descriptor structure.
This is always an input field. The initial value of this field is PDVER1.
Initial values
Field name | Name of constant | Value of constant |
---|---|---|
PDSID | PDSIDV | 'PD' |
PDVER | PDVER1 | 1 |
PDOPT | PDNONE | 0 |
PDSUP | PDSUPO | 0 |
PDCT | PDNOC | 0 |
PDCPYOPT | COPDEF | 0 |
RPG declaration
D* MQDMHO Structure D* D* D* Structure identifier D DMSID 1 4 INZ('DMHO') D* D* Structure version number D DMVER 5 8I 0 INZ(1) D* D* Options that control the action of MQDLTMH D DMOPT 9 12I 0 INZ(0)