Thank you Jody,
Yes, please update the report, or I do it if you prefer, the only thing is that
I think I dont have priviledges to change the name of the bug report, do you?
I will try to play a bit more with FilterEncodingPreProcessor to see If can I
get any farther.
De: Jody Garnett [mailto:[email protected]]
Enviado el: sábado, 09 de abril de 2011 2:39
Para: Joaquín Rodriguez-Guerra Urcelay
CC: [email protected]; Justin Deoliveira; Gabriel Roldan
Asunto: WFS Filter composed by fid filter and comparation filter not being
accepted by mapserver
Hello Joaquín:
I am following you across lists. WFS is an unsupported module, generally
meaning it does not meet the QA levels expected for GeoTools.
The "pom.xml" file
(http://svn.osgeo.org/geotools/trunk/modules/unsupported/wfs/pom.xml) lists two
contacts as module maintainer: justin and gabriel who I have CCed.
I had a look in the list of open issue for GeoTools WFS:
- http://jira.codehaus.org/browse/GEOT/component/11098
It shows a fairly large number of open issues; including a couple that match
what you are describing. The difference is that your email has enough details
that we could look into what is going on.
Here are the close matches:
- http://jira.codehaus.org/browse/GEOT-3151 Deegree 3 reports WFS-T seriously
broken (references UDIG-1673<http://jira.codehaus.org/browse/UDIG-1673> )
- http://jira.codehaus.org/browse/GEOT-2112 XML for WFS GetFeature query has
invalid filter
- http://jira.codehaus.org/browse/GEOT-1013 FidFilter not working in WFS data
store?
- http://jira.codehaus.org/browse/GEOT-1499 WFSFeatureSource.getFeatures()
always returns empty set with ALL query
The first one is the best match (and links to UDIG-1673); it ends with the
following comment:
I talked with Markus and by "nested filter" they mean a filter in which you mid
fid filters with something else. Fid filters are supposed to be the root of the
filter, they cannot be mixed with anything else in OGC filter (both versions).
Solving the above it's a matter of splitting the filter and deciding which part
of it to send the remote wfs.
Anyways, there is a bigger issue... who's going to fix this one? No
maintainer....
So I would like to update this bug report with the details you have provided
(and maybe give it a better name so it is easier to find).
--
Jody Garnett
On Friday, 8 April 2011 at 7:49 PM, Joaquín Rodriguez-Guerra Urcelay wrote:
Hello list
This is the first time I write here, so hello everybody :)
I have recently started to work in a project using uDig, which works with
geotools.
The other day I was having an issue with a filter udig was sending to a wfs
layer. The filter is a fid filter, but geotoool's streaming renderer is adding
a bbox filter to it, and mapserver is not understanding it probably due to an
encoding issue.
This is the filter sent by udig to mapserver (failing it due to the filter tag
contained in the main filter tag):
http://localhost:8080/cgi-bin/mywfs?SERVICE=WFS&VERSION=1.0.0&request=getfeature&typename=PositionReal&Filter=
<Filter>
<And>
<Filter>
<FeatureId fid="PositionReal.3"/>
</Filter>
<BBOX>
<PropertyName>point</PropertyName>
<Box>
<coordinates decimal="." cs="," ts=" ">-100.82219958499486,-57.14285725714286
100.82219958499486,57.14285725714286</coordinates>
</Box>
</BBOX>
</And>
</Filter>
And this is what mapserver understands:
http://localhost:8080/cgi-bin/mywfs?SERVICE=WFS&VERSION=1.0.0&request=getfeature&typename=PositionReal&Filter=
<Filter>
<And>
<FeatureId fid="PositionReal.3"/>
<BBOX>
<PropertyName>point</PropertyName>
<Box>
<coordinates decimal="." cs="," ts=" ">-100.82219958499486,-57.14285725714286
100.82219958499486,57.14285725714286</coordinates>
</Box>
</BBOX>
</And>
</Filter>
Joddy Garnett helped me in the udig-devel list and he suggested that it could
be an encoding issue, and maybe using the FilterEncodingPreProcessor we could
fix it.
I have tried to understand the FilterEncodingPreProcessor, but I am having some
dificulties. I have created a filter composed by a fid filter and a comparation
filter. My goal is to have them encoded on the same xml filter, but no luck. I
have tried the 3 compliance levels, hoping that after accepting each visitor
(one for each level) in the filter, I would be able to invoke visitor.getFilter
and obtain the new filter, hopefully one of them encoded as I want. So I
printed the xml code of the getFilter() filter of each visitor, but I guess I
didnt unerstand this correctly, right?
CODE:
org.geotools.xml.Configuration conf2 =D new
org.geotools.filter.v1_1.OGCConfiguration();
FilterFactory2 factory = CommonFactoryFinder.getFilterFactory2(null);
String fid1 = "FID.1";
Filter fidFilter= createFidFilter("FID.1");
Filter normalFilter = CQL.toFilter("id = 1");
Filter filter = factory.and( fidFilter, normalFilter);
FFilterEncodingPreProcessor visitor1 = new
FilterEncodingPreProcessor(XMLHandlerHints.VALUE_FILTER_COMPLIANCE_LOW);
FFilterEncodingPreProcessor visitor2 = new
FilterEncodingPreProcessor(XMLHandlerHints.VALUE_FILTER_COMPLIANCE_MEDIUM);
FFilterEncodingPreProcessor visitor3 = new
FilterEncodingPreProcessor(XMLHandlerHints.VALUE_FILTER_COMPLIANCE_HIGH);
System.out.println(""LOW");
FFilters.accept(filter, visitor1);
org.geotools.xml.Encoder encoder = new org.geotools.xml.Encoder(conf2);
encoder.setIndenting(true);
encoder.setIndentSSize(2);
encoder.encode(visitor1.getFilter(), org.geotools.filter.v1_1.OGC.Filter,
System.out );
encoder = new org.geotools.xml.Encoder(conf2);
encoder.setIndenting(true);
encoder.setIndentSize(2);
encoder.encode( visitor1.getFFidFilter(), org.geotools.filter.v1_1.OGC.Filter,
System.out );
System.out.println(""MEDIUM");
Filters.accept(filter, visitor2);
encoder = new org.geotools.xml.Encoder(conf2);
encoder.setIndenting(true);
encoder.setIndentSize(2);
encoder.encode( visitor22.getFilter(), org.geotools.filter.v1_1.OGC.Filter,
System.out );
encoder = new org.geotools.xml.Encoder(conf2);
encoder.setIndenting(true);
encoder.setInddentSize(2);
encoder.encode( visitor2.getFidFilter(), org.geotools.filter.v1_1.OGC.Filter,
System.out );
System.out.println(""HIGH");
FFilters.accept(filter, visitor3);
encoder = new org.geotools.xml.Encoder(conf2);
encoder.setIndenting(true);
encoder.setIndentSize(2);
encoder.encode( visitor3.getFilter(), org.geotools.filter.v1_0.OGC.Filter,
System.out );
encoder = new org.geotools.xml.Encoder(conf2);
encoder.setIndenting(true);
encoder.setIndentSize(2);
encoder.encode( visittor3.getFidFilter(), org.geotools.filter.v1_1.OGC.Filter,
System.out );
OUTPUT:
LOW
<?xml version="1.0" encoding="UTF-8"?>
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc"
xmlns:gml="http://www.opengis.net/gml">
<ogc:And>
<ogc:PropertyIsEqualTo matchCase="true">
<ogc:PropertyName>id</ogc:PropertyName>
<ogc:Literal>1</ogc:Literal>
</ogc:PropertyIsEqualTo>
</ogc:And>
</ogc:Filter>
<?xml version="1.0" encoding="UTF-8"?>
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc"
xmlns:gml="http://www.opengis.net/gml"/>
MEDIUM
<?xml version="1.0" encoding="UTF-8"?>
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc"
xmlns:gml="http://www.opengis.net/gml"/>
<?xml version="1.0" encoding="UTF-8"?>
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc"
xmlns:gml="http://www.opengis.net/gml">
<ogc:FeatureId fid="FID.1"/>
</ogc:Filter>
HIGH
<?xml version="1.0" encoding="UTF-8"?>
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc"
xmlns:gml="http://www.opengis.net/gml"/>
<?xml version="1.0" encoding="UTF-8"?>
<ogc:Filter xmlns:ogc="http://www.opengis.net/ogc"
xmlns:gml="http://www.opengis.net/gml">
<ogc:FeatureId fid="FID.1"/>
</ogc:Filter>
are we on the right track? any close to the solution?
Thank you!
Joaquín
______________________
This message including any attachments may contain confidential
information, according to our Information Security Management System,
and intended solely for a specific individual to whom they are addressed.
Any unauthorised copy, disclosure or distribution of this message
is strictly forbidden. If you have received this transmission in error,
please notify the sender immediately and delete it.
______________________
Este mensaje, y en su caso, cualquier fichero anexo al mismo,
puede contener informacion clasificada por su emisor como confidencial
en el marco de su Sistema de Gestion de Seguridad de la
Informacion siendo para uso exclusivo del destinatario, quedando
prohibida su divulgacion copia o distribucion a terceros sin la
autorizacion expresa del remitente. Si Vd. ha recibido este mensaje
erroneamente, se ruega lo notifique al remitente y proceda a su borrado.
Gracias por su colaboracion.
______________________
------------------------------------------------------------------------------
Xperia(TM) PLAY
It's a major breakthrough. An authentic gaming
smartphone on the nation's most reliable network.
And it wants your games.
http://p.sf.net/sfu/verizon-sfdev
_______________________________________________
Geotools-gt2-users mailing list
[email protected]<mailto:[email protected]>
https://lists.sourceforge.net/lists/listinfo/geotools-gt2-users
______________________
This message including any attachments may contain confidential
information, according to our Information Security Management System,
and intended solely for a specific individual to whom they are addressed.
Any unauthorised copy, disclosure or distribution of this message
is strictly forbidden. If you have received this transmission in error,
please notify the sender immediately and delete it.
______________________
Este mensaje, y en su caso, cualquier fichero anexo al mismo,
puede contener informacion clasificada por su emisor como confidencial
en el marco de su Sistema de Gestion de Seguridad de la
Informacion siendo para uso exclusivo del destinatario, quedando
prohibida su divulgacion copia o distribucion a terceros sin la
autorizacion expresa del remitente. Si Vd. ha recibido este mensaje
erroneamente, se ruega lo notifique al remitente y proceda a su borrado.
Gracias por su colaboracion.
______________________
------------------------------------------------------------------------------
Xperia(TM) PLAY
It's a major breakthrough. An authentic gaming
smartphone on the nation's most reliable network.
And it wants your games.
http://p.sf.net/sfu/verizon-sfdev
_______________________________________________
Geotools-gt2-users mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/geotools-gt2-users