Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kunalgolani/cassandra-co
A very basic ORM and Client for Cassandra, inspired by 3logic's apollo-cassandra
https://github.com/kunalgolani/cassandra-co
cassandra generator nodejs promise
Last synced: 3 months ago
JSON representation
A very basic ORM and Client for Cassandra, inspired by 3logic's apollo-cassandra
- Host: GitHub
- URL: https://github.com/kunalgolani/cassandra-co
- Owner: kunalgolani
- Created: 2015-03-03T10:22:16.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2016-11-17T05:47:22.000Z (about 8 years ago)
- Last Synced: 2024-10-12T09:02:57.758Z (3 months ago)
- Topics: cassandra, generator, nodejs, promise
- Language: JavaScript
- Size: 85.9 KB
- Stars: 9
- Watchers: 1
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# cassandra-co
[![Join the chat at https://gitter.im/kunalgolani/cassandra-co][gitter-img]][gitter-url]
[![npm version][version-img]][npm-url]
[![npm downloads][downloads-img]][npm-url]
[![GitHub issues][issues-img]][issues-url]
[![Deps][deps-img]][deps-url]
[![Dev Deps][devDeps-img]][deps-url]A very basic ORM and Client for Cassandra, inspired by [3logic's apollo-cassandra](https://github.com/3logic/apollo-cassandra/).
---
## Motivation
- apollo-cassandra and other node.js Cassandra ORMs require you to define the schema in code. This means that any time the DB schema is altered, the code also needs to be updated. The code needs to be aware of the schema in the DB even if it's not otherwise using all columns of a table.
- When I looked into the internals of apollo-cassandra before starting this project, I couldn't find evidence of it using [prepared statements](http://docs.datastax.com/en/developer/nodejs-driver/2.1/nodejs-driver/reference/threeSimpleRules.html?scroll=three-simple-rules__prepared-statement-section). With Cassandra, if you're executing the same CQL query with different paramters repeatedly, preparing it makes its execution faster.
- apollo-cassandra and other node.js Cassandra ORMs don't support es2015 Promises. This is important since with es2016 `async` functions, only Promises can be `await`ed. Also, _#nomorecallbacks!_
- As of writing this, the last commit on apollo-cassandra was in March, 2015. It seems to be out of active development.---
## Usage
### Installation
```bash
npm install --save cassandra-co
```### Promises and yields
All asynchronous operations return a `Promise`. Using [`co`](https://github.com/tj/co) or [`koa`](koajs.com), these promises can also be `yield`ed. This documentation uses `yield` instead of `.then()` on the `Promise`s.__Example__
```js
// Promise
asyncOperation().then(function(result) {
// use the result here
});// yield
var result = yield asyncOperation();
// use the result here
```### Instantiation
__Parameters__
- {String} `keyspace`: The keyspace to operate on
- {Array} `hosts`: Hostnames of cassandra servers
- {Object} `options` [optional]: Any other client options as defined in http://www.datastax.com/drivers/nodejs/2.0/global.html#ClientOptions.__Example__ Initialize cassandra-co with `game_of_thrones` keyspace and local Cassandra
```js
var db = require('cassandra-co')('game_of_thrones', ['127.0.0.1']);
```### Model
__Parameters__
- {String} `table`: The name of the table__Example__ Initialize the model for `characters` table
```js
var Characters = yield db.getModel('characters');
```Unlike with most other Cassandra node.js ORMs, you don't need to define the model yourself. This statement fetches the model from the schema meta-tables for you.
### SELECT
__Parameters__
- {Object} `criteria` [optional]: The where clause criteria, with column names as keys, and values as:
+ value for exact match, or
+ {Object} where:
* operators as keys and operands as values for numerical comparison
* `in` as key and `{Array}` of values for `in` clause
* `contains` or `containsKey` as key and the respective value or key to check for in the set, list or map as value
- {Object} `clauses` [optional]: Additional clauses such as:
+ `distinct: ['column1', 'column2']`
+ `count: true`
+ `orderBy: column_name` for default (ascending), or `{Object}` with order (`asc|desc`) as key and `column_name` as value
+ `limit: 100`
+ `allowFiltering: true`
+ `raw`: not wrapped in a `cassandra-co` object
- {Object} `options` [optional]: Any other query options as defined in http://www.datastax.com/drivers/nodejs/2.0/global.html#QueryOptions__Example__ Find at max 5 Starks, born before Robert's Rebellion, sorted younger to older
```js
var starks = yield Characters.find({
house: 'Stark',
born: {
'<': 282
}
}, {
limit: 5,
orderBy: {
desc: 'born'
}
});
```### INSERT
__Parameters__
- {Object} `data`: Data to initialize row instance with, column names as keys
- {Object} `clauses` [optional]: `ttl` and / or `timestamp` for the row being saved__Example__ Add a new row to `characters` with a ttl of 14 years
```js
var joff = new Characters({
name: 'Joffrey',
house: 'Baratheon'
born: 286
});yield joff.save({
ttl: 60 * 60 * 24 * 365 * 14
});
```### UPDATE
__Parameters__
- {Object} `clauses` [optional]: `ttl` and / or `timestamp` for the row being saved__Example__ Change the name of the youngest Stark born before Robert's Rebellion to `Ben`
```js
starks[0].name = 'Ben';
yield starks[0].save();
```### Counters
__Parameters__
- {String} column [optional]: the specific counter column to increment, not required if there's only one such column
- {Number} by [optional]: the amount to increment the counter by, assumed 1 if not given__Example__ Increment the kills for `Daenerys Targaryen` whether or not the row exists, and decrement the kills for `Jaime Lannister` by 2
```js
var Kills = yield db.getModel('kills'),
danysKills = new Kills({character: 'Daenerys Targaryen'});
yield danysKills.increment();var kingslayersKillses = yield Kills.find({character: 'Jaime Lannister'});
yield kingslayersKillses[0].decrement(2);
```### DELETE
__Parameters__
- {Array} `columns` [optional]: If provided, the values from the given columns will be deleted; otherwise, the row will be deleted__Example__ Delete Ben's birth year
```js
yield starks[0].delete('born');
```---
## Caveats
- Only prepared statements are supported. All operations will be executed as prepared statements.
- cassandra-co needs the following ES2015/2016 features.
+ [Generator Functions](http://davidwalsh.name/es6-generators)
+ [Arrow Functions](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions)
+ [Shorthand and Computed Object Properties](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Object_initializer#New_notations_in_ECMAScript_2015)
+ [Spread Operator](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_operator)
+ [`Array.prototype.includes`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/includes)You can check if the above features are available in your javascript environment [here](http://kangax.github.io/compat-table/es6/). If you don't have them, you can get them in the following ways:
+ _The `--harmony` flag for node.js_ enables all stable es6 features in the v8 engine used in your version of node.js. Details: `man node | grep harmony`
+ _The `--harmony_` flags for node.js and io.js_ enable the respective features behind those flags in the v8 engine used in your version of [node|io].js. Details: `node|iojs --v8-options`
+ _Transpilers and Polyfills_ such as [Babel](babeljs.io) or [Traceur](https://github.com/google/traceur-compiler)---
[gitter-img]: https://badges.gitter.im/kunalgolani/cassandra-co.svg
[gitter-url]: https://gitter.im/kunalgolani/cassandra-co?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
[version-img]: https://img.shields.io/npm/v/cassandra-co.svg
[npm-url]: https://www.npmjs.com/package/cassandra-co
[downloads-img]: https://img.shields.io/npm/dt/cassandra-co.svg
[issues-img]: https://img.shields.io/github/issues-raw/kunalgolani/cassandra-co.svg?maxAge=2592000
[issues-url]: https://github.com/kunalgolani/cassandra-co/issues
[deps-img]: https://img.shields.io/david/kunalgolani/cassandra-co.svg
[devDeps-img]: https://img.shields.io/david/dev/kunalgolani/cassandra-co.svg
[deps-url]: https://github.com/kunalgolani/cassandra-co/blob/master/package.json