/*
* Geotoolkit - An Open Source Java GIS Toolkit
* http://www.geotoolkit.org
*
* (C) 2011, Geomatys
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*/
package org.geotoolkit.wfs.xml.v100;
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlType;
import org.geotoolkit.ogc.xml.v100.FeatureIdType;
import org.geotoolkit.wfs.xml.TransactionResponse;
import org.geotoolkit.wfs.xml.WFSResponse;
import org.opengis.filter.identity.FeatureId;
/**
*
* The WFS_TransactionResponseType defines the format of
* the XML document that a Web Feature Service generates
* in response to a Transaction request. The response
* includes the completion status of the transaction
* and the feature identifiers of any newly created
* feature instances.
*
*
* <p>Java class for WFS_TransactionResponseType complex type.
*
* <p>The following schema fragment specifies the expected content contained within this class.
*
* <pre>
* <complexType name="WFS_TransactionResponseType">
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <sequence>
* <element name="InsertResult" type="{http://www.opengis.net/wfs}InsertResultType" maxOccurs="unbounded" minOccurs="0"/>
* <element name="TransactionResult" type="{http://www.opengis.net/wfs}TransactionResultType"/>
* </sequence>
* <attribute name="version" use="required" type="{http://www.w3.org/2001/XMLSchema}string" fixed="1.0.0" />
* </restriction>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "WFS_TransactionResponseType", propOrder = {
"insertResult",
"transactionResult"
})
public class WFSTransactionResponseType implements WFSResponse, TransactionResponse {
@XmlElement(name = "InsertResult")
private List<InsertResultType> insertResult;
@XmlElement(name = "TransactionResult", required = true)
private TransactionResultType transactionResult;
@XmlAttribute(required = true)
private String version;
public WFSTransactionResponseType() {
}
public WFSTransactionResponseType(final TransactionResultType transactionResults, final List<InsertResultType> insertResults, final String version) {
this.transactionResult = transactionResults;
this.insertResult = insertResults;
this.version = version;
}
/**
* Gets the value of the insertResult property.
*
*/
public List<InsertResultType> getInsertResult() {
if (insertResult == null) {
insertResult = new ArrayList<InsertResultType>();
}
return this.insertResult;
}
/**
* Gets the value of the transactionResult property.
*
* @return
* possible object is
* {@link TransactionResultType }
*
*/
public TransactionResultType getTransactionResult() {
return transactionResult;
}
/**
* Sets the value of the transactionResult property.
*
* @param value
* allowed object is
* {@link TransactionResultType }
*
*/
public void setTransactionResult(TransactionResultType value) {
this.transactionResult = value;
}
/**
* Gets the value of the version property.
*
* @return
* possible object is
* {@link String }
*
*/
public String getVersion() {
if (version == null) {
return "1.0.0";
} else {
return version;
}
}
/**
* Sets the value of the version property.
*
* @param value
* allowed object is
* {@link String }
*
*/
public void setVersion(String value) {
this.version = value;
}
@Override
public List<FeatureId> getInsertedFID() {
final List<FeatureId> ids = new ArrayList<FeatureId>();
if (insertResult != null) {
for(InsertResultType ift : insertResult){
for(FeatureIdType fit : ift.getFeatureId()){
ids.add(fit);
}
}
}
return ids;
}
}