Neocons now uses Cheshire 5.x.
Keys with colons are now handled correctly (as of Urly 2.0.0-alpha5
).
Neocons now correctly encodes all parts of URIs, which means index keys and values can contain whitespace and Unicode characters, for example.
GH issue: #20
Neocons now uses clj-http 0.6.4.
Neocons now uses ClojureWerkz Support 0.12.0.
Neocons now uses ClojureWerkz Support 0.10.0.
Neocons now uses clj-http 0.6.3.
clojurewerkz.neocons.rest.relationship/maybe-create
now correctly works with node ids
as well as Node
records.
GH issue: #19.
HTTP exceptions bubbling up now will carry more information (namely the response :body
).
Contributed by Adrian Gruntkowski.
clojurewerkz.neocons.rest.relationships/get-many
is a new function that fetches multiple relationships
by id in a single request:
(require '[clojurewerkz.neocons.rest.relationships :as rel])
(rel/get-many [id1 id2 id3])
Contributed by Adrian Gruntkowski.
Neocons now has initial support for the Neo4J Spatial plugin in the clojurewerkz.neocons.spatial
namespace.
Contributed by Kyle Goodwin.
Neocons now uses (and depends on) Cheshire for JSON serialization. clojure.data.json is no longer a dependency.
Neocons now depends on org.clojure/clojure
version 1.4.0
. It is still compatible with Clojure 1.3 and if your project.clj
depends
on 1.3, it will be used, but 1.4 is the default now.
We encourage all users to upgrade to 1.4, it is a drop-in replacement for the majority of projects out there.
clojurewerkz.neocons.rest.nodes/create-index
now correctly passes index configuration
to Neo4J Server. Reported in #6.
Neocons now uses clj-http 0.5.5.
clojurewerkz.neocons.rest.nodes/create-unique-in-index
and clojurewerkz.neocons.rest.relationships/create-unique-in-index
are
two functions that create a node (relationship) and add it to an index while ensuring entry uniqueness atomically.
Contributed by Zhemin Lin.
clojurewerkz.neocons.rest.batch/perform
allows for executing any sequence of operations in batch using Neo4J REST API for batch operations:
(ns clojurewerkz.neocons.examples
(:require [clojurewerkz.neocons.rest :as neorest]
[clojurewerkz.neocons.rest.batch :as b]))
(neorest/connect! "http://localhost:7474/db/data/")
(let [ops [{:method "POST"
:to "/node"
:body {}
:id 0}
{:method "POST"
:to "/node"
:body {}
:id 1}
{:method "POST",
:to "{0}/relationships",
:body {:to "{1}"
:data {}
:type "knows"}
:id 2}]
res (doall (b/perform ops))]
(println res))
This is a relatively low level function. It is reasonable to expect an easier to use way of executing batch operations in future versions of Neocons.
A new function, clojurewerkz.neocons.rest.nodes/create-batch
, can be used to efficiently insert a large number of nodes
at the same time (up to hundreds of thousands or millions).
It returns a lazy sequence of results, which both makes it more memory efficient and may require forcing the evaluation
with clojure.core/doall
in some cases.
clojurewerkz.neocons.rest.nodes/create-index
now accepts a new configuration option: :unique
, which makes
the index unique (that allows/guarantees only one entry per key).
clojurewerkz.neocons.rest.relationships/create-index
works the same way.
clojurewerkz.neocons.rest.nodes/add-to-index
and
clojurewerkz.neocons.rest.relationships/add-to-index
now take an additional (optional) argument that, when set to true,
will add the entity to the index as unique
This include clojurewerkz.neocons.rest.relationships/create-index
, clojurewerkz.neocons.rest.relationships/add-to-index
and other functions that are clojurewerkz.neocons.rest.nodes
counterparts but for relationships.
Thanks to Neo4J Server's consistent REST API, indexes support for relationships is almost identical to that on nodes.
We started working on documentation guides for Neocons at clojureneo4j.info
clojurewerkz.neocons.rest.relationships/create
is now more robust and handles cases when given nodes
may only have :id
set on them. This may happen in part a regression and in part because of edge cases
in the REST API in our own code.
Neocons now uses clj-http 0.4.0.
clojurewerkz.neocons.rest.nodes/find-one
finds a single node in an index. Supposed to be used with
unique indexes.
clojurewerkz.neocons.rest.relationships/replace-outgoing
deletes outgoing relationships of a certain
type on a node and creates new relationships of the same type with another set of nodes.
clojurewerkz.neocons.rest.nodes/destroy-many
is a new function that destroys multiple nodes using
clojurewerkz.neocons.rest.nodes/destroy
A new function that purges all node relationships and immediately deletes the node using clojurewerkz.neocons.rest.nodes/delete
.
clojurewerkz.neocons.rest.relationships/delete-many
deletes multiple relationships using
clojurewerkz.neocons.rest.relationships/delete
.
clojurewerkz.neocons.rest.nodes/delete-many
is a new function that deletes multiple nodes using
clojurewerkz.neocons.rest.nodes/delete
. For a node to be deleted, it must have no relationships.
To purge all node relationships and immediately delete the node, use clojurewerkz.neocons.rest.nodes/destroy
.
clojurewerkz.neocons.rest.nodes/delete
, /update
and /set-property
are now polymorhic: they accept
both clojurewerkz.neocons.rest.record.Node
instances and node ids as longs.
clojurewerkz.neocons.rest.nodes/multi-get
has been renamed to clojurewerkz.neocons.rest.nodes/get-many
to be consistent with
similar functions in other namespaces. clojurewerkz.neocons.rest.nodes/multi-get
is not yet removed (for ease of upgrading)
but is deprecated and will be removed completely in the future.
Two Relationship
record fields were renamed to match REST API responses better:
:start-uri
is now:start
:end-uri
is now:end
clojurewerkz.neocons.rest.relationships/starts-with?
and clojurewerkz.neocons.rest.relationships/ends-with?
predicates check whether
given relationships starts (or ends, respectively) with a node with the given id. This is often useful
for automated testing of logic that creates relationships.
clojurewerkz.neocons.rest.cypher/empty?
is a new function that can be used to tell empty Cypher responses from
non-empty ones.
clojurewerkz.neocons.rest.relationships/create-many
is a new function that creates multiple relationships
from one node to several other nodes. All relationships will be of the same type. Relationships
are created concurrently using clojure.core/pmap. As a consequence, this function is supposed
to be used when number of relationships created is in dozens, hundreds of thousands.
clojurewerkz.neocons.rest.relationships/maybe-delete
is a new function that deletes a relationship if that exists and does nothing
otherwise.
Neocons now uses clj-http 0.3.6.
Neocons now supports basic HTTP authentication. Credentials can be passed to clojurewerkz.neocons.rest.connect
and
clojurewerkz.neocons.rest.connect!
functions as well as via NEO4J_LOGIN
and NEO4J_PASSWORD
environment variables
(to be Heroku-friendly).
clojurewerkz.neocons.rest.connect
and clojurewerkz.neocons.rest.connect!
no longer accept java.net.URI instances. Please use strings from now on.
This makes implementation of HTTP authentication and Heroku add-on support much simpler at a price of this small
undocumented feature.
Neocons now uses clj-http 0.3.4.
New function clojurewerkz.neocons.rest.cypher/tableize
transforms Cypher query responses (that list columns and row sets separately) into tables,
much like SQL queries do. The following test demonstrates how it works:
(deftest ^{:cypher true} test-tableize
(let [columns ["x.name" "x.age"]
rows [["John" 27] ["Sarah" 28]]]
(is (= [{"x.name" "John" "x.age" 27}
{"x.name" "Sarah" "x.age" 28}] (vec (cy/tableize columns rows))))))
clojurewerkz.neocons.rest.cypher/tquery
combines clojurewerkz.neocons.rest.cypher/query
and clojurewerkz.neocons.rest.cypher/tableize
: it executes Cypher queries and returns results
formatted as table.
clojurewerkz.neocons.rest.nodes/connected-out
implementation is now based on clojurewerkz.neocons.rest.nodes/multi-get
and is much more efficient for nodes
with many outgoing relationships.
clojurewerkz.neocons.rest.nodes/multi-get
function efficiently (in a single HTTP request) fetches multiple nodes by id.
It implemented on top of the Cypher query language and thus requires Neo4J Server 1.6.0 or later.
Neocons now uses Leiningen 2.