Provided by: libglobus-gram-protocol-doc_13.5-1_all bug

NAME

       globus_gram_protocol_unpack - Message Unpacking

        - Message Unpacking.

SYNOPSIS

   Functions
       int globus_gram_protocol_unpack_job_request (const globus_byte_t *query, globus_size_t
           querysize, int *job_state_mask, char **callback_url, char **description)
           Unpack a GRAM Job Request.
       int globus_gram_protocol_unpack_job_request_reply (const globus_byte_t *reply,
           globus_size_t replysize, int *status, char **job_contact)
           Unpack a GRAM reply message.
       int globus_gram_protocol_unpack_job_request_reply_with_extensions (const globus_byte_t
           *reply, globus_size_t replysize, int *status, char **job_contact, globus_hashtable_t
           *extensions)
           Unpack a GRAM reply message, parsing all extensions.
       int globus_gram_protocol_unpack_status_request (const globus_byte_t *query, globus_size_t
           querysize, char **status_request)
           Unpack a GRAM query message.
       int globus_gram_protocol_unpack_status_reply (const globus_byte_t *reply, globus_size_t
           replysize, int *job_status, int *failure_code, int *job_failure_code)
           Unpack a GRAM query reply.
       int globus_gram_protocol_unpack_status_reply_with_extensions (const globus_byte_t *reply,
           globus_size_t replysize, globus_hashtable_t *extensions)
           Unpack a GRAM query reply with extensions.
       int globus_gram_protocol_unpack_status_update_message (const globus_byte_t *reply,
           globus_size_t replysize, char **job_contact, int *status, int *failure_code)
           Unpack a GRAM status update message.
       int globus_gram_protocol_unpack_status_update_message_with_extensions (const globus_byte_t
           *reply, globus_size_t replysize, globus_hashtable_t *extensions)
           Unpack a GRAM status update message with extensions.
       void globus_gram_protocol_hash_destroy (globus_hashtable_t *message_hash)

Detailed Description

       Message Unpacking.

Function Documentation

   void globus_gram_protocol_hash_destroy (globus_hashtable_t * message_hash)
       Destroy message attribute hash

       Parameters
           message_hash Hashtable of globus_gram_protocol_extension_t * values to destroy

   int globus_gram_protocol_unpack_job_request (const globus_byte_t * query, globus_size_t
       querysize, int * job_state_mask, char ** callback_url, char ** description)
       Unpack a GRAM Job Request. The globus_gram_protocol_unpack_job_request() function parses
       the job request message packed in the query message and returns copies of the standard
       message attributes in the job_state_mask, callback_url, and description parameters.

       Parameters
           query The unframed job request message to parse.
           querysize The length of the job request message string.
           job_state_mask A pointer to an integer to be set to the job state mask from the job
           request.
           callback_url A pointer to be set with a copy of the URL of the callback contact to be
           registered for this job request. The caller must free this memory by calling free().
           description A pointer to be set to a copy of the job description RSL string for this
           job request. The caller must free this memory by calling free().

       Returns
           Upon success, globus_gram_protocol_unpack_job_request() will return GLOBUS_SUCCESS and
           modify the job_state_mask, callback_url, and description parameters to values
           extracted from the message in query. If an error occurs, an integer error code will be
           returned and the values of job_state_mask, callback_url, and description will be
           undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAM_PROTOCOL_ERROR_NULL_PARAMETER Null parameter
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

   int globus_gram_protocol_unpack_job_request_reply (const globus_byte_t * reply, globus_size_t
       replysize, int * status, char ** job_contact)
       Unpack a GRAM reply message. The globus_gram_protocol_unpack_job_request_reply() function
       parses the reply message packed in the reply message and returns copies of the standard
       message attributes in the status and job_contact parameters.

       Parameters
           reply The unframed job reply message to parse.
           replysize The length of the reply string.
           status A pointer to an integer to be set to the failure code associated with the job
           request. This may be GLOBUS_SUCCESS, if the job request was successful.
           job_contact A pointer to a string to be set to the job contact string. This may set to
           NULL if the job request failed. If globus_gram_protocol_unpack_job_request_reply()
           returns GLOBUS_SUCCESS, then the caller must free this string using free().

       Returns
           Upon success, globus_gram_protocol_unpack_job_request_reply() returns GLOBUS_SUCCESS
           and modifies the status and job_contact parameters to point to the values described
           above. If an error occurs, an integer error code is returned and the values pointed to
           by status and job_contact are undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAN_PROTOCOL_ERROR_NULL_PARAMETER Null parameter
           GLOBUS_GRAM_PROTOCOL_ERROR_MALLOC_FAILED Out of memory
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

   int globus_gram_protocol_unpack_job_request_reply_with_extensions (const globus_byte_t *
       reply, globus_size_t replysize, int * status, char ** job_contact, globus_hashtable_t *
       extensions)
       Unpack a GRAM reply message, parsing all extensions. The
       globus_gram_protocol_unpack_job_request_reply_with_extensions() function parses the reply
       message packed in the reply message parameter and returns copies of the standard message
       attributes in the status and job_contact parameters, and all other extension attributes in
       the hashtable pointed to by extensions. Each entry in the hashtable will be keyed by the
       attribute name and the value will be a pointer to a globus_gram_protocol_extension_t
       structure.

       Parameters
           status A pointer to an integer to be set to the failure code associated with the job
           request. This may be GLOBUS_SUCCESS, if the job request was successful.
           job_contact A pointer to a string to be set to the job contact string. This may set to
           NULL if the job request failed. If
           globus_gram_protocol_unpack_job_request_reply_with_extensions() returns
           GLOBUS_SUCCESS, then the caller must free this string using free().
           extensions A pointer to be set to a hash table containing the names and values of all
           protocol extensions present in the response message. If
           globus_gram_protocol_unpack_job_request_reply_with_extensions() returns
           GLOBUS_SUCCESS, the caller must free this hash table and its values by calling
           globus_gram_protocol_hash_destroy().
           reply The unframed job reply message to parse.
           replysize The length of the reply string.

       Returns
           Upon success, globus_gram_protocol_unpack_job_request_reply_with_extensions() returns
           GLOBUS_SUCCESS and modifies the status, job_contact, and extensions to point to the
           values described above. If an error occurs, an integer error code is returned and the
           values pointed to by status, job_contact, and extensions are undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAN_PROTOCOL_ERROR_NULL_PARAMETER Null parameter
           GLOBUS_GRAM_PROTOCOL_ERROR_MALLOC_FAILED Out of memory
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

   int globus_gram_protocol_unpack_status_reply (const globus_byte_t * reply, globus_size_t
       replysize, int * job_status, int * failure_code, int * job_failure_code)
       Unpack a GRAM query reply. The globus_gram_protocol_unpack_status_reply() function parses
       the message packed in the reply parameter and sets the current job state, protocol failure
       code, and job failure code values in its output parameters.

       Parameters
           reply The unframed reply message to parse.
           replysize The length of the reply message.
           job_status A pointer to an integer to be set to the job's current job state.
           failure_code A pointer to an integer to be set to the failure code associated with the
           query request. This may be GLOBUS_SUCCESS, if the request was successful.
           job_failure_code A pointer to an integer to be set to the failure code for the job, if
           the job_status is GLOBUS_GRAM_PROTOCOL_JOB_STATE_FAILED.

       Returns
           Upon success, globus_gram_protocol_unpack_status_reply() returns GLOBUS_SUCCESS and
           modifies the job_status, failure_code, and job_failure_code parameters to point to the
           value described above. If an error occurs, an integer error code is returned and the
           values pointed to by job_status, failure_code, and job_failure_code are undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch
           GLOBUS_GRAM_PROTOCOL_ERROR_NULL_PARAMETER Null parameter

   int globus_gram_protocol_unpack_status_reply_with_extensions (const globus_byte_t * reply,
       globus_size_t replysize, globus_hashtable_t * extensions)
       Unpack a GRAM query reply with extensions. The
       globus_gram_protocol_unpack_status_reply_with_extensions() function parses the message
       packed in the reply parameter, storing all attributes and values in a hash table. The
       extensions parameter is modified to point to that hash table. The caller of
       globus_gram_protocol_unpack_status_reply_with_extensions() must free that hash table by
       calling globus_gram_protocol_hash_destroy().

       Parameters
           reply The unframed reply message to parse.
           replysize The length of the reply message.
           extensions A pointer to be set to a hash table containing the names and values of all
           protocol attributes present in the reply message. If
           globus_gram_protocol_unpack_status_reply_with_extensions() returns GLOBUS_SUCCESS, the
           caller must free this hash table and its values by calling
           globus_gram_protocol_hash_destroy().

       Returns
           Upon success, globus_gram_protocol_unpack_status_reply_with_extensions() returns
           GLOBUS_SUCCESS and modifies the extensions parameter to point to the value described
           above. If an error occurs, an integer error code is returned and the value pointed to
           by extensions is undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

   int globus_gram_protocol_unpack_status_request (const globus_byte_t * query, globus_size_t
       querysize, char ** status_request)
       Unpack a GRAM query message. The globus_gram_protocol_unpack_status_request() function
       parses the message packed in the query parameter and returns a copy of the message in the
       status_request parameter.

       Parameters
           query The unframed query message to parse.
           querysize The length of the query string.
           status_request A pointer to a string to be set to the query value. The caller must
           free this string using free().

       Returns
           Upon success, globus_gram_protocol_unpack_status_request() returns GLOBUS_SUCCESS and
           modifies the status_request parameter to point to the value described above. If an
           error occurs, an integer error code is returned and the value pointed to by
           status_request is undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAM_PROTOCOL_ERROR_NULL_PARAMETER Null parameter
           GLOBUS_GRAM_PROTOCOL_ERROR_MALLOC_FAILED Out of memory
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

   int globus_gram_protocol_unpack_status_update_message (const globus_byte_t * reply,
       globus_size_t replysize, char ** job_contact, int * status, int * failure_code)
       Unpack a GRAM status update message. The
       globus_gram_protocol_unpack_status_update_message() function parses the message packed in
       the reply parameter, storing the standard message attribute values in its return
       parameters job_contact, status, and failure_code. The caller is responsible for freeing
       the job_contact value.

       Parameters
           reply The unframed reply message to parse.
           replysize The length of the reply message.
           job_contact An output parameter to be set to the job contact string. If
           globus_gram_protocol_unpack_status_update_message() returns GLOBUS_SUCCESS, then the
           caller must free this string using free().
           status An output parameter to be set to the integer value of the job's current job
           state.
           failure_code An output parameter to be set to the integer failure code for the job if
           the job_status is GLOBUS_GRAM_PROTOCOL_JOB_STATE_FAILED.

       Returns
           Upon success, globus_gram_protocol_unpack_status_update_message() returns
           GLOBUS_SUCCESS and modifies the job_contact, status, and failure_code parameters as
           described above. If an error occurs, an integer error code is returned and the values
           pointed to by the job_contact, status, and failure_code parameters are undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAM_PROTOCOL_ERROR_NULL_PARAMETER Null parameter
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_MALLOC_FAILED Out of memory
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

   int globus_gram_protocol_unpack_status_update_message_with_extensions (const globus_byte_t *
       reply, globus_size_t replysize, globus_hashtable_t * extensions)
       Unpack a GRAM status update message with extensions. The
       globus_gram_protocol_unpack_status_update_message_with_extensions() function parses the
       message packed in the reply parameter, storing the message attribute values in its return
       parameter extensions. The caller is responsible for freeing the extensions hash table by
       calling globus_gram_protocol_hash_destroy().

       Parameters
           reply The unframed reply message to parse.
           replysize The length of the reply message.
           extensions An output parameter which will be initialized to a hashtable containing the
           message attributes. The caller must destroy this hashtable calling
           globus_gram_protocol_hash_destroy().

       Returns
           Upon success, globus_gram_protocol_unpack_status_update_message_with_extensions()
           returns GLOBUS_SUCCESS and modifies the extensions parameter as described above. If an
           error occurs, an integer error code is returned and the value pointed to by the
           extensions parameters is undefined.

       Return values
           GLOBUS_SUCCESS Success
           GLOBUS_GRAM_PROTOCOL_ERROR_HTTP_UNPACK_FAILED Unpack failed
           GLOBUS_GRAM_PROTOCOL_ERROR_MALLOC_FAILED Malloc failed
           GLOBUS_GRAM_PROTOCOL_ERROR_VERSION_MISMATCH Version mismatch

Author

       Generated automatically by Doxygen for globus_gram_protocol from the source code.