2016-10-05 10:57:49 +02:00
# orbit-db API documentation
2016-10-05 10:33:45 +02:00
2016-11-02 13:50:05 +01:00
OrbitDB provides various types of databases for different data models:
2017-03-31 10:54:56 +02:00
- [log ](#lognameaddress ) is an append-only log with traversable history. Useful for *"latest N"* use cases or as a message queue.
- [feed ](#feednameaddress ) is a log with traversable history. Entries can be added and removed. Useful for *"shopping cart" type of use cases, or for example as a feed of blog posts or "tweets".
- [keyvalue ](#keyvaluenameaddress ) is a key-value database just like your favourite key-value database.
- [docs ](#docsnameaddress-options ) is a document database to which documents can be stored and indexed by a specified key. Useful for example building search indices or version controlling documents and data.
- [counter ](#counternameaddress ) for counting. Useful for example counting events separate from log/feed data.
2016-10-05 10:33:45 +02:00
2016-11-02 13:50:05 +01:00
Which database to use depends on your use case and data model.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
## Usage
Read the ** [GETTING STARTED ](https://github.com/orbitdb/orbit-db/blob/master/GUIDE.md )** guide for a more in-depth tutorial and to understand how OrbitDB works.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
### Using as a module
Install [orbit-db ](https://www.npmjs.com/package/orbit-db ) and [ipfs ](https://www.npmjs.com/package/ipfs ) from npm:
2016-10-05 10:33:45 +02:00
```
npm install orbit-db ipfs
```
2016-11-02 13:50:05 +01:00
Require it in your program and create the instance:
2016-10-05 10:33:45 +02:00
```javascript
const IPFS = require('ipfs')
const OrbitDB = require('orbit-db')
const ipfs = new IPFS()
2017-03-31 10:54:56 +02:00
ipfs.on('ready', () => {
const orbitdb = new OrbitDB(ipfs)
// Create / Open a database
const db = await orbitdb.log('hello')
await db.load()
// Listen for updates from peers
db.events.on('replicated', (address) => {
console.log(db.iterator({ limit: -1 }).collect())
})
// Add an entry
const hash = await db.add('world')
console.log(hash)
// Query
const result = db.iterator({ limit: -1 }).collect()
console.log(result)
})
2016-10-05 10:33:45 +02:00
```
2016-11-02 13:50:05 +01:00
`orbitdb` is now the [OrbitDB ](#orbitdb ) instance we can use to interact with the databases.
2017-03-31 10:54:56 +02:00
This will tell `orbit-db` to use the [Javascript implementation ](https://github.com/ipfs/js-ipfs ) of IPFS. Choose this options if you're using `orbitd-db` to develop **browser** applications.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
### Using with a running IPFS daemon
2016-10-05 10:33:45 +02:00
Alternatively, you can use [ipfs-api ](https://npmjs.org/package/ipfs-api ) to use `orbit-db` with a locally running IPFS daemon:
```
npm install orbit-db ipfs-api
```
```javascript
const IpfsApi = require('ipfs-api')
const OrbitDB = require('orbit-db')
const ipfs = IpfsApi('localhost', '5001')
const orbitdb = new OrbitDB(ipfs)
2017-03-31 10:54:56 +02:00
const db = await orbitdb.log('hello')
...
2016-10-05 10:33:45 +02:00
```
2016-11-02 13:50:05 +01:00
`orbitdb` is now the [OrbitDB ](#orbitdb ) instance we can use to interact with the databases.
2017-03-31 10:54:56 +02:00
Choose this options if you're using `orbitd-db` to develop **backend** or **desktop** applications, eg. with [Electron ](https://electron.atom.io ).
## API
- [OrbitDB ](#orbitdb )
- [constructor(ipfs, [directory], [options])](#constructoripfs -directory-options)
- [keyvalue(name|address) ](#keyvaluenameaddress )
- [put(key, value) ](#putkey-value )
- [set(key, value) ](#setkey-value )
- [get(key) ](#getkey )
- [log(name|address) ](#lognameaddress )
- [add(event) ](#addevent )
- [get(hash) ](#gethash )
- [iterator([options])](#iteratoroptions )
- [feed(name|address) ](#feednameaddress )
- [add(data) ](#adddata )
- [get(hash) ](#gethash-1 )
- [remove(hash) ](#removehash )
- [iterator([options])](#iteratoroptions )
- [docs(name|address, options) ](#docsnameaddress-options )
- [put(doc) ](#putdoc )
- [get(hash) ](#getkey-1 )
- [query(mapper) ](#querymapper )
- [del(key) ](#delkey )
- [counter(name|address) ](#counternameaddress )
- [value ](#value )
- [inc([value])](#incvalue )
- [stop() ](#stop )
- [Store ](#store )
- [load() ](#load )
- [close() ](#close )
- [drop() ](#drop )
2016-11-02 13:50:05 +01:00
- [events ](#events )
2017-03-31 10:54:56 +02:00
- [key ](#key )
- [type ](#type )
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
## OrbitDB
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
### constructor(ipfs, [directory], [options])
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const IPFS = require('ipfs')
const OrbitDB = require('orbit-db')
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
const ipfs = new IPFS()
ipfs.on('ready', () => {
const orbitdb = new OrbitDB(ipfs)
})
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
After creating an `OrbitDB` instance , you can access the different data stores. Creating a database instance, eg. with `orbitdb.keyvalue(...)` , returns a *Promise* that resolves to a [database instance ](#store ). See the [Store ](#store ) section for details of common methods and properties.
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const db = await orbitdb.kvstore('profile')
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
### keyvalue(name|address)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Module: [orbit-db-kvstore ](https://github.com/orbitdb/orbit-db-kvstore )
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const db = await orbitdb.keyvalue('application.settings')
// Or:
const db = await orbitdb.keyvalue(anotherkvdb.address)
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
**See the [Store ](#store ) section for details of common methods and properties.**
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
#### put(key, value)
```javascript
await db.put('hello', { name: 'World' })
```
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
#### set(key, value)
2016-10-05 10:33:45 +02:00
```javascript
2017-03-31 10:54:56 +02:00
await db.set('hello', { name: 'Friend' })
```
#### get(key)
```javascript
const value = db.get('hello')
// { name: 'Friend' }
2016-10-05 10:33:45 +02:00
```
2017-03-31 10:54:56 +02:00
### log(name|address)
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
Module: [orbit-db-eventstore ](https://github.com/orbitdb/orbit-db-eventstore )
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
```javascript
const db = await orbitdb.eventlog('site.visitors')
// Or:
const db = await orbitdb.eventlog(anotherlogdb.address)
```
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
**See the [Store ](#store ) section for details of common methods and properties.**
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
#### add(event)
```javascript
const hash = await db.add({ name: 'User1' })
```
#### get(hash)
```javascript
const event = db.get(hash)
.map((e) => e.payload.value)
// { name: 'User1' }
```
#### iterator([options])
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
**options** : It is an object which supports the following properties
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`gt - (string)` Greater than
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`gte - (string)` Greater than or equal to
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`lt - (string)` Less than
`lte - (string)` Less than or equal to
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
`limit - (integer)` Limiting the entries of result
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
`reverse - (boolean)` If set to true will result in reversing the result.
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const all = db.iterator({ limit: -1 })
.collect()
.map((e) => e.payload.value)
// [{ name: 'User1' }]
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
### feed(name|address)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Module: [orbit-db-feedstore ](https://github.com/orbitdb/orbit-db-feedstore )
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const db = await orbitdb.feed('orbit-db.issues')
// Or:
const db = await orbitdb.feed(anotherfeeddb.address)
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
See the [Store ](#store ) section for details of common methods and properties.
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
#### add(data)
2016-10-05 10:33:45 +02:00
```javascript
2017-03-31 10:54:56 +02:00
const hash = await db.add({ name: 'User1' })
2016-10-05 10:33:45 +02:00
```
2017-03-31 10:54:56 +02:00
#### get(hash)
```javascript
const event = db.get(hash)
.map((e) => e.payload.value)
// { name: 'User1' }
```
#### remove(hash)
```javascript
const hash = await db.remove(hash)
```
#### iterator([options])
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
**options** : It is an object which supports the following properties
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`gt - (string)` Greater than
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`gte - (string)` Greater than or equal to
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`lt - (string)` Less than
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`lte - (string)` Less than or equal to
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`limit - (integer)` Limiting the entries of result
2017-09-17 16:02:07 +05:30
2017-03-31 10:54:56 +02:00
`reverse - (boolean)` If set to true will result in reversing the result.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const all = db.iterator({ limit: -1 })
.collect()
.map((e) => e.payload.value)
// [{ name: 'User1' }]
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
### docs(name|address, options)
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
Module: [orbit-db-docstore ](https://github.com/orbitdb/orbit-db-docstore )
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const db = await orbitdb.docs('orbit.users.shamb0t.profile')
// Or:
const db = await orbitdb.docs(anotherdocdb.address)
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
By default, documents are indexed by field `_id` . You can also specify the field to index by:
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
const db = await orbitdb.docs('orbit.users.shamb0t.profile', { indexBy: 'name' })
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
**See the [Store ](#store ) section for details of common methods and properties.**
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
#### put(doc)
```javascript
const hash = await db.put({ _id: 'QmAwesomeIpfsHash', name: 'shamb0t', followers: 500 })
```
#### get(key)
```javascript
const profile = db.get('shamb0t')
.map((e) => e.payload.value)
// [{ _id: 'shamb0t', name: 'shamb0t', followers: 500 }]
```
#### query(mapper)
```javascript
const all = db.query((doc) => doc.followers >= 500)
// [{ _id: 'shamb0t', name: 'shamb0t', followers: 500 }]
```
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
#### del(key)
2016-10-10 16:09:00 -04:00
```javascript
2017-03-31 10:54:56 +02:00
const hash = await db.del('shamb0t')
2016-10-10 16:09:00 -04:00
```
2017-03-31 10:54:56 +02:00
### counter(name|address)
Module: [orbit-db-counterstore ](https://github.com/orbitdb/orbit-db-counterstore )
```javascript
const counter = await orbitdb.counter('song_123.play_count')
// Or:
const counter = await orbitdb.counter(anothercounterdb.address)
```
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
**See the [Store ](#store ) section for details of common methods and properties.**
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
#### value
2016-10-10 16:09:00 -04:00
```javascript
2017-03-31 10:54:56 +02:00
counter.value // 0
2016-10-10 16:09:00 -04:00
```
2017-03-31 10:54:56 +02:00
#### inc([value])
```javascript
await counter.inc()
counter.value // 1
await counter.inc(7)
counter.value // 8
await counter.inc(-2)
counter.value // 8
```
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
### stop()
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
Stop OrbitDB, close databases and disconnect the databases from the network.
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
```javascript
orbitdb.stop()
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
## Store
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
Every database (store) has the following methods available in addition to their specific methods.
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
#### load()
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
Load the locally persisted database state to memory.
2016-10-05 10:57:49 +02:00
2017-03-31 10:54:56 +02:00
With events:
```javascript
db.events.on('ready', () => {
/* database is now ready to be queried */
})
db.load()
```
2016-10-10 16:09:00 -04:00
2017-03-31 10:54:56 +02:00
Async:
```javascript
await db.load()
/* database is now ready to be queried */
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
#### close()
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
Close the database.
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
Async:
```javascript
await db.close()
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
#### drop()
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Remove the database locally. This does not delete any data from peers.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
await db.drop()
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
#### key
2016-10-05 10:57:49 +02:00
2017-11-29 21:23:08 +01:00
The [keypair ](https://github.com/orbitdb/orbit-db/blob/master/GUIDE.md#keys ) used to access the database.
```
const key = db.key
console.log(key)
// < Key priv: db8ef129f3d26ac5d7c17b402027488a8f4b2e7fa855c27d680b714cf9c1f87e
// pub: < EC Point x: f0e33d60f9824ce10b2c8983d3da0311933e82cf5ec9374cd82c0af699cbde5b
// y: ce206bfccf889465c6g6f9a7fdf452f9c3e1204a6f1b4582ec427ec12b116de9> >
```
The key contains the keypair used to sign the database entries. The public key can be retrieved with:
```
console.log(db.key.getPublic('hex'))
// 04d009bd530f2fa0cda29202e1b15e97247893cb1e88601968abfe787f7ea03828fdb7624a618fd67c4c437ad7f48e670cc5a6ea2340b896e42b0c8a3e4d54aebe
```
The key can also be accessed from the [OrbitDB ](#orbitdb ) instance: `orbitdb.key.getPublic('hex')` .
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
#### type
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
The type of the database as a string.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
#### events
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Each database in `orbit-db` contains an `events` ([EventEmitter ](https://nodejs.org/api/events.html )) object that emits events that describe what's happening in the database. Events can be listened to with:
```javascript
db.events.on(name, callback)
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
- **`replicated` ** - (address)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Emitted when a the database was synced with another peer. This is usually a good place to re-query the database for updated results, eg. if a value of a key was changed or if there are new events in an event log.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('replicated', (address) => ... )
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
- **`replicate` ** - (address)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Emitted before replicating a part of the database with a peer.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('replicate', (address) => ... )
```
- **`replicate.progress` ** - (address, hash, entry, progress, have)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Emitted while replicating a database. *address* is id of the database that emitted the event. *hash* is the multihash of the entry that was just loaded. *entry* is the database operation entry. *progress* is the current progress. *have* is a map of database pieces we have.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('replicate.progress', (address, hash, entry, progress, have) => ... )
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
- **`load` ** - (dbname)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Emitted before loading the database.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('load', (dbname) => ... )
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
- **`load.progress` ** - (address, hash, entry, progress, total)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Emitted while loading the local database, once for each entry. *dbname* is the name of the database that emitted the event. *hash* is the multihash of the entry that was just loaded. *entry* is the database operation entry. *progress* is a sequential number starting from 0 upon calling `load()` .
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('load.progress', (address, hash, entry, progress, total) => ... )
```
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
- **`ready` ** - (dbname)
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
Emitted after fully loading the local database.
2017-03-30 18:43:47 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('ready', (dbname) => ... )
```
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
- **`write` ** - (dbname, hash, entry)
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
Emitted after an entry was added locally to the database. *hash* is the IPFS hash of the latest state of the database. *entry* is the added database op.
2016-10-05 10:33:45 +02:00
2017-03-31 10:54:56 +02:00
```javascript
db.events.on('write', (dbname, hash, entry) => ... )
```