The MQAXC structure describes the context information that is passed to an API exit. The context information relates to the environment in which the application is running.
This structure is supported in the following environments: AIX, HP-UX, Solaris, Linux, and Windows.
The MQAXC structure contains the following fields:
Structure identifier.
For the C programming language, the constant MQAXC_STRUC_ID_ARRAY is also defined; this has the same value as MQAXC_STRUC_ID, but is an array of characters instead of a string.
This is an input field to the exit.
Structure version number.
The following constant specifies the version number of the current version:
Note: | When a new version of the MQAXC structure is introduced, the layout of the existing part is not changed. The exit should therefore check that the version number is equal to or greater than the lowest version which contains the fields that the exit needs to use. |
This is an input field to the exit.
Environment.
This indicates the environment from which the API call was issued. The value is one of the following:
This is an input field to the exit.
User identifier.
This is the user identifier associated with the program that issued the API call. For a client connection (MQXE_MCA_SVRCONN), UserId contains the user identifier of the adopted user, and not the user identifier of the MCA.
The length of this field is given by MQ_USER_ID_LENGTH. This is an input field to the exit.
Security identifier.
This is the security identifier associated with the program that issued the API call. For a client connection (MQXE_MCA_SVRCONN), SecurityId contains the security identifier of the adopted user, and not the security identifier of the MCA. If the security identifier is not known, SecurityId has the value:
The value is binary zero for the length of the field.
For the C programming language, the constant MQSID_NONE_ARRAY is also defined; this has the same value as MQSID_NONE, but is an array of characters instead of a string.
The length of this field is given by MQ_SECURITY_ID_LENGTH. This is an input field to the exit.
Connection name.
For a client connection (MQXE_MCA_SVRCONN), this field contains the address of the client (for example, the TCP/IP address). In other cases, this field is blank.
The length of this field is given by MQ_CONN_NAME_LENGTH. This is an input field to the exit.
Length of long MCA user identifier.
For MQXE_MCA and MQXE_MCA_SVRCONN, this is the length in bytes of the full MCA user identifier pointed to by LongMCAUserIdPtr. In other cases, this field is zero.
This is an input field to the exit.
Length of long remote user identifier.
For MQXE_MCA and MQXE_MCA_SVRCONN, this is the length in bytes of the full remote user identifier pointed to by LongRemoteUserIdPtr. In other cases, this field is zero.
This is an input field to the exit.
Address of long MCA user identifier.
For MQXE_MCA and MQXE_MCA_SVRCONN, this is the address of the full MCA user identifier. The length of the full identifier is given by LongMCAUserIdLength. In other cases, this field is the null pointer.
This is an input field to the exit.
Address of long remote user identifier.
For MQXE_MCA and MQXE_MCA_SVRCONN, this is the address of the full remote user identifier. The length of the full identifier is given by LongRemoteUserIdLength. In other cases, this field is the null pointer.
This is an input field to the exit.
Application name.
This is the name of the application that issued the API call. This name is obtained in the same way as the default value for the PutApplName field in MQMD.
The length of this field is given by MQ_APPL_NAME_LENGTH. This is an input field to the exit.
Application type.
This is the type of the application that issued the API call. The value is the same as MQAT_DEFAULT for the environment for which the application was compiled.
This is an input field to the exit.
Process identifier.
This is the identifier of the OS process from which the API call was issued. If not applicable, the value is zero.
This is an input field to the exit.
Thread identifier.
This is the identifier of the OS thread from which the API call was issued. If not applicable, the value is zero.
This is an input field to the exit.
typedef struct tagMQAXC MQAXC; struct tagMQAXC { MQCHAR4 StrucId; /* Structure identifier */ MQLONG Version; /* Structure version number */ MQLONG Environment; /* Environment */ MQCHAR12 UserId; /* User identifier */ MQBYTE40 SecurityId; /* Security identifier */ MQCHAR264 ConnectionName; /* Connection name */ MQLONG LongMCAUserIdLength; /* Length of long MCA user identifier */ MQLONG LongRemoteUserIdLength; /* Length of long remote user identifier */ MQPTR LongMCAUserIdPtr; /* Address of long MCA user identifier */ MQPTR LongRemoteUserIdPtr; /* Address of long remote user identifier */ MQCHAR28 ApplName; /* Application name */ MQLONG ApplType; /* Application type */ MQPID ProcessId; /* Process identifier */ MQTID ThreadId; /* Thread identifier */ };