harvester-d4science/ckanext/harvest/controllers/view.py

206 lines
7.2 KiB
Python
Raw Normal View History

2011-03-10 10:45:16 +01:00
import urllib2
from pylons.i18n import _
import ckan.lib.helpers as h, json
from ckan.lib.base import BaseController, c, g, request, \
response, session, render, config, abort, redirect
from ckan.model import Package
class ViewController(BaseController):
api_url = config.get('ckan.api_url', 'http://localhost:5000').rstrip('/')+'/api/2/rest'
2011-03-10 17:48:50 +01:00
form_api_url = config.get('ckan.api_url', 'http://localhost:5000').rstrip('/')+'/api/2/form'
2011-03-10 16:32:51 +01:00
api_key = config.get('ckan.harvesting.api_key')
2011-03-10 10:45:16 +01:00
def __before__(self, action, **env):
super(ViewController, self).__before__(action, **env)
# All calls to this controller must be with a sysadmin key
if not self.authorizer.is_sysadmin(c.user):
response_msg = _('Not authorized to see this page')
status = 401
abort(status, response_msg)
2011-03-10 16:32:51 +01:00
def _do_request(self,url,data = None):
2011-03-10 10:45:16 +01:00
2011-03-10 16:32:51 +01:00
http_request = urllib2.Request(
url = url,
headers = {'Authorization' : self.api_key}
)
if data:
http_request.add_data(data)
try:
return urllib2.urlopen(http_request)
except urllib2.HTTPError as e:
raise
2011-03-10 16:32:51 +01:00
def index(self):
# Request all harvesting sources
sources_url = self.api_url + '/harvestsource'
2011-03-15 17:19:13 +01:00
try:
doc = self._do_request(sources_url).read()
2011-03-10 16:32:51 +01:00
2011-03-15 17:19:13 +01:00
sources_ids = json.loads(doc)
2011-03-10 16:32:51 +01:00
2011-03-15 17:19:13 +01:00
source_url = sources_url + '/%s'
sources = []
# For each source, request its details
for source_id in sources_ids:
doc = self._do_request(source_url % source_id).read()
sources.append(json.loads(doc))
c.sources = sources
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
h.flash_error(msg)
except urllib2.URLError as e:
msg = 'Could not find server %r: %r' % (sources_url, e)
h.flash_error(msg)
2011-03-15 17:19:13 +01:00
2011-03-10 16:32:51 +01:00
return render('ckanext/harvest/index.html')
def create(self):
# This is the DGU form API, so we don't use self.api_url
2011-03-10 17:48:50 +01:00
form_url = self.form_api_url + '/harvestsource/create'
if request.method == 'GET':
2011-03-23 18:02:02 +01:00
try:
# Request the fields
c.form = self._do_request(form_url).read()
c.mode = 'create'
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
h.flash_error(msg)
return render('ckanext/harvest/create.html')
if request.method == 'POST':
# Build an object like the one expected by the DGU form API
data = {
'form_data':
{'HarvestSource--url': request.POST['HarvestSource--url'],
'HarvestSource--description': request.POST['HarvestSource--description']},
'user_ref':'',
'publisher_ref':''
}
data = json.dumps(data)
try:
r = self._do_request(form_url,data)
h.flash_success('Harvesting source added successfully')
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
# The form API returns just a 500, so we are not exactly sure of what
# happened, but most probably it was a duplicate entry
2011-03-11 14:42:21 +01:00
if e.getcode() == 500:
msg = msg + ' Does the source already exist?'
h.flash_error(msg)
finally:
redirect(h.url_for(controller='harvest', action='index'))
def show(self,id):
sources_url = self.api_url + '/harvestsource/%s' % id
2011-03-23 18:02:02 +01:00
try:
doc = self._do_request(sources_url).read()
c.source = json.loads(doc)
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
h.flash_error(msg)
2011-03-11 13:38:09 +01:00
return render('ckanext/harvest/show.html')
def delete(self,id):
form_url = self.form_api_url + '/harvestsource/delete/%s' % id
2011-03-23 18:02:02 +01:00
try:
r = self._do_request(form_url)
2011-03-23 18:02:02 +01:00
h.flash_success('Harvesting source deleted successfully')
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
h.flash_error(msg)
redirect(h.url_for(controller='harvest', action='index', id=None))
2011-03-11 14:42:21 +01:00
def edit(self,id):
form_url = self.form_api_url + '/harvestsource/edit/%s' % id
if request.method == 'GET':
# Request the fields
c.form = self._do_request(form_url).read()
c.mode = 'edit'
return render('ckanext/harvest/create.html')
if request.method == 'POST':
# Build an object like the one expected by the DGU form API
data = {
'form_data':
{'HarvestSource-%s-url' % id: request.POST['HarvestSource-%s-url' % id] ,
'HarvestSource-%s-description' % id: request.POST['HarvestSource-%s-description' % id]},
'user_ref':'',
'publisher_ref':''
}
data = json.dumps(data)
try:
r = self._do_request(form_url,data)
h.flash_success('Harvesting source edited successfully')
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
h.flash_error(msg)
finally:
redirect(h.url_for(controller='harvest', action='index', id=None))
2011-03-10 18:24:23 +01:00
def create_harvesting_job(self,id):
2011-03-10 17:48:50 +01:00
form_url = self.api_url + '/harvestingjob'
data = {
2011-03-10 18:24:23 +01:00
'source_id': id,
2011-03-10 17:48:50 +01:00
'user_ref': ''
}
data = json.dumps(data)
try:
r = self._do_request(form_url,data)
h.flash_success('Refresh requested, harvesting will take place within 15 minutes.')
except urllib2.HTTPError as e:
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
if e.getcode() == 400:
msg = msg + ' ' + e.read()
h.flash_error(msg)
finally:
redirect(h.url_for(controller='harvest', action='index', id=None))
def map_view(self,id):
#check if package exists
2011-03-23 11:00:39 +01:00
c.pkg = Package.get(id)
if c.pkg is None:
abort(404, 'Package not found')
for res in c.pkg.resources:
if res.format == "WMS":
c.wms = res
break
if not c.wms:
abort(400, 'This package does not have a WMS')
return render('ckanext/harvest/map.html')
def proxy(self):
if not 'url' in request.params:
abort(400)
try:
server_response = urllib2.urlopen(request.params['url'])
headers = server_response.info()
if headers.get('Content-Type'):
response.content_type = headers.get('Content-Type')
return server_response.read()
except urllib2.HTTPError as e:
response.status_int = e.getcode()
return