diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2020-01-03 17:26:41 +0100 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2020-01-03 17:26:41 +0100 |
commit | 13cc881d6eb1da1ab4abed8dc11d2574ce37edda (patch) | |
tree | 0ff4927ac85605a24df691361e8306175abfbefb /ishtar_common/views.py | |
parent | 93b83586f6b291ac4c4b2ac30ceb96aede1cf650 (diff) | |
download | Ishtar-13cc881d6eb1da1ab4abed8dc11d2574ce37edda.tar.bz2 Ishtar-13cc881d6eb1da1ab4abed8dc11d2574ce37edda.zip |
Extra actions: regenerate external_id
Diffstat (limited to 'ishtar_common/views.py')
-rw-r--r-- | ishtar_common/views.py | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/ishtar_common/views.py b/ishtar_common/views.py index 7b7a890fb..b44e07f48 100644 --- a/ishtar_common/views.py +++ b/ishtar_common/views.py @@ -65,7 +65,7 @@ from ishtar_common.models import get_current_profile from ishtar_common.templatetags.link_to_window import simple_link_to_window from ishtar_common.utils import clean_session_cache, CSV_OPTIONS, \ get_field_labels_from_path, get_random_item_image_link, shortify, \ - dict_to_tuple, put_session_message + dict_to_tuple, put_session_message, get_model_by_slug from ishtar_common.widgets import JQueryAutoComplete from .views_item import CURRENT_ITEM_KEYS, CURRENT_ITEM_KEYS_DICT, \ @@ -973,6 +973,24 @@ def merge_action(model, form, key): return merge +def regenerate_external_id(request): + if not request.user.is_superuser: + raise Http404() + model = None + for key in request.GET: + model = get_model_by_slug(key) + if model: + break + if not model: + raise Http404() + try: + item = model.objects.get(pk=request.GET[model.SLUG]) + except model.DoesNotExist: + raise Http404() + item.regenerate_external_id() + return HttpResponseRedirect(reverse("success")) + + person_merge = merge_action(models.Person, forms.MergePersonForm, 'person') organization_merge = merge_action( models.Organization, |