| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html><head><title>Apache Axis2/C - modules/mod_log/log_out_handler.c</title><div class="contentBox"><div class="section"><font face="Monospace"> |
| <font color="#808080"><i>/*<br></br> |
| * Licensed to the Apache Software Foundation (ASF) under one or more<br></br> |
| * contributor license agreements. See the NOTICE file distributed with<br></br> |
| * this work for additional information regarding copyright ownership.<br></br> |
| * The ASF licenses this file to You under the Apache License, Version 2.0<br></br> |
| * (the "License"); you may not use this file except in compliance with<br></br> |
| * the License. You may obtain a copy of the License at<br></br> |
| *<br></br> |
| * http://www.apache.org/licenses/LICENSE-2.0<br></br> |
| *<br></br> |
| * Unless required by applicable law or agreed to in writing, software<br></br> |
| * distributed under the License is distributed on an "AS IS" BASIS,<br></br> |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<br></br> |
| * See the License for the specific language governing permissions and<br></br> |
| * limitations under the License.<br></br> |
| */</i></font><br></br> |
| <br></br> |
| <font color="#008000">#include <axis2_handler_desc.h><br></br></font> |
| <font color="#008000">#include <axutil_array_list.h><br></br></font> |
| <font color="#008000">#include <axiom_soap_const.h><br></br></font> |
| <font color="#008000">#include <axiom_soap_envelope.h><br></br></font> |
| <font color="#008000">#include <axiom_soap_header.h><br></br></font> |
| <font color="#008000">#include <axiom_soap_header_block.h><br></br></font> |
| <font color="#008000">#include <axis2_op.h><br></br></font> |
| <font color="#008000">#include <axis2_msg_ctx.h><br></br></font> |
| <font color="#008000">#include <axis2_conf_ctx.h><br></br></font> |
| <font color="#008000">#include <axis2_msg_info_headers.h><br></br></font> |
| <font color="#008000">#include <axutil_property.h><br></br></font> |
| <br></br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></br> |
| <font color="#000000">axutil_log_out_handler_invoke</font>(<font color="#000000"><b>struct</b></font> <font color="#000000">axis2_handler</font> *<font color="#000000">handler</font>, <br></br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>,<br></br> |
| <font color="#000000"><b>struct</b></font> <font color="#000000">axis2_msg_ctx</font> *<font color="#000000">msg_ctx</font>);<br></br> |
| <br></br> |
| <font color="#000000">AXIS2_EXTERN</font> <font color="#000000">axis2_handler_t</font>* <font color="#000000">AXIS2_CALL</font><br></br> |
| <font color="#000000">axutil_log_out_handler_create</font>(<font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>, <br></br> |
| <font color="#000000">axutil_string_t</font> *<font color="#000000">name</font>) <br></br> |
| {<br></br> |
| <font color="#000000">axis2_handler_t</font> *<font color="#000000">handler</font> = <font color="#000000">NULL</font>;<br></br> |
| <br></br> |
| <font color="#000000">AXIS2_ENV_CHECK</font>(<font color="#000000">env</font>, <font color="#000000">NULL</font>);<br></br> |
| <br></br> |
| <font color="#000000">handler</font> = <font color="#000000">axis2_handler_create</font>(<font color="#000000">env</font>);<br></br> |
| <font color="#000000"><b>if</b></font> (!<font color="#000000">handler</font>)<br></br> |
| {<br></br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">NULL</font>;<br></br> |
| }<br></br> |
| <br></br> |
| <font color="#000000">axis2_handler_set_invoke</font>(<font color="#000000">handler</font>, <font color="#000000">env</font>, <font color="#000000">axutil_log_out_handler_invoke</font>);<br></br> |
| <br></br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">handler</font>;<br></br> |
| }<br></br> |
| <br></br> |
| <br></br> |
| <font color="#000000">axis2_status_t</font> <font color="#000000">AXIS2_CALL</font><br></br> |
| <font color="#000000">axutil_log_out_handler_invoke</font>(<font color="#000000"><b>struct</b></font> <font color="#000000">axis2_handler</font> *<font color="#000000">handler</font>, <br></br> |
| <font color="#800000">const</font> <font color="#000000">axutil_env_t</font> *<font color="#000000">env</font>,<br></br> |
| <font color="#000000"><b>struct</b></font> <font color="#000000">axis2_msg_ctx</font> *<font color="#000000">msg_ctx</font>)<br></br> |
| {<br></br> |
| <font color="#000000">axiom_soap_envelope_t</font> *<font color="#000000">soap_envelope</font> = <font color="#000000">NULL</font>;<br></br> |
| <font color="#000000">axiom_node_t</font> *<font color="#000000">ret_node</font> = <font color="#000000">NULL</font>;<br></br> |
| <br></br> |
| <font color="#000000">AXIS2_ENV_CHECK</font>( <font color="#000000">env</font>, <font color="#000000">AXIS2_FAILURE</font>);<br></br> |
| <font color="#000000">AXIS2_PARAM_CHECK</font>(<font color="#000000">env</font>-><font color="#000000">error</font>, <font color="#000000">msg_ctx</font>, <font color="#000000">AXIS2_FAILURE</font>);<br></br> |
| <br></br> |
| <font color="#000000">AXIS2_LOG_INFO</font>(<font color="#000000">env</font>-><font color="#000000">log</font>, <font color="#FF0000">"Starting logging out handler ........."</font>);<br></br> |
| <br></br> |
| <font color="#000000">soap_envelope</font> = <font color="#000000">axis2_msg_ctx_get_soap_envelope</font>(<font color="#000000">msg_ctx</font>, <font color="#000000">env</font>);<br></br> |
| <br></br> |
| <font color="#000000"><b>if</b></font> (<font color="#000000">soap_envelope</font>)<br></br> |
| {<br></br> |
| <font color="#000000">ret_node</font> = <font color="#000000">axiom_soap_envelope_get_base_node</font>(<font color="#000000">soap_envelope</font>, <font color="#000000">env</font>);<br></br> |
| <br></br> |
| <font color="#000000"><b>if</b></font>(<font color="#000000">ret_node</font>)<br></br> |
| {<br></br> |
| <font color="#000000">axis2_char_t</font> *<font color="#000000">om_str</font> = <font color="#000000">NULL</font>;<br></br> |
| <font color="#000000">om_str</font> = <font color="#000000">axiom_node_to_string</font>(<font color="#000000">ret_node</font>, <font color="#000000">env</font>);<br></br> |
| <font color="#000000"><b>if</b></font>(<font color="#000000">om_str</font>)<br></br> |
| {<br></br> |
| <font color="#000000">AXIS2_LOG_INFO</font>(<font color="#000000">env</font>-><font color="#000000">log</font>, <font color="#FF0000">"Output message: %s"</font>, <font color="#000000">om_str</font>);<br></br> |
| }<br></br> |
| }<br></br> |
| }<br></br> |
| <br></br> |
| <font color="#000000"><b>return</b></font> <font color="#000000">AXIS2_SUCCESS</font>;<br></br> |
| }<br></br> |
| <br></br> |
| <br></br> |
| </font></div></div></div><div class="clear"><hr></hr></div></body></html> |