You are viewing a plain text version of this content. The canonical link for it is here.
Posted to sandesha-dev@ws.apache.org by sa...@apache.org on 2006/07/17 08:06:15 UTC

svn commit: r422630 - in /webservices/sandesha/trunk/c: include/sandesha2/sandesha2_ack_req_msg_processor.h include/sandesha2/sandesha2_utils.h src/msgprocessors/Makefile.am src/msgprocessors/ack_req_msg_processor.c src/util/utils.c

Author: sahan
Date: Sun Jul 16 23:06:15 2006
New Revision: 422630

URL: http://svn.apache.org/viewvc?rev=422630&view=rev
Log:
Adding ack requested msg processor

Added:
    webservices/sandesha/trunk/c/include/sandesha2/sandesha2_ack_req_msg_processor.h
    webservices/sandesha/trunk/c/src/msgprocessors/ack_req_msg_processor.c
Modified:
    webservices/sandesha/trunk/c/include/sandesha2/sandesha2_utils.h
    webservices/sandesha/trunk/c/src/msgprocessors/Makefile.am
    webservices/sandesha/trunk/c/src/util/utils.c

Added: webservices/sandesha/trunk/c/include/sandesha2/sandesha2_ack_req_msg_processor.h
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/include/sandesha2/sandesha2_ack_req_msg_processor.h?rev=422630&view=auto
==============================================================================
--- webservices/sandesha/trunk/c/include/sandesha2/sandesha2_ack_req_msg_processor.h (added)
+++ webservices/sandesha/trunk/c/include/sandesha2/sandesha2_ack_req_msg_processor.h Sun Jul 16 23:06:15 2006
@@ -0,0 +1,49 @@
+/*
+ * Copyright 2004,2005 The Apache Software Foundation.
+ *
+ * Licensed 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 SANDESHA2_ACK_REQ_MSG_PROCESSOR_H
+#define SANDESHA2_ACK_REQ_MSG_PROCESSOR_H
+
+/**
+  * @file sandesha2_ack_req_msg_processor.h
+  * @brief 
+  */
+
+#include <axis2_utils_defines.h>
+#include <axis2_env.h>
+#include <sandesha2/sandesha2_msg_processor.h>
+
+
+#ifdef __cplusplus
+extern "C"
+{
+#endif
+
+/** @defgroup sandesha2_ack_req_msg_processor
+ * @ingroup sandesha2_msgprocessors
+ * @{
+ */
+    
+AXIS2_EXTERN sandesha2_msg_processor_t* AXIS2_CALL
+sandesha2_ack_req_msg_processor_create(
+						const axis2_env_t *env);
+/** @} */
+#ifdef __cplusplus
+}
+#endif
+
+#endif                          /* SANDESHA2_ACK_REQ_MSG_PROCESSOR_H */
+

Modified: webservices/sandesha/trunk/c/include/sandesha2/sandesha2_utils.h
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/include/sandesha2/sandesha2_utils.h?rev=422630&r1=422629&r2=422630&view=diff
==============================================================================
--- webservices/sandesha/trunk/c/include/sandesha2/sandesha2_utils.h (original)
+++ webservices/sandesha/trunk/c/include/sandesha2/sandesha2_utils.h Sun Jul 16 23:06:15 2006
@@ -136,6 +136,10 @@
                         sandesha2_msg_ctx_t *ref_rm_msg,
                         axis2_op_t *op);
                         
+AXIS2_EXTERN  int AXIS2_CALL
+sandesha2_utils_get_soap_version(const axis2_env_t *env, 
+                        axiom_soap_envelope_t *envelope);
+                        
 
 /** @} */
 #ifdef __cplusplus

Modified: webservices/sandesha/trunk/c/src/msgprocessors/Makefile.am
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/src/msgprocessors/Makefile.am?rev=422630&r1=422629&r2=422630&view=diff
==============================================================================
--- webservices/sandesha/trunk/c/src/msgprocessors/Makefile.am (original)
+++ webservices/sandesha/trunk/c/src/msgprocessors/Makefile.am Sun Jul 16 23:06:15 2006
@@ -3,7 +3,8 @@
 
 libsandesha2_msgprocessors_la_SOURCES = app_msg_processor.c\
                                         create_seq_msg_processor.c\
-                                        ack_msg_processor.c
+                                        ack_msg_processor.c\
+                                        ack_req_msg_processor.c
 
 INCLUDES = -I$(top_builddir)/include \
            @AXIS2INC@

Added: webservices/sandesha/trunk/c/src/msgprocessors/ack_req_msg_processor.c
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/src/msgprocessors/ack_req_msg_processor.c?rev=422630&view=auto
==============================================================================
--- webservices/sandesha/trunk/c/src/msgprocessors/ack_req_msg_processor.c (added)
+++ webservices/sandesha/trunk/c/src/msgprocessors/ack_req_msg_processor.c Sun Jul 16 23:06:15 2006
@@ -0,0 +1,397 @@
+/*
+ * Copyright 2004,2005 The Apache Software Foundation.
+ *
+ * Licensed 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.
+ */
+#include <sandesha2/sandesha2_ack_req_msg_processor.h>
+#include <sandesha2_seq_property_mgr.h>
+#include <sandesha2_seq_property_bean.h>
+#include <sandesha2_storage_mgr.h>
+#include <sandesha2_fault_mgr.h>
+#include <sandesha2/sandesha2_constants.h>
+#include <sandesha2/sandesha2_utils.h>
+#include <sandesha2/sandesha2_msg_ctx.h>
+#include <axis2_msg_ctx.h>
+#include <axis2_string.h>
+#include <axis2_engine.h>
+#include <axiom_soap_const.h>
+#include <stdio.h>
+#include <sandesha2_storage_mgr.h>
+#include <axis2_msg_ctx.h>
+#include <axis2_conf_ctx.h>
+#include <axis2_core_utils.h>
+#include <sandesha2/sandesha2_seq_ack.h>
+#include <sandesha2/sandesha2_create_seq_res.h>
+#include <axis2_uuid_gen.h>
+#include <sandesha2_create_seq_bean.h>
+#include <sandesha2_create_seq_mgr.h>
+#include <axis2_endpoint_ref.h>
+#include <axis2_op_ctx.h>
+#include <sandesha2/sandesha2_spec_specific_consts.h>
+#include <sandesha2/sandesha2_ack_requested.h>
+#include <axis2_addr.h>
+
+/** 
+ * @brief Ack Requested Message Processor struct impl
+ *	Sandesha2 Ack Requested Msg Processor
+ */
+typedef struct sandesha2_ack_req_msg_processor_impl 
+                        sandesha2_ack_req_msg_processor_impl_t;  
+  
+struct sandesha2_ack_req_msg_processor_impl
+{
+	sandesha2_msg_processor_t msg_processor;
+};
+
+#define SANDESHA2_INTF_TO_IMPL(msg_proc) \
+						((sandesha2_ack_req_msg_processor_impl_t *)(msg_proc))
+
+/***************************** Function headers *******************************/
+axis2_status_t AXIS2_CALL 
+sandesha2_ack_req_msg_processor_process_in_msg (
+                        sandesha2_msg_processor_t *msg_processor,
+						const axis2_env_t *env,
+                        sandesha2_msg_ctx_t *rm_msg_ctx);
+    
+axis2_status_t AXIS2_CALL 
+sandesha2_ack_req_msg_processor_process_out_msg(
+                        sandesha2_msg_processor_t *msg_processor,
+                    	const axis2_env_t *env, 
+                        sandesha2_msg_ctx_t *rm_msg_ctx);
+    
+axis2_status_t AXIS2_CALL 
+sandesha2_ack_req_msg_processor_free (sandesha2_msg_processor_t *element, 
+						const axis2_env_t *env);								
+
+/***************************** End of function headers ************************/
+
+AXIS2_EXTERN sandesha2_msg_processor_t* AXIS2_CALL
+sandesha2_ack_req_msg_processor_create(const axis2_env_t *env)
+{
+    sandesha2_ack_req_msg_processor_impl_t *msg_proc_impl = NULL;
+    AXIS2_ENV_CHECK(env, NULL);
+              
+    msg_proc_impl =  (sandesha2_ack_req_msg_processor_impl_t *)AXIS2_MALLOC 
+                        (env->allocator, 
+                        sizeof(sandesha2_ack_req_msg_processor_impl_t));
+	
+    if(NULL == msg_proc_impl)
+	{
+		AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
+        return NULL;
+	}
+    
+    msg_proc_impl->msg_processor.ops = AXIS2_MALLOC(env->allocator,
+        sizeof(sandesha2_msg_processor_ops_t));
+    if(NULL == msg_proc_impl->msg_processor.ops)
+	{
+		sandesha2_ack_req_msg_processor_free((sandesha2_msg_processor_t*)
+                         msg_proc_impl, env);
+        AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE);
+        return NULL;
+	}
+    
+    msg_proc_impl->msg_processor.ops->process_in_msg = 
+                        sandesha2_ack_req_msg_processor_process_in_msg;
+    msg_proc_impl->msg_processor.ops->process_out_msg = 
+    					sandesha2_ack_req_msg_processor_process_out_msg;
+    msg_proc_impl->msg_processor.ops->free = 
+                        sandesha2_ack_req_msg_processor_free;
+                        
+	return &(msg_proc_impl->msg_processor);
+}
+
+
+axis2_status_t AXIS2_CALL 
+sandesha2_ack_req_msg_processor_free (sandesha2_msg_processor_t *msg_processor, 
+						const axis2_env_t *env)
+{
+    sandesha2_ack_req_msg_processor_impl_t *msg_proc_impl = NULL;
+	AXIS2_ENV_CHECK(env, AXIS2_FAILURE);
+    msg_proc_impl = SANDESHA2_INTF_TO_IMPL(msg_processor);
+    
+    if(NULL != msg_processor->ops)
+        AXIS2_FREE(env->allocator, msg_processor->ops);
+    
+	AXIS2_FREE(env->allocator, SANDESHA2_INTF_TO_IMPL(msg_processor));
+	return AXIS2_SUCCESS;
+}
+
+
+axis2_status_t AXIS2_CALL 
+sandesha2_ack_req_msg_processor_process_in_msg (
+                        sandesha2_msg_processor_t *msg_processor,
+						const axis2_env_t *env,
+                        sandesha2_msg_ctx_t *rm_msg_ctx)
+{
+    sandesha2_ack_requested_t *ack_requested = NULL;
+    axis2_msg_ctx_t *msg_ctx = NULL;
+    axis2_char_t *seq_id = NULL;
+    axis2_conf_ctx_t *conf_ctx = NULL;
+    sandesha2_storage_mgr_t *storage_mgr = NULL;
+    sandesha2_seq_property_mgr_t *seq_prop_mgr = NULL;
+    sandesha2_seq_property_bean_t *acks_to_bean = NULL;
+    axis2_endpoint_ref_t *acks_to = NULL;
+    axis2_char_t *acks_to_str = NULL;
+    axis2_op_t *ack_op = NULL;
+    axis2_op_t *rm_msg_op = NULL;
+    axis2_msg_ctx_t *ack_msg_ctx = NULL;
+    axis2_property_t *property = NULL;
+    sandesha2_msg_ctx_t *ack_rm_msg = NULL;
+    axiom_soap_envelope_t *envelope = NULL;
+    axis2_char_t *wsa_version = NULL;
+    axis2_char_t *addr_ns_val = NULL;
+    axis2_char_t *anon_uri = NULL;
+    
+    AXIS2_ENV_CHECK(env, AXIS2_FAILURE);
+    AXIS2_PARAM_CHECK(env->error, rm_msg_ctx, AXIS2_FAILURE);
+    
+    ack_requested = (sandesha2_ack_requested_t*)SANDESHA2_MSG_CTX_GET_MSG_PART(
+                        rm_msg_ctx, env, SANDESHA2_MSG_PART_ACK_REQUEST);
+    if(NULL == ack_requested)
+    {
+        AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "[sandesha2] Ack requested "
+                        "part is missing");
+        AXIS2_ERROR_SET(env->error, SANDESHA2_ERROR_REQD_MSG_PART_MISSING,
+                        AXIS2_FAILURE);
+        return AXIS2_FAILURE;
+    }
+    SANDESHA2_ACK_REQUESTED_SET_MUST_UNDERSTAND(ack_requested, env, AXIS2_FALSE);
+    SANDESHA2_MSG_CTX_ADD_SOAP_ENVELOPE(rm_msg_ctx, env);
+    
+    msg_ctx = SANDESHA2_MSG_CTX_GET_MSG_CTX(rm_msg_ctx, env);
+    seq_id = SANDESHA2_IDENTIFIER_GET_IDENTIFIER(
+                        SANDESHA2_ACK_REQUESTED_GET_IDENTIFIER(ack_requested, 
+                        env), env);
+    conf_ctx = AXIS2_MSG_CTX_GET_CONF_CTX(msg_ctx, env);
+    storage_mgr = sandesha2_utils_get_storage_mgr(env, conf_ctx, 
+                        AXIS2_CONF_CTX_GET_CONF(conf_ctx, env));
+    seq_prop_mgr = SANDESHA2_STORAGE_MGR_GET_SEQ_PROPERTY_MGR(storage_mgr, env);
+    acks_to_bean = SANDESHA2_SEQ_PROPERTY_MGR_RETRIEVE(seq_prop_mgr, env, seq_id,
+                        SANDESHA2_SEQ_PROP_ACKS_TO_EPR);
+    acks_to_str = SANDESHA2_SEQ_PROPERTY_BEAN_GET_VALUE(acks_to_bean, env);
+    
+    if(NULL == acks_to_str)
+    {
+        AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "[sandesha2] acks_to_str"
+                        " seqeunce property is not set correctly");
+        return AXIS2_FAILURE;
+    }
+    acks_to = axis2_endpoint_ref_create(env, acks_to_str);
+    ack_op = axis2_op_create(env);
+    AXIS2_OP_SET_MSG_EXCHANGE_PATTERN(ack_op, env, AXIS2_MEP_URI_IN_ONLY);
+    rm_msg_op = AXIS2_MSG_CTX_GET_OP(msg_ctx, env);
+    if(NULL != rm_msg_op)
+    {
+        axis2_array_list_t *out_flow = NULL;
+        out_flow = AXIS2_OP_GET_PHASES_OUTFLOW(rm_msg_op, env);
+        if(NULL != out_flow)
+        {
+            AXIS2_OP_SET_PHASES_OUTFLOW(ack_op, env, out_flow);
+            AXIS2_OP_SET_PHASES_OUT_FAULT_FLOW(ack_op, env, out_flow);
+        }
+    }
+    ack_msg_ctx = sandesha2_utils_create_new_related_msg_ctx(env, rm_msg_ctx, 
+                        ack_op);
+    property = axis2_property_create(env);
+    AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+    AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(SANDESHA2_VALUE_TRUE, 
+                        env));
+    AXIS2_MSG_CTX_SET_PROPERTY(ack_msg_ctx, env, 
+                        SANDESHA2_APPLICATION_PROCESSING_DONE, property, 
+                        AXIS2_FALSE);
+    ack_rm_msg = sandesha2_msg_initilizer_init_msg(env, ack_msg_ctx);
+    SANDESHA2_MSG_CTX_SET_RM_NS_VAL(ack_rm_msg, env, 
+                        SANDESHA2_MSG_CTX_GET_RM_NS_VAL(rm_msg_ctx, env));
+    AXIS2_MSG_CTX_SET_MSG_ID(ack_msg_ctx, env, axis2_uuid_gen(env));
+    
+    envelope = axiom_soap_envelope_create_default_soap_envelope(env, 
+                        sandesha2_utils_get_soap_version(env, 
+                        AXIS2_MSG_CTX_GET_SOAP_ENVELOPE(msg_ctx, env)));
+    AXIS2_MSG_CTX_SET_SOAP_ENVELOPE(ack_msg_ctx, env, envelope);
+    AXIS2_MSG_CTX_SET_TO(ack_msg_ctx, env, acks_to);
+    AXIS2_MSG_CTX_SET_REPLY_TO(ack_msg_ctx, env, AXIS2_MSG_CTX_GET_TO(msg_ctx, 
+                        env));
+    sandesha2_msg_creator_add_ack_msg(env, ack_rm_msg, seq_id, storage_mgr);
+    AXIS2_MSG_CTX_SET_SVR_SIDE(ack_msg_ctx, env, AXIS2_TRUE);
+    
+    property = AXIS2_MSG_CTX_GET_PROPERTY(msg_ctx, env, AXIS2_WSA_VERSION, 
+                        AXIS2_FALSE);
+    if(NULL != property)
+        wsa_version = AXIS2_PROPERTY_GET_VALUE(property, env);
+    
+    property = axis2_property_create(env);
+    AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+    AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(wsa_version, env));
+    AXIS2_MSG_CTX_SET_PROPERTY(ack_msg_ctx, env, AXIS2_WSA_VERSION, property, 
+                        AXIS2_FALSE);
+    
+    addr_ns_val = sandesha2_utils_get_seq_property(env, seq_id, 
+                        SANDESHA2_SEQ_PROP_ADDRESSING_NAMESPACE_VALUE,
+                        storage_mgr);
+    anon_uri = sandesha2_spec_specific_consts_get_anon_uri(env, addr_ns_val);
+    if(0 == AXIS2_STRCMP(anon_uri, acks_to_str))
+    {
+        axis2_engine_t *engine = NULL;
+        axis2_ctx_t *ctx = NULL;
+        
+        if(NULL == AXIS2_MSG_CTX_GET_OP(msg_ctx, env))
+        {
+            axis2_op_t *operation = NULL;
+            axis2_op_ctx_t *operation_ctx = NULL;
+            
+            operation = axis2_op_create(env);
+            AXIS2_OP_SET_MSG_EXCHANGE_PATTERN(operation, env, 
+                        AXIS2_MEP_URI_IN_OUT);
+            operation_ctx = axis2_op_ctx_create(env, operation, NULL);
+            AXIS2_MSG_CTX_SET_OP(msg_ctx, env, operation);
+            AXIS2_MSG_CTX_SET_OP_CTX(msg_ctx, env, operation_ctx);            
+        }
+        ctx = AXIS2_OP_CTX_GET_BASE(AXIS2_MSG_CTX_GET_OP_CTX(msg_ctx, env), env);
+        
+        property = axis2_property_create(env);
+        AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+        AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP("TRUE", env));
+        AXIS2_CTX_SET_PROPERTY(ctx, env, AXIS2_RESPONSE_WRITTEN,
+                        property, AXIS2_FALSE);
+        
+        property = axis2_property_create(env);
+        AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+        AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(
+                        SANDESHA2_VALUE_TRUE, env));
+        AXIS2_MSG_CTX_SET_PROPERTY(msg_ctx, env, SANDESHA2_ACK_WRITTEN, 
+                        property, AXIS2_FALSE);
+        
+        engine = axis2_engine_create(env, conf_ctx);
+        if(AXIS2_FAILURE == AXIS2_ENGINE_SEND(engine, env, ack_msg_ctx))
+        {
+            AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "[sandesha2] ack sending"
+                        " failed");
+            AXIS2_ERROR_SET(env->error, SANDESHA2_ERROR_SENDING_ACK, 
+                        AXIS2_FAILURE);
+            return AXIS2_FAILURE;
+        }        
+    }
+    else
+    {
+        sandesha2_sender_mgr_t *retrans_mgr = NULL;
+        axis2_char_t *key = NULL;
+        sandesha2_sender_bean_t *ack_bean = NULL;
+        sandesha2_sender_bean_t *find_bean = NULL;
+        sandesha2_property_bean_t *prop_bean = NULL;
+        long ack_interval = 0;
+        long time_to_send = 0;
+        axis2_array_list_t *found_list = NULL;
+        axis2_msg_ctx_t *msg_ctx = NULL;
+        axis2_engine_t *engine = NULL;
+        
+        retrans_mgr = SANDESHA2_STORAGE_MGR_GET_RETRANS_MGR(storage_mgr, env);
+        key = axis2_uuid_gen(env);
+        ack_bean = sandesha2_sender_bean_create(env);
+        SANDESHA2_SENDER_BEAN_SET_MSG_CONTEXT_REF_KEY(ack_bean, env, key);
+        SANDESHA2_SENDER_BEAN_SET_MSG_ID(ack_bean, env, 
+                        AXIS2_MSG_CTX_GET_MSG_ID(ack_msg_ctx, env));
+        SANDESHA2_SENDER_BEAN_SET_RESEND(ack_bean, env, AXIS2_FALSE);
+        SANDESHA2_SENDER_BEAN_SET_SEQ_ID(ack_bean, env, seq_id);
+        SANDESHA2_SENDER_BEAN_SET_SEND(ack_bean, env, AXIS2_TRUE);
+        SANDESHA2_SENDER_BEAN_SET_MSG_TYPE(ack_bean, env, 
+                        SANDESHA2_MSG_TYPE_ACK);
+                        
+        property = axis2_property_create(env);
+        AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+        AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(
+                        SANDESHA2_VALUE_FALSE, env));
+        AXIS2_MSG_CTX_SET_PROPERTY(ack_msg_ctx, env, 
+                        SANDESHA2_QUALIFIED_FOR_SENDING, property, AXIS2_FALSE);
+        
+        prop_bean = sandesha2_utils_get_property_bean_from_op(env, 
+                        AXIS2_MSG_CTX_GET_OP(msg_ctx, env));
+        ack_interval = SANDESHA2_PROPERTY_BEAN_GET_ACK_INTERVAL(prop_bean, env);
+        time_to_send = sandesha2_utils_get_current_time_in_millis(env) +
+                        ack_interval;
+                        
+        find_bean = sandesha2_sender_bean_create(env);
+        SANDESHA2_SENDER_BEAN_SET_RESEND(find_bean, env, AXIS2_FALSE);
+        SANDESHA2_SENDER_BEAN_SET_SEND(find_bean, env, AXIS2_TRUE);
+        SANDESHA2_SENDER_BEAN_SET_MSG_TYPE(find_bean, env, 
+                        SANDESHA2_MSG_TYPE_ACK);
+                        
+        found_list = SANDESHA2_SENDER_MGR_FIND_BY_SENDER_BEAN(retrans_mgr, env, 
+                        find_bean);
+        if(NULL != found_list)
+        {
+            int i = 0;
+            for(i = 0; i < AXIS2_ARRAY_LIST_SIZE(found_list, env); i++)
+            {
+                sandesha2_sender_bean_t *old_ack_bean = NULL;
+                old_ack_bean = AXIS2_ARRAY_LIST_GET(found_list, env, i);
+                time_to_send = SANDESHA2_SENDER_BEAN_GET_TIME_TO_SEND(
+                        old_ack_bean, env);
+                SANDESHA2_SENDER_MGR_REMOVE(retrans_mgr, env, 
+                        SANDESHA2_SENDER_BEAN_GET_MSG_ID(old_ack_bean, env));
+            }
+        }
+        SANDESHA2_SENDER_BEAN_SET_TIME_TO_SEND(ack_bean, env, time_to_send); 
+        SANDESHA2_STORAGE_MGR_STORE_MSG_CTX(storage_mgr, env, key, ack_msg_ctx);
+        SANDESHA2_SENDER_MGR_INSERT(retrans_mgr, env, ack_bean);
+        
+        property = axis2_property_create(env);
+        AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+        AXIS2_PROPERTY_SET_VALUE(property, env, 
+                        AXIS2_MSG_CTX_GET_TRANSPORT_OUT_DESC(ack_msg_ctx, env));
+        AXIS2_MSG_CTX_SET_PROPERTY(ack_msg_ctx, env, 
+                        SANDESHA2_ORIGINAL_TRANSPORT_OUT_DESC, property, 
+                        AXIS2_FALSE);
+        
+        property = axis2_property_create(env);
+        AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+        AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(
+                        SANDESHA2_VALUE_TRUE, env));
+        AXIS2_MSG_CTX_SET_PROPERTY(ack_msg_ctx, env, 
+                        SANDESHA2_SET_SEND_TO_TRUE, property, AXIS2_FALSE);
+        
+        property = axis2_property_create(env);
+        AXIS2_PROPERTY_SET_SCOPE(property, env, AXIS2_SCOPE_REQUEST);
+        AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(key, env));
+        AXIS2_MSG_CTX_SET_PROPERTY(ack_msg_ctx, env, 
+                        SANDESHA2_MESSAGE_STORE_KEY, property, AXIS2_FALSE);
+                        
+        AXIS2_MSG_CTX_SET_TRANSPORT_OUT_DESC(ack_msg_ctx, env, 
+                        sandesha2_utils_get_transport_out(env));
+        engine = axis2_engine_create(env, conf_ctx);
+        if(AXIS2_FAILURE == AXIS2_ENGINE_SEND(engine, env, ack_msg_ctx))
+        {
+            AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "[sandesha2] ack sending"
+                        " failed");
+            AXIS2_ERROR_SET(env->error, SANDESHA2_ERROR_SENDING_ACK, 
+                        AXIS2_FAILURE);
+            return AXIS2_FAILURE;
+        }
+        sandesha2_utils_start_sender_for_seq(env, conf_ctx, seq_id);
+        AXIS2_MSG_CTX_PAUSE(msg_ctx, env);
+    }
+    return AXIS2_SUCCESS;
+}
+    
+axis2_status_t AXIS2_CALL 
+sandesha2_ack_req_msg_processor_process_out_msg(
+                        sandesha2_msg_processor_t *msg_processor,
+                    	const axis2_env_t *env, 
+                        sandesha2_msg_ctx_t *rm_msg_ctx)
+{
+    
+    AXIS2_ENV_CHECK(env, AXIS2_FAILURE);
+    AXIS2_PARAM_CHECK(env->error, rm_msg_ctx, AXIS2_FAILURE);
+    
+    return AXIS2_SUCCESS;
+}

Modified: webservices/sandesha/trunk/c/src/util/utils.c
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/src/util/utils.c?rev=422630&r1=422629&r2=422630&view=diff
==============================================================================
--- webservices/sandesha/trunk/c/src/util/utils.c (original)
+++ webservices/sandesha/trunk/c/src/util/utils.c Sun Jul 16 23:06:15 2006
@@ -612,3 +612,13 @@
     return new_msg;
 }
 
+AXIS2_EXTERN  int AXIS2_CALL
+sandesha2_utils_get_soap_version(const axis2_env_t *env, 
+                        axiom_soap_envelope_t *envelope)
+{
+    AXIS2_ENV_CHECK(env, -1);
+    AXIS2_PARAM_CHECK(env->error, envelope, -1);
+    
+    return AXIOM_SOAP_ENVELOPE_GET_SOAP_VERSION(envelope, env);
+}
+



---------------------------------------------------------------------
To unsubscribe, e-mail: sandesha-dev-unsubscribe@ws.apache.org
For additional commands, e-mail: sandesha-dev-help@ws.apache.org