| |
| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. See the NOTICE file distributed with |
| * this work for additional information regarding copyright ownership. |
| * The ASF licenses this file to You under the Apache License, Version 2.0 |
| * (the "License"); you may not use this file except in compliance with |
| * the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| #ifndef AXIS2_CALLBACK_H |
| #define AXIS2_CALLBACK_H |
| |
| /** |
| * @defgroup axis2_callback callback |
| * @ingroup axis2_client_api |
| * callback represents the callback mechanisms to be used in case of asynchronous |
| * invocations. It holds the complete status of the invocation, the resulting |
| * SOAP envelope and also callback specific data. One can define a function |
| * to be called on complete of the callback as well as a function to be called |
| * on error. |
| * @{ |
| */ |
| |
| /** |
| * @file axis2_callback.h |
| */ |
| |
| #include <axis2_defines.h> |
| #include <axutil_env.h> |
| #include <axis2_async_result.h> |
| #include <axiom_soap_envelope.h> |
| |
| #ifdef __cplusplus |
| extern "C" |
| { |
| #endif |
| |
| /** Type name for axis2_callback */ |
| typedef struct axis2_callback axis2_callback_t; |
| |
| /** Type name for function pointer to be called on complete of callback */ |
| typedef axis2_status_t AXIS2_CALL |
| axis2_on_complete_func_ptr( |
| axis2_callback_t *, |
| const axutil_env_t *); |
| |
| /** Type name for function pointer to be called on error of callback */ |
| typedef axis2_status_t AXIS2_CALL |
| axis2_on_error_func_ptr( |
| axis2_callback_t *, |
| const axutil_env_t *, |
| int); |
| |
| /** |
| * This function is called once the asynchronous operation is successfully |
| * completed and the result is available. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @param result pointer to async result |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_invoke_on_complete( |
| axis2_callback_t * callback, |
| const axutil_env_t * env, |
| axis2_async_result_t * result); |
| |
| /** |
| * This function is called once the asynchronous operation fails and |
| * the failure code returns. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @param exception error code representing the error |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_report_error( |
| axis2_callback_t * callback, |
| const axutil_env_t * env, |
| const int exception); |
| |
| /** |
| * Gets the complete status for the callback. This method is useful |
| * for polling (busy waiting). |
| * e.g. |
| * <code> |
| * <pre> |
| * while(!axis2_callback_get_complete(callback, env) |
| * { |
| * sleep(10); |
| * } |
| * do whatever you need here |
| * </pre> |
| * </code> |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @return AXIS2_TRUE if callback is complete, else AXIS2_FALSE |
| */ |
| AXIS2_EXTERN axis2_bool_t AXIS2_CALL |
| axis2_callback_get_complete( |
| const axis2_callback_t * callback, |
| const axutil_env_t * env); |
| |
| /** |
| * Sets the complete status. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @param complete bool value representing the status |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_set_complete( |
| axis2_callback_t * callback, |
| const axutil_env_t * env, |
| const axis2_bool_t complete); |
| |
| /** |
| * Gets the resulting SOAP envelope. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @return result SOAP envelope if present, else NULL |
| */ |
| AXIS2_EXTERN axiom_soap_envelope_t *AXIS2_CALL |
| axis2_callback_get_envelope( |
| const axis2_callback_t * callback, |
| const axutil_env_t * env); |
| |
| /** |
| * Sets the SOAP envelope. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @param envelope pointer to SOAP envelope |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_set_envelope( |
| axis2_callback_t * callback, |
| const axutil_env_t * env, |
| axiom_soap_envelope_t * envelope); |
| |
| /** |
| * Gets the resulting message context. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @return result message context if present, else NULL |
| */ |
| AXIS2_EXTERN axis2_msg_ctx_t *AXIS2_CALL |
| axis2_callback_get_msg_ctx( |
| const axis2_callback_t * callback, |
| const axutil_env_t * env); |
| |
| /** |
| * Sets the message context. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @param msg_ctx pointer to message context |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_set_msg_ctx( |
| axis2_callback_t * callback, |
| const axutil_env_t * env, |
| axis2_msg_ctx_t * msg_ctx); |
| |
| /** |
| * Gets error code representing the error. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @return error code representing the error |
| */ |
| AXIS2_EXTERN int AXIS2_CALL |
| axis2_callback_get_error( |
| const axis2_callback_t * callback, |
| const axutil_env_t * env); |
| |
| /** |
| * Sets the error code. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @param error error code representing the error |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_set_error( |
| axis2_callback_t * callback, |
| const axutil_env_t * env, |
| const int error); |
| |
| /** |
| * Sets the callback data. |
| * @param callback pointer to callback struct |
| * @param data pointer to data |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_callback_set_data( |
| axis2_callback_t * callback, |
| void *data); |
| |
| /** |
| * Gets the callback data. |
| * @param callback pointer to callback struct |
| * @return pointer to callback data |
| */ |
| AXIS2_EXTERN void *AXIS2_CALL |
| axis2_callback_get_data( |
| const axis2_callback_t * callback); |
| |
| /** |
| * Sets the on complete callback function. |
| * @param callback pointer to callback struct |
| * @param f on complete callback function pointer |
| */ |
| AXIS2_EXTERN void AXIS2_CALL |
| axis2_callback_set_on_complete( |
| axis2_callback_t * callback, |
| axis2_on_complete_func_ptr f); |
| |
| /** |
| * Sets the on error callback function. |
| * @param callback pointer to callback struct |
| * @param f on error callback function pointer |
| */ |
| AXIS2_EXTERN void AXIS2_CALL |
| axis2_callback_set_on_error( |
| axis2_callback_t * callback, |
| axis2_on_error_func_ptr f); |
| |
| /** |
| * Frees callback struct. |
| * @param callback pointer to callback struct |
| * @param env pointer to environment struct |
| * @return AXIS2_SUCCESS on success, else AXIS2_FAILURE |
| */ |
| AXIS2_EXTERN void AXIS2_CALL |
| axis2_callback_free( |
| axis2_callback_t * callback, |
| const axutil_env_t * env); |
| |
| /** |
| * Creates a callback struct. |
| * @param env pointer to environment struct |
| * @return pointer to newly created callback struct |
| */ |
| AXIS2_EXTERN axis2_callback_t *AXIS2_CALL |
| axis2_callback_create( |
| const axutil_env_t * env); |
| |
| /** @} */ |
| #ifdef __cplusplus |
| } |
| #endif |
| |
| #endif /* AXIS2_CALL_BACK_H */ |