001    //$HeadURL: svn+ssh://rbezema@svn.wald.intevation.org/deegree/base/branches/2.2_testing/src/org/deegree/ogcwebservices/csw/manager/Insert.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    package org.deegree.ogcwebservices.csw.manager;
044    
045    import java.util.HashMap;
046    import java.util.List;
047    import java.util.Map;
048    
049    import org.w3c.dom.Element;
050    
051    /**
052     * An Insert object is a container for one or more records that are to be inserted into the
053     * catalogue. The schema of the record(s) must conform to the schema of the information model that
054     * the catalogue supports as described using the DescribeRecord operation.
055     * 
056     * @author <a href="mailto:poth@lat-lon.de">Andreas Poth</a>
057     * @author last edited by: $Author: apoth $
058     * 
059     * @version $Revision: 9345 $, $Date: 2007-12-27 17:22:25 +0100 (Do, 27 Dez 2007) $
060     * 
061     */
062    public class Insert extends Operation {
063    
064        private List<Element> records = null;
065    
066        private Map<String, Element> extrinsicObjects;
067    
068        /**
069         * 
070         * @param handle
071         *            attribute of the insert.
072         * @param records
073         *            a list containing all (firstlevel) child xml elements beneath the <csw:insert>
074         *            element
075         * 
076         */
077        public Insert( String handle, List<Element> records ) {
078            super( "Insert", handle );
079            this.records = records;
080            this.extrinsicObjects = new HashMap<String, Element>();
081        }
082    
083        /**
084         * @param handle
085         *            attribute of the insert.
086         * @param records
087         *            a list containing all (firstlevel) child xml elements beneath the <csw:insert>
088         *            element
089         * @param extrinsicObjects
090         *            a mapping of the lid of the values to the rim:ExtrinsicObject w3c-element. They
091         *            are needed to find the actual extrinsic objects into the multiparts send to the
092         *            csw.
093         * 
094         */
095        public Insert( String handle, List<Element> records, Map<String, Element> extrinsicObjects ) {
096            super( "Insert", handle );
097            this.records = records;
098            if( extrinsicObjects != null ){
099                this.extrinsicObjects = extrinsicObjects;
100            } else {
101                this.extrinsicObjects = new HashMap<String, Element>();
102            }
103        }
104    
105        /**
106         * returns records to insert
107         * 
108         * @return records to insert
109         */
110        public List<Element> getRecords() {
111            return records;
112        }
113    
114        /**
115         * @return the ebrim extrinsicObjects which should be inserted or an empty map if no
116         *         ExtrinsicObject should be inserted, or no ebrim is used in this catalogue.
117         */
118        public Map<String, Element> getExtrinsicObjects() {
119            return extrinsicObjects;
120        }
121    
122    }