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

it.geosolutions.geoserver.rest.encoder.metadata.virtualtable.VTParameterEncoder Maven / Gradle / Ivy

/*
 *  GeoServer-Manager - Simple Manager Library for GeoServer
 *  
 *  Copyright (C) 2007,2011 GeoSolutions S.A.S.
 *  http://www.geo-solutions.it
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 * 
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
package it.geosolutions.geoserver.rest.encoder.metadata.virtualtable;

import it.geosolutions.geoserver.rest.encoder.utils.ElementUtils;
import it.geosolutions.geoserver.rest.encoder.utils.XmlElement;
import org.jdom.Element;
import org.jdom.filter.Filter;

/**
 * VTParameterEncoder - Encodes a metadata VirtualTable parameter for a
 * GeoServer featureType, as follows:
 *
 * @author Emmanuel Blondel - [email protected] |
 *         [email protected]
 * 
 */
public class VTParameterEncoder extends XmlElement {

	/** 
	 * A class to filter the VirtualTable parameters by name
	 *
	 */
	private static class filterByName implements Filter {

		final private String key;

		public filterByName(String name) {
			this.key = name;
		}

		private static final long serialVersionUID = 1L;

		public boolean matches(Object obj) {
			Element el = ((Element) obj)
					.getChild(VTParameter.name.toString());
			if (el != null && el.getTextTrim().equals(key)) {
				return true;
			}
			return false;
		}
	}

	/** 
	 * Get a Filter using the VTParameter name
	 * 
	 * @param name name
	 * @return the filter
	 */
	public static Filter getFilterByName(String name) {
		return new filterByName(name);
	}
	
	/**
	 * Constructs a GSVirtualTableParamEncoder
	 */
	public VTParameterEncoder() {
		super("parameter");
	}

	/**
	 * Constructs quickly a VTParameterEncoder
	 * 
	 * @param name (required)
	 * @param defaultValue (required)
	 * @param regexpValidator (required)
	 */
	public VTParameterEncoder(String name, String defaultValue, String regexpValidator){
		super("parameter");
		this.setup(name, defaultValue, regexpValidator);
	}
	
	/**
	 * Set-up quickly a VirtualTable parameter
	 * 
	 * @param name name
	 * @param defaultValue defaultValue
	 * @param regexpValidator regexpValidator
	 */
	protected void setup(String name, String defaultValue, String regexpValidator) {
		setName(name);
		setDefaultValue(defaultValue);
		setRegexpValidator(regexpValidator);
	}

	/**
	 * Set a VirtualTableParameter member
	 * 
	 * @param type type
	 * @param value value
	 */
	protected void setMember(VTParameter type,
			String value) {
		set(type.toString(), value);
	}
	
	/**
	 * Set the parameter name
	 * 
	 * @param name name
	 */
	public void setName(String name){
		this.setMember(VTParameter.name, name);
	}
	
	/**
	 * Set the parameter default value
	 * 
	 * @param value value
	 */
	public void setDefaultValue(String value){
		this.setMember(VTParameter.defaultValue, value);
	}

	/**
	 * Set the parameter regexp validator
	 * 
	 * @param validator validator
	 */
	public void setRegexpValidator(String validator){
		this.setMember(VTParameter.regexpValidator, validator);
	}
	
	/**
	 * Deletes a VirtualTableParameter member
	 * 
	 * @param type type
	 * @return boolean
	 */
	protected boolean delMember(VTParameter type) {
		return ElementUtils.remove(this.getRoot(), this.getRoot().getChild(type.toString()));
	}

	/**
	 * Deletes the name
	 * 
	 * @return true if removed, false otherwise
	 */
	public boolean delName(){
		return this.delMember(VTParameter.name);
	}
	
	/**
	 * Deletes the default value
	 * 
	 * @return true if removed, false otherwise
	 */
	public boolean delDefaultValue(){
		return this.delMember(VTParameter.defaultValue);
	}
	
	/**
	 * Deletes the Regexp validator
	 * 
	 * @return true if removed, false otherwise
	 */
	public boolean delRegexpValidator(){
		return this.delMember(VTParameter.regexpValidator);
	}
	
	
	/**
	 * Get a VirtualTableParameter member
	 * 
	 * @param type type
	 * @return String
	 */
	protected String getMember(VTParameter type) {
		Element el = getRoot().getChild(type.toString());
		if (el != null)
			return el.getTextTrim();
		else
			return null;
	}
	
	/**
	 * Get the parameter name
	 * 
	 * @return String
	 */
	public String getName(){
		return this.getMember(VTParameter.name);
	}
	
	/**
	 * Get the parameter default value
	 * 
	 * @return String
	 */
	public String getDefaultValue(){
		return this.getMember(VTParameter.defaultValue);
	}
	
	/**
	 * Get the parameter regexp validator
	 * 
	 * @return String
	 */
	public String getRegexpValidator(){
		return this.getMember(VTParameter.regexpValidator);
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy