| /* |
| * 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 <axis2_soap12_builder_helper.h> |
| #include <axis2_array_list.h> |
| #include <axis2_soap_body.h> |
| #include <axis2_soap_fault.h> |
| #include <axis2_soap_envelope.h> |
| #include <axis2_soap_message.h> |
| #include <axis2_soap_fault_code.h> |
| #include <axis2_soap_fault_node.h> |
| #include <axis2_soap_fault_detail.h> |
| #include <axis2_soap_fault_reason.h> |
| #include <axis2_soap_fault_role.h> |
| #include <axis2_soap_fault_value.h> |
| #include <axis2_soap_fault_text.h> |
| |
| /********************* impl struct ********************************************/ |
| |
| typedef struct axis2_soap12_builder_helper_impl_t |
| { |
| axis2_soap12_builder_helper_t builder_helper; |
| |
| axis2_soap_builder_t *soap_builder; |
| |
| axis2_bool_t code_present; |
| |
| axis2_bool_t reason_present; |
| |
| axis2_bool_t node_present; |
| |
| axis2_bool_t role_present; |
| |
| axis2_bool_t detail_present; |
| |
| axis2_bool_t subcode_value_present; |
| |
| axis2_bool_t value_present; |
| |
| axis2_bool_t sub_code_present; |
| |
| axis2_bool_t sub_sub_code_present; |
| |
| axis2_bool_t code_processing; |
| |
| axis2_bool_t sub_code_processing; |
| |
| axis2_bool_t reason_processing; |
| |
| axis2_array_list_t *detail_element_names; |
| |
| |
| }axis2_soap12_builder_helper_impl_t; |
| |
| /******************** Macro ***************************************************/ |
| |
| #define AXIS2_INTF_TO_IMPL(builder_helper) ((axis2_soap12_builder_helper_impl_t*)builder_helper) |
| |
| /******************** function prototypes *************************************/ |
| |
| axis2_status_t AXIS2_CALL |
| axis2_soap12_builder_helper_free(axis2_soap12_builder_helper_t *builder_helper, |
| axis2_env_t **env); |
| |
| axis2_status_t AXIS2_CALL |
| axis2_soap12_builder_helper_handle_event |
| (axis2_soap12_builder_helper_t *builder_helper, |
| axis2_env_t **env, |
| axis2_om_node_t *om_element_node, |
| int element_level); |
| |
| /******************** function implementations ********************************/ |
| |
| AXIS2_DECLARE(axis2_soap12_builder_helper_t*) |
| axis2_soap12_builder_helper_create(axis2_env_t **env, |
| axis2_soap_builder_t *soap_builder) |
| { |
| axis2_soap12_builder_helper_impl_t *builder_helper_impl = NULL; |
| AXIS2_ENV_CHECK(env, NULL); |
| AXIS2_PARAM_CHECK((*env)->error, soap_builder, NULL); |
| |
| builder_helper_impl = (axis2_soap12_builder_helper_impl_t*)AXIS2_MALLOC( |
| (*env)->allocator, sizeof(axis2_soap12_builder_helper_impl_t)); |
| if(!builder_helper_impl) |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| return NULL; |
| } |
| |
| builder_helper_impl->code_present = AXIS2_FALSE; |
| builder_helper_impl->detail_present = AXIS2_FALSE; |
| builder_helper_impl->reason_present = AXIS2_FALSE; |
| builder_helper_impl->role_present = AXIS2_FALSE; |
| builder_helper_impl->sub_code_present = AXIS2_FALSE; |
| builder_helper_impl->reason_processing = AXIS2_FALSE; |
| builder_helper_impl->code_processing = AXIS2_FALSE; |
| builder_helper_impl->sub_code_processing = AXIS2_FALSE; |
| builder_helper_impl->detail_element_names = NULL; |
| builder_helper_impl->node_present = AXIS2_FALSE; |
| builder_helper_impl->soap_builder = soap_builder; |
| builder_helper_impl->sub_sub_code_present = AXIS2_FALSE; |
| builder_helper_impl->value_present = AXIS2_FALSE; |
| builder_helper_impl->subcode_value_present = AXIS2_FALSE; |
| builder_helper_impl->builder_helper.ops = NULL; |
| builder_helper_impl->builder_helper.ops = (axis2_soap12_builder_helper_ops_t*) AXIS2_MALLOC( |
| (*env)->allocator, sizeof(axis2_soap12_builder_helper_ops_t)); |
| if(!(builder_helper_impl->builder_helper.ops)) |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_FREE((*env)->allocator, builder_helper_impl); |
| return NULL; |
| } |
| |
| builder_helper_impl->builder_helper.ops->free_fn = |
| axis2_soap12_builder_helper_free; |
| builder_helper_impl->builder_helper.ops->handle_event = |
| axis2_soap12_builder_helper_handle_event; |
| |
| return &(builder_helper_impl->builder_helper); |
| } |
| |
| axis2_status_t AXIS2_CALL |
| axis2_soap12_builder_helper_free(axis2_soap12_builder_helper_t *builder_helper, |
| axis2_env_t **env) |
| { |
| axis2_soap12_builder_helper_impl_t *builder_helper_impl = NULL; |
| AXIS2_ENV_CHECK(env, AXIS2_FAILURE); |
| builder_helper_impl = AXIS2_INTF_TO_IMPL(builder_helper); |
| |
| if(builder_helper_impl->detail_element_names) |
| { |
| AXIS2_ARRAY_LIST_FREE(builder_helper_impl->detail_element_names, env); |
| builder_helper_impl->detail_element_names = NULL; |
| } |
| if(builder_helper_impl->builder_helper.ops) |
| { |
| AXIS2_FREE((*env)->allocator, builder_helper_impl->builder_helper.ops); |
| builder_helper_impl->builder_helper.ops = NULL; |
| } |
| |
| AXIS2_FREE((*env)->allocator, builder_helper_impl); |
| builder_helper_impl = NULL; |
| return AXIS2_SUCCESS; |
| } |
| |
| axis2_status_t AXIS2_CALL |
| axis2_soap12_builder_helper_handle_event (axis2_soap12_builder_helper_t *builder_helper, |
| axis2_env_t **env, |
| axis2_om_node_t *om_ele_node, |
| int element_level) |
| { |
| axis2_soap12_builder_helper_impl_t *builder_helper_impl = NULL; |
| axis2_char_t* ele_localname = NULL; |
| axis2_om_element_t *om_ele = NULL; |
| axis2_soap_body_t *soap_body = NULL; |
| axis2_soap_fault_t *soap_fault = NULL; |
| axis2_soap_envelope_t *soap_envelope = NULL; |
| |
| AXIS2_ENV_CHECK(env, AXIS2_FAILURE); |
| AXIS2_PARAM_CHECK((*env)->error, om_ele_node, AXIS2_FAILURE); |
| |
| builder_helper_impl = AXIS2_INTF_TO_IMPL(builder_helper); |
| om_ele = (axis2_om_element_t *)AXIS2_OM_NODE_GET_DATA_ELEMENT(om_ele_node, env); |
| ele_localname = AXIS2_OM_ELEMENT_GET_LOCALNAME(om_ele, env); |
| soap_envelope = AXIS2_SOAP_BUILDER_GET_SOAP_ENVELOPE(builder_helper_impl->soap_builder, env); |
| soap_body = AXIS2_SOAP_ENVELOPE_GET_BODY(soap_envelope, env); |
| soap_fault = AXIS2_SOAP_BODY_GET_FAULT(soap_body, env); |
| if(!soap_fault) |
| printf("soap fault null"); |
| if(element_level == 4) |
| { |
| if(AXIS2_STRCMP(AXIS2_SOAP12_SOAP_FAULT_CODE_LOCAL_NAME, ele_localname) == 0) |
| { |
| |
| if(builder_helper_impl->code_present) |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_MULTIPLE_CODE_ELEMENTS_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_CODE_ELEMENTS_ENCOUNTERED", AXIS2_LOG_LEVEL_DEBUG); |
| |
| return AXIS2_FAILURE; |
| }else |
| { |
| axis2_soap_fault_code_t* soap_fault_code = NULL; |
| soap_fault_code = axis2_soap_fault_code_create(env); |
| AXIS2_SOAP_FAULT_CODE_SET_BASE_NODE(soap_fault_code , env, om_ele_node); |
| AXIS2_SOAP_FAULT_CODE_SET_SOAP_VERSION(soap_fault_code, env, AXIS2_SOAP12); |
| |
| AXIS2_SOAP_FAULT_CODE_SET_BUILDER(soap_fault_code, env, |
| builder_helper_impl->soap_builder); |
| AXIS2_SOAP_FAULT_SET_CODE(soap_fault, env, soap_fault_code); |
| builder_helper_impl->code_present = AXIS2_TRUE; |
| builder_helper_impl->code_processing = AXIS2_TRUE; |
| } |
| } |
| else if(AXIS2_STRCMP(AXIS2_SOAP12_SOAP_FAULT_REASON_LOCAL_NAME, ele_localname) == 0) |
| { |
| if(!(builder_helper_impl->code_processing) && !(builder_helper_impl->sub_code_processing)) |
| { |
| if(builder_helper_impl->code_present) |
| { |
| if(builder_helper_impl->reason_present) |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_MULTIPLE_REASON_ELEMENTS_ENCOUNTERED, AXIS2_FAILURE); |
| |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_REASON_ELEMENTS_ENCOUNTERED",AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| axis2_soap_fault_reason_t *fault_reason = NULL; |
| fault_reason = axis2_soap_fault_reason_create(env); |
| AXIS2_SOAP_FAULT_REASON_SET_BASE_NODE(fault_reason, env, om_ele_node); |
| AXIS2_SOAP_FAULT_SET_SOAP_VERSION(fault_reason, env, AXIS2_SOAP12); |
| AXIS2_SOAP_FAULT_SET_REASON(soap_fault, env, fault_reason); |
| AXIS2_SOAP_FAULT_REASON_SET_BUILDER(soap_fault, env, |
| builder_helper_impl->soap_builder); |
| |
| builder_helper_impl->reason_present = AXIS2_TRUE; |
| builder_helper_impl->reason_processing = AXIS2_TRUE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED",AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else |
| { |
| if(builder_helper_impl->code_processing) |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_SOAP_FAULT_CODE_DOES_NOT_HAVE_A_VALUE, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_SOAP_FAULT_CODE_DOES_NOT_HAVE_A_VALUE",AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_SOAP_FAULT_CODE_DOES_NOT_HAVE_A_VALUE, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_SOAP_FAULT_CODE_DOES_NOT_HAVE_A_VALUE", AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| } |
| else if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_NODE_LOCAL_NAME) == 0) |
| { |
| if(!(builder_helper_impl->reason_processing)) |
| { |
| if(builder_helper_impl->reason_present && |
| !(builder_helper_impl->role_present) && |
| !(builder_helper_impl->detail_present)) |
| { |
| if(builder_helper_impl->node_present) |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_MULTIPLE_NODE_ELEMENTS_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_NODE_ELEMENTS_ENCOUNTERED",AXIS2_LOG_LEVEL_CRITICAL); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| axis2_soap_fault_node_t *soap_fault_node = NULL; |
| soap_fault_node = axis2_soap_fault_node_create(env); |
| |
| AXIS2_SOAP_FAULT_NODE_SET_BASE_NODE(soap_fault_node, env, om_ele_node); |
| AXIS2_SOAP_FAULT_NODE_SET_SOAP_VERSION(soap_fault_node, env, AXIS2_SOAP12); |
| AXIS2_SOAP_FAULT_SET_NODE(soap_fault, env, soap_fault_node); |
| builder_helper_impl->node_present = AXIS2_TRUE; |
| } |
| }else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED, AXIS2_FALSE); |
| |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED",AXIS2_LOG_LEVEL_CRITICAL); |
| |
| return AXIS2_FAILURE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_SOAP_FAULT_REASON_ELEMENT_SHOULD_HAVE_A_TEXT, AXIS2_FALSE); |
| return AXIS2_FAILURE; |
| } |
| |
| } |
| else if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_ROLE_LOCAL_NAME) == 0) |
| { |
| if(!(builder_helper_impl->reason_processing)) |
| { |
| if(builder_helper_impl->reason_present && !(builder_helper_impl->detail_present)) |
| { |
| if(builder_helper_impl->role_present) |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_MULTIPLE_ROLE_ELEMENTS_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_MULTIPLE_ROLE_ELEMENTS_ENCOUNTERED", AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| axis2_soap_fault_role_t *soap_fault_role = NULL; |
| soap_fault_role = axis2_soap_fault_role_create(env); |
| AXIS2_SOAP_FAULT_ROLE_SET_BASE_NODE(soap_fault_role, env, om_ele_node); |
| AXIS2_SOAP_FAULT_ROLE_SET_SOAP_VRESION(soap_fault_role, env, AXIS2_SOAP12); |
| AXIS2_SOAP_FAULT_SET_ROLE(soap_fault, env, soap_fault_role); |
| builder_helper_impl->role_present = AXIS2_TRUE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else |
| { |
| |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_SOAP_FAULT_ROLE_ELEMENT_SHOULD_HAVE_A_TEXT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_SOAP_FAULT_ROLE_ELEMENT_SHOULD_HAVE_A_TEXT", AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_DETAIL_LOCAL_NAME) == 0) |
| { |
| if(!(builder_helper_impl->reason_processing)) |
| { |
| if(builder_helper_impl->reason_present) |
| { |
| if(builder_helper_impl->detail_present) |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_MULTIPLE_DETAIL_ELEMENTS_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_DETAIL_ELEMENTS_ENCOUNTERED", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| |
| axis2_soap_fault_detail_t *soap_fault_detail = NULL; |
| soap_fault_detail = axis2_soap_fault_detail_create(env); |
| AXIS2_SOAP_FAULT_DETAIL_SET_BASE_NODE(soap_fault_detail, env, om_ele_node); |
| AXIS2_SOAP_FAULT_SET_SOAP_VERSION(soap_fault_detail, env, AXIS2_SOAP12); |
| AXIS2_SOAP_FAULT_SET_DETAIL(soap_fault, env, soap_fault_detail); |
| builder_helper_impl->detail_present = AXIS2_TRUE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_WRONG_ELEMENT_ORDER_ENCOUNTERED", |
| AXIS2_LOG_LEVEL_DEBUG); |
| |
| return AXIS2_FAILURE; |
| |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_SOAP_FAULT_REASON_ELEMENT_SHOULD_HAVE_A_TEXT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_SOAP_FAULT_REASON_ELEMENT_SHOULD_HAVE_A_TEXT", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_UNSUPPORTED_ELEMENT_IN_SOAP_FAULT_ELEMENT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_UNSUPPORTED_ELEMENT_IN_SOAP_FAULT_ELEMENT", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else if(element_level == 5) |
| { |
| axis2_om_node_t *parent_node = NULL; |
| axis2_om_element_t *parent_ele = NULL; |
| axis2_char_t *parent_localname = NULL; |
| parent_node = AXIS2_OM_NODE_GET_PARENT(om_ele_node, env); |
| parent_ele = (axis2_om_element_t *)AXIS2_OM_NODE_GET_DATA_ELEMENT(parent_node, env); |
| parent_localname = AXIS2_OM_ELEMENT_GET_LOCALNAME(parent_ele, env); |
| if(AXIS2_STRCMP(parent_localname, |
| AXIS2_SOAP12_SOAP_FAULT_CODE_LOCAL_NAME) == 0) |
| { |
| if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_VALUE_LOCAL_NAME) == 0) |
| { |
| if(!(builder_helper_impl->value_present)) |
| { |
| axis2_soap_fault_value_t *soap_fault_value = NULL; |
| axis2_soap_fault_code_t *parent_fcode = NULL; |
| soap_fault_value = axis2_soap_fault_value_create(env); |
| AXIS2_SOAP_FAULT_VALUE_SET_BASE_NODE(soap_fault_value, env, om_ele_node); |
| AXIS2_SOAP_FAULT_VALUE_SET_SOAP_VERSION(soap_fault_value, env, AXIS2_SOAP12); |
| parent_fcode = AXIS2_SOAP_FAULT_GET_CODE(soap_fault, env); |
| AXIS2_SOAP_FAULT_CODE_SET_VALUE(parent_fcode, env, soap_fault_value); |
| |
| builder_helper_impl->value_present = AXIS2_TRUE; |
| builder_helper_impl->code_processing = AXIS2_FALSE; |
| |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_MULTIPLE_VALUE_ENCOUNTERED_IN_CODE_ELEMENT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_VALUE_ENCOUNTERED_IN_CODE_ELEMENT", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else if(AXIS2_STRCMP(ele_localname, |
| AXIS2_SOAP12_SOAP_FAULT_SUB_CODE_LOCAL_NAME) == 0) |
| { |
| if(!(builder_helper_impl->sub_code_present)) |
| { |
| if(builder_helper_impl->value_present) |
| { |
| |
| axis2_soap_fault_sub_code_t *fault_subcode = NULL; |
| axis2_soap_fault_code_t *fault_code = NULL; |
| fault_subcode = axis2_soap_fault_sub_code_create(env); |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_BASE_NODE(fault_subcode, env, om_ele_node); |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_SOAP_VRESION(fault_subcode, env, AXIS2_SOAP12); |
| fault_code = AXIS2_SOAP_FAULT_GET_CODE(soap_fault, env); |
| AXIS2_SOAP_FAULT_CODE_SET_SUB_CODE(fault_code, env, fault_subcode); |
| |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_BUILDER(fault_subcode, env, |
| builder_helper_impl->soap_builder); |
| |
| builder_helper_impl->sub_code_present = AXIS2_TRUE; |
| builder_helper_impl->sub_code_processing = AXIS2_TRUE; |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_SOAP_FAULT_VALUE_SHOULD_BE_PRESENT_BEFORE_SUB_CODE, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_SOAP_FAULT_VALUE_SHOULD_BE_PRESENT_BEFORE_SUB_CODE", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_MULTIPLE_SUB_CODE_VALUES_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_SUB_CODE_VALUES_ENCOUNTERED", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, |
| AXIS2_ERROR_THIS_LOCALNAME_NOT_SUPPORTED_INSIDE_THE_CODE_ELEMENT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_THIS_LOCALNAME_NOT_SUPPORTED_INSIDE_THE_CODE_ELEMENT", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else if(AXIS2_STRCMP(parent_localname, AXIS2_SOAP12_SOAP_FAULT_REASON_LOCAL_NAME) == 0) |
| { |
| if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_TEXT_LOCAL_NAME) == 0) |
| { |
| axis2_soap_fault_text_t *soap_fault_text = NULL; |
| axis2_soap_fault_reason_t *fault_reason = NULL; |
| soap_fault_text = axis2_soap_fault_text_create(env); |
| AXIS2_SOAP_FAULT_TEXT_SET_BASE_NODE(soap_fault_text, env, om_ele_node); |
| AXIS2_SOAP_FAULT_TEXT_SET_SOAP_VERSION(soap_fault_text, env, AXIS2_SOAP12); |
| fault_reason = AXIS2_SOAP_FAULT_GET_REASON(soap_fault, env); |
| AXIS2_SOAP_FAULT_REASON_SET_SOAP_TEXT(fault_reason, env, soap_fault_text); |
| /***************** |
| AXIS2_OM_NODE_SET_BUILD_STATUS(om_ele_node, env, AXIS2_FALSE); |
| ******************/ |
| builder_helper_impl->reason_processing = AXIS2_FALSE; |
| AXIS2_SOAP_BUILDER_SET_BOOL_PROCESSING_MANDATORY_FAULT_ELEMENTS(builder_helper_impl->soap_builder, env, AXIS2_FALSE ); |
| |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_THIS_LOCALNAME_IS_NOT_SUPPORTED_INSIDE_THE_REASON_ELEMENT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_THIS_LOCALNAME_IS_NOT_SUPPORTED_INSIDE_THE_REASON_ELEMENT", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| |
| }else if(AXIS2_STRCMP(parent_localname, AXIS2_SOAP12_SOAP_FAULT_DETAIL_LOCAL_NAME) == 0) |
| { |
| AXIS2_SOAP_BUILDER_SET_PROCESSING_DETAIL_ELEMENTS(builder_helper_impl->soap_builder, env, AXIS2_TRUE); |
| if(!(builder_helper_impl->detail_element_names)) |
| { |
| builder_helper_impl->detail_element_names = axis2_array_list_create(env, 20); |
| } |
| |
| AXIS2_ARRAY_LIST_ADD(builder_helper_impl->detail_element_names, env, ele_localname); |
| |
| } |
| else |
| { |
| axis2_char_t error_msg[200]; |
| sprintf(error_msg,"%s should not nave a child element",parent_localname); |
| AXIS2_LOG_WRITE((*env)->log, error_msg, AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| |
| }else if(element_level > 5) |
| { |
| axis2_om_node_t *parent_node = NULL; |
| axis2_om_element_t *parent_ele = NULL; |
| axis2_char_t *parent_localname = NULL; |
| parent_node = AXIS2_OM_NODE_GET_PARENT(om_ele_node, env); |
| parent_ele = (axis2_om_element_t *)AXIS2_OM_NODE_GET_DATA_ELEMENT(parent_node, env); |
| parent_localname = AXIS2_OM_ELEMENT_GET_LOCALNAME(parent_ele, env); |
| |
| if(AXIS2_STRCMP(parent_localname, AXIS2_SOAP12_SOAP_FAULT_SUB_CODE_LOCAL_NAME) == 0) |
| { |
| if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_VALUE_LOCAL_NAME) == 0) |
| { |
| if(builder_helper_impl->subcode_value_present) |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_MULTIPLE_SUB_CODE_VALUES_ENCOUNTERED, AXIS2_FAILURE); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| |
| axis2_soap_fault_sub_code_t *sub_code = NULL; |
| axis2_soap_fault_code_t *code = NULL; |
| axis2_soap_fault_value_t *value = NULL; |
| code = AXIS2_SOAP_FAULT_GET_CODE(soap_fault, env); |
| sub_code = AXIS2_SOAP_FAULT_CODE_GET_SUB_CODE(code, env); |
| value = axis2_soap_fault_value_create(env); |
| AXIS2_SOAP_FAULT_VALUE_SET_BASE_NODE(value, env, om_ele_node); |
| AXIS2_SOAP_FAULT_VALUE_SET_SOAP_VERSION(value, env, AXIS2_SOAP12); |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_VALUE(sub_code, env, value); |
| |
| builder_helper_impl->subcode_value_present = AXIS2_TRUE; |
| builder_helper_impl->sub_sub_code_present = AXIS2_FALSE; |
| builder_helper_impl->sub_code_processing = AXIS2_FALSE; |
| } |
| } |
| else if(AXIS2_STRCMP(ele_localname, AXIS2_SOAP12_SOAP_FAULT_SUB_CODE_LOCAL_NAME) == 0) |
| { |
| if(builder_helper_impl->subcode_value_present) |
| { |
| if(!(builder_helper_impl->sub_sub_code_present)) |
| { |
| axis2_soap_fault_code_t *fault_code = NULL; |
| axis2_soap_fault_sub_code_t *parent_subcode = NULL; |
| axis2_soap_fault_sub_code_t *subcode = NULL; |
| subcode = axis2_soap_fault_sub_code_create(env); |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_BASE_NODE(subcode, env, om_ele_node); |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_SOAP_VRESION(subcode, env, AXIS2_SOAP12); |
| fault_code = AXIS2_SOAP_FAULT_GET_CODE(soap_fault, env); |
| parent_subcode = AXIS2_SOAP_FAULT_CODE_GET_SUB_CODE(fault_code, env); |
| AXIS2_SOAP_FAULT_SUB_CODE_SET_SUB_CODE(parent_subcode, env, subcode); |
| builder_helper_impl->subcode_value_present = AXIS2_FALSE; |
| builder_helper_impl->sub_sub_code_present = AXIS2_TRUE; |
| builder_helper_impl->sub_code_processing = AXIS2_TRUE; |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_MULTIPLE_SUB_CODE_VALUES_ENCOUNTERED, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_MULTIPLE_SUB_CODE_VALUES_ENCOUNTERED", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_SOAP_FAULT_VALUE_SHOULD_BE_PRESENT_BEFORE_SUB_CODE, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log,"AXIS2_ERROR_SOAP_FAULT_VALUE_SHOULD_BE_PRESENT_BEFORE_SUB_CODE", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| |
| } |
| } |
| else |
| { |
| AXIS2_ERROR_SET((*env)->error, AXIS2_ERROR_THIS_LOCALNAME_IS_NOT_SUPPORTED_INSIDE_THE_SUB_CODE_ELEMENT, AXIS2_FAILURE); |
| AXIS2_LOG_WRITE((*env)->log, "AXIS2_ERROR_THIS_LOCALNAME_IS_NOT_SUPPORTED_INSIDE_THE_SUB_CODE_ELEMENT", |
| AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| else if(AXIS2_SOAP_BUILDER_IS_PROCESSING_DETAIL_ELEMENTS(builder_helper_impl->soap_builder, env)) |
| { |
| |
| int detail_element_level = 0; |
| axis2_bool_t local_name_exists = AXIS2_FALSE; |
| int i = 0; |
| for(i =0; i < AXIS2_ARRAY_LIST_SIZE(builder_helper_impl->detail_element_names, env) ; i++) |
| { |
| if(AXIS2_STRCMP(parent_localname, AXIS2_ARRAY_LIST_GET(builder_helper_impl->detail_element_names, env, i)) == 0) |
| { |
| local_name_exists = AXIS2_TRUE; |
| detail_element_level = i+ 1; |
| } |
| } |
| if(local_name_exists) |
| { |
| AXIS2_ARRAY_LIST_ADD(builder_helper_impl->detail_element_names, env, ele_localname); |
| |
| } |
| else |
| { |
| axis2_char_t error_msg[200]; |
| sprintf(error_msg,"%s should not have child at element level %d",parent_localname, element_level); |
| AXIS2_LOG_WRITE((*env)->log,error_msg, AXIS2_LOG_LEVEL_DEBUG); |
| return AXIS2_FAILURE; |
| } |
| } |
| } |
| return AXIS2_SUCCESS; |
| } |