From bba45e955a0dd58cda22e7d928c7b5e9fe9e5f5c Mon Sep 17 00:00:00 2001 From: Florian Necas Date: Wed, 20 Nov 2024 15:46:39 +0100 Subject: [PATCH] Merge pull request #304 from georchestra/domain-change-type-of-column-to-abritrary-long-text domain - set some columns to arbitrary length (TEXT type) --- .github/pull_request_template.md | 2 +- .github/workflows/georchestra-gn4.yml | 1 - .../java/org/fao/geonet/domain/Group.java | 27 +++---------------- .../domain/external/ExternalGroupLink.java | 14 +++++----- georchestra-migration/migration-dev-guide.md | 20 +++++++------- 5 files changed, 22 insertions(+), 42 deletions(-) diff --git a/.github/pull_request_template.md b/.github/pull_request_template.md index 787605aca7..16f3491639 100644 --- a/.github/pull_request_template.md +++ b/.github/pull_request_template.md @@ -4,5 +4,5 @@ - [ ] PR only involves cherry-picked commits from upstream. - [ ] PR contains custom code which will soon be available in an upstream release and can be overriden => mention core-geonetwork version if possible. - [ ] PR contains custom geOrchestra code, which need to be verified during future migrations. - - [ ] I have properly filled the [migration-helper-changelog.md](../georchestra-migration/migration-helper-changelog.md) file. + - [ ] I have properly filled the [migration-dev-guide.md](/georchestra/geonetwork/blob/georchestra-gn4.4.x/georchestra-migration/migration-dev-guide.md) file. diff --git a/.github/workflows/georchestra-gn4.yml b/.github/workflows/georchestra-gn4.yml index 12d0637404..fb256ff9d9 100644 --- a/.github/workflows/georchestra-gn4.yml +++ b/.github/workflows/georchestra-gn4.yml @@ -61,4 +61,3 @@ jobs: with: name: geonetwork.war path: web/target/geonetwork.war - diff --git a/domain/src/main/java/org/fao/geonet/domain/Group.java b/domain/src/main/java/org/fao/geonet/domain/Group.java index 333b36a167..8327389391 100644 --- a/domain/src/main/java/org/fao/geonet/domain/Group.java +++ b/domain/src/main/java/org/fao/geonet/domain/Group.java @@ -31,28 +31,8 @@ import javax.annotation.Nonnull; import javax.annotation.Nullable; -import javax.persistence.Access; -import javax.persistence.AccessType; -import javax.persistence.Cacheable; -import javax.persistence.CascadeType; -import javax.persistence.CollectionTable; -import javax.persistence.Column; -import javax.persistence.Convert; -import javax.persistence.ElementCollection; -import javax.persistence.Entity; -import javax.persistence.EntityListeners; -import javax.persistence.FetchType; -import javax.persistence.GeneratedValue; -import javax.persistence.GenerationType; -import javax.persistence.Id; -import javax.persistence.JoinColumn; -import javax.persistence.JoinTable; -import javax.persistence.ManyToMany; -import javax.persistence.ManyToOne; -import javax.persistence.MapKeyColumn; -import javax.persistence.SequenceGenerator; -import javax.persistence.Table; -import javax.persistence.Transient; +import javax.persistence.*; + import org.fao.geonet.domain.converter.BooleanToYNConverter; import org.fao.geonet.entitylistener.GroupEntityListenerManager; @@ -141,7 +121,7 @@ public Group setName(String name) { * * @return the description. */ - @Column(length = 255) + @Column(columnDefinition = "TEXT") public String getDescription() { return _description; } @@ -245,6 +225,7 @@ public boolean isReserved() { * @return the filename of the logo or null if there is no logo associated with this group. */ @Nullable + @Column(columnDefinition = "TEXT") public String getLogo() { return logo; } diff --git a/domain/src/main/java/org/fao/geonet/domain/external/ExternalGroupLink.java b/domain/src/main/java/org/fao/geonet/domain/external/ExternalGroupLink.java index 2106a57a2f..5554fdd241 100644 --- a/domain/src/main/java/org/fao/geonet/domain/external/ExternalGroupLink.java +++ b/domain/src/main/java/org/fao/geonet/domain/external/ExternalGroupLink.java @@ -20,12 +20,7 @@ import java.util.Objects; -import javax.persistence.Access; -import javax.persistence.AccessType; -import javax.persistence.Entity; -import javax.persistence.Id; -import javax.persistence.OneToOne; -import javax.persistence.Table; +import javax.persistence.*; import org.fao.geonet.domain.Group; @@ -55,6 +50,7 @@ public enum GroupSyncMode { private String externalId; private GroupSyncMode origin; private String name; + private String description; private String linkage; private String lastUpdated; @@ -108,6 +104,12 @@ public ExternalGroupLink setName(String name) { return this; } + /** + * Note: this is not portable, as the TEXT definition does not + * exist on all DBMS. But considering geOrchestra, we are supposed + * to rely on a PostGreSQL server. + */ + @Column(columnDefinition = "TEXT") public String getDescription() { return description; } diff --git a/georchestra-migration/migration-dev-guide.md b/georchestra-migration/migration-dev-guide.md index f2ce88f72b..97fd1f2c82 100644 --- a/georchestra-migration/migration-dev-guide.md +++ b/georchestra-migration/migration-dev-guide.md @@ -1,6 +1,6 @@ # Geonetwork migration in Georchestra -This document aims to help simplify future migration for geonetwork in Georchestra. +This document aims to help simplify future migration for geonetwork in Georchestra. ## Upgrade Process @@ -17,14 +17,12 @@ A more detailed guide is available in [upgrade_geonetwork.md](upgrade_geonetwork ## Georchestra custom implementations -### Georchestra 4.2.7 and Gn 4.2.7 - -All versions in `pom.xml` files must be updated. E.g. for this version `4.2.7-georchestra`. +All versions in `pom.xml` files must be updated. E.g. for this version `4.4.5-georchestra`. All italic folder just have the `pom.xml` change. - .github - workflows `linux.yml` `mvn-dep-tree.yml` `sonarcloud.yml` `dependabot.yml` are deleted. Only `georchestra-gn4.yml` is used -- *cachingxslt* +- *cachingxslt* - common - `ZipUtilTest.java` : In `assertExampleZip` method, assertions which are supposed check folders must check with trailing slash too. - core @@ -37,17 +35,18 @@ All italic folder just have the `pom.xml` change. - `CswFilter2Es.java` : Keep `{@}` instead of `%s` until it is fixed upstream (not supporting some CSW request) - `CswFilter2EsTest.java` : Keep `{@}` instead of `%s` - `SearchController.java` : Keep `{@}` instead of `%s` with StringUtils.replace -- **docker** +- **docker** - Mandatory, get everything from geOrchestra - *docs* - *doi* - domain - - ExternalGroupLink.java : get file from geOrchestra - - ExternalUserLink.java : get file from geOrchestra + - `ExternalGroupLink.java` : get file from geOrchestra + - `ExternalUserLink.java` : get file from geOrchestra + - `Group.java` : set column definition to `TEXT` (which is PostGreSQL specific) on `description` and `logo` - *es* - *estest* - *events* -- **georchestra-integration** +- **georchestra-integration** - Mandatory, get everything from geOrchestra - harvesters - `Harvester.java`: Use parseJDK11 method @@ -115,7 +114,7 @@ All italic folder just have the `pom.xml` change. - `src/main/resources/catalog/views/georchestra/`: Get files from georchestra - *workers* - *wro4j* -- .gitignore +- .gitignore - add idea and settings to it - pom.xml - Implement JDK 11 specific things, add georchestra-integration module, set db-type @@ -127,4 +126,3 @@ All italic folder just have the `pom.xml` change. A branch has been created from core-geonetwork 4.2.7 tag and merged into `georchestra-gn4.2.x`. All conflicts files have been resolved with taking gn changes and not grochestra's one. Then changes have been reimplemented. -