This function is provided by a MQZAS_VERSION_2 authorization service component, and is invoked by the queue manager to check whether an entity has authority to perform a particular action, or actions, on a specified object.
The function identifier for this function (for MQZEP ) is MQZID_CHECK_AUTHORITY.
MQZ_CHECK_AUTHORITY_2 is similar to MQZ_CHECK_AUTHORITY , but with the EntityName parameter replaced by the EntityData parameter.
|
The MQZ_CHECK_AUTHORITY_2 call has the following parameters.
Queue manager name.
The name of the queue manager calling the component. This name is padded with blanks to the full length of the parameter; the name is not terminated by a null character.
The queue-manager name is passed to the component for information; the authorization service interface does not require the component to make use of it in any defined manner.
Entity data.
Data relating to the entity whose authorization to the object is to be checked. See MQZED - Entity descriptor for details.
It is not essential for this entity to be known to the underlying security service. If it is not known, the authorizations of the special nobody group (to which all entities are assumed to belong) are used for the check. An all-blank name is valid and can be used in this way.
Entity type.
The type of entity specified by EntityData. It is one of the following:
Object name.
The name of the object to which access is required. The maximum length of the string is 48 characters; if it is shorter than that it is padded to the right with blanks. The name is not terminated by a null character.
If ObjectType is MQOT_Q_MGR, this name is the same as QMgrName.
Object type.
The type of entity specified by ObjectName. It is one of the following:
Authority to be checked.
If one authorization is being checked, this field is equal to the appropriate authorization operation (MQZAO_* constant). If more than one authorization is being checked, it is the bitwise OR of the corresponding MQZAO_* constants.
The following authorizations apply to use of the MQI calls:
This allows the MQGMO_BROWSE_FIRST, MQGMO_BROWSE_MSG_UNDER_CURSOR, or MQGMO_BROWSE_NEXT option to be specified on the MQGET call.
This allows the MQOO_INPUT_SHARED, MQOO_INPUT_EXCLUSIVE, or MQOO_INPUT_AS_Q_DEF option to be specified on the MQOPEN call.
This allows the MQOO_OUTPUT option to be specified on the MQOPEN call.
This allows the MQOO_INQUIRE option to be specified on the MQOPEN call.
This allows the MQOO_SET option to be specified on the MQOPEN call.
This allows the MQOO_PASS_IDENTITY_CONTEXT option to be specified on the MQOPEN call, and the MQPMO_PASS_IDENTITY_CONTEXT option to be specified on the MQPUT and MQPUT1 calls.
This allows the MQOO_PASS_ALL_CONTEXT option to be specified on the MQOPEN call, and the MQPMO_PASS_ALL_CONTEXT option to be specified on the MQPUT and MQPUT1 calls.
This allows the MQOO_SET_IDENTITY_CONTEXT option to be specified on the MQOPEN call, and the MQPMO_SET_IDENTITY_CONTEXT option to be specified on the MQPUT and MQPUT1 calls.
This allows the MQOO_SET_ALL_CONTEXT option to be specified on the MQOPEN call, and the MQPMO_SET_ALL_CONTEXT option to be specified on the MQPUT and MQPUT1 calls.
This allows the MQOO_ALTERNATE_USER_AUTHORITY option to be specified on the MQOPEN call, and the MQPMO_ALTERNATE_USER_AUTHORITY option to be specified on the MQPUT1 call.
This enables all of the authorizations described above.
The following authorizations apply to administration of a queue manager:
The following authorizations apply to both use of the MQI and to administration of a queue manager:
Component data.
This data is kept by the queue manager on behalf of this particular component; any changes made to it by any of the functions provided by this component are preserved, and presented the next time one of this component's functions is called.
The length of this data area is passed by the queue manager in the ComponentDataLength parameter of the MQZ_INIT_AUTHORITY call.
Continuation indicator set by component.
The following values can be specified:
For MQZ_CHECK_AUTHORITY_2 this has the same effect as MQZCI_STOP.
Completion code.
Reason code qualifying CompCode.
If CompCode is MQCC_FAILED:
For more information on these reason codes, see the WebSphere MQ Application Programming Reference.
MQZ_CHECK_AUTHORITY_2 (QMgrName, &EntityData, EntityType, ObjectName, ObjectType, Authority, ComponentData, &Continuation, &CompCode, &Reason);
The parameters passed to the service are declared as follows:
MQCHAR48 QMgrName; /* Queue manager name */ MQZED EntityData; /* Entity data */ MQLONG EntityType; /* Entity type */ MQCHAR48 ObjectName; /* Object name */ MQLONG ObjectType; /* Object type */ MQLONG Authority; /* Authority to be checked */ MQBYTE ComponentData[n]; /* Component data */ MQLONG Continuation; /* Continuation indicator set by component */ MQLONG CompCode; /* Completion code */ MQLONG Reason; /* Reason code qualifying CompCode */