blob: d9c2bccf48e1a995ab97709c58cf70cf8f1f5ceb [file] [log] [blame]
/*
* 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 <sandesha2_report.h>
#include <axis2_addr.h>
#include <axis2_options.h>
#include <ctype.h>
#define SANDESHA2_MAX_COUNT 4
static void
usage(
axis2_char_t *prog_name);
int main(int argc, char** argv)
{
const axutil_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;
axutil_property_t *property = NULL;
axis2_listener_manager_t *listener_manager = NULL;
axis2_char_t *offered_seq_id = NULL;
axis2_char_t *seq_key = NULL;
axiom_node_t *result = NULL;
sandesha2_report_t *report = NULL;
int c;
/* Set up the environment */
env = axutil_env_create_all("rm_report.log",
AXIS2_LOG_LEVEL_DEBUG);
/* Set end point reference of report service */
address = "http://127.0.0.1:9090/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 (axutil_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");
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 = axutil_uuid_gen(env);
property = axutil_property_create(env);
if(property)
{
axutil_property_set_value(property, env, axutil_strdup(env,
offered_seq_id));
axis2_options_set_property(options, env,
SANDESHA2_CLIENT_OFFERED_SEQ_ID, property);
}
/* RM Version 1.1 */
property = axutil_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);
}
seq_key = axutil_uuid_gen(env);
property = axutil_property_create_with_args(env, 3, 0, 0, seq_key);
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);
property = axutil_property_create_with_args(env, 0, 0, 0, "12");
if(property)
{
axis2_options_set_property(options, env, AXIS2_TIMEOUT_IN_SECONDS,
property);
}
payload = build_om_payload_for_echo_svc(env, "echo1", seq_key);
result = axis2_svc_client_send_receive(svc_client, env, payload);
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;
report = sandesha2_client_get_report(env, conf_ctx);
if(report)
{
int i = 0, size = 0;
axutil_array_list_t *incoming_seq_list = NULL;
axutil_array_list_t *outgoing_seq_list = NULL;
incoming_seq_list = sandesha2_report_get_incoming_seq_list(report, env);
if(incoming_seq_list)
size = axutil_array_list_size(incoming_seq_list, env);
printf("Sandesha client report.\n");
printf(".......................\n");
for(i = 0; i < size; i++)
{
axis2_char_t *seq_id = axutil_array_list_get(incoming_seq_list, env, i);
if(seq_id)
{
printf("Incoming sequence ID %d : %s\n", i+1, seq_id);
}
}
size = 0;
outgoing_seq_list = sandesha2_report_get_outgoing_seq_list(report, env);
if(outgoing_seq_list)
size = axutil_array_list_size(outgoing_seq_list, env);
for(i = 0; i < size; i++)
{
axis2_char_t *seq_id = axutil_array_list_get(outgoing_seq_list, env, i);
if(seq_id)
{
long completed_msgs_count = -1;
printf("Outgoing sequence ID %d : %s\n", i+1, seq_id);
completed_msgs_count = sandesha2_report_get_completed_msgs_count(
report, env, seq_id);
printf("Completed message count : %ld\n", completed_msgs_count);
}
}
printf("End of Sandesha client report.\n");
}
property = axutil_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", seq_key);
result = axis2_svc_client_send_receive(svc_client, env, payload);
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);
AXIS2_FREE(env->allocator, seq_key);
if (svc_client)
{
axis2_svc_client_free(svc_client, env);
svc_client = NULL;
}
return 0;
}
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:9090/axis2/services/RMSampleService \n");
fprintf(stdout, " Help :\n\t-h \t display this help screen.\n\n");
}