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 da...@apache.org on 2007/03/01 05:57:43 UTC

svn commit: r513140 - in /webservices/sandesha/trunk/c/samples/rm_report: ./ Makefile.am report.c report_util.c report_util.h

Author: damitha
Date: Wed Feb 28 20:57:42 2007
New Revision: 513140

URL: http://svn.apache.org/viewvc?view=rev&rev=513140
Log:
Added rm report testing sample. This is the initial versio of the
sample and it is not implemented yet propertly

Added:
    webservices/sandesha/trunk/c/samples/rm_report/
    webservices/sandesha/trunk/c/samples/rm_report/Makefile.am
    webservices/sandesha/trunk/c/samples/rm_report/report.c
    webservices/sandesha/trunk/c/samples/rm_report/report_util.c
    webservices/sandesha/trunk/c/samples/rm_report/report_util.h

Added: webservices/sandesha/trunk/c/samples/rm_report/Makefile.am
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/samples/rm_report/Makefile.am?view=auto&rev=513140
==============================================================================
--- webservices/sandesha/trunk/c/samples/rm_report/Makefile.am (added)
+++ webservices/sandesha/trunk/c/samples/rm_report/Makefile.am Wed Feb 28 20:57:42 2007
@@ -0,0 +1,26 @@
+prgbindir=$(prefix)/bin/samples
+prgbin_PROGRAMS = rm_report
+samplesdir=$(prefix)/samples/client/rm_report
+samples_DATA=report.c Makefile.am Makefile.in
+rm_report_SOURCES = report.c report_util.c
+
+rm_report_LDADD   =  \
+                    -L$(AXIS2C_HOME)/lib \
+					-laxis2_util \
+                    -laxis2_axiom \
+                    -laxis2_engine \
+                    -laxis2_parser \
+                    -lpthread \
+                    -laxis2_http_sender \
+                    -laxis2_http_receiver \
+                    -L$(AXIS2C_HOME)/modules/sandesha2 \
+					-lsandesha2_client \
+					-lsandesha2 \
+					-lsqlite3 \
+                    $(GUTHTHILA_LIBS) \
+                    $(LIBXML2_LIBS)
+
+INCLUDES = -I$(AXIS2C_HOME)/include \
+			-I$(AXIS2C_HOME)/modules/sandesha2 \
+			@UTILINC@ \
+			@AXIOMINC@

Added: webservices/sandesha/trunk/c/samples/rm_report/report.c
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/samples/rm_report/report.c?view=auto&rev=513140
==============================================================================
--- webservices/sandesha/trunk/c/samples/rm_report/report.c (added)
+++ webservices/sandesha/trunk/c/samples/rm_report/report.c Wed Feb 28 20:57:42 2007
@@ -0,0 +1,337 @@
+/*
+ * 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 "report_util.h"
+#include <axis2_util.h>
+#include <axiom_soap.h>
+#include <axis2_client.h>
+#include <axis2_svc_ctx.h>
+#include <axis2_conf_ctx.h>
+#include <axis2_op_client.h>
+#include <axis2_listener_manager.h>
+#include <axis2_callback_recv.h>
+#include <axis2_svc_client.h>
+#include <sandesha2_client_constants.h>
+#include <sandesha2_constants.h>
+#include <sandesha2_client.h>
+#include <axis2_addr.h>
+#include <axis2_options.h>
+#include <ctype.h>
+
+#define SANDESHA2_MAX_COUNT 4
+
+/* on_complete callback function */
+axis2_status_t AXIS2_CALL
+rm_report_callback_on_complete(
+    struct axis2_callback *callback,
+    const axis2_env_t *env);
+
+/* on_error callback function */
+axis2_status_t AXIS2_CALL
+rm_report_callback_on_error(
+    struct axis2_callback *callback,
+    const axis2_env_t *env,
+    int exception);
+
+void wait_on_callback(
+    const axis2_env_t *env,
+    axis2_callback_t *callback);
+
+static void 
+usage(
+    axis2_char_t *prog_name);
+
+int main(int argc, char** argv)
+{
+    const axis2_env_t *env = NULL;
+    const axis2_char_t *address = NULL;
+    axis2_endpoint_ref_t* endpoint_ref = NULL;
+    axis2_endpoint_ref_t* reply_to = NULL;
+    axis2_options_t *options = NULL;
+    const axis2_char_t *client_home = NULL;
+    axis2_svc_client_t* svc_client = NULL;
+    axis2_svc_ctx_t *svc_ctx = NULL;
+    axis2_conf_ctx_t *conf_ctx = NULL;
+    axiom_node_t *payload = NULL;
+    axis2_property_t *property = NULL;
+    axis2_listener_manager_t *listener_manager = NULL;
+    axis2_char_t *offered_seq_id = NULL;
+    axiom_soap_envelope_t *result = NULL;
+    int c;
+    int i = 0, size = 0;
+   
+    /* Set up the environment */
+    /*env = axis2_env_create_all("report_non_blocking_dual.log", 
+            AXIS2_LOG_LEVEL_DEBUG);*/
+    /*env = axis2_env_create_all("report_non_blocking_dual.log", 
+            AXIS2_LOG_LEVEL_ERROR);*/
+    env = axis2_env_create_all("rm_report.log", 
+            AXIS2_LOG_LEVEL_DEBUG);
+
+    /* Set end point reference of report service */
+    /*address = "http://127.0.0.1:8888/axis2/services/RMSampleService";*/
+    address = "http://127.0.0.1:5555/axis2/services/RMSampleService";
+    while ((c = AXIS2_GETOPT(argc, argv, ":a:")) != -1)
+    {
+
+        switch (c)
+        {
+            case 'a':
+                address = optarg;
+                break;
+            case ':':
+                fprintf(stderr, "\nOption -%c requires an operand\n", optopt);
+                usage(argv[0]);
+                return -1;
+            case '?':
+                if (isprint(optopt))
+                    fprintf(stderr, "\nUnknown option `-%c'.\n", optopt);
+                usage(argv[0]);
+                return -1;
+        }
+    }
+    if (AXIS2_STRCMP(address, "-h") == 0)
+    {
+        printf("Usage : %s [endpoint_url] [offer]\n", argv[0]);
+        printf("use -h for help\n");
+        return 0;
+    }
+    printf ("Using endpoint : %s\n", address);
+    
+    /* Create EPR with given address */
+    endpoint_ref = axis2_endpoint_ref_create(env, address);
+
+    /* Setup options */
+    options = axis2_options_create(env);
+    AXIS2_OPTIONS_SET_TO(options, env, endpoint_ref);
+    
+    /* Seperate listner needs addressing, hence addressing stuff in options */
+    AXIS2_OPTIONS_SET_ACTION(options, env,
+        "http://127.0.0.1:8080/axis2/services/RMSampleService/anonOutInOp");
+    property = axis2_property_create_with_args(env, 3, 0, 0, "4");
+    if(property)
+    {
+        AXIS2_OPTIONS_SET_PROPERTY(options, env, AXIS2_TIMEOUT_IN_SECONDS, 
+            property);
+    }
+    reply_to = axis2_endpoint_ref_create(env, AXIS2_WSA_ANONYMOUS_URL);
+    /*AXIS2_OPTIONS_SET_REPLY_TO(options, env, reply_to);*/
+
+    /* Set up deploy folder. It is from the deploy folder, the configuration is 
+     * picked up using the axis2.xml file.
+     * In this sample client_home points to the Axis2/C default deploy folder. 
+     * The client_home can be different from this folder on your system. For 
+     * example, you may have a different folder (say, my_client_folder) with its 
+     * own axis2.xml file. my_client_folder/modules will have the modules that 
+     * the client uses
+     */
+    client_home = AXIS2_GETENV("AXIS2C_HOME");
+    if (!client_home)
+        client_home = "../../deploy";
+
+    /* Create service client */
+    svc_client = axis2_svc_client_create(env, client_home);
+    if (!svc_client)
+    {
+        printf("Error creating service client\n");
+        AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Stub invoke FAILED: Error code:"
+                  " %d :: %s", env->error->error_number,
+                        AXIS2_ERROR_GET_MESSAGE(env->error));
+        return -1;
+    }
+
+    /* Set service client options */
+    AXIS2_SVC_CLIENT_SET_OPTIONS(svc_client, env, options);    
+    
+    AXIS2_SVC_CLIENT_ENGAGE_MODULE(svc_client, env, AXIS2_MODULE_ADDRESSING);  
+    AXIS2_SVC_CLIENT_ENGAGE_MODULE(svc_client, env, "sandesha2");
+
+    listener_manager = axis2_listener_manager_create(env);
+    if (!listener_manager)
+    {
+        return AXIS2_FAILURE;
+    }
+    /* Offer sequence */
+    offered_seq_id = axis2_uuid_gen(env);
+    property = axis2_property_create(env);
+    if(property)
+    {
+        AXIS2_PROPERTY_SET_VALUE(property, env, AXIS2_STRDUP(offered_seq_id, 
+            env));
+        AXIS2_OPTIONS_SET_PROPERTY(options, env, 
+            SANDESHA2_CLIENT_OFFERED_SEQ_ID, property);
+    }
+    /* RM Version 1.1 */
+    property = axis2_property_create_with_args(env, 3, 0, 0, 
+        SANDESHA2_SPEC_VERSION_1_0);
+    if(property)
+    {
+        AXIS2_OPTIONS_SET_PROPERTY(options, env, 
+            SANDESHA2_CLIENT_RM_SPEC_VERSION, property);
+    }
+    property = axis2_property_create_with_args(env, 3, 0, 0, "sequence1");
+    if(property)
+    {
+        AXIS2_OPTIONS_SET_PROPERTY(options, env, SANDESHA2_CLIENT_SEQ_KEY, 
+            property);
+    }
+     
+    /*svc_ctx = AXIS2_SVC_CLIENT_GET_SVC_CTX(svc_client, env);
+    conf_ctx = axis2_svc_ctx_get_conf_ctx(svc_ctx, env);
+    result = sandesha2_client_get_response_envelope(env, conf_ctx, svc_client, 1);*/
+   
+    payload = build_om_payload_for_echo_svc(env, "echo1", "sequence1");
+    result = AXIS2_SVC_CLIENT_SEND_RECEIVE(svc_client, env, payload);
+
+    /*result = sandesha2_client_get_response_envelope(env, conf_ctx, svc_client, 2);*/
+    if(result)
+    {
+        axis2_char_t *om_str = NULL;
+        om_str = AXIOM_NODE_TO_STRING(result, env);
+        if (om_str)
+            printf("\nReceived OM : %s\n", om_str);
+        printf("\necho client two way single channel invoke SUCCESSFUL!\n");
+
+        AXIS2_FREE(env->allocator, om_str);
+        result = NULL;
+    }
+    else
+    {
+        printf("\necho client two way single channel invoke FAILED!\n");
+    }
+    payload = NULL;
+
+    property = axis2_property_create_with_args(env, 0, 0, 0, AXIS2_VALUE_TRUE);
+    AXIS2_OPTIONS_SET_PROPERTY(options, env, "Sandesha2LastMessage", property);
+    payload = build_om_payload_for_echo_svc(env, "echo2", "sequence1");
+    result = AXIS2_SVC_CLIENT_SEND_RECEIVE(svc_client, env, payload);
+    /*result = sandesha2_client_get_response_envelope(env, conf_ctx, svc_client, 3);*/
+    if(result)
+    {
+        axis2_char_t *om_str = NULL;
+        om_str = AXIOM_NODE_TO_STRING(result, env);
+        if (om_str)
+            printf("\nReceived OM : %s\n", om_str);
+        printf("\necho client two way single channel invoke SUCCESSFUL!\n");
+
+        AXIS2_FREE(env->allocator, om_str);
+        result = NULL;
+    }
+    else
+    {
+        printf("\necho client two way single channel invoke FAILED!\n");
+    }
+    payload = NULL;
+    AXIS2_SLEEP(2 * SANDESHA2_MAX_COUNT);
+
+    if (svc_client)
+    {
+        /*AXIS2_SVC_CLIENT_FREE(svc_client, env);*/
+        svc_client = NULL;
+    }
+    
+    return 0;
+}
+
+axis2_status_t AXIS2_CALL
+rm_report_callback_on_complete(
+    struct axis2_callback *callback,
+    const axis2_env_t *env)
+{
+   /** SOAP response has arrived here; get the soap envelope 
+     from the callback object and do whatever you want to do with it */
+   
+   axiom_soap_envelope_t *soap_envelope = NULL;
+   axiom_node_t *ret_node = NULL;
+   axis2_status_t status = AXIS2_SUCCESS;
+   
+   soap_envelope = AXIS2_CALLBACK_GET_ENVELOPE(callback, env);
+   
+   if (!soap_envelope)
+   {
+       AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Stub invoke FAILED: Error code:"
+            " %d :: %s", env->error->error_number,
+            AXIS2_ERROR_GET_MESSAGE(env->error));
+      printf("report stub invoke FAILED!\n");
+      status = AXIS2_FAILURE;
+   }
+    else
+    {
+        ret_node = AXIOM_SOAP_ENVELOPE_GET_BASE_NODE(soap_envelope, env);
+    
+        if(!ret_node)
+        {
+            AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, 
+                    "Stub invoke FAILED: Error code:%d :: %s", 
+                    env->error->error_number, 
+                    AXIS2_ERROR_GET_MESSAGE(env->error));
+            printf("report stub invoke FAILED!\n");
+            status = AXIS2_FAILURE;
+        }
+        else
+        {
+            axis2_char_t *om_str = NULL;
+            om_str = AXIOM_NODE_TO_STRING(ret_node, env);
+            if (om_str)
+                printf("\nReceived OM : %s\n", om_str);
+            printf("\nreport client invoke SUCCESSFUL!\n");
+        }
+    }    
+    return status;
+}
+
+axis2_status_t AXIS2_CALL
+rm_report_callback_on_error(
+    struct axis2_callback *callback,
+    const axis2_env_t *env,
+    int exception)
+{
+   /** take necessary action on error */
+   printf("\nEcho client invoke FAILED. Error code:%d ::%s", exception, 
+         AXIS2_ERROR_GET_MESSAGE(env->error));
+   return AXIS2_SUCCESS;
+}
+
+void wait_on_callback(
+    const axis2_env_t *env,
+    axis2_callback_t *callback)
+{
+    /** Wait till callback is complete. Simply keep the parent thread running
+       until our on_complete or on_error is invoked */
+    while(1)
+    {
+        if (AXIS2_CALLBACK_GET_COMPLETE(callback, env))
+        {
+            /* We are done with the callback */
+            break;
+        }
+    }
+    return;
+}
+
+static void 
+usage(
+    axis2_char_t *prog_name)
+{
+    fprintf(stdout, "\n Usage : %s", prog_name);
+    fprintf(stdout, " [-a ADDRESS]");
+    fprintf(stdout, " Options :\n");
+    fprintf(stdout, "\t-a ADDRESS \t endpoint address.. The" \
+        " default is http://127.0.0.1:5555/axis2/services/RMSampleService \n");
+    fprintf(stdout, " Help :\n\t-h \t display this help screen.\n\n");
+}
+
+

Added: webservices/sandesha/trunk/c/samples/rm_report/report_util.c
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/samples/rm_report/report_util.c?view=auto&rev=513140
==============================================================================
--- webservices/sandesha/trunk/c/samples/rm_report/report_util.c (added)
+++ webservices/sandesha/trunk/c/samples/rm_report/report_util.c Wed Feb 28 20:57:42 2007
@@ -0,0 +1,50 @@
+/*
+ * 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 "report_util.h"
+
+/* build SOAP request message content using OM */
+axiom_node_t *
+build_om_payload_for_echo_svc(
+   const axis2_env_t *env,
+   axis2_char_t *text,
+   axis2_char_t *seq)
+{
+    axiom_node_t *echo_om_node = NULL;
+    axiom_element_t* echo_om_ele = NULL;
+    axiom_node_t* text_om_node = NULL;
+    axiom_element_t * text_om_ele = NULL;
+    axiom_node_t* seq_om_node = NULL;
+    axiom_element_t * seq_om_ele = NULL;
+    axiom_namespace_t *ns1 = NULL;
+    axis2_char_t *om_str = NULL;
+    axis2_char_t *ns = NULL;
+
+    ns = "http://tempuri.org/";
+    
+    ns1 = axiom_namespace_create (env, ns, "ns1");
+    echo_om_ele = axiom_element_create(env, NULL, "echoString", ns1, &echo_om_node);
+    text_om_ele = axiom_element_create(env, echo_om_node, "Text", ns1, &text_om_node);
+    seq_om_ele = axiom_element_create(env, echo_om_node, "Sequence", ns1, &seq_om_node);
+    AXIOM_ELEMENT_SET_TEXT(text_om_ele, env, text, text_om_node);
+    AXIOM_ELEMENT_SET_TEXT(text_om_ele, env, seq, seq_om_node);
+    
+    om_str = AXIOM_NODE_TO_STRING(echo_om_node, env);
+    if (om_str)
+        printf("\nSending OM : %s\n", om_str);
+
+    return echo_om_node;
+}

Added: webservices/sandesha/trunk/c/samples/rm_report/report_util.h
URL: http://svn.apache.org/viewvc/webservices/sandesha/trunk/c/samples/rm_report/report_util.h?view=auto&rev=513140
==============================================================================
--- webservices/sandesha/trunk/c/samples/rm_report/report_util.h (added)
+++ webservices/sandesha/trunk/c/samples/rm_report/report_util.h Wed Feb 28 20:57:42 2007
@@ -0,0 +1,29 @@
+/*
+ * 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 AXIS2_UG_ECHO_UTIL_H
+#define AXIS2_UG_ECHO_UTIL_H
+
+#include <stdio.h>
+#include <axiom.h>
+
+axiom_node_t *
+build_om_payload_for_echo_svc(
+   const axis2_env_t *env,
+   axis2_char_t *text,
+   axis2_char_t *seq);
+
+#endif



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