All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hazelcast.spring.HazelcastInstanceDefinitionParser Maven / Gradle / Ivy

/*
 * Copyright (c) 2008-2016, Hazelcast, Inc. All Rights Reserved.
 *
 * 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.
 */

package com.hazelcast.spring;

import com.hazelcast.instance.HazelcastInstanceFactory;
import org.springframework.beans.factory.support.AbstractBeanDefinition;
import org.springframework.beans.factory.support.BeanDefinitionBuilder;
import org.springframework.beans.factory.xml.ParserContext;
import org.w3c.dom.Element;
import org.w3c.dom.Node;

/**
 * BeanDefinitionParser for Hazelcast Instance Configuration
 * 

* * Sample Spring XML for Hazelcast Instance: *

 * <hz:hazelcast id="instance">
 *      <hz:config>
 *          <hz:group name="dev" password="password"/>
 *          <hz:network port="5701" port-auto-increment="false">
 *              <hz:join>
 *                  <hz:multicast enabled="false" multicast-group="224.2.2.3" multicast-port="54327"/>
 *                   <hz:tcp-ip enabled="true">
 *                      <hz:members>10.10.1.2, 10.10.1.3</hz:members>
 *                   </hz:tcp-ip>
 *              </hz:join>
 *          </hz:network>
 *          <hz:map name="map" backup-count="2" max-size="0" eviction-percentage="30"
 *              read-backup-data="true" eviction-policy="NONE"
 *          merge-policy="com.hazelcast.map.merge.PassThroughMergePolicy"/>
 *      </hz:config>
 * </hz:hazelcast>
 * 
*/ public class HazelcastInstanceDefinitionParser extends AbstractHazelcastBeanDefinitionParser { @Override protected AbstractBeanDefinition parseInternal(Element element, ParserContext parserContext) { final SpringXmlBuilder springXmlBuilder = new SpringXmlBuilder(parserContext); springXmlBuilder.handle(element); return springXmlBuilder.getBeanDefinition(); } private class SpringXmlBuilder extends SpringXmlBuilderHelper { private final ParserContext parserContext; private BeanDefinitionBuilder builder; public SpringXmlBuilder(ParserContext parserContext) { this.parserContext = parserContext; this.builder = BeanDefinitionBuilder.rootBeanDefinition(HazelcastInstanceFactory.class); this.builder.setFactoryMethod("newHazelcastInstance"); this.builder.setDestroyMethodName("shutdown"); } public AbstractBeanDefinition getBeanDefinition() { return builder.getBeanDefinition(); } public void handle(Element element) { handleCommonBeanAttributes(element, builder, parserContext); Element config = null; for (Node node : childElements(element)) { final String nodeName = cleanNodeName(node); if ("config".equals(nodeName)) { config = (Element) node; } } final HazelcastConfigBeanDefinitionParser configParser = new HazelcastConfigBeanDefinitionParser(); final AbstractBeanDefinition configBeanDef = configParser.parseInternal(config, parserContext); this.builder.addConstructorArgValue(configBeanDef); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy