☄️💫 The OrbitDB community and documentation repo
orbit-db
is a serverless, distributed, peer-to-peer database. orbit-db
uses IPFS as its data storage and IPFS Pubsub to automatically sync databases with peers. It's an eventually consistent database that uses CRDTs for conflict-free database merges making orbit-db
an excellent choice for offline-first applications.
This organization is a place to bring together all fo the Orbit repositories, and to work together on making orbit better. This repo is the center of that organization.
We have a fortnightly community call every other Tuesday. The time, date and other info for each week's call is announced in an issue in this repository. Propose agenda items for the call by commenting on the issue!
Consult the OrbitDB calendar for the scheduled dates.
We do not record these calls, as we want people to feel comfortable joining in and talking without worrying about being recorded. If you miss a call, take a look at the notes, in meeting-notes
.
We rotate the notetaker and facilitator every week. If you would like to be part of the rotation, add your name to meeting-notes/facilitators.md
!
The @orbitdb organization on GitHub contains many different repositories. For the most part, these fall into three categories: code which relates to OrbitDB, the peer to peer database for the decentralized web; Orbit Chat, a decentralized chat program built using OrbitDB; and various non-code repositories. Those three repositories are:
- The welcome community repo, which you're in right now;
- awesome-orbitdb, which is an attempt to list everything that is using OrbitDB, or could help people. Basically, what has been built? And;
- research, where you can find research papers and interesting research work on CRDTs and the like.
OrbitDB is a peer-to-peer database for the decentralized web (to put it succinctly). The most important repositories are:
And then, there are a whole host of helper modules. It should be noted that all of these are JavaScript modules on npm.
- crdts - A library of Conflict-Free Replicated Data Types for JavaScript. Used in orbit-db-counterstore; mostly just one function is used.
- orbit-db-cache - Actually a persistency layer, not a cache. Saves the latest HEAD of each db locally into LevelDB. Doesn't store a huge amount of data, just the amount of DBs you have. For all of the dbs you have locally, you have a hash for each.
- orbit-db-cli - CLI for OrbitDB.
- orbit-db-counterstore - Datastore in OrbitDB. Uses CRDTs, inherits from orbit-db-store.
- orbit-db-docstore - Another OrbitDB store which allows you to index a blob.
- orbit-db-eventstore - Another data model type. Like ipfs-log. Wraps into a store interface.
- orbit-db-feedstore - Database type in OrbitDB. This is exactly like eventlog, but you can delete events from the log.
- orbit-db-keystore - Keystore is actually a module that stores the keys locally. You can generate keys, it persists them in the data folder, you can import and export keys - it is basically a key manager.
- orbit-db-kvstore - KeyValue store. Another DB type in OrbitDB. This may occasionally be unclear in the code, where
kvstore
is calledkeyvalue
store. - orbit-db-pubsub - Message propagation module for OrbitDB. A layer between OrbitDB and IPFS Pubsub.
- orbit-db-store - Base class for OrbitDB data stores. A Base Class defines the common interface for all databases.
And then there is the Orbit Chat, which is a chat program built on top of OrbitDB. These will most likely be renamed at some point to stop the confusion. The most important repository is:
- orbit-web - The browser client of Orbit Chat.
Other repositories include:
- orbit - This is a landing page repo, without code, and may be the start for a new Orbit Chat org if we end up making one. It needs to be updated.
- orbit-core - The JavaScript npm module that implements the Orbit Chat protocol.
- orbit-electron - Desktop application for Orbit Chat. Uses orbit-core and IPFS.
- orbit-textui - A terminal client for Orbit Chat.
- orbit-bot - Unsurprisingly, a bot for Orbit Chat.
There are other repositories that aren't in the organization around the web which are important - for instance, of course, ipfs. For now, these are the main ones in the @orbitdb organization.
If there is something missing form this list, please let us know! Either open a PR or an issue, and we'll add it. Thank you.
Why "OrbitDB"? Because it was available on GitHub, and it matches orbitdb
. Why "Orbit"? Because that is the name of the chat app built on top of orbit-db. Why was that called "Orbit"? You'll have to ask @haadcode, but it's probably something to do with the InterPlanetary File System (IPFS).
There are variants of the name. For now, the canonical versions are: OrbitDB for the general project, orbit-db
for the codebase at orbitdb/orbit-db
, @orbitdb
for the organization, and Orbit Chat for what used to be called just Orbit.
Please contribute! Dive into the issues!
Check out our contributing document for more information on how we work, and about contributing in general. Please be aware that all interactions related to OrbitDB are subject to the OrbitDB Code of Conduct.
Small note: If editing the README, please conform to the standard-readme specification.
This repository is maintained by @RichardLitt. If you've got any questions for him, feel free to open an issue or a pull request, or to email him privately. we're always looking for more maintainers!
This repository is only for documents. All of these are licensed under the CC-BY-SA 3.0 license © 2016-2018 Protocol Labs Inc., Haja Networks Oy. Any code is under a MIT © 2016-2018 Protocol Labs Inc., Haja Networks Oy.