001    //$HeadURL: $
002    /*----------------    FILE HEADER  ------------------------------------------
003     This file is part of deegree.
004     Copyright (C) 2001-2007 by:
005     Department of Geography, University of Bonn
006     http://www.giub.uni-bonn.de/deegree/
007     lat/lon GmbH
008     http://www.lat-lon.de
009    
010     This library is free software; you can redistribute it and/or
011     modify it under the terms of the GNU Lesser General Public
012     License as published by the Free Software Foundation; either
013     version 2.1 of the License, or (at your option) any later version.
014     This library is distributed in the hope that it will be useful,
015     but WITHOUT ANY WARRANTY; without even the implied warranty of
016     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
017     Lesser General Public License for more details.
018     You should have received a copy of the GNU Lesser General Public
019     License along with this library; if not, write to the Free Software
020     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
021     Contact:
022    
023     Andreas Poth
024     lat/lon GmbH
025     Aennchenstr. 19
026     53177 Bonn
027     Germany
028     E-Mail: poth@lat-lon.de
029    
030     Prof. Dr. Klaus Greve
031     Department of Geography
032     University of Bonn
033     Meckenheimer Allee 166
034     53115 Bonn
035     Germany
036     E-Mail: greve@giub.uni-bonn.de
037     ---------------------------------------------------------------------------*/
038    
039    
040    package org.deegree.ogcwebservices.csw.capabilities;
041    
042    import java.net.URI;
043    import java.util.HashMap;
044    import java.util.List;
045    import java.util.Map;
046    
047    import org.deegree.i18n.Messages;
048    
049    /**
050     * The <code>CSWFeature</code> class is a simple bean holding a property map.
051     *
052     * @author <a href="mailto:bezema@lat-lon.de">Rutger Bezema</a>
053     *
054     * @author last edited by: $Author:$
055     *
056     * @version $Revision:$, $Date:$
057     *
058     */
059    
060    public class CSWFeature {
061        private Map<URI, List<String>> properties;
062        
063        
064        /**
065         * Initialisded with no properties.
066         */
067        public CSWFeature( ){
068            this.properties = new HashMap< URI, List<String>>();
069        }
070        /**
071         * sets the features properties to the given map.
072         * @param properties to set to.
073         */
074        public CSWFeature( Map<URI, List<String> > properties ){
075            this.properties = properties;
076        }
077    
078        /**
079         * @return the properties.
080         */
081        public Map<URI, List<String>> getAllProperties() {
082            return properties;
083        }
084        
085        /**
086         * @param propName an unambiguous name for the property to insert
087         * @param values of the properties
088         * @param properties An other properties value.
089         * @throws IllegalArgumentException if the propName is empty, unambiguous or null.
090         */
091        public void addPropertie( URI propName, List<String> values ) {
092            if( propName == null || "".equals( propName.toASCIIString().trim()) ){
093                throw new IllegalArgumentException( Messages.getMessage( "WRS_NULL_FEAT_PROP" ) );
094            }
095            if( properties.containsKey( propName ) ){
096                throw new IllegalArgumentException( Messages.getMessage( "WRS_UNAMBIGUOUS_FEAT_PROP", propName.toString()) );
097            }                 
098            this.properties.put( propName, values );
099        }
100        
101        
102        
103    }
104