| /* |
| * 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 <axis2_desc_builder.h> |
| #include <axutil_string.h> |
| #include <axutil_class_loader.h> |
| #include <axutil_utils.h> |
| #include <axutil_generic_obj.h> |
| #include <axis2_raw_xml_in_out_msg_recv.h> |
| #include <neethi_engine.h> |
| |
| struct axis2_desc_builder |
| { |
| /** |
| * Store the full path to configuration file. |
| */ |
| axis2_char_t *file_name; |
| axiom_node_t *root; |
| struct axis2_dep_engine *engine; |
| }; |
| |
| static axis2_status_t |
| set_attrs_and_value( |
| axutil_param_t * param, |
| const axutil_env_t * env, |
| axiom_element_t * param_element, |
| axiom_node_t * param_node); |
| |
| AXIS2_EXTERN axis2_desc_builder_t *AXIS2_CALL |
| axis2_desc_builder_create( |
| const axutil_env_t * env) |
| { |
| axis2_desc_builder_t *desc_builder = NULL; |
| |
| desc_builder = (axis2_desc_builder_t *)AXIS2_MALLOC(env-> allocator, |
| sizeof(axis2_desc_builder_t)); |
| |
| if(!desc_builder) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "No memory. Cannot allocate memory to desc_builder"); |
| return NULL; |
| } |
| desc_builder->file_name = NULL; |
| desc_builder->engine = NULL; |
| desc_builder->root = NULL; |
| |
| return desc_builder; |
| } |
| |
| AXIS2_EXTERN axis2_desc_builder_t *AXIS2_CALL |
| axis2_desc_builder_create_with_file_and_dep_engine( |
| const axutil_env_t * env, |
| axis2_char_t * file_name, |
| axis2_dep_engine_t * engine) |
| { |
| axis2_desc_builder_t *desc_builder = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, file_name, NULL); |
| AXIS2_PARAM_CHECK(env->error, engine, NULL); |
| |
| desc_builder = (axis2_desc_builder_t *)axis2_desc_builder_create(env); |
| if(!desc_builder) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "No memory. Cannot allocate memory to desc_builder"); |
| return NULL; |
| } |
| |
| desc_builder->root = NULL; |
| |
| desc_builder->file_name = axutil_strdup(env, file_name); |
| if(!desc_builder->file_name) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "No memory. Cannot allocate memory to desc_builder->file_name"); |
| return NULL; |
| } |
| desc_builder->engine = engine; |
| |
| return desc_builder; |
| } |
| |
| AXIS2_EXTERN axis2_desc_builder_t *AXIS2_CALL |
| axis2_desc_builder_create_with_dep_engine( |
| const axutil_env_t * env, |
| struct axis2_dep_engine * engine) |
| { |
| axis2_desc_builder_t *desc_builder = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, engine, NULL); |
| |
| desc_builder = (axis2_desc_builder_t *)axis2_desc_builder_create(env); |
| if(!desc_builder) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "No memory. Cannot allocate memory to desc_builder"); |
| return NULL; |
| } |
| |
| desc_builder->engine = engine; |
| |
| return desc_builder; |
| } |
| |
| AXIS2_EXTERN void AXIS2_CALL |
| axis2_desc_builder_free( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env) |
| { |
| if(desc_builder->file_name) |
| { |
| AXIS2_FREE(env->allocator, desc_builder->file_name); |
| } |
| |
| if(desc_builder->root) |
| { |
| axiom_node_free_tree(desc_builder->root, env); |
| } |
| |
| /* we cannot free deployment engine here */ |
| desc_builder->engine = NULL; |
| |
| if(desc_builder) |
| { |
| AXIS2_FREE(env->allocator, desc_builder); |
| } |
| return; |
| } |
| |
| AXIS2_EXTERN axiom_node_t *AXIS2_CALL |
| axis2_desc_builder_build_om( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env) |
| { |
| axiom_xml_reader_t *reader = NULL; |
| axiom_document_t *document = NULL; |
| axiom_stax_builder_t *builder = NULL; |
| |
| if(!desc_builder->file_name) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_INVALID_STATE_DESC_BUILDER, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Invalid state desc builder. Unable to continue"); |
| return NULL; |
| } |
| |
| /** create pull parser using the file path to configuration file */ |
| reader = axiom_xml_reader_create_for_file(env, desc_builder->file_name, NULL); |
| |
| if(!reader) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_CREATING_XML_STREAM_READER, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Could not create xml reader for %s", |
| desc_builder->file_name); |
| return NULL; |
| }; |
| |
| /** create axiom_stax_builder by parsing pull_parser struct */ |
| builder = axiom_stax_builder_create(env, reader); |
| |
| if(!(builder)) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_CREATING_XML_STREAM_READER, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Could not create xml stream reader for desc builder %s. Unable " |
| "to continue", desc_builder->file_name); |
| return NULL; |
| } |
| |
| /** |
| get the om document form builder |
| document is the container of om model created using builder |
| */ |
| document = axiom_stax_builder_get_document(builder, env); |
| |
| /** |
| get root element , building starts hear |
| */ |
| |
| desc_builder->root = axiom_document_get_root_element(document, env); |
| /** |
| * In description building we don't want defferred building. So build |
| * the whole tree at once |
| */ |
| axiom_document_build_all(document, env); |
| |
| /** |
| We have built the whole document. So no need of keeping the builder. |
| */ |
| axiom_stax_builder_free_self(builder, env); |
| |
| return desc_builder->root; |
| } |
| |
| AXIS2_EXTERN axis2_flow_t *AXIS2_CALL |
| axis2_desc_builder_process_flow( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axiom_element_t * flow_element, |
| axutil_param_container_t * parent, |
| axiom_node_t * flow_node) |
| { |
| axis2_flow_t *flow = NULL; |
| axiom_children_qname_iterator_t *handlers = NULL; |
| axutil_qname_t *qchild = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, parent, NULL); |
| AXIS2_PARAM_CHECK(env->error, flow_node, NULL); |
| |
| flow = axis2_flow_create(env); |
| if(!flow) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "No memory. Could not allocate to flow"); |
| return NULL; |
| } |
| |
| if(!flow_element) |
| { |
| AXIS2_LOG_DEBUG(env->log, AXIS2_LOG_SI, "There is no flow element to process"); |
| return NULL; |
| } |
| |
| qchild = axutil_qname_create(env, AXIS2_HANDLERST, NULL, NULL); |
| handlers = axiom_element_get_children_with_qname(flow_element, env, qchild, flow_node); |
| if(qchild) |
| { |
| axutil_qname_free(qchild, env); |
| } |
| |
| while(axiom_children_qname_iterator_has_next(handlers, env)) |
| { |
| axiom_node_t *handler_node = NULL; |
| axis2_handler_desc_t *handler_desc = NULL; |
| axis2_status_t status = AXIS2_FAILURE; |
| |
| handler_node = (axiom_node_t *)axiom_children_qname_iterator_next(handlers, env); |
| |
| handler_desc = axis2_desc_builder_process_handler(desc_builder, env, handler_node, parent); |
| status = axis2_flow_add_handler(flow, env, handler_desc); |
| if(!status) |
| { |
| const axutil_string_t *handler_name = NULL; |
| const axis2_char_t *hname = NULL; |
| handler_name = axis2_handler_desc_get_name(handler_desc, env); |
| hname = axutil_string_get_buffer(handler_name, env); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Adding handler %s to flow failed", hname); |
| axis2_flow_free(flow, env); |
| return NULL; |
| } |
| } |
| return flow; |
| } |
| |
| struct axis2_handler_desc *AXIS2_CALL |
| axis2_desc_builder_process_handler( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axiom_node_t * handler_node, |
| struct axutil_param_container *parent) |
| { |
| axis2_handler_desc_t *handler_desc = NULL; |
| axiom_attribute_t *name_attrib = NULL; |
| axutil_qname_t *attr_qname = NULL; |
| axiom_attribute_t *class_attrib = NULL; |
| axutil_qname_t *class_qname = NULL; |
| axis2_status_t status = AXIS2_FAILURE; |
| axis2_char_t *attrib_value = NULL; |
| axiom_element_t *handler_element = NULL; |
| axiom_node_t *order_node = NULL; |
| axiom_element_t *order_element = NULL; |
| axutil_qname_t *order_qname = NULL; |
| axutil_string_t *handler_name = NULL; |
| const axis2_char_t *hname = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, handler_node, NULL); |
| AXIS2_PARAM_CHECK(env->error, parent, NULL); |
| |
| handler_desc = axis2_handler_desc_create(env, NULL); |
| if(!handler_desc) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Could not create handler description"); |
| return NULL; |
| } |
| /* Setting Handler name */ |
| attr_qname = axutil_qname_create(env, AXIS2_ATTNAME, NULL, NULL); |
| handler_element = axiom_node_get_data_element(handler_node, env); |
| name_attrib = axiom_element_get_attribute(handler_element, env, attr_qname); |
| if(attr_qname) |
| { |
| axutil_qname_free(attr_qname, env); |
| } |
| |
| if(!name_attrib) |
| { |
| axis2_handler_desc_free(handler_desc, env); |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_INVALID_HANDLER_STATE, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Name attribute not fould for handler."); |
| return NULL; |
| } |
| else |
| { |
| axis2_char_t *value = NULL; |
| |
| value = axiom_attribute_get_value(name_attrib, env); |
| handler_name = axutil_string_create(env, value); |
| status = axis2_handler_desc_set_name(handler_desc, env, handler_name); |
| if(handler_name) |
| { |
| axutil_string_free(handler_name, env); |
| } |
| |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Setting name for handler description failed in %s", desc_builder->file_name); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| } |
| hname = axutil_string_get_buffer(handler_name, env); |
| /*Setting Handler Class name */ |
| class_qname = axutil_qname_create(env, AXIS2_CLASSNAME, NULL, NULL); |
| class_attrib = axiom_element_get_attribute(handler_element, env, class_qname); |
| if(class_qname) |
| { |
| axutil_qname_free(class_qname, env); |
| } |
| |
| if(!class_attrib) |
| { |
| axis2_handler_desc_free(handler_desc, env); |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_INVALID_HANDLER_STATE, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Library name attribute not found for handler %s", |
| hname); |
| return NULL; |
| } |
| else |
| { |
| attrib_value = axiom_attribute_get_value(class_attrib, env); |
| status = axis2_handler_desc_set_class_name(handler_desc, env, attrib_value); |
| } |
| |
| /*processing phase Rules (order) */ |
| |
| order_qname = axutil_qname_create(env, AXIS2_ORDER, NULL, NULL); |
| order_element = axiom_element_get_first_child_with_qname(handler_element, env, order_qname, |
| handler_node, &order_node); |
| if(order_qname) |
| { |
| axutil_qname_free(order_qname, env); |
| } |
| |
| if(!order_element || !order_node) |
| { |
| axis2_handler_desc_free(handler_desc, env); |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_INVALID_HANDLER_STATE, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Order node not found for handler description %s", |
| hname); |
| return NULL; |
| } |
| else |
| { |
| axutil_hash_t *order_itr = NULL; |
| axiom_children_qname_iterator_t *params = NULL; |
| axutil_qname_t *param_qname = NULL; |
| axutil_hash_index_t *index_i = NULL; |
| |
| order_itr = axiom_element_get_all_attributes(order_element, env); |
| if(!order_itr) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Order element for handler desc %s does not contain any " |
| "attribute", hname); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| |
| index_i = axutil_hash_first(order_itr, env); |
| |
| while(index_i) |
| { |
| axiom_attribute_t *order_attrib = NULL; |
| axutil_qname_t *qname = NULL; |
| axis2_char_t *name = NULL; |
| axis2_char_t *value = NULL; |
| void *v = NULL; |
| |
| axutil_hash_this(index_i, NULL, NULL, &v); |
| order_attrib = (axiom_attribute_t *)v; |
| qname = axiom_attribute_get_qname(order_attrib, env); |
| name = axutil_qname_get_localpart(qname, env); |
| |
| value = axiom_attribute_get_value(order_attrib, env); |
| if(!axutil_strcmp(AXIS2_AFTER, name)) |
| { |
| struct axis2_phase_rule *phase_rule = NULL; |
| |
| phase_rule = axis2_handler_desc_get_rules(handler_desc, env); |
| status = axis2_phase_rule_set_after(phase_rule, env, value); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Setting %s phase rule failed for handler %s", AXIS2_AFTER, hname); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| } |
| if(!axutil_strcmp(AXIS2_BEFORE, name)) |
| { |
| struct axis2_phase_rule *phase_rule = NULL; |
| phase_rule = axis2_handler_desc_get_rules(handler_desc, env); |
| status = axis2_phase_rule_set_before(phase_rule, env, value); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Setting %s phase rule failed for handler %s", AXIS2_BEFORE, hname); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| } |
| if(!axutil_strcmp(AXIS2_PHASE, name)) |
| { |
| struct axis2_phase_rule *phase_rule = NULL; |
| phase_rule = axis2_handler_desc_get_rules(handler_desc, env); |
| status = axis2_phase_rule_set_name(phase_rule, env, value); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Setting phase rule name failed for handler %s", hname); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| } |
| if(!axutil_strcmp(AXIS2_PHASEFIRST, name)) |
| { |
| axis2_char_t *bool_val = NULL; |
| |
| bool_val = axis2_desc_builder_get_value(desc_builder, env, value); |
| if(!axutil_strcmp(bool_val, AXIS2_VALUE_TRUE)) |
| { |
| struct axis2_phase_rule *phase_rule = NULL; |
| phase_rule = axis2_handler_desc_get_rules(handler_desc, env); |
| status = axis2_phase_rule_set_first(phase_rule, env, AXIS2_TRUE); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Setting %s property for phase rules for handler " |
| "%s failed", AXIS2_PHASEFIRST, hname); |
| axis2_handler_desc_free(handler_desc, env); |
| AXIS2_FREE(env->allocator, bool_val); |
| return NULL; |
| } |
| } |
| else if(!axutil_strcmp(bool_val, AXIS2_VALUE_FALSE)) |
| { |
| struct axis2_phase_rule *phase_rule = NULL; |
| phase_rule = axis2_handler_desc_get_rules(handler_desc, env); |
| status = axis2_phase_rule_set_first(phase_rule, env, AXIS2_FALSE); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Setting %s property for phase rules for handler " |
| "%s failed", AXIS2_PHASEFIRST, hname); |
| axis2_handler_desc_free(handler_desc, env); |
| AXIS2_FREE(env->allocator, bool_val); |
| return NULL; |
| } |
| } |
| AXIS2_FREE(env->allocator, bool_val); |
| } |
| index_i = axutil_hash_next(env, index_i); |
| } |
| |
| param_qname = axutil_qname_create(env, AXIS2_PARAMETERST, NULL, NULL); |
| params = axiom_element_get_children_with_qname(handler_element, env, param_qname, |
| handler_node); |
| axutil_qname_free(param_qname, env); |
| status = axis2_desc_builder_process_params(desc_builder, env, params, |
| axis2_handler_desc_get_param_container(handler_desc, env), parent); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Processing params failed for handler %s", |
| hname); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| } |
| |
| status = axis2_handler_desc_set_parent(handler_desc, env, parent); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Setting parent failed for handler %s", hname); |
| axis2_handler_desc_free(handler_desc, env); |
| return NULL; |
| } |
| |
| return handler_desc; |
| } |
| |
| static axis2_status_t |
| set_attrs_and_value( |
| axutil_param_t * param, |
| const axutil_env_t * env, |
| axiom_element_t * param_element, |
| axiom_node_t * param_node) |
| { |
| axis2_status_t status = AXIS2_FAILURE; |
| axutil_hash_t *attrs = NULL; |
| axiom_child_element_iterator_t *childs = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, param, AXIS2_FAILURE); |
| AXIS2_PARAM_CHECK(env->error, param_element, AXIS2_FAILURE); |
| AXIS2_PARAM_CHECK(env->error, param_node, AXIS2_FAILURE); |
| |
| /* Setting attributes */ |
| attrs = axiom_element_extract_attributes(param_element, env, param_node); |
| if(attrs) |
| { |
| axutil_hash_index_t *i = NULL; |
| |
| for(i = axutil_hash_first(attrs, env); i; i = axutil_hash_next(env, i)) |
| { |
| void *v = NULL; |
| axiom_attribute_t *value = NULL; |
| axutil_generic_obj_t *obj = NULL; |
| axutil_qname_t *attr_qname = NULL; |
| axis2_char_t *attr_name = NULL; |
| |
| axutil_hash_this(i, NULL, NULL, &v); |
| if(!v) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Attibute missing in the parameter element"); |
| axutil_param_free(param, env); |
| return AXIS2_FAILURE; |
| } |
| obj = axutil_generic_obj_create(env); |
| if(!obj) |
| { |
| axutil_param_free(param, env); |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "No memory"); |
| return AXIS2_FAILURE; |
| } |
| value = (axiom_attribute_t *)v; |
| axutil_generic_obj_set_value(obj, env, value); |
| axutil_generic_obj_set_free_func(obj, env, axiom_attribute_free_void_arg); |
| attr_qname = axiom_attribute_get_qname(value, env); |
| attr_name = axutil_qname_to_string(attr_qname, env); |
| axutil_hash_set(attrs, attr_name, AXIS2_HASH_KEY_STRING, obj); |
| } |
| axutil_param_set_attributes(param, env, attrs); |
| } |
| |
| childs = axiom_element_get_child_elements(param_element, env, param_node); |
| if(childs) |
| { |
| axutil_array_list_t *value_list = NULL; |
| |
| value_list = axutil_array_list_create(env, 0); |
| axutil_param_set_value_list(param, env, value_list); |
| |
| while(AXIOM_CHILD_ELEMENT_ITERATOR_HAS_NEXT(childs, env)) |
| { |
| axiom_node_t *node = NULL; |
| axiom_element_t *element = NULL; |
| axutil_param_t *param = NULL; |
| axis2_char_t *pname = NULL; |
| |
| node = AXIOM_CHILD_ELEMENT_ITERATOR_NEXT(childs, env); |
| element = axiom_node_get_data_element(node, env); |
| param = axutil_param_create(env, NULL, NULL); |
| pname = axiom_element_get_localname(element, env); |
| status = axutil_param_set_name(param, env, pname); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Setting name to parameter failed"); |
| axutil_param_free(param, env); |
| return status; |
| } |
| axutil_param_set_param_type(param, env, AXIS2_DOM_PARAM); |
| set_attrs_and_value(param, env, element, node); |
| axutil_array_list_add(value_list, env, param); |
| } |
| } |
| else |
| { |
| axis2_char_t *para_test_value = NULL; |
| axis2_char_t *temp = NULL; |
| |
| temp = axiom_element_get_text(param_element, env, param_node); |
| para_test_value = axutil_strdup(env, temp); |
| status = axutil_param_set_value(param, env, para_test_value); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Setting value to parameter failed"); |
| axutil_param_free(param, env); |
| AXIS2_FREE(env->allocator, para_test_value); |
| return status; |
| } |
| axutil_param_set_param_type(param, env, AXIS2_TEXT_PARAM); |
| } |
| return AXIS2_SUCCESS; |
| } |
| |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_desc_builder_process_rest_params( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axiom_node_t * op_node, |
| axis2_op_t * op_desc) |
| { |
| axiom_element_t *op_element = NULL; |
| axutil_qname_t *qname = NULL; |
| axutil_qname_t *param_qname = NULL; |
| axiom_node_t *rest_node = NULL; |
| axiom_element_t *rest_element = NULL; |
| axiom_children_qname_iterator_t *rest_mappings = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, op_desc, AXIS2_FAILURE); |
| |
| op_element = axiom_node_get_data_element(op_node, env); |
| |
| param_qname = axutil_qname_create(env, AXIS2_PARAMETERST, NULL, NULL); |
| qname = axutil_qname_create(env, AXIS2_ATTNAME, NULL, NULL); |
| |
| if(op_element) |
| { |
| rest_mappings |
| = axiom_element_get_children_with_qname(op_element, env, param_qname, op_node); |
| } |
| |
| while(rest_mappings && axiom_children_qname_iterator_has_next(rest_mappings, env)) |
| { |
| axis2_char_t *param_value = NULL; |
| rest_node = (axiom_node_t *)axiom_children_qname_iterator_next(rest_mappings, env); |
| rest_element = axiom_node_get_data_element(rest_node, env); |
| param_value = axiom_element_get_attribute_value(rest_element, env, qname); |
| if(!strcmp(param_value, AXIS2_REST_HTTP_METHOD)) |
| { |
| axis2_op_set_rest_http_method(op_desc, env, axiom_element_get_text(rest_element, env, |
| rest_node)); |
| } |
| param_value = axiom_element_get_attribute_value(rest_element, env, qname); |
| if(!strcmp(param_value, AXIS2_REST_HTTP_LOCATION)) |
| { |
| axis2_op_set_rest_http_location(op_desc, env, axiom_element_get_text(rest_element, env, |
| rest_node)); |
| } |
| if(axis2_op_get_rest_http_method(op_desc, env) && axis2_op_get_rest_http_location(op_desc, |
| env)) |
| { |
| break; |
| } |
| } |
| |
| axutil_qname_free(qname, env); |
| axutil_qname_free(param_qname, env); |
| return AXIS2_SUCCESS; |
| } |
| |
| /** |
| * Populate the Axis2 Operation with details from the actionMapping, |
| * outputActionMapping and faultActionMapping elements from the operation |
| * element. |
| * |
| * @param operation |
| * @param op_desc |
| */ |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_desc_builder_process_action_mappings( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axiom_node_t * op_node, |
| axis2_op_t * op_desc) |
| { |
| axiom_element_t *op_element = NULL; |
| axutil_qname_t *qname = NULL; |
| axiom_children_qname_iterator_t *action_mappings = NULL; |
| axutil_array_list_t *mapping_list = axutil_array_list_create(env, 0); |
| AXIS2_PARAM_CHECK(env->error, op_desc, AXIS2_FAILURE); |
| |
| op_element = axiom_node_get_data_element(op_node, env); |
| qname = axutil_qname_create(env, AXIS2_ACTION_MAPPING, NULL, NULL); |
| if(op_element) |
| { |
| action_mappings = axiom_element_get_children_with_qname(op_element, env, qname, op_node); |
| } |
| |
| axutil_qname_free(qname, env); |
| qname = NULL; |
| if(!action_mappings) |
| { |
| if(mapping_list) |
| { |
| axutil_array_list_free(mapping_list, env); |
| mapping_list = NULL; |
| } |
| return AXIS2_SUCCESS; |
| } |
| while(axiom_children_qname_iterator_has_next(action_mappings, env)) |
| { |
| axiom_element_t *mapping_element = NULL; |
| axiom_node_t *mapping_node = NULL; |
| axis2_char_t *input_action_string = NULL; |
| axis2_char_t *temp_str = NULL; |
| |
| /* This is to check whether some one has locked the parmter at the top |
| * level |
| */ |
| mapping_node = (axiom_node_t *)axiom_children_qname_iterator_next(action_mappings, env); |
| mapping_element = axiom_node_get_data_element(mapping_node, env); |
| temp_str = axiom_element_get_text(mapping_element, env, mapping_node); |
| input_action_string = axutil_strtrim(env, temp_str, NULL); |
| AXIS2_LOG_DEBUG(env->log, AXIS2_LOG_SI, "Input action mapping found %s", |
| input_action_string); |
| if(axutil_strcmp("", input_action_string)) |
| { |
| axutil_array_list_add(mapping_list, env, input_action_string); |
| } |
| else |
| { |
| AXIS2_LOG_DEBUG(env->log, AXIS2_LOG_SI, "Zero length " |
| "input_action_string found. Not added to the mapping list"); |
| } |
| } |
| axis2_op_set_wsamapping_list(op_desc, env, mapping_list); |
| return AXIS2_SUCCESS; |
| } |
| |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_desc_builder_process_params( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axiom_children_qname_iterator_t * params, |
| axutil_param_container_t * param_container, |
| axutil_param_container_t * parent) |
| { |
| axis2_status_t status = AXIS2_FAILURE; |
| |
| AXIS2_PARAM_CHECK(env->error, params, AXIS2_FAILURE); |
| AXIS2_PARAM_CHECK(env->error, param_container, AXIS2_FAILURE); |
| |
| while(axiom_children_qname_iterator_has_next(params, env)) |
| { |
| axiom_element_t *param_element = NULL; |
| axiom_node_t *param_node = NULL; |
| axutil_param_t *param = NULL; |
| axutil_param_t *parent_para = NULL; |
| axiom_attribute_t *para_name = NULL; |
| axiom_attribute_t *para_locked = NULL; |
| axutil_qname_t *att_locked = NULL; |
| axutil_qname_t *att_qname = NULL; |
| axis2_char_t *pname = NULL; |
| |
| /* This is to check whether some one has locked the parmter at the top |
| * level |
| */ |
| param_node = (axiom_node_t *)axiom_children_qname_iterator_next(params, env); |
| param_element = axiom_node_get_data_element(param_node, env); |
| param = axutil_param_create(env, NULL, NULL); |
| |
| /* Setting paramter name */ |
| att_qname = axutil_qname_create(env, AXIS2_ATTNAME, NULL, NULL); |
| para_name = axiom_element_get_attribute(param_element, env, att_qname); |
| axutil_qname_free(att_qname, env); |
| if(!para_name) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Parameter name attribute not found for parameter"); |
| axutil_param_free(param, env); |
| return AXIS2_FAILURE; |
| } |
| pname = axiom_attribute_get_value(para_name, env); |
| status = axutil_param_set_name(param, env, pname); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Could not set parameter name for parameter"); |
| axutil_param_free(param, env); |
| return status; |
| } |
| |
| /* Setting paramter Value (the chiled elemnt of the paramter) */ |
| set_attrs_and_value(param, env, param_element, param_node); |
| |
| /* Setting locking attrib */ |
| att_locked = axutil_qname_create(env, AXIS2_ATTLOCKED, NULL, NULL); |
| para_locked = axiom_element_get_attribute(param_element, env, att_locked); |
| axutil_qname_free(att_locked, env); |
| if(parent) |
| { |
| axis2_char_t *param_name = NULL; |
| |
| param_name = axutil_param_get_name(param, env); |
| parent_para = axutil_param_container_get_param(parent, env, param_name); |
| } |
| if(para_locked) |
| { |
| axis2_char_t *locked_value = NULL; |
| locked_value = axiom_attribute_get_value(para_locked, env); |
| if(!axutil_strcmp(AXIS2_VALUE_TRUE, locked_value)) |
| { |
| axis2_char_t *param_name = NULL; |
| axis2_bool_t is_param_locked = AXIS2_FALSE; |
| /*if the parameter is locked at some level parameter value replace |
| * by that |
| */ |
| param_name = axutil_param_get_name(param, env); |
| is_param_locked = axutil_param_container_is_param_locked(parent, env, param_name); |
| if(parent && is_param_locked) |
| { |
| axutil_param_free(param, env); |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_CONFIG_NOT_FOUND, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Parameter %s is locked", param_name); |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| axutil_param_set_locked(param, env, AXIS2_TRUE); |
| } |
| } |
| else |
| { |
| axutil_param_set_locked(param, env, AXIS2_FALSE); |
| } |
| } |
| |
| if(parent) |
| { |
| axis2_char_t *name = NULL; |
| axis2_bool_t bvalue = AXIS2_FALSE; |
| |
| name = axutil_param_get_name(param, env); |
| bvalue = axutil_param_container_is_param_locked(parent, env, name); |
| if(parent_para || !bvalue) |
| { |
| status = axutil_param_container_add_param(param_container, env, param); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Adding parameter %s failed", name); |
| axutil_param_free(param, env); |
| return status; |
| } |
| } |
| } |
| else |
| { |
| status = axutil_param_container_add_param(param_container, env, param); |
| if(!status) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Adding parameter %s failed", pname); |
| axutil_param_free(param, env); |
| return status; |
| } |
| } |
| } |
| return AXIS2_SUCCESS; |
| } |
| |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_desc_builder_process_op_module_refs( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axiom_children_qname_iterator_t * module_refs, |
| axis2_op_t * op) |
| { |
| axiom_element_t *moduleref = NULL; |
| axiom_attribute_t *module_ref_attrib = NULL; |
| axutil_qname_t *qref = NULL; |
| axis2_status_t status = AXIS2_FAILURE; |
| |
| AXIS2_PARAM_CHECK(env->error, op, AXIS2_FAILURE); |
| |
| while(module_refs && axiom_children_qname_iterator_has_next(module_refs, env)) |
| { |
| axiom_node_t *moduleref_node = axiom_children_qname_iterator_next(module_refs, env); |
| moduleref = (axiom_element_t *)axiom_node_get_data_element(moduleref_node, env); |
| |
| qref = axutil_qname_create(env, AXIS2_REF, NULL, NULL); |
| module_ref_attrib = axiom_element_get_attribute(moduleref, env, qref); |
| axutil_qname_free(qref, env); |
| if(module_ref_attrib) |
| { |
| axis2_char_t *ref_name = NULL; |
| axutil_qname_t *ref_qname = NULL; |
| axis2_module_desc_t *module_desc = NULL; |
| |
| ref_name = axiom_attribute_get_value(module_ref_attrib, env); |
| ref_qname = axutil_qname_create(env, ref_name, NULL, NULL); |
| module_desc = axis2_dep_engine_get_module(desc_builder->engine, env, ref_qname); |
| if(!module_desc) |
| { |
| axutil_qname_free(ref_qname, env); |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_MODULE_NOT_FOUND, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Module %s not found in the deployment engine", ref_name); |
| |
| return AXIS2_FAILURE; |
| } |
| else |
| { |
| status = axis2_op_add_module_qname(op, env, ref_qname); |
| axutil_qname_free(ref_qname, env); |
| if(AXIS2_SUCCESS != status) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_MODULE_NOT_FOUND, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, |
| "Adding module ref %s to operation %s failed", ref_name, |
| axutil_qname_get_localpart(axis2_op_get_qname(op, env), env)); |
| |
| return AXIS2_FAILURE; |
| } |
| } |
| } |
| } |
| |
| return AXIS2_SUCCESS; |
| } |
| |
| AXIS2_EXTERN axis2_msg_recv_t *AXIS2_CALL |
| axis2_desc_builder_load_msg_recv( |
| axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| struct axiom_element * recv_element) |
| { |
| axiom_attribute_t *recv_name = NULL; |
| axis2_char_t *class_name = NULL; |
| axis2_msg_recv_t *msg_recv = NULL; |
| axutil_qname_t *class_qname = NULL; |
| axutil_param_t *impl_info_param = NULL; |
| axutil_dll_desc_t *dll_desc = NULL; |
| axis2_char_t *repos_name = NULL; |
| axis2_char_t *dll_name = NULL; |
| axis2_char_t *temp_path = NULL; |
| axis2_char_t *temp_path2 = NULL; |
| axis2_char_t *temp_path3 = NULL; |
| axis2_conf_t *conf = NULL; |
| axis2_char_t *msg_recv_dll_name = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, recv_element, NULL); |
| |
| class_qname = axutil_qname_create(env, AXIS2_CLASSNAME, NULL, NULL); |
| recv_name = axiom_element_get_attribute(recv_element, env, class_qname); |
| axutil_qname_free(class_qname, env); |
| class_name = axiom_attribute_get_value(recv_name, env); |
| |
| conf = axis2_dep_engine_get_axis_conf(desc_builder->engine, env); |
| if(!conf) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Configuration not found in the deployment engine"); |
| return NULL; |
| } |
| impl_info_param = axis2_conf_get_param(conf, env, class_name); |
| |
| if(!impl_info_param) |
| { |
| dll_desc = axutil_dll_desc_create(env); |
| msg_recv_dll_name = axutil_dll_desc_create_platform_specific_dll_name(dll_desc, env, |
| class_name); |
| repos_name = axis2_dep_engine_get_repos_path(desc_builder->engine, env); |
| if (!repos_name) |
| { |
| /* If we rely solely on an axis2.xml repo then the engine still expects |
| * to find a message receiver shared lib in a "lib" dir off some unspecified repo folder; |
| * So we must tell it to instead look at what we specified for a libDir param in the axis2.xml */ |
| axutil_param_t* lib_dir_param = axis2_conf_get_param(conf, env, AXIS2_LIB_DIR); |
| if (lib_dir_param) |
| { |
| temp_path2 = (axis2_char_t *) axutil_strdup(env, (axis2_char_t *)axutil_param_get_value(lib_dir_param, env)); |
| } |
| else |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, "Unable to resolve lib dir for deployment engine"); |
| return NULL; |
| } |
| } |
| else |
| { |
| temp_path = axutil_stracat(env, repos_name, AXIS2_PATH_SEP_STR); |
| temp_path2 = axutil_stracat(env, temp_path, AXIS2_LIB_FOLDER); |
| } |
| temp_path3 = axutil_stracat(env, temp_path2, AXIS2_PATH_SEP_STR); |
| dll_name = axutil_stracat(env, temp_path3, msg_recv_dll_name); |
| AXIS2_FREE(env->allocator, temp_path); |
| AXIS2_FREE(env->allocator, temp_path2); |
| AXIS2_FREE(env->allocator, temp_path3); |
| axutil_dll_desc_set_name(dll_desc, env, dll_name); |
| AXIS2_FREE(env->allocator, dll_name); |
| axutil_dll_desc_set_type(dll_desc, env, AXIS2_MSG_RECV_DLL); |
| impl_info_param = axutil_param_create(env, class_name, NULL); |
| axutil_param_set_value(impl_info_param, env, dll_desc); |
| axutil_param_set_value_free(impl_info_param, env, axutil_dll_desc_free_void_arg); |
| /* set the impl_info_param(which contain dll_desc as value) so that |
| * loaded msg_recv loader lib can be re-used in future |
| */ |
| axis2_conf_add_param(conf, env, impl_info_param); |
| } |
| |
| axutil_class_loader_init(env); |
| msg_recv = (axis2_msg_recv_t *)axutil_class_loader_create_dll(env, impl_info_param); |
| return msg_recv; |
| } |
| |
| AXIS2_EXTERN struct axis2_msg_recv *AXIS2_CALL |
| axis2_desc_builder_load_default_msg_recv( |
| const axutil_env_t * env) |
| { |
| axis2_msg_recv_t *msg_recv = NULL; |
| |
| msg_recv = axis2_raw_xml_in_out_msg_recv_create(env); |
| return msg_recv; |
| } |
| |
| AXIS2_EXTERN axis2_char_t *AXIS2_CALL |
| axis2_desc_builder_get_short_file_name( |
| const axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axis2_char_t * file_name) |
| { |
| const axis2_char_t *separator = NULL; |
| axis2_char_t *value = NULL; |
| axis2_char_t *file_name_l = NULL; |
| axis2_char_t *short_name = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, file_name, NULL); |
| |
| file_name_l = axutil_strdup(env, file_name); |
| if(!file_name_l) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, ""); |
| return NULL; |
| } |
| separator = "."; |
| |
| value = axutil_strstr(file_name_l, separator); |
| |
| value[0] = AXIS2_EOLN; |
| short_name = file_name_l; |
| |
| return short_name; |
| } |
| |
| AXIS2_EXTERN axis2_char_t *AXIS2_CALL |
| axis2_desc_builder_get_file_name_without_prefix( |
| const axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axis2_char_t * short_file_name) |
| { |
| axis2_char_t *file_name_l = NULL; |
| axis2_char_t *short_name = NULL; |
| int len = 0; |
| AXIS2_PARAM_CHECK(env->error, short_file_name, NULL); |
| file_name_l = axutil_strdup(env, short_file_name); |
| if(!file_name_l) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, ""); |
| return NULL; |
| } |
| len = axutil_strlen(AXIS2_LIB_PREFIX); |
| short_name = &file_name_l[len]; |
| return short_name; |
| |
| } |
| |
| AXIS2_EXTERN axis2_char_t *AXIS2_CALL |
| axis2_desc_builder_get_value( |
| const axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env, |
| axis2_char_t * in) |
| { |
| const axis2_char_t *separator = ":"; |
| axis2_char_t *value = NULL; |
| axis2_char_t *in_l = NULL; |
| |
| AXIS2_PARAM_CHECK(env->error, in, NULL); |
| |
| in_l = axutil_strdup(env, in); |
| if(!in_l) |
| { |
| AXIS2_ERROR_SET(env->error, AXIS2_ERROR_NO_MEMORY, AXIS2_FAILURE); |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, ""); |
| return NULL; |
| } |
| value = axutil_strstr(in_l, separator); |
| value = value + 1; |
| |
| return value; |
| } |
| |
| AXIS2_EXTERN struct axis2_dep_engine *AXIS2_CALL |
| axis2_desc_builder_get_dep_engine( |
| const axis2_desc_builder_t * desc_builder, |
| const axutil_env_t * env) |
| { |
| return desc_builder->engine; |
| } |
| |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_process_policy_elements( |
| const axutil_env_t * env, |
| int type, |
| axiom_children_qname_iterator_t * iterator, |
| axis2_policy_include_t * policy_include) |
| { |
| while(axiom_children_qname_iterator_has_next(iterator, env)) |
| { |
| axiom_node_t *node = NULL; |
| node = axiom_children_qname_iterator_next(iterator, env); |
| if(node) |
| { |
| axiom_element_t *element = NULL; |
| neethi_policy_t *policy = NULL; |
| |
| element = axiom_node_get_data_element(node, env); |
| policy = neethi_engine_get_policy(env, node, element); |
| if(!policy) |
| { |
| AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, ""); |
| return AXIS2_FAILURE; |
| } |
| axis2_policy_include_add_policy_element(policy_include, env, type, policy); |
| } |
| } |
| return AXIS2_SUCCESS; |
| } |
| |
| AXIS2_EXTERN axis2_status_t AXIS2_CALL |
| axis2_process_policy_reference_elements( |
| const axutil_env_t * env, |
| int type, |
| axiom_children_qname_iterator_t * iterator, |
| axis2_policy_include_t * policy_include) |
| { |
| while(axiom_children_qname_iterator_has_next(iterator, env)) |
| { |
| axiom_node_t *node = NULL; |
| node = axiom_children_qname_iterator_next(iterator, env); |
| if(node) |
| { |
| /* TODO: add neethi_engine_get_policy_reference |
| axiom_element_t *element = NULL; |
| neethi_reference_t *reference = NULL; |
| |
| element = axiom_node_get_data_element(node, env); |
| reference = neethi_engine_get_policy_reference(env, node, element); */ |
| axis2_policy_include_add_policy_reference_element(policy_include, env, type, NULL); |
| } |
| } |
| return AXIS2_SUCCESS; |
| } |
| |