Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lucianopalmeida/ogmneo
[No Maintenance] Neo4j nodeJS OGM(object-graph mapping) abstraction layer
https://github.com/lucianopalmeida/ogmneo
batch bolt coverage cypher database database-abstraction es6 javascript neo4j neo4j-driver nodejs object-graph-mapper ogm-neo4j orm transaction
Last synced: 4 months ago
JSON representation
[No Maintenance] Neo4j nodeJS OGM(object-graph mapping) abstraction layer
- Host: GitHub
- URL: https://github.com/lucianopalmeida/ogmneo
- Owner: LucianoPAlmeida
- License: mit
- Archived: true
- Created: 2017-04-13T02:47:59.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2020-03-23T19:36:16.000Z (almost 5 years ago)
- Last Synced: 2024-09-30T05:08:56.179Z (4 months ago)
- Topics: batch, bolt, coverage, cypher, database, database-abstraction, es6, javascript, neo4j, neo4j-driver, nodejs, object-graph-mapper, ogm-neo4j, orm, transaction
- Language: JavaScript
- Homepage:
- Size: 773 KB
- Stars: 54
- Watchers: 5
- Forks: 7
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[![No Maintenance Intended](http://unmaintained.tech/badge.svg)](http://unmaintained.tech/)
# :warning: Deprecated :warning:
This library is deprecated and will no longer be updated.
# OGMNeo
Abstract some trivial operations on the Neo4j driver for Nodejs and make the use simpler. That's why we created OGMNeo.
[![npm version](https://badge.fury.io/js/ogmneo.svg)](https://badge.fury.io/js/ogmneo)
[![npm](https://img.shields.io/npm/dt/ogmneo.svg)](https://www.npmjs.com/package/ogmneo)
[![MIT](https://img.shields.io/badge/License-MIT-red.svg)](https://opensource.org/licenses/MIT)
[![Travis](https://img.shields.io/travis/LucianoPAlmeida/OGMNeo.svg)](https://travis-ci.org/LucianoPAlmeida/OGMNeo?branch=master)
[![Codecov](https://img.shields.io/codecov/c/github/LucianoPAlmeida/OGMNeo.svg)](https://codecov.io/gh/LucianoPAlmeida/OGMNeo)## Installation
You can find ogmneo in npm [here](https://www.npmjs.com/package/ogmneo) and install using the follow command
```sh
npm install ogmneo
```
## Usage### Connecting to neo4j database
```js
const ogmneo = require('ogmneo');
ogmneo.Connection.connect('neo4j', 'databasepass', 'localhost');
// Or if you want to add some neo4j driver configuration options
ogmneo.Connection.connect('neo4j', 'databasepass', 'localhost', { maxTransactionRetryTime: 30000, encrypted: false });
// See more about the config options you can add on: http://neo4j.com/docs/api/javascript-driver/current/function/index.html#static-function-driver```
OGMNeo connects using the neo4j bolt protocol.
### Log generated cypher on consoleYou can see the generated Cypher on your console by setting Connection.logCypherEnabled property true.
```js
const ogmneo = require('ogmneo');
ogmneo.Connection.logCypherEnabled = true;```
### Create node example```js
const ogmneo = require('ogmneo');
ogmneo.Node.create({ name: 'name', tes: 3 }, 'test')
.then((node) => {
//Created returned object => {id: 1, name: 'name', tes: 3}
}).catch((error) => {
//Handle error
});
```### Find Nodes
```js
const ogmneo = require('ogmneo');
let query = ogmneo.Query.create('test')
.where(new ogmneo.Where('name', { $eq: 'name1' }));ogmneo.Node.find(query)
.then((nodes) => {
//Found nodes.
}).catch((error) => {
//Handle error.
});
```
### Create relations
You can create relations between nodes.```js
const ogmneo = require('ogmneo');
ogmneo.Relation.relate(node1.id, 'relatedto', node2.id, {property: 'a'})
.then((rels) => {
// Created relation node {id: 2, type: 'relatedto', property: 'a'}
}).catch((error) => {
//Handle error
});
```## Find Relations
You can find the relation nodes.```js
const ogmneo = require('ogmneo');
let query = ogmneo.RelationQuery.create('relatedto')
.startNode(node1.id)
.endNode(node2.id)
.relationWhere(ogmneo.Where.create('property', { $eq: 'c' }))
.ascOrderBy('property')
.limit(3);
ogmneo.Relation.find(query)
.then((nodes) => {
//Found relation nodes.
}).catch((error) => {
//Handle error.
});
//OR
ogmneo.Relation.findPopulated(query)
.then((nodes) => {
//Found relation nodes with start and end nodes populated.
}).catch((error) => {
//Handle error.
});
```## Executing Cypher
You can execute Cypher using the direct [Neo4j Driver](https://github.com/neo4j/neo4j-javascript-driver) session object. Or you can use OGMNeoCypher.```js
const ogmneo = require('ogmneo');ogmneo.Cypher.transactionalRead(cypherStatement)
.then((result) => {
console.log(result);
}).catch((error) => {
reject(error);
});
//OR
ogmneo.Cypher.transactionalWrite(cypherStatement)
.then((result) => {
console.log(result);
}).catch((error) => {
reject(error);
});
```
## Creating and dropping indexes
You can create and drop indexes in properties.```js
const ogmneo = require('ogmneo');
//Creating
ogmneo.Index.create('label', ['property'])
.then((result) => {
//Handle creation
});
//Dropping
ogmneo.Index.drop('label', ['property'])
.then((result) => {
//Handle drop
});
```## Operation API
Almost every method of ogmneo.Node and ogmneo.Relation have now the Operation API, that instead of executing the function on database returning a promise, it creates an ogmneo.Operation object that can be executed after by the ogmneo.OperationExecuter. Exemple:
```js
const ogmneo = require('ogmneo');
let operation = ogmneo.Node.createOperation({ name: 'name', tes: 3 }, 'test');
ogmneo.OperationExecuter.execute(operation)
.then((node) => {
//Created returned object => {id: 1, name: 'name', tes: 3}
}).catch((error) => {
//Handle error
});
```## Transactional API
With the Operation API we can now execute as many READ or WRITE operations on the same transaction.
For example, you want to create nodes and then relate those two. But if the relationship operation fails you want to rollback all the operations.```js
const ogmneo = require('ogmneo');
let createDriver = ogmneo.Node.createOperation({name: 'Ayrton Senna', carNumber: 12 }, 'Driver');
ogmneo.OperationExecuter.write((transaction) => {
return ogmneo.OperationExecuter.execute(createDriver, transaction)
.then((driver) => {
let createCar = ogmneo.Node.createOperation({name: 'MP4/4'}, 'Car');
return ogmneo.OperationExecuter.execute(createCar, transaction).then((car) => {
let relate = ogmneo.Relation.relateOperation(driver.id, 'DRIVES', car.id, {year: 1988});
return ogmneo.OperationExecuter.execute(relate, transaction);
});
});
}).then((result) => {
//Result here
});
```
All of those operations will be executed on the same transaction and you can rollback anytime you want. The transaction is the [neo4j driver](https://github.com/neo4j/neo4j-javascript-driver) transaction object and you can see more about it on their docs [here](http://neo4j.com/docs/api/javascript-driver/current/class/src/v1/transaction.js~Transaction.html).### Batching operation in a single transaction
You can also batch many operation READ or WRITE operations in a single transaction.
```js
const ogmneo = require('ogmneo');
let createUser1 = OGMNeoNode.createOperation({name: 'Ayrton Senna'}, 'Person');
let createUser2 = OGMNeoNode.createOperation({name: 'Alain Prost'}, 'Person');ogmneo.OperationExecuter.batchWriteOperations([createUser1, createUser2]).then((result) => {
let created1 = result[0];
let created2 = result[1];
console.log(created1.name); // 'Ayrton Senna'
console.log(created2.name); // 'Alain Prost'
});
```
If one of those fails, all other operations on the transaction will be rolledback automatically.## Documentation
See the full **API** documentation at [docs](http://ogmneo-docs.getforge.io/). All docs was generated by [JSDoc](https://github.com/jsdoc3/jsdoc).
## Exemple
See a demo sample on the [ogmneo-demo repository](https://github.com/LucianoPAlmeida/ogmneo-demo).
## TestsMost of this library functions are covered by unit tests.
See the code coverage on [codecov.io](https://codecov.io/gh/LucianoPAlmeida/OGMNeo).## Licence
OGMNeo is released under the [MIT License](https://opensource.org/licenses/MIT).