[FeatureServer] GeoAlchemy, what is the trick?

Gery . gamejihou at hotmail.com
Wed Dec 5 03:22:22 PST 2012


Thanks a lot Michel, it worked like a charm. Now I'm getting the whole table as GeoJSON. However I have a doubt about the querying option, for example:

/fs/boreholes?format=GeoJSON&source__ilike=ODP&queryable=source ---> this source_ilike comes from Ext JS, and should give only the rows in source column with "odp".
/fs/boreholes?format=GeoJSON&queryable=source&source=ODP
 ---> this should work as above with FeatureServer but it gives this:
An error occurred: string indices must be integers, not str
  File "/var/www/html/mop/fs/web_request/handlers.py", line 230, in cgi
    accepts = accepts )
  File "/var/www/html/mop/fs/FeatureServer/Server.py", line 245, in dispatchRequest
    result = method(action)
  File "/var/www/html/mop/fs/FeatureServer/DataSource/GeoAlchemy.py", line 160, in select
    for k, v in action.attributes.iteritems()]


{'source': 'ODP', 'queryable': 'source', 'format': 'GeoJSON'}
Because I'm using Ext JS to do the search (search button), I'd like this form: /fs/boreholes?format=GeoJSON&source__ilike=ODP&queryable=source, could it be possible to adapt this in FeatureServer?

Thanks again,

Gery

PS: this is the error coming from the Ext JS example above:
An error occurred: 'str' object has no attribute 'query_action_types'
  File "/var/www/html/mop/fs/web_request/handlers.py", line 230, in cgi
    accepts = accepts )
  File "/var/www/html/mop/fs/FeatureServer/Server.py", line 207, in dispatchRequest
    request.parse(params, path_info, host, post_data, request_method)
  File "/var/www/html/mop/fs/FeatureServer/Service/GeoJSON.py", line 44, in parse
    Request.parse(self, params, path_info, host, post_data, request_method, format_obj=g)
  File "/var/www/html/mop/fs/FeatureServer/Service/Request.py", line 70, in parse
    action = self.get_select_action(path_info, params)
  File "/var/www/html/mop/fs/FeatureServer/Service/Request.py", line 145, in get_select_action
    if type in ds.query_action_types:


{'source__ilike': 'ODP', 'queryable': 'source', 'format': 'GeoJSON'}

__________________________________________________________________________________________
Piensa en el medio ambiente - mantenlo en la pantalla. NO lo imprimas si NO es necesario.
Think green - keep it on the screen. Do NOT print if it is NOT necessary.
Denken Sie an die Umwelt - bewahren Sie es auf dem Bildschirm. Drucken Sie NICHT, wenn es NICHT notwendig ist.


Subject: Re: [FeatureServer] GeoAlchemy, what is the trick?
From: iocast at me.com
Date: Wed, 5 Dec 2012 08:34:15 +0100
CC: featureserver at lists.osgeo.org
To: gamejihou at hotmail.com

Hi Gery
In the test files I found an example and tried to adapt it:
The config entry I changed as follow:************************[boreholes]type=GeoAlchemydburi=postgresql://<user>:<password>@localhost:5432/mapmodel=model.boreholes_modelcls=Boreholesfid=idgeometry=geom************************where the model is a subdirectory of the featureserver root directory and boreholes_model is a file called boreholes_model.py. I also added a __init__.py file in the model folder to be sure that it is recognised as a Python package.cls is the class name of your model, so it should be Boreholes.
You could also look at the 'Road' example in the folder testsDataSource.GeoAlchemy.txt andgeoalchemy_model.py for the model declaration
Hopefully it would helpMichel



On Dec 5, 2012, at 8:00 AM, Iocast <iocast at me.com> wrote:Hi Gery
I never tried/changed the GeoAlchemy data source, however I'm going to try your setup and have a look if I get the same error.
Cheers,Michel

I get this error recently, I'm not sure why, someone has an idea? thanks

An error occurred: 'NoneType' object has no attribute 'items'
  File "/var/www/html/mop/fs/web_request/handlers.py", line 236, in cgi
    for (key, value) in returned_data[2].items():


{}



On Dec 4, 2012, at 10:31 AM, Gery . <gamejihou at hotmail.com> wrote:Hello,

I'm using GeoAlchemy with FeatureServer, but I'm new using both, so sorry for the very simple questions. This is my model (boreholes.model) for one of my PostGis tables:

*****************************
print "Content-type: text/html\n\n";

from sqlalchemy import *
from sqlalchemy.orm import *
from sqlalchemy.dialects.postgresql import *
from geoalchemy import *
from geoalchemy.postgis import *

engine = create_engine('postgresql://postgres:pass@localhost:5432/map', echo=False)
metadata = MetaData(engine)

session = sessionmaker(bind=engine)()

boreholes_table = Table('boreholes_point_wgs84', metadata,
                        Column('id', SMALLINT, primary_key=True),
                        Column('fid', SMALLINT),
                        Column('longitude', DOUBLE_PRECISION),
                        Column('latitude', DOUBLE_PRECISION),
                        Column('w_depth_m', DOUBLE_PRECISION),
                        Column('station', VARCHAR(150)),
                        Column('type', VARCHAR(150)),
                        Column('survey', VARCHAR(150)),
                        Column('source', VARCHAR(150)),
                        Column('max_pen_m', VARCHAR(150)),
                        Column('core_rec_m', VARCHAR(150)),
                        Column('t_g_ckm1', VARCHAR(150)),
                        Column('h_f_mwm2', VARCHAR(150)),
                        Column('comments', TEXT),
                        GeometryExtensionColumn('geom', Geometry(3)))

class Boreholes(object):
    def __init__ (self, id, fid, longitude, latitude, w_depth_m, station, type, survey, source, max_pen_m, core_rec_m, t_g_ckm1, h_f_mwm2, comments):
        self.id = id
        self.fid = fid
        self.longitude = longitude
        self.latitude = latitude
        self.w_depth_m = w_depth_m
        self.station = station
        self.type = type
        self.survey = survey
        self.source = source
        self.max_pen_m = max_pen_m
        self.core_rec_m = core_rec_m
        self.t_g_ckm1 = t_g_ckm1
        self.h_f_mwm2 = h_f_mwm2
        self.comments = comments

mapper(Boreholes, boreholes_table,
       properties={
                 'geom': GeometryColumn(boreholes_table.c.geom,
                                        comparator=PGComparator)
                  })

GeometryDDL(boreholes_table)

*****************************

and this is what I have in my featureserver.cfg:

*****************************
[boreholes]
type=GeoAlchemy
dburi=postgresql://postgres:pass@localhost:5432/map
model=../model/boreholes.model
cls=boreholes_point_wgs84
fid=id
geometry=geom
*****************************

so what I want is to query this table and output that in GeoJSON format. I'm doing the query in OpenLayers using GeoExt like this:

*****************************
var searchformPanel = new GeoExt.form.FormPanel(
        {
            width: 250,
            bodyStyle: 'padding:5px',
            labelAlign: 'top',
            defaults:
            {
                anchor: '100%'
            },
            protocol: new OpenLayers.Protocol.HTTP(
            {
                url: 'http://www.mop.org/fs/boreholes?format=GeoJSON',
                format: new OpenLayers.Format.GeoJSON(
                {
                    ignoreExtraDims: true,
                    'internalProjection': new OpenLayers.Projection("EPSG:900913"),
                    'externalProjection': new OpenLayers.Projection("EPSG:4326")
                }
                )
            }
            ),
            items:
            [
            {
                xtype: 'textfield',
                name: 'station__like',
                fieldLabel: 'Enter a word',
                allowBlank: false
            }
            ],
...
...
*****************************

by the way, this PostGis table is served by MarServer as WMS, but I think this has nothing to do with the query. So, to do this query I'm sure I need something else related to GeoAlchemy and featureserver itself but not sure what it is, I'd be grateful for some support on this, thanks in advance for any help.

Best regards,

Gery
 
__________________________________________________________________________________________
Piensa en el medio ambiente - mantenlo en la pantalla. NO lo imprimas si NO es necesario.
Think green - keep it on the screen. Do NOT print if it is NOT necessary.
Denken Sie an die Umwelt - bewahren Sie es auf dem Bildschirm. Drucken Sie NICHT, wenn es NICHT notwendig ist.
_______________________________________________
FeatureServer mailing list
FeatureServer at lists.osgeo.org
http://lists.osgeo.org/mailman/listinfo/featureserver

_______________________________________________
FeatureServer mailing list
FeatureServer at lists.osgeo.org
http://lists.osgeo.org/mailman/listinfo/featureserver

 		 	   		  
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/featureserver/attachments/20121205/5cd9d183/attachment-0001.html>


More information about the FeatureServer mailing list