From 2ad2be87b00a402343e2c29c22e3ffa9d981a6f8 Mon Sep 17 00:00:00 2001 From: Florian Necas Date: Fri, 9 Aug 2024 17:15:06 +0200 Subject: [PATCH 1/2] fix: override only desc and name on role based sync --- .../integration/AbstractGroupSynchronizer.java | 10 +++++++--- .../integration/RolesBasedGroupSynchronizer.java | 8 ++++++++ 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/AbstractGroupSynchronizer.java b/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/AbstractGroupSynchronizer.java index a36b13fe23..852178064f 100644 --- a/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/AbstractGroupSynchronizer.java +++ b/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/AbstractGroupSynchronizer.java @@ -155,15 +155,19 @@ public GroupLink synchronize(CanonicalGroup canonical) { updateLabelTranslations(canonical, group); } + link = externalGroupLinks.save(getSyncElements(group, canonical, link)); + assert link.isUpToDateWith(canonical); + + return link; + } + + protected GroupLink getSyncElements(Group group, CanonicalGroup canonical, GroupLink link) { logoUpdater.synchronize(canonical.getId(), group); group.setName(canonical.getName()); group.setDescription(canonical.getDescription()); group.setWebsite(canonical.getLinkage()); group.setEmail(canonical.getMail()); link.setCanonical(canonical); - link = externalGroupLinks.save(link); - assert link.isUpToDateWith(canonical); - return link; } diff --git a/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/RolesBasedGroupSynchronizer.java b/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/RolesBasedGroupSynchronizer.java index ea2c163f8b..cec1354adc 100644 --- a/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/RolesBasedGroupSynchronizer.java +++ b/georchestra-integration/externalized-accounts/src/main/java/org/geonetwork/security/external/integration/RolesBasedGroupSynchronizer.java @@ -27,6 +27,7 @@ import java.util.stream.IntStream; import java.util.stream.Stream; +import org.fao.geonet.domain.Group; import org.geonetwork.security.external.configuration.ExternalizedSecurityProperties; import org.geonetwork.security.external.model.CanonicalGroup; import org.geonetwork.security.external.model.CanonicalUser; @@ -124,4 +125,11 @@ private boolean doesNotMatchesGeorchestraDefaultRoleNameFilter(CanonicalGroup ro return doesNotMatchesGeorchestraDefaultRoleNameFilter(role.getName()); } + @Override + protected GroupLink getSyncElements(Group group, CanonicalGroup canonical, GroupLink link) { + group.setName(canonical.getName()); + group.setDescription(canonical.getDescription()); + link.setCanonical(canonical); + return link; + } } From d606c18139cd2dde80cfa6ccd15b6cb6b345b375 Mon Sep 17 00:00:00 2001 From: Florian Necas Date: Mon, 12 Aug 2024 10:04:46 +0200 Subject: [PATCH 2/2] fix: tests on roles based sync --- .../security/external/integration/IntegrationTestSupport.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/georchestra-integration/externalized-accounts/src/test/java/org/geonetwork/security/external/integration/IntegrationTestSupport.java b/georchestra-integration/externalized-accounts/src/test/java/org/geonetwork/security/external/integration/IntegrationTestSupport.java index 4da71202a9..261b22b72c 100644 --- a/georchestra-integration/externalized-accounts/src/test/java/org/geonetwork/security/external/integration/IntegrationTestSupport.java +++ b/georchestra-integration/externalized-accounts/src/test/java/org/geonetwork/security/external/integration/IntegrationTestSupport.java @@ -186,7 +186,9 @@ public GroupLink assertGroupLink(CanonicalGroup expected) { public void assertGroup(CanonicalGroup expected, Group actual) { assertEquals(expected.getName(), actual.getName()); assertEquals(expected.getDescription(), actual.getDescription()); - assertEquals(expected.getLinkage(), actual.getWebsite()); + if (!getConfig().getSyncMode().equals(GroupSyncMode.roles)) { + assertEquals(expected.getLinkage(), actual.getWebsite()); + } } public void addGeonetworkGroup(CanonicalGroup g) {