Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/outr/neo4akka
Neo4j Scala client using Akka-Http
https://github.com/outr/neo4akka
Last synced: about 2 months ago
JSON representation
Neo4j Scala client using Akka-Http
- Host: GitHub
- URL: https://github.com/outr/neo4akka
- Owner: outr
- Created: 2016-06-26T12:13:41.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-03-09T15:50:08.000Z (almost 8 years ago)
- Last Synced: 2024-10-30T15:50:44.711Z (2 months ago)
- Language: Scala
- Homepage:
- Size: 22.5 KB
- Stars: 15
- Watchers: 8
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-scala - neo4akka ★ 6 ⧗ 117 - Neo4j Scala client using Akka HTTP with compile-time query interpolation, case class support, true non-blocking IO, and much more. (Database)
README
# neo4akka
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/43729f4be7514d6e82c27a9495ab296d)](https://www.codacy.com/app/matthicks/neo4akka?utm_source=github.com&utm_medium=referral&utm_content=outr/neo4akka&utm_campaign=badger)
[![Build Status](https://travis-ci.org/outr/neo4akka.svg?branch=master)](https://travis-ci.org/outr/neo4akka)
[![Stories in Ready](https://badge.waffle.io/outr/neo4akka.png?label=ready&title=Ready)](https://waffle.io/outr/neo4akka)
[![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/outr/neo4akka)
[![Maven Central](https://img.shields.io/maven-central/v/com.outr/neo4akka_2.11.svg)](https://maven-badges.herokuapp.com/maven-central/com.outr/neo4akka_2.11)Neo4j client for Scala using Akka-Http
All existing Scala clients try to be too clever adding obfuscation on top of the communication, creating a limiting DSL, or not using true non-blocking communication.
At its core this client will attempt to be a very clean and representative client allowing full use of Neo4j with Akka-Http in an entirely non-blocking way while still remaining true to the Cypher query language.
## Status
Fully functional API that supports the majority of use-cases but ongoing development is still happening to make it more
useful and convenient.## Features for 1.0.0
* [X] Asynchronous, true non-blocking IO with Akka HTTP
* [X] Cypher String Interpolator
* [X] Cypher Query Parser
* [X] Cypher Query Parser via Macro on Interpolation at compile-time
* [X] Structured QueryResponse
* [X] Macro support for extracting case class from QueryResponse## Features for 1.1.0
* [ ] Insert and update from case class into database
* [ ] Transactions
* [ ] Practical Pagination support## Documentation
In desperate need of help. For now just look at the tests until we can get the first release finished.
## Setup
neo4akka is published to Sonatype OSS and Maven Central and supports JVM with 2.11 and 2.12:
```
libraryDependencies += "com.outr" %% "neo4akka" % "1.0.1"
```## Using
### Imports
The only import necessary to use neo4akka is the following import along with an execution context for futures:
```scala
import com.outr.neo4akka._import scala.concurrent.ExecutionContext.Implicits.global
```### Creating a Session
Supply the host, port, and credentials to validate and establish a session with neo4j:
```scala
val sessionFuture[Future[Neo4Akka]] = Neo4Akka("localhost", 7474, "neo4j", "password")
```### Creating a Query
With neo4akka's powerful Cypher language interpolation (uses neo4j's built-in query validation) we can create compile-time
validated Cypher queries with ease:```scala
val name = "Tom Hanks"
val query = cypher"MATCH (p: Person {name: $name}) RETURN p"
```If the query is malformed compilation will fail and injected arguments are properly assigned to the argument list for sending
to the database as unique arguments.### Executing a Query
Since our `Neo4Akka` instance may or may not have completed yet, we can `flatMap` the `Future` in order to execute the
query against the database and get back a `Future[ResultSet]`. For the purposes of this example, we'll simply do a blocking
`Await` to get the `ResultSet`:```scala
val resultSetFuture[Future[ResultSet]] = sessionFuture.flatMap(session => session(query))
val resultSet: ResultSet = Await.result(request, Duration.Inf)
```### Processing Results
Now that we have a `ResultSet` we can access the return `p` from our query by name and use a compile-time Macro to populate
a case class `Person` with the values:```scala
case class Person(name: String, born: Int)val people: Vector[Person] = resultSet("p")[Person]
```### Disposing
Because neo4akka uses Akka Actors internally, it must be properly disposed to release the `ActorSystem` and `ActorMaterializer`.
Note: An instance of `Neo4Akka` uses Akka HTTP for true asynchronous non-blocking IO, so there is no state or unsafe reference
information stored in the `session`.```scala
sessionFuture.map(_.dispose())
```