<!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>