2019-12-11 13:23:03 +01:00
|
|
|
from future import standard_library
|
|
|
|
standard_library.install_aliases()
|
2013-02-19 18:02:28 +01:00
|
|
|
import logging
|
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
try:
|
2019-12-11 13:23:03 +01:00
|
|
|
from io import StringIO
|
2017-05-24 13:33:07 +02:00
|
|
|
except ImportError:
|
2019-12-11 13:23:03 +01:00
|
|
|
from io import StringIO
|
2012-10-19 12:19:01 +02:00
|
|
|
|
|
|
|
from pylons import response
|
|
|
|
from pkg_resources import resource_stream
|
|
|
|
from lxml import etree
|
|
|
|
|
2011-09-29 16:41:45 +02:00
|
|
|
from ckan.lib.base import request, config, abort
|
2011-05-26 16:34:21 +02:00
|
|
|
from ckan.controllers.api import ApiController as BaseApiController
|
2012-10-19 12:19:01 +02:00
|
|
|
from ckan.model import Session
|
2011-04-11 19:04:28 +02:00
|
|
|
|
2013-02-19 18:02:28 +01:00
|
|
|
from ckanext.harvest.model import HarvestObject, HarvestObjectExtra
|
2011-12-13 18:40:47 +01:00
|
|
|
from ckanext.spatial.lib import get_srid, validate_bbox, bbox_query
|
2011-04-11 19:04:28 +02:00
|
|
|
|
2013-02-19 18:02:28 +01:00
|
|
|
log = logging.getLogger(__name__)
|
2011-04-11 19:04:28 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
|
2011-04-11 19:04:28 +02:00
|
|
|
class ApiController(BaseApiController):
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2011-04-11 19:04:28 +02:00
|
|
|
def spatial_query(self):
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
error_400_msg = \
|
|
|
|
'Please provide a suitable bbox parameter [minx,miny,maxx,maxy]'
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2011-04-11 19:04:28 +02:00
|
|
|
if not 'bbox' in request.params:
|
2017-05-24 13:33:07 +02:00
|
|
|
abort(400, error_400_msg)
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2011-12-13 18:40:47 +01:00
|
|
|
bbox = validate_bbox(request.params['bbox'])
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2011-12-13 18:40:47 +01:00
|
|
|
if not bbox:
|
2017-05-24 13:33:07 +02:00
|
|
|
abort(400, error_400_msg)
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
srid = get_srid(request.params.get('crs')) if 'crs' in \
|
|
|
|
request.params else None
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
extents = bbox_query(bbox, srid)
|
2011-09-29 16:41:45 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
format = request.params.get('format', '')
|
2011-12-13 18:40:47 +01:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
return self._output_results(extents, format)
|
2011-12-13 18:40:47 +01:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
def _output_results(self, extents, format=None):
|
2011-11-14 19:00:56 +01:00
|
|
|
|
2011-09-29 16:41:45 +02:00
|
|
|
ids = [extent.package_id for extent in extents]
|
2017-05-24 13:33:07 +02:00
|
|
|
output = dict(count=len(ids), results=ids)
|
2011-04-11 19:04:28 +02:00
|
|
|
|
2011-09-29 16:41:45 +02:00
|
|
|
return self._finish_ok(output)
|
2012-10-19 12:19:01 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
|
2012-10-19 12:19:01 +02:00
|
|
|
class HarvestMetadataApiController(BaseApiController):
|
|
|
|
|
2013-02-19 18:02:28 +01:00
|
|
|
def _get_content(self, id):
|
2012-10-19 12:19:01 +02:00
|
|
|
|
|
|
|
obj = Session.query(HarvestObject) \
|
2017-05-24 13:33:07 +02:00
|
|
|
.filter(HarvestObject.id == id).first()
|
2013-02-19 18:02:28 +01:00
|
|
|
if obj:
|
|
|
|
return obj.content
|
|
|
|
else:
|
|
|
|
return None
|
2012-10-19 12:19:01 +02:00
|
|
|
|
2013-02-19 18:02:28 +01:00
|
|
|
def _get_original_content(self, id):
|
|
|
|
extra = Session.query(HarvestObjectExtra).join(HarvestObject) \
|
2017-05-24 13:33:07 +02:00
|
|
|
.filter(HarvestObject.id == id) \
|
|
|
|
.filter(
|
|
|
|
HarvestObjectExtra.key == 'original_document'
|
|
|
|
).first()
|
2013-02-19 18:02:28 +01:00
|
|
|
if extra:
|
|
|
|
return extra.value
|
|
|
|
else:
|
|
|
|
return None
|
2012-10-19 12:19:01 +02:00
|
|
|
|
2013-02-19 18:02:28 +01:00
|
|
|
def _transform_to_html(self, content, xslt_package=None, xslt_path=None):
|
2012-10-19 12:19:01 +02:00
|
|
|
|
2017-05-30 17:04:38 +02:00
|
|
|
xslt_package = xslt_package or __name__
|
2017-05-24 13:33:07 +02:00
|
|
|
xslt_path = xslt_path or \
|
2017-05-30 17:04:38 +02:00
|
|
|
'../templates/ckanext/spatial/gemini2-html-stylesheet.xsl'
|
2012-10-19 12:19:01 +02:00
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
# optimise -- read transform only once and compile rather
|
|
|
|
# than at each request
|
2013-02-19 18:02:28 +01:00
|
|
|
with resource_stream(xslt_package, xslt_path) as style:
|
2012-10-19 12:19:01 +02:00
|
|
|
style_xml = etree.parse(style)
|
|
|
|
transformer = etree.XSLT(style_xml)
|
2013-02-19 18:02:28 +01:00
|
|
|
|
|
|
|
xml = etree.parse(StringIO(content.encode('utf-8')))
|
2012-10-19 12:19:01 +02:00
|
|
|
html = transformer(xml)
|
|
|
|
|
2013-02-19 18:02:28 +01:00
|
|
|
response.headers['Content-Type'] = 'text/html; charset=utf-8'
|
|
|
|
response.headers['Content-Length'] = len(content)
|
|
|
|
|
|
|
|
result = etree.tostring(html, pretty_print=True)
|
|
|
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
def _get_xslt(self, original=False):
|
|
|
|
|
|
|
|
if original:
|
2017-05-24 13:33:07 +02:00
|
|
|
config_option = \
|
|
|
|
'ckanext.spatial.harvest.xslt_html_content_original'
|
2013-02-19 18:02:28 +01:00
|
|
|
else:
|
|
|
|
config_option = 'ckanext.spatial.harvest.xslt_html_content'
|
|
|
|
|
|
|
|
xslt_package = None
|
|
|
|
xslt_path = None
|
|
|
|
xslt = config.get(config_option, None)
|
|
|
|
if xslt:
|
|
|
|
if ':' in xslt:
|
|
|
|
xslt = xslt.split(':')
|
|
|
|
xslt_package = xslt[0]
|
|
|
|
xslt_path = xslt[1]
|
|
|
|
else:
|
2017-05-24 13:33:07 +02:00
|
|
|
log.error(
|
|
|
|
'XSLT should be defined in the form <package>:<path>' +
|
|
|
|
', eg ckanext.myext:templates/my.xslt')
|
2013-02-19 18:02:28 +01:00
|
|
|
|
|
|
|
return xslt_package, xslt_path
|
|
|
|
|
|
|
|
def display_xml_original(self, id):
|
|
|
|
content = self._get_original_content(id)
|
|
|
|
|
|
|
|
if not content:
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
response.headers['Content-Type'] = 'application/xml; charset=utf-8'
|
|
|
|
response.headers['Content-Length'] = len(content)
|
|
|
|
|
2013-03-01 18:31:28 +01:00
|
|
|
if not '<?xml' in content.split('\n')[0]:
|
|
|
|
content = u'<?xml version="1.0" encoding="UTF-8"?>\n' + content
|
2013-02-19 18:02:28 +01:00
|
|
|
return content.encode('utf-8')
|
|
|
|
|
2017-05-24 13:33:07 +02:00
|
|
|
def display_html(self, id):
|
2013-02-19 18:02:28 +01:00
|
|
|
content = self._get_content(id)
|
|
|
|
|
|
|
|
if not content:
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
xslt_package, xslt_path = self._get_xslt()
|
|
|
|
return self._transform_to_html(content, xslt_package, xslt_path)
|
|
|
|
|
|
|
|
def display_html_original(self, id):
|
|
|
|
content = self._get_original_content(id)
|
|
|
|
|
|
|
|
if content is None:
|
|
|
|
abort(404)
|
|
|
|
|
|
|
|
xslt_package, xslt_path = self._get_xslt(original=True)
|
|
|
|
return self._transform_to_html(content, xslt_package, xslt_path)
|