Skip to content

Releases: neo4j/neo4j-ogm

v4.0.6

12 Jul 11:10
Compare
Choose a tag to compare
  • [bug] Fix NullPointerException when parsing notification position from BoltResponse (#950)

v3.2.40

15 Jun 13:44
Compare
Choose a tag to compare
  • Improve Optional handling in FieldInfo.

v4.0.5

04 Apr 11:39
v4.0.5
1b059b3
Compare
Choose a tag to compare
  • [feat] Try to retrieve assigned ids in the optimistic locking checker when internal ids are not available. (#937)
  • [dependencies] Bump neo4j-java-driver from 5.6.0 to 5.7.0
  • [build] Properly configure jvmTarget via ${maven.compiler.release}.

v4.0.4

09 Mar 09:10
v4.0.4
a5e4d44
Compare
Choose a tag to compare
  • [dependencies] Bump neo4j-java-driver from 5.5.0 to 5.6.0
  • [dependencies] Bump classgraph from 4.8.151 to 4.8.156

v4.0.3

20 Feb 09:53
v4.0.3
c088276
Compare
Choose a tag to compare
  • [dependencies] Bump neo4j-java-driver from 5.3.1 to 5.5.0
  • [refactor] Use recent Java compiler plugin.
  • [bug] Remove unused import.
  • [refactor] Add an extension API for custom transaction managers. (#935)
  • [docs] Update link to example project in documentation.

Thanks to @gaurav-bagga for their input and feedback!

v4.0.2

31 Jan 14:05
Compare
Choose a tag to compare
  • bugfix: Checking for possible composite converters in GraphEntityMapper.writeProperty #932 (thanks @oxisto)
  • docs: Add build status badge to README.adoc. #930 (thanks @h1alexbel)
  • refactor: Add missing @OverRide to toString of MappedRelationship. #929 (thanks @h1alexbel)
  • refactor: Migrate to JUnit 5.
  • docs: Add attribute to fix version in code example.

v4.0.1

21 Dec 13:55
Compare
Choose a tag to compare
  • Fix support for collections in constructor mapping.
  • Allow for classes to be registered dynamically with DomainInfo.
  • Check both index and classpath for known entities.
  • Introduce equals/hashCode for Class/FieldInfo.
  • [dependencies] Upgrade to Neo4j Java Driver 5.3.1.
  • [documentation] Update Neo4j-OGM tutorial..

v3.2.39

19 Dec 16:20
v3.2.39
3a3faa5
Compare
Choose a tag to compare
  • Allow for classes to be registered dynamically with DomainInfo.
  • Introduce simple DTO mapping.
  • Fix testing with local instance.
  • Check both index and classpath for known entities
  • Introduce equals/hashCode for Class/FieldInfo.
  • Make use of driver provider in test.
  • Add this branch to GH workflow.
  • Allow dynamic user and database selection.

Dynamic user and database selection works over Bolt only, make sure you have included the right version of the underlying Neo4j-Java-Driver. It might be that you need to pin it in addition to the OGM dependencies. Configuration should work along these lines:

Configuration ogmConfiguration = new Configuration.Builder()
    .uri("neo4j://yourInstance:7687")
    .credentials("neo4j", "verysecret")
    // In case you need this
    // .databaseSelectionProvider(() -> DatabaseSelection.select("anotherDatabase"))
    // Can also be something that picks the data from a JWT, whatever
    .userSelectionProvider(() -> UserSelection.impersonate("theImposter"))
    // Anything else you need
    .build();

SessionFactory sessionFactory = new SessionFactory(ogmConfiguration, "your.packages");

v4.0.0

29 Nov 11:59
Compare
Choose a tag to compare

New baselines

The minimum required versions are Java 17 and Neo4j 5.x.

Removal of Auto Index Manager

The Auto Index Manager that was responsible for creating indexes and constraints out-of-the-box
got removed from the Neo4j-OGM.
Please use tools like Neo4j-Migrations (has support for Neo4j-OGM annotations out of the box) or Liquibase with the Neo4j-Plugin enabled (needs manual scripts for OGM entities) to control your schema. They offer a broader feature set than just focus on indexes and constraints.
Although the functionality was removed, the annotations are still available. Those will stay in place to avoid refactoring your codebase and support Neo4j-Migrations' annotation processor to make the transition easier.

Removal of HTTP and embedded transport support

Since Neo4j 4.x Neo4j-OGM did not offer embedded transport but the module was still available for users connecting to a 3.5.x instance.
Because the baseline of the official supported database was raised to Neo4j 5.x with this release, the embedded option got deprecated.
The HTTP transport mode was removed because it was rarely used and could not compete with the broad feature set that Bolt allows you to have.

v3.2.38

26 Oct 16:24
v3.2.38
346e5b5
Compare
Choose a tag to compare
  • Revert "Avoid unessary creation of builders."
  • Revert "Make reuse of existing builders threadsafe, check for property equality."