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-04-13 13:46:52 +02:00
|
|
|
api_key = config.get('ckan.harvest.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
|
|
|
|
|
|
|
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-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'],
|
2011-04-12 17:15:14 +02:00
|
|
|
'HarvestSource--description': request.POST['HarvestSource--description'],
|
|
|
|
'HarvestSource--type': request.POST['HarvestSource--type'],
|
|
|
|
},
|
|
|
|
'user_id':'',
|
|
|
|
'publisher_id':''
|
2011-03-10 15:02:21 +01:00
|
|
|
}
|
|
|
|
data = json.dumps(data)
|
2011-03-11 13:35:27 +01:00
|
|
|
try:
|
2011-04-12 17:15:14 +02:00
|
|
|
rq = 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')
|
2011-05-05 17:47:34 +02:00
|
|
|
redirect(h.url_for('harvest'))
|
|
|
|
|
2011-03-11 13:35:27 +01:00
|
|
|
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-04-12 17:15:14 +02:00
|
|
|
elif e.getcode() == 400:
|
2011-04-18 18:19:04 +02:00
|
|
|
err_msg = e.read()
|
|
|
|
if '<form' in c.form:
|
|
|
|
c.form = err_msg
|
|
|
|
c.mode = 'create'
|
|
|
|
return render('ckanext/harvest/create.html')
|
|
|
|
else:
|
|
|
|
msg = err_msg
|
|
|
|
|
|
|
|
h.flash_error(msg)
|
2011-05-05 17:47:34 +02:00
|
|
|
redirect(h.url_for('harvest'))
|
2011-04-05 14:39:23 +02:00
|
|
|
|
2011-03-11 13:35:27 +01:00
|
|
|
def show(self,id):
|
2011-04-11 17:30:56 +02:00
|
|
|
try:
|
|
|
|
c.source = get_harvest_source(id)
|
|
|
|
|
|
|
|
return render('ckanext/harvest/show.html')
|
|
|
|
except:
|
|
|
|
abort(404,'Harvest source not found')
|
2011-03-23 18:02:02 +01:00
|
|
|
|
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-05-05 17:47:34 +02:00
|
|
|
redirect(h.url_for('harvest'))
|
2011-03-11 13:41:13 +01:00
|
|
|
|
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] ,
|
2011-04-12 17:15:14 +02:00
|
|
|
'HarvestSource-%s-type' % id: request.POST['HarvestSource-%s-type' % id],
|
2011-03-11 14:42:21 +01:00
|
|
|
'HarvestSource-%s-description' % id: request.POST['HarvestSource-%s-description' % id]},
|
2011-04-12 17:15:14 +02:00
|
|
|
'user_id':'',
|
|
|
|
'publisher_id':''
|
2011-03-11 14:42:21 +01:00
|
|
|
}
|
|
|
|
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')
|
2011-04-12 17:15:14 +02:00
|
|
|
|
2011-05-05 17:47:34 +02:00
|
|
|
redirect(h.url_for('harvest'))
|
2011-04-12 17:15:14 +02:00
|
|
|
except urllib2.HTTPError as e:
|
|
|
|
if e.getcode() == 400:
|
|
|
|
c.form = e.read()
|
|
|
|
c.mode = 'edit'
|
|
|
|
return render('ckanext/harvest/create.html')
|
|
|
|
else:
|
|
|
|
msg = 'An error occurred: [%s %s]' % (str(e.getcode()),e.msg)
|
|
|
|
h.flash_error(msg)
|
2011-05-05 17:47:34 +02:00
|
|
|
redirect(h.url_for('harvest'))
|
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-05-05 17:47:34 +02:00
|
|
|
redirect(h.url_for('harvest'))
|
2011-03-22 18:33:58 +01:00
|
|
|
|