2011-04-11 18:23:27 +02:00
|
|
|
import os
|
|
|
|
from logging import getLogger
|
2011-09-30 12:33:36 +02:00
|
|
|
from pylons.i18n import _
|
2011-04-11 18:23:27 +02:00
|
|
|
from genshi.input import HTML
|
|
|
|
from genshi.filters import Transformer
|
|
|
|
|
|
|
|
import ckan.lib.helpers as h
|
|
|
|
|
2011-09-29 16:40:49 +02:00
|
|
|
from ckan.lib.helpers import json
|
|
|
|
|
2011-04-11 18:23:27 +02:00
|
|
|
from ckan.plugins import implements, SingletonPlugin
|
|
|
|
from ckan.plugins import IRoutes, IConfigurer
|
2011-10-28 14:03:31 +02:00
|
|
|
from ckan.plugins import IGenshiStreamFilter
|
2011-09-29 16:40:49 +02:00
|
|
|
from ckan.plugins import IPackageController
|
|
|
|
|
|
|
|
from ckan.logic import ValidationError
|
|
|
|
from ckan.logic.action.update import package_error_summary
|
2011-04-11 18:23:27 +02:00
|
|
|
|
|
|
|
import html
|
|
|
|
|
2011-09-29 16:40:49 +02:00
|
|
|
from ckanext.spatial.lib import save_package_extent
|
|
|
|
|
2011-04-11 18:23:27 +02:00
|
|
|
log = getLogger(__name__)
|
|
|
|
|
2011-04-11 19:04:28 +02:00
|
|
|
class SpatialQuery(SingletonPlugin):
|
|
|
|
|
|
|
|
implements(IRoutes, inherit=True)
|
2011-09-29 16:40:49 +02:00
|
|
|
implements(IPackageController, inherit=True)
|
2011-04-11 19:04:28 +02:00
|
|
|
|
|
|
|
def before_map(self, map):
|
|
|
|
|
2011-10-03 14:39:18 +02:00
|
|
|
map.connect('api_spatial_query', '/api/2/search/{register:dataset|package}/geo',
|
2011-04-11 19:04:28 +02:00
|
|
|
controller='ckanext.spatial.controllers.api:ApiController',
|
|
|
|
action='spatial_query')
|
|
|
|
return map
|
|
|
|
|
2011-09-29 16:40:49 +02:00
|
|
|
def create(self, package):
|
|
|
|
self.check_spatial_extra(package)
|
|
|
|
|
|
|
|
def edit(self, package):
|
|
|
|
self.check_spatial_extra(package)
|
|
|
|
|
|
|
|
def check_spatial_extra(self,package):
|
2011-10-17 00:40:19 +02:00
|
|
|
if not package.id:
|
|
|
|
log.warning('Couldn\'t store spatial extent because no id was provided for the package')
|
|
|
|
return
|
|
|
|
|
|
|
|
# TODO: deleted extra
|
2011-09-29 16:40:49 +02:00
|
|
|
for extra in package.extras_list:
|
|
|
|
if extra.key == 'spatial':
|
|
|
|
if extra.state == 'active':
|
|
|
|
try:
|
|
|
|
log.debug('Received: %r' % extra.value)
|
|
|
|
geometry = json.loads(extra.value)
|
|
|
|
except ValueError,e:
|
|
|
|
error_dict = {'spatial':[u'Error decoding JSON object: %s' % str(e)]}
|
|
|
|
raise ValidationError(error_dict, error_summary=package_error_summary(error_dict))
|
|
|
|
except TypeError,e:
|
|
|
|
error_dict = {'spatial':[u'Error decoding JSON object: %s' % str(e)]}
|
|
|
|
raise ValidationError(error_dict, error_summary=package_error_summary(error_dict))
|
|
|
|
|
|
|
|
try:
|
|
|
|
save_package_extent(package.id,geometry)
|
|
|
|
|
|
|
|
except ValueError,e:
|
|
|
|
error_dict = {'spatial':[u'Error creating geometry: %s' % str(e)]}
|
|
|
|
raise ValidationError(error_dict, error_summary=package_error_summary(error_dict))
|
|
|
|
except Exception, e:
|
|
|
|
error_dict = {'spatial':[u'Error: %s' % str(e)]}
|
|
|
|
raise ValidationError(error_dict, error_summary=package_error_summary(error_dict))
|
|
|
|
|
|
|
|
elif extra.state == 'deleted':
|
|
|
|
# Delete extent from table
|
|
|
|
save_package_extent(package.id,None)
|
|
|
|
|
|
|
|
break
|
|
|
|
|
|
|
|
|
|
|
|
def delete(self, package):
|
|
|
|
save_package_extent(package.id,None)
|
2011-04-11 19:04:28 +02:00
|
|
|
|
|
|
|
|
2011-09-30 12:33:36 +02:00
|
|
|
class DatasetExtentMap(SingletonPlugin):
|
|
|
|
|
|
|
|
implements(IGenshiStreamFilter)
|
|
|
|
implements(IConfigurer, inherit=True)
|
|
|
|
|
|
|
|
def filter(self, stream):
|
|
|
|
from pylons import request, tmpl_context as c
|
|
|
|
routes = request.environ.get('pylons.routes_dict')
|
|
|
|
if routes.get('controller') == 'package' and \
|
|
|
|
routes.get('action') == 'read' and c.pkg.id:
|
|
|
|
|
|
|
|
extent = c.pkg.extras.get('spatial',None)
|
|
|
|
if extent:
|
|
|
|
data = {'extent': extent,
|
|
|
|
'title': _('Geographic extent')}
|
|
|
|
stream = stream | Transformer('body//div[@class="dataset"]')\
|
|
|
|
.append(HTML(html.PACKAGE_MAP % data))
|
|
|
|
stream = stream | Transformer('head')\
|
|
|
|
.append(HTML(html.PACKAGE_MAP_EXTRA_HEADER % data))
|
|
|
|
stream = stream | Transformer('body')\
|
|
|
|
.append(HTML(html.PACKAGE_MAP_EXTRA_FOOTER % data))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return stream
|
|
|
|
|
|
|
|
def update_config(self, config):
|
|
|
|
here = os.path.dirname(__file__)
|
|
|
|
|
|
|
|
template_dir = os.path.join(here, 'templates')
|
|
|
|
public_dir = os.path.join(here, 'public')
|
|
|
|
|
|
|
|
if config.get('extra_template_paths'):
|
|
|
|
config['extra_template_paths'] += ','+template_dir
|
|
|
|
else:
|
|
|
|
config['extra_template_paths'] = template_dir
|
|
|
|
if config.get('extra_public_paths'):
|
|
|
|
config['extra_public_paths'] += ','+public_dir
|
|
|
|
else:
|
|
|
|
config['extra_public_paths'] = public_dir
|
|
|
|
|