2011-03-10 10:45:16 +01:00
|
|
|
import urllib2
|
2011-03-25 18:01:26 +01:00
|
|
|
|
|
|
|
from pylons.i18n import _
|
|
|
|
|
|
|
|
import ckan.lib.helpers as h, json
|
2011-03-09 19:56:55 +01:00
|
|
|
from ckan.lib.base import BaseController, c, g, request, \
|
2011-03-10 15:02:21 +01:00
|
|
|
response, session, render, config, abort, redirect
|
2011-03-22 18:33:58 +01:00
|
|
|
|
|
|
|
from ckan.model import Package
|
|
|
|
|
2011-04-05 14:39:23 +02:00
|
|
|
from ckanext.harvest.lib import *
|
2011-03-09 19:56:55 +01:00
|
|
|
|
|
|
|
class ViewController(BaseController):
|
|
|
|
|
2011-03-10 15:02:21 +01:00
|
|
|
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
|
|
|
|
2011-03-25 18:01:26 +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)
|
2011-04-05 14:39:23 +02:00
|
|
|
|
2011-03-10 16:32:51 +01:00
|
|
|
try:
|
|
|
|
return urllib2.urlopen(http_request)
|
2011-03-10 15:02:21 +01:00
|
|
|
except urllib2.HTTPError as e:
|
2011-03-11 13:35:27 +01:00
|
|
|
raise
|
2011-03-10 16:32:51 +01:00
|
|
|
|
|
|
|
def index(self):
|
2011-04-05 14:39:23 +02:00
|
|
|
# Request all harvest sources
|
|
|
|
c.sources = get_harvest_sources()
|
2011-03-10 16:32:51 +01:00
|
|
|
|
2011-04-05 14:39:23 +02:00
|
|
|
#TODO: show source reports
|
2011-03-10 16:32:51 +01:00
|
|
|
return render('ckanext/harvest/index.html')
|
2011-04-05 14:39:23 +02:00
|
|
|
|
2011-03-09 19:56:55 +01:00
|
|
|
def create(self):
|
2011-03-10 15:02:21 +01:00
|
|
|
|
2011-03-09 19:56:55 +01:00
|
|
|
# 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'
|
2011-03-09 19:56:55 +01:00
|
|
|
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)
|
2011-03-10 15:02:21 +01:00
|
|
|
|
2011-03-09 19:56:55 +01:00
|
|
|
return render('ckanext/harvest/create.html')
|
|
|
|
if request.method == 'POST':
|
2011-03-10 15:02:21 +01:00
|
|
|
# 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)
|
2011-03-11 13:35:27 +01:00
|
|
|
try:
|
|
|
|
r = self._do_request(form_url,data)
|
2011-04-05 14:39:23 +02:00
|
|
|
|
2011-03-11 13:35:27 +01:00
|
|
|
h.flash_success('Harvesting source added successfully')
|
|
|
|
except urllib2.HTTPError as e:
|
|
|
|
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
|
2011-04-05 14:39:23 +02:00
|
|
|
# The form API returns just a 500, so we are not exactly sure of what
|
2011-03-11 13:35:27 +01:00
|
|
|
# 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?'
|
2011-03-11 13:35:27 +01:00
|
|
|
h.flash_error(msg)
|
|
|
|
finally:
|
|
|
|
redirect(h.url_for(controller='harvest', action='index'))
|
2011-04-05 14:39:23 +02:00
|
|
|
|
2011-03-11 13:35:27 +01:00
|
|
|
def show(self,id):
|
2011-04-05 14:39:23 +02:00
|
|
|
c.source = get_harvest_source(id)
|
2011-03-23 18:02:02 +01:00
|
|
|
|
2011-04-05 14:39:23 +02:00
|
|
|
#TODO: show source reports
|
2011-03-11 13:38:09 +01:00
|
|
|
return render('ckanext/harvest/show.html')
|
2011-03-11 13:41:13 +01:00
|
|
|
|
|
|
|
def delete(self,id):
|
2011-03-23 18:02:02 +01:00
|
|
|
try:
|
2011-04-05 14:39:23 +02:00
|
|
|
delete_harvest_source(id)
|
2011-03-23 18:02:02 +01:00
|
|
|
h.flash_success('Harvesting source deleted successfully')
|
2011-04-05 14:39:23 +02:00
|
|
|
except Exception as e:
|
|
|
|
msg = 'An error occurred: [%s]' % e.message
|
2011-03-23 18:02:02 +01:00
|
|
|
h.flash_error(msg)
|
|
|
|
|
2011-03-11 13:41:13 +01:00
|
|
|
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)
|
2011-04-05 14:39:23 +02:00
|
|
|
|
2011-03-11 14:42:21 +01:00
|
|
|
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-04-05 14:39:23 +02:00
|
|
|
|
2011-03-10 18:24:23 +01:00
|
|
|
def create_harvesting_job(self,id):
|
2011-03-11 13:35:27 +01:00
|
|
|
try:
|
2011-04-05 14:39:23 +02:00
|
|
|
create_harvest_job(id)
|
2011-03-11 13:35:27 +01:00
|
|
|
h.flash_success('Refresh requested, harvesting will take place within 15 minutes.')
|
2011-04-05 14:39:23 +02:00
|
|
|
except Exception as e:
|
|
|
|
msg = 'An error occurred: [%s]' % e.message
|
|
|
|
h.flash_error(msg)
|
2011-03-22 18:33:58 +01:00
|
|
|
|
2011-04-05 14:39:23 +02:00
|
|
|
redirect(h.url_for(controller='harvest', action='index', id=None))
|
2011-03-22 18:33:58 +01:00
|
|
|
|
|
|
|
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:
|
2011-03-22 18:33:58 +01:00
|
|
|
abort(404, 'Package not found')
|
|
|
|
|
2011-03-28 10:40:17 +02:00
|
|
|
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')
|
2011-03-22 18:33:58 +01:00
|
|
|
|
2011-03-28 10:40:17 +02:00
|
|
|
return render('ckanext/harvest/map.html')
|
2011-03-22 18:33:58 +01:00
|
|
|
|
|
|
|
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
|