blob: d6eaa06909eb7d414d50eeff491cadbd204a8ff0 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>modules/mod_log/log_out_handler.c</title>
<meta name="generator" content="c2html 1.1.0" >
<meta http-equiv="content-type" content="text/html; charset=ISO-8859-1" >
<meta http-equiv="Content-Script-Type" content="text/javascript" >
<meta http-equiv="Content-Style-Type" content="text/css" >
</head>
<body text="#000000">
<font face="Monospace">
<font color="#808080"><i>/*<br>
&nbsp;*&nbsp;Licensed&nbsp;to&nbsp;the&nbsp;Apache&nbsp;Software&nbsp;Foundation&nbsp;(ASF)&nbsp;under&nbsp;one&nbsp;or&nbsp;more<br>
&nbsp;*&nbsp;contributor&nbsp;license&nbsp;agreements.&nbsp;&nbsp;See&nbsp;the&nbsp;NOTICE&nbsp;file&nbsp;distributed&nbsp;with<br>
&nbsp;*&nbsp;this&nbsp;work&nbsp;for&nbsp;additional&nbsp;information&nbsp;regarding&nbsp;copyright&nbsp;ownership.<br>
&nbsp;*&nbsp;The&nbsp;ASF&nbsp;licenses&nbsp;this&nbsp;file&nbsp;to&nbsp;You&nbsp;under&nbsp;the&nbsp;Apache&nbsp;License,&nbsp;Version&nbsp;2.0<br>
&nbsp;*&nbsp;(the&nbsp;&quot;License&quot;);&nbsp;you&nbsp;may&nbsp;not&nbsp;use&nbsp;this&nbsp;file&nbsp;except&nbsp;in&nbsp;compliance&nbsp;with<br>
&nbsp;*&nbsp;the&nbsp;License.&nbsp;&nbsp;You&nbsp;may&nbsp;obtain&nbsp;a&nbsp;copy&nbsp;of&nbsp;the&nbsp;License&nbsp;at<br>
&nbsp;*<br>
&nbsp;*&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;http://www.apache.org/licenses/LICENSE-2.0<br>
&nbsp;*<br>
&nbsp;*&nbsp;Unless&nbsp;required&nbsp;by&nbsp;applicable&nbsp;law&nbsp;or&nbsp;agreed&nbsp;to&nbsp;in&nbsp;writing,&nbsp;software<br>
&nbsp;*&nbsp;distributed&nbsp;under&nbsp;the&nbsp;License&nbsp;is&nbsp;distributed&nbsp;on&nbsp;an&nbsp;&quot;AS&nbsp;IS&quot;&nbsp;BASIS,<br>
&nbsp;*&nbsp;WITHOUT&nbsp;WARRANTIES&nbsp;OR&nbsp;CONDITIONS&nbsp;OF&nbsp;ANY&nbsp;KIND,&nbsp;either&nbsp;express&nbsp;or&nbsp;implied.<br>
&nbsp;*&nbsp;See&nbsp;the&nbsp;License&nbsp;for&nbsp;the&nbsp;specific&nbsp;language&nbsp;governing&nbsp;permissions&nbsp;and<br>
&nbsp;*&nbsp;limitations&nbsp;under&nbsp;the&nbsp;License.<br>
&nbsp;*/</i></font><br>
<br>
<font color="#008000">#include&nbsp;&lt;axis2_handler_desc.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axutil_array_list.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axiom_soap_const.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axiom_soap_envelope.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axiom_soap_header.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axiom_soap_header_block.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axis2_op.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axis2_msg_ctx.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axis2_conf_ctx.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axis2_msg_info_headers.h&gt;<br></font>
<font color="#008000">#include&nbsp;&lt;axutil_property.h&gt;<br></font>
<br>
<font color="#000000">axis2_status_t</font>&nbsp;<font color="#000000">AXIS2_CALL</font><br>
<font color="#000000">axutil_log_out_handler_invoke</font>(<font color="#000000"><b>struct</b></font>&nbsp;<font color="#000000">axis2_handler</font>&nbsp;*<font color="#000000">handler</font>,&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#800000">const</font>&nbsp;<font color="#000000">axutil_env_t</font>&nbsp;*<font color="#000000">env</font>,<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>struct</b></font>&nbsp;<font color="#000000">axis2_msg_ctx</font>&nbsp;*<font color="#000000">msg_ctx</font>);<br>
<br>
<font color="#000000">AXIS2_EXTERN</font>&nbsp;<font color="#000000">axis2_handler_t</font>*&nbsp;<font color="#000000">AXIS2_CALL</font><br>
<font color="#000000">axutil_log_out_handler_create</font>(<font color="#800000">const</font>&nbsp;<font color="#000000">axutil_env_t</font>&nbsp;*<font color="#000000">env</font>,&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">axutil_string_t</font>&nbsp;*<font color="#000000">name</font>)&nbsp;<br>
{<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">axis2_handler_t</font>&nbsp;*<font color="#000000">handler</font>&nbsp;=&nbsp;<font color="#000000">NULL</font>;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">AXIS2_ENV_CHECK</font>(<font color="#000000">env</font>,&nbsp;<font color="#000000">NULL</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">handler</font>&nbsp;=&nbsp;<font color="#000000">axis2_handler_create</font>(<font color="#000000">env</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>if</b></font>&nbsp;(!<font color="#000000">handler</font>)<br>
&nbsp;&nbsp;&nbsp;&nbsp;{<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>return</b></font>&nbsp;<font color="#000000">NULL</font>;<br>
&nbsp;&nbsp;&nbsp;&nbsp;}<br>
&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">axis2_handler_set_invoke</font>(<font color="#000000">handler</font>,&nbsp;<font color="#000000">env</font>,&nbsp;<font color="#000000">axutil_log_out_handler_invoke</font>);<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>return</b></font>&nbsp;<font color="#000000">handler</font>;<br>
}<br>
<br>
<br>
<font color="#000000">axis2_status_t</font>&nbsp;<font color="#000000">AXIS2_CALL</font><br>
<font color="#000000">axutil_log_out_handler_invoke</font>(<font color="#000000"><b>struct</b></font>&nbsp;<font color="#000000">axis2_handler</font>&nbsp;*<font color="#000000">handler</font>,&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#800000">const</font>&nbsp;<font color="#000000">axutil_env_t</font>&nbsp;*<font color="#000000">env</font>,<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>struct</b></font>&nbsp;<font color="#000000">axis2_msg_ctx</font>&nbsp;*<font color="#000000">msg_ctx</font>)<br>
{<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">axiom_soap_envelope_t</font>&nbsp;*<font color="#000000">soap_envelope</font>&nbsp;=&nbsp;<font color="#000000">NULL</font>;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">axiom_node_t</font>&nbsp;*<font color="#000000">ret_node</font>&nbsp;=&nbsp;<font color="#000000">NULL</font>;<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">AXIS2_ENV_CHECK</font>(&nbsp;<font color="#000000">env</font>,&nbsp;<font color="#000000">AXIS2_FAILURE</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">AXIS2_PARAM_CHECK</font>(<font color="#000000">env</font>-&gt;<font color="#000000">error</font>,&nbsp;<font color="#000000">msg_ctx</font>,&nbsp;<font color="#000000">AXIS2_FAILURE</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">AXIS2_LOG_INFO</font>(<font color="#000000">env</font>-&gt;<font color="#000000">log</font>,&nbsp;<font color="#FF0000">&quot;Starting&nbsp;logging&nbsp;out&nbsp;handler&nbsp;.........&quot;</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">soap_envelope</font>&nbsp;=&nbsp;&nbsp;<font color="#000000">axis2_msg_ctx_get_soap_envelope</font>(<font color="#000000">msg_ctx</font>,&nbsp;<font color="#000000">env</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>if</b></font>&nbsp;(<font color="#000000">soap_envelope</font>)<br>
&nbsp;&nbsp;&nbsp;&nbsp;{<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">ret_node</font>&nbsp;=&nbsp;<font color="#000000">axiom_soap_envelope_get_base_node</font>(<font color="#000000">soap_envelope</font>,&nbsp;<font color="#000000">env</font>);<br>
<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>if</b></font>(<font color="#000000">ret_node</font>)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">axis2_char_t</font>&nbsp;*<font color="#000000">om_str</font>&nbsp;=&nbsp;<font color="#000000">NULL</font>;<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">om_str</font>&nbsp;=&nbsp;<font color="#000000">axiom_node_to_string</font>(<font color="#000000">ret_node</font>,&nbsp;<font color="#000000">env</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>if</b></font>(<font color="#000000">om_str</font>)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000">AXIS2_LOG_INFO</font>(<font color="#000000">env</font>-&gt;<font color="#000000">log</font>,&nbsp;<font color="#FF0000">&quot;Output&nbsp;message:&nbsp;%s&quot;</font>,&nbsp;<font color="#000000">om_str</font>);<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}<br>
&nbsp;&nbsp;&nbsp;&nbsp;}<br>
&nbsp;&nbsp;&nbsp;&nbsp;<br>
&nbsp;&nbsp;&nbsp;&nbsp;<font color="#000000"><b>return</b></font>&nbsp;<font color="#000000">AXIS2_SUCCESS</font>;<br>
}<br>
<br>
<br>
</font>
</body>
</html>