summaryrefslogtreecommitdiffstats
path: root/samples/server/notify/notify.c
diff options
context:
space:
mode:
Diffstat (limited to 'samples/server/notify/notify.c')
-rw-r--r--samples/server/notify/notify.c77
1 files changed, 77 insertions, 0 deletions
diff --git a/samples/server/notify/notify.c b/samples/server/notify/notify.c
new file mode 100644
index 0000000..80dc5bd
--- /dev/null
+++ b/samples/server/notify/notify.c
@@ -0,0 +1,77 @@
+
+/*
+ * 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.
+ */
+#include "notify.h"
+#include <stdio.h>
+
+void
+axis2_notify_notify(
+ const axutil_env_t * env,
+ axiom_node_t * node)
+{
+ axiom_node_t *text_node = NULL;
+
+ if (!env || !env)
+ {
+ return;
+ }
+
+ /* Expected request format is :-
+ <m:notify xmlns:m="http://example.org/notify">Message 3</m:notify>
+ */
+ if (!node) /* 'notify' node */
+ {
+ AXIS2_ERROR_SET(env->error, AXIS2_ERROR_SVC_SKEL_INPUT_OM_NODE_NULL,
+ AXIS2_FAILURE);
+ AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Echo client ERROR: input parameter NULL");
+ return;
+ }
+
+ text_node = axiom_node_get_first_child(node, env);
+ if (!text_node) /* actual text to notify */
+ {
+ AXIS2_ERROR_SET(env->error,
+ AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
+ AXIS2_FAILURE);
+ AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Echo client ERROR: invalid XML in request");
+ return;
+ }
+
+ if (axiom_node_get_node_type(text_node, env) == AXIOM_TEXT)
+ {
+ axiom_text_t *text =
+ (axiom_text_t *) axiom_node_get_data_element(text_node, env);
+ if (text && axiom_text_get_value(text, env))
+ {
+ axis2_char_t *text_str =
+ (axis2_char_t *) axiom_text_get_value(text, env);
+ AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Notification received : %s", text_str);
+ }
+ }
+ else
+ {
+ AXIS2_ERROR_SET(env->error,
+ AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
+ AXIS2_FAILURE);
+ printf("\n");
+ AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Echo client ERROR: invalid XML in request");
+ return;
+ }
+
+ return;
+}
+