Ready to take your JavaScript development to the next level? Meet npm Enterprise - the ultimate in enterprise JavaScript. Learn more »

moleculer-db-adapter-rethinkdb

0.2.9 • Public • Published

Moleculer logo

moleculer-db-adapter-rethinkdb

RethinkDB adapter for Moleculer DB service.

Coverage Status Build Status NPM version Downloads

Install

$ npm install moleculer-db moleculer-db-adapter-rethinkdb --save

Usage

"use strict";
 
const { ServiceBroker } = require("moleculer");
const DbService = require("moleculer-db");
const RethinkDBAdapter = require("moleculer-db-adapter-rethinkdb");
 
const broker = new ServiceBroker();
 
// Create a RethinkDB service for `post` entities
broker.createService({
    name: "posts",
    mixins: [DbService],
    adapter: new RethinkDBAdapter({host: "127.0.0.1" || "", port: 29015}),
    database: "app",
    table: "posts"
});
 
 
broker.start()
// Create a new post
.then(() => broker.call("posts.create", {
    title: "My first post",
    content: "Lorem ipsum...",
    votes: 0
}))
 
// Get all posts
.then(() => broker.call("posts.find").then(console.log));
 
// Change feeds
const { client: conn } = this.schema.adapter;
// Lets get a rethinkdb.table instance
const rTable = this.schema.adapter.getTable();
// You can also get a rethinkdb instance with below
// const rethinkdb = this.schema.adapter.getR();
 
rTable.changes().run(conn, function(err, cursor) {
    cursor.each(console.log);
});
 
// Map Reduce with same way
rTable.map((user) => 1).run(conn);
 
// You can access all underlying API

Options

Example with connection options

new RethinkDBAdapter({
    host: "localhost",
    port: 29015
})

Above options is used as default when you dont specify any option or pass empty

Test

$ npm test

In development with watching

$ npm run ci

License

The project is available under the MIT license.

install

npm i moleculer-db-adapter-rethinkdb

Downloadsweekly downloads

8

version

0.2.9

license

MIT

homepage

github.com

repository

Gitgithub

last publish

collaborators

  • avatar
Report a vulnerability