001 //$HeadURL: svn+ssh://rbezema@svn.wald.intevation.org/deegree/base/branches/2.2_testing/src/org/deegree/ogcwebservices/wcs/getcapabilities/ContentMetadata.java $
002 /*---------------- FILE HEADER ------------------------------------------
003
004 This file is part of deegree.
005 Copyright (C) 2001-2008 by:
006 EXSE, Department of Geography, University of Bonn
007 http://www.giub.uni-bonn.de/deegree/
008 lat/lon GmbH
009 http://www.lat-lon.de
010
011 This library is free software; you can redistribute it and/or
012 modify it under the terms of the GNU Lesser General Public
013 License as published by the Free Software Foundation; either
014 version 2.1 of the License, or (at your option) any later version.
015
016 This library is distributed in the hope that it will be useful,
017 but WITHOUT ANY WARRANTY; without even the implied warranty of
018 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
019 Lesser General Public License for more details.
020
021 You should have received a copy of the GNU Lesser General Public
022 License along with this library; if not, write to the Free Software
023 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
024
025 Contact:
026
027 Andreas Poth
028 lat/lon GmbH
029 Aennchenstr. 19
030 53115 Bonn
031 Germany
032 E-Mail: poth@lat-lon.de
033
034 Prof. Dr. Klaus Greve
035 Department of Geography
036 University of Bonn
037 Meckenheimer Allee 166
038 53115 Bonn
039 Germany
040 E-Mail: greve@giub.uni-bonn.de
041
042
043 ---------------------------------------------------------------------------*/
044 package org.deegree.ogcwebservices.wcs.getcapabilities;
045
046 import java.io.Serializable;
047 import java.util.HashMap;
048 import java.util.Map;
049
050 import org.deegree.ogcwebservices.wcs.CoverageOfferingBrief;
051
052 /**
053 * @version $Revision: 9345 $
054 * @author <a href="mailto:poth@lat-lon.de">Andreas Poth</a>
055 * @author last edited by: $Author: apoth $
056 *
057 * @version $Revision: 9345 $, $Date: 2007-12-27 17:22:25 +0100 (Do, 27 Dez 2007) $
058 */
059
060 public class ContentMetadata implements Serializable {
061
062 private String version = null;
063
064 private String updateSequence = null;
065
066 /**
067 *
068 */
069 private CoverageOfferingBrief[] coverageOfferingBrief;
070
071 private Map<String, CoverageOfferingBrief> map = new HashMap<String, CoverageOfferingBrief>( 100 );
072
073 /**
074 * @param version
075 * @param updateSequence
076 * @param coverageOfferingBrief
077 */
078 public ContentMetadata( String version, String updateSequence, CoverageOfferingBrief[] coverageOfferingBrief ) {
079
080 this.version = version;
081 this.updateSequence = updateSequence;
082 setCoverageOfferingBrief( coverageOfferingBrief );
083 }
084
085 /**
086 * @return Returns the coverageOfferingBrief.
087 */
088 public CoverageOfferingBrief[] getCoverageOfferingBrief() {
089 return coverageOfferingBrief;
090 }
091
092 /**
093 * returns the <tt>CoverageOfferingBrief<tt> for the coverage matching
094 * the passed name. if no coverage with this name is available <tt>null</tt>
095 * will be returned.
096 *
097 * @param coverageName
098 * @return the <tt>CoverageOfferingBrief<tt> for the coverage matching
099 * the passed name. if no coverage with this name is available <tt>null</tt>
100 * will be returned.
101 */
102 public CoverageOfferingBrief getCoverageOfferingBrief( String coverageName ) {
103 return map.get( coverageName );
104 }
105
106 /**
107 * @param coverageOfferingBrief
108 * The coverageOfferingBrief to set.
109 */
110 public void setCoverageOfferingBrief( CoverageOfferingBrief[] coverageOfferingBrief ) {
111 map.clear();
112 this.coverageOfferingBrief = new CoverageOfferingBrief[coverageOfferingBrief.length];
113
114 for ( int i = 0; i < coverageOfferingBrief.length; i++ ) {
115 this.coverageOfferingBrief[i] = coverageOfferingBrief[i];
116 map.put( coverageOfferingBrief[i].getName(), coverageOfferingBrief[i] );
117 }
118 }
119
120 /**
121 * @return Returns the updateSequence.
122 */
123 public String getUpdateSequence() {
124 return updateSequence;
125 }
126
127 /**
128 * @param updateSequence
129 * The updateSequence to set.
130 */
131 public void setUpdateSequence( String updateSequence ) {
132 this.updateSequence = updateSequence;
133 }
134
135 /**
136 * @return Returns the version.
137 */
138 public String getVersion() {
139 return version;
140 }
141
142 /**
143 * @param version
144 * The version to set.
145 */
146 public void setVersion( String version ) {
147 this.version = version;
148 }
149
150 }