Fix source clean command on CKAN > 2.5, as related don't exist any more

This commit is contained in:
amercader 2016-02-04 13:40:02 +00:00
parent 86edc4209b
commit 6354ad5656
1 changed files with 33 additions and 18 deletions

View File

@ -109,6 +109,9 @@ def harvest_source_clear(context, data_dict):
model = context['model'] model = context['model']
# CKAN-2.6 or above: related don't exist any more
if toolkit.check_ckan_version(max_version='2.5.99'):
sql = '''select id from related where id in ( sql = '''select id from related where id in (
select related_id from related_dataset where dataset_id in ( select related_id from related_dataset where dataset_id in (
select package_id from harvest_object select package_id from harvest_object
@ -194,15 +197,27 @@ def harvest_source_clear(context, data_dict):
select id from package where state = 'to_delete'); select id from package where state = 'to_delete');
delete from member where table_id in ( delete from member where table_id in (
select id from package where state = 'to_delete'); select id from package where state = 'to_delete');
'''.format(
harvest_source_id=harvest_source_id)
if toolkit.check_ckan_version(max_version='2.5.99'):
sql += '''
delete from related_dataset where dataset_id in ( delete from related_dataset where dataset_id in (
select id from package where state = 'to_delete'); select id from package where state = 'to_delete');
delete from related where id in {related_ids}; delete from related where id in {related_ids};
delete from package where id in ( delete from package where id in (
select id from package where state = 'to_delete'); select id from package where state = 'to_delete');
commit; '''.format(related_ids=related_ids)
'''.format( else:
harvest_source_id=harvest_source_id, related_ids=related_ids) # CKAN-2.6 or above: related don't exist any more
sql += '''
delete from package where id in (
select id from package where state = 'to_delete');
'''
sql += '''
commit;
'''
model.Session.execute(sql) model.Session.execute(sql)
# Refresh the index for this source to update the status object # Refresh the index for this source to update the status object