From a94daa4e1b36dfec3db25efa7b3ac195aa74e6b1 Mon Sep 17 00:00:00 2001 From: BernhardKoschicek Date: Fri, 22 Sep 2023 09:26:22 +0200 Subject: [PATCH] ext references for vocabs import hierarchies --- openatlas/api/import_scripts/vocabs.py | 16 +++++++++++----- openatlas/views/vocabs.py | 11 +++++------ 2 files changed, 16 insertions(+), 11 deletions(-) diff --git a/openatlas/api/import_scripts/vocabs.py b/openatlas/api/import_scripts/vocabs.py index 9ef1cb6cf..48b1efc47 100644 --- a/openatlas/api/import_scripts/vocabs.py +++ b/openatlas/api/import_scripts/vocabs.py @@ -37,6 +37,9 @@ def fetch_top_groups( hierarchy, 'custom', form_data['classes'], form_data['multiple']) + exact_match_id = get_exact_match().id + name = group[0].rsplit('/', 1)[-1] + ref.link('P67', hierarchy, name, type_id=exact_match_id) import_member( group[0], id_, @@ -44,8 +47,9 @@ def fetch_top_groups( ref, hierarchy) count.append(group[0]) - if Type.check_hierarchy_exists(group[1]): - duplicates.append(group[0]) + if (Type.check_hierarchy_exists(group[1]) + and group[0] in form_data['top_concepts']): + duplicates.append(group[1]) return count, duplicates @@ -55,7 +59,6 @@ def import_member( lang: str, ref: ReferenceSystem, super_: Optional[Entity], ) -> bool: - exact_match_id = get_exact_match().id req = vocabs_requests(id_, 'groupMembers', {'uri': uri, 'lang': lang}) child = None for member in req['members']: @@ -63,7 +66,7 @@ def import_member( if super_: child = Entity.insert('type', member['prefLabel']) child.link('P127', super_) - ref.link('P67', child, name, type_id=exact_match_id) + ref.link('P67', child, name, type_id=get_exact_match().id) if member['hasMembers']: import_member(member['uri'], id_, lang, ref, child) return True @@ -88,6 +91,9 @@ def fetch_top_level( hierarchy, 'custom', form_data['classes'], form_data['multiple']) + exact_match_id = get_exact_match().id + name = entry['uri'].rsplit('/', 1)[-1] + ref.link('P67', hierarchy, name, type_id=exact_match_id) entry['subs'] = import_children( entry['uri'], id_, @@ -96,7 +102,7 @@ def fetch_top_level( hierarchy) count.append(entry) if Type.check_hierarchy_exists(entry['label']): - duplicates.append(entry) + duplicates.append(entry['label']) return count, duplicates diff --git a/openatlas/views/vocabs.py b/openatlas/views/vocabs.py index d9656ea65..b4e6d5793 100644 --- a/openatlas/views/vocabs.py +++ b/openatlas/views/vocabs.py @@ -160,20 +160,19 @@ class ImportVocabsHierarchyForm(FlaskForm): 'classes': form.classes.data, 'multiple': form.multiple.data, 'language': form.language.data} - try: results = import_vocabs_data(id_, form_data, details, category) count = len(results[0]) Transaction.commit() g.logger.log('info', 'import', f'import: {count} top concepts') - for duplicate in results[1]: - g.logger.log( - 'notice', - 'import', - f'Did not import {duplicate["label"]}, duplicate.') import_str = f"{_('import of')}: {count} {_('top concepts')}" if results[1]: import_str += f'. {_("Check log for not imported concepts")}' + for duplicate in results[1]: + g.logger.log( + 'info', + 'import', + f'Did not import "{duplicate}", duplicate.') flash(import_str, 'info') except Exception as e: # pragma: no cover Transaction.rollback()