NAME
Neo4j::Driver - Perl implementation of the Neo4j Driver API
VERSION
version 0.16
SYNOPSIS
use Neo4j::Driver;
$uri = 'bolt://localhost'; # requires Neo4j::Bolt
$uri = 'http://localhost';
$driver = Neo4j::Driver->new($uri)->basic_auth('neo4j', 'password');
sub say_friends_of {
$query = 'MATCH (a:Person)-[:KNOWS]->(f) '
. 'WHERE a.name = {name} RETURN f.name';
$records = $driver->session->run($query, name => shift)->list;
foreach $record ( @$records ) {
say $record->get('f.name');
}
}
say_friends_of 'Alice';
DESCRIPTION
This is an unofficial Perl implementation of the Neo4j Driver API. It enables interacting with a Neo4j database server using the same classes and method calls as the official Neo4j drivers do.
This driver extends the uniformity across languages, which is a stated goal of the Neo4j Driver API, to Perl. The downside is that this driver doesn't offer fully-fledged object bindings like the existing REST::Neo4p module does. Nor does it offer any DBI integration. However, it avoids the legacy cypher
endpoint, assuring compatibility with Neo4j versions 2.3, 3.x and 4.x.
The HTTP and Bolt protocols are supported for connecting to Neo4j. Bolt requires installing the XS module Neo4j::Bolt. Using Bolt is much faster than HTTP, but at time of this writing the libneo4j-client backend library that Neo4j::Bolt uses to connect to the database server only supports Neo4j version 3.x.
As of version 0.13, the interface of this software may be considered stable.
However, bugs may still exist. Also, experimental features may be changed or deprecated at any time. If you find yourself reliant on an experimental feature, please file a new issue requesting that it be made stable.
There is an ongoing effort to clean up the experimental features. For each of them, the goal is to eventually either declare it stable or deprecate it. There is also ongoing work to further improve general stability and reliability of this software. However, there is no schedule for the completion of these efforts.
METHODS
Neo4j::Driver implements the following methods.
basic_auth
$driver->basic_auth('neo4j', 'password');
Set basic auth credentials with a given user and password. This method returns the modified Neo4j::Driver object, so that method chaining is possible.
$session = $driver->basic_auth('neo4j', 'password')->session;
config
$driver->config( option1 => 'foo', option2 => 'bar' );
Sets the specified configuration option or options on a Neo4j::Driver object. The options are given in hash syntax. This method returns the modified object, so that method chaining is possible.
$session = $driver->config(timeout => 60)->session;
See below for an explanation of all supported configuration options. Setting configuration options on a driver is only allowed before creating the driver's first session.
Calling this method with just a single parameter will return the current value of the config option named by the parameter.
$timeout = $driver->config('timeout');
new
$driver = Neo4j::Driver->new('http://localhost');
Construct a new Neo4j::Driver object. This object holds the details required to establish connections with a Neo4j database, including server URIs, credentials and other configuration.
The URI passed to this method determines the type of driver created. The http
, https
, and bolt
URI schemes are supported. Use of bolt
URIs requires Neo4::Bolt to be installed.
If a part of the URI or even the entire URI is missing, suitable default values will be substituted. In particular, the host name localhost
and the protocol http
will be used as defaults; if no port is specified, the protocol's default port will be used.
# all of these are semantically equal
$driver = Neo4j::Driver->new;
$driver = Neo4j::Driver->new('http:');
$driver = Neo4j::Driver->new('localhost');
$driver = Neo4j::Driver->new('http://localhost');
$driver = Neo4j::Driver->new('http://localhost:7474');
session
$session = $driver->session;
Creates and returns a new Session.
EXPERIMENTAL FEATURES
Neo4j::Driver implements the following experimental features. These are subject to unannounced modification or removal in future versions. Expect your code to break if you depend upon these features.
Database selection
$session = $driver->session( database => 'system' );
Starting with version 4.0, Neo4j supports multiple databases within a single installation. A specific database may be selected using the optional session config option database
.
If this option is not given, the driver will attempt to select whichever database is configured as the default in neo4j.conf. As of Neo4j::Driver 0.16, this sometimes doesn't work reliably with Neo4j 4.x (see "BUGS").
The result of using this option on Neo4j versions earlier than 4.0 is undefined.
Parameter syntax conversion
$driver->config(cypher_filter => 'params');
When this option is set, the driver automatically uses a regular expression to convert the old Cypher parameter syntax {param}
supported by Neo4j versions 2 and 3 to the new syntax $param
supported by Neo4j versions 3 and 4.
Type system customisation
$driver->config(cypher_types => {
node => 'Local::Node',
relationship => 'Local::Relationship',
path => 'Local::Path',
point => 'Local::Point',
temporal => 'Local::Temporal',
init => sub { my $object = shift; ... },
});
The package names used for bless
ing objects in query results can be modified. This allows clients to add their own methods to such objects.
Clients must make sure their custom type packages are subtypes of the base type packages that this module provides (e. g. using @ISA
):
Clients may only use the documented API to access the data in the base type. Direct data structure access might also work, but is unsupported and discouraged because it makes your code prone to fail when any internals change in the implementation of Neo4j::Driver. For those objects that are implemented as blessed hash refs, clients may use any hash keys that begin with two underscores (__
) to store private data. All other hash keys are reserved for use by Neo4j::Driver.
CONFIGURATION OPTIONS
Neo4j::Driver implements the following configuration options.
timeout
$driver->config(timeout => 60); # seconds
Specifies the connection timeout. The semantics of this config option vary by network library. Its default value is therefore not defined here and is subject to change.
For details, see "timeout" in LWP::UserAgent when using HTTP or select(2) when using Bolt.
The old $driver->{http_timeout}
syntax remains supported for the time being in order to ensure backwards compatibility, but its use is discouraged and it may be deprecated in future.
tls
$driver->config(tls => 1);
Specifies whether to use secure communication using TLS. This implies not just encryption, but also verification of the server's identity.
By default, the local system's trust store will be used to verify the server's identity. This will fail unless your Neo4j installation uses a key pair that is trusted and verifiable through the global CA infrastructure. If that's not the case, you may need to additionally use the tls_ca
option.
This option defaults to 0
(no encryption). This is generally what you want if you connect to a server on localhost
.
This option is only useful for Bolt connections. For HTTP connections, the use of TLS encryption is governed by the chosen URI scheme (http
/ https
).
tls_ca
$driver->config(tls_ca => 'neo4j/certificates/neo4j.cert');
Specifies the path to a file containing one or more trusted TLS certificates. When this option is given, encrypted connections will only be accepted if the server's identity can be verified using the certificates provided.
The certificates in the file must in PEM encoding. They are expected to be "root" certificates, i. e. the "CA bit" needs to be set and the certificate presented by the server must be signed by one of the certificates in this file (or by an intermediary).
Self-signed certificates (such as those automatically provided by some Neo4j versions) should also work if their "CA bit" is set.
ENVIRONMENT
This software currently targets Neo4j versions 2.3, 3.x and 4.x.
This software requires at least Perl 5.10, though you should consider using Perl 5.16 or newer if you can.
DIAGNOSTICS
Neo4j::Driver currently dies as soon as an error condition is discovered. Use eval
, Try::Tiny or similar to catch this.
Warnings are given when deprecated or ambiguous method calls are used. These warnings may be disabled if desired.
no warnings 'deprecated';
no warnings 'ambiguous';
BUGS
There is a known issue (#6) that may prevent automatic selection of the default database on some Neo4j 4.0 installations. In these cases, Neo4j::Driver will report Network error: 404 Not Found
when you try to run any statement. As a workaround, you can select the default database (usually named neo4j
or graph.db
) manually like this:
$session = $driver->session(database => 'neo4j');
See the TODO document and Github for known issues and planned improvements. Please report new issues and other feedback on Github.
Just like the official Neo4j drivers, this driver has been designed to strike a balance between an idiomatic API for Perl and a uniform surface across all languages. Differences between this driver and the official Neo4j drivers in either the API or the behaviour are generally to be regarded as bugs unless there is a compelling reason for a different approach in Perl.
Due to lack of resources, only the Neo4j community edition is targeted by this driver at present.
SEE ALSO
Official API documentation: Neo4j Drivers Manual, Neo4j HTTP API Docs
Other modules for working with Neo4j: DBD::Neo4p, Neo4j::Bolt, Neo4j::Cypher::Abstract, REST::Cypher, REST::Neo4p
AUTHOR
Arne Johannessen <ajnn@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2016-2020 by Arne Johannessen.
This is free software, licensed under:
The Artistic License 2.0 (GPL Compatible)