/* (c) 2014 Open Source Geospatial Foundation - all rights reserved * (c) 2001 - 2013 OpenPlans * This code is licensed under the GPL 2.0 license, available at the root * application directory. */ package org.geoserver.wfs.xml.v1_1_0; import javax.xml.namespace.QName; import net.opengis.wfs.DescribeFeatureTypeType; import net.opengis.wfs.WfsFactory; import org.geotools.xml.AbstractComplexBinding; import org.geotools.xml.ElementInstance; import org.geotools.xml.Node; /** * Binding object for the type http://www.opengis.net/wfs:DescribeFeatureTypeType. * * <p> * <pre> * <code> * <xsd:complexType name="DescribeFeatureTypeType"> * <xsd:annotation> * <xsd:documentation> * The DescribeFeatureType operation allows a client application * to request that a Web Feature Service describe one or more * feature types. A Web Feature Service must be able to generate * feature descriptions as valid GML3 application schemas. * * The schemas generated by the DescribeFeatureType operation can * be used by a client application to validate the output. * * Feature instances within the WFS interface must be specified * using GML3. The schema of feature instances specified within * the WFS interface must validate against the feature schemas * generated by the DescribeFeatureType request. * </xsd:documentation> * </xsd:annotation> * <xsd:complexContent> * <xsd:extension base="wfs:BaseRequestType"> * <xsd:sequence> * <xsd:element maxOccurs="unbounded" minOccurs="0" * name="TypeName" type="xsd:QName"> * <xsd:annotation> * <xsd:documentation> * The TypeName element is used to enumerate the * feature types to be described. If no TypeName * elements are specified then all features should * be described. The name must be a valid type * that belongs to the feature content as defined * by the GML Application Schema. * </xsd:documentation> * </xsd:annotation> * </xsd:element> * </xsd:sequence> * <xsd:attribute default="text/xml; subtype=gml/3.1.1" * name="outputFormat" type="xsd:string" use="optional"> * <xsd:annotation> * <xsd:documentation> * The outputFormat attribute is used to specify what schema * description language should be used to describe features. * The default value of 'text/xml; subtype=3.1.1' means that * the WFS must generate a GML3 application schema that can * be used to validate the GML3 output of a GetFeature * request or feature instances specified in Transaction * operations. * For the purposes of experimentation, vendor extension, * or even extensions that serve a specific community of * interest, other acceptable output format values may be * advertised by a WFS service in the capabilities document. * The meaning of such values in not defined in the WFS * specification. The only proviso is such cases is that * clients may safely ignore outputFormat values that do * not recognize. * </xsd:documentation> * </xsd:annotation> * </xsd:attribute> * </xsd:extension> * </xsd:complexContent> * </xsd:complexType> * * </code> * </pre> * @generated */ public class DescribeFeatureTypeTypeBinding extends AbstractComplexBinding { WfsFactory wfsfactory; public DescribeFeatureTypeTypeBinding(WfsFactory wfsfactory) { this.wfsfactory = wfsfactory; } /** * @generated */ public QName getTarget() { return WFS.DESCRIBEFEATURETYPETYPE; } public int getExecutionMode() { return BEFORE; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * * @generated modifiable */ public Class getType() { return DescribeFeatureTypeType.class; } /** * <!-- begin-user-doc --> * <!-- end-user-doc --> * * @generated modifiable */ public Object parse(ElementInstance instance, Node node, Object value) throws Exception { DescribeFeatureTypeType describeFeatureType = wfsfactory .createDescribeFeatureTypeType(); //<xsd:element maxOccurs="unbounded" minOccurs="0" // name="TypeName" type="xsd:QName"> describeFeatureType.getTypeName().addAll(node.getChildValues(QName.class)); //lt;xsd:attribute default="text/xml; subtype=gml/3.1.1" // name="outputFormat" type="xsd:string" use="optional"> if (node.hasAttribute("outputFormat")) { describeFeatureType.setOutputFormat((String) node.getAttributeValue("outputFormat")); } return describeFeatureType; } }