https://github.com/clientdb/clientdb
  
  
    ClientDB is an open source in-memory database for enabling real-time web apps. 
    https://github.com/clientdb/clientdb
  
        Last synced: 6 months ago 
        JSON representation
    
ClientDB is an open source in-memory database for enabling real-time web apps.
- Host: GitHub
- URL: https://github.com/clientdb/clientdb
- Owner: clientdb
- License: apache-2.0
- Created: 2022-06-27T13:12:00.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-02-12T19:33:03.000Z (over 2 years ago)
- Last Synced: 2025-04-11T22:47:39.740Z (7 months ago)
- Language: TypeScript
- Homepage: https://clientdb.dev
- Size: 3.27 MB
- Stars: 643
- Watchers: 11
- Forks: 16
- Open Issues: 2
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE
 
Awesome Lists containing this project
- awesome-repositories - clientdb/clientdb - ClientDB is an open source in-memory database for enabling real-time web apps. (TypeScript)
README
          # ClientDB
ClientDB is an open-source in-memory database for enabling real-time web apps. Build fast, scalable apps that feel silky smooth for users.
## Installation
Install clientdb with yarn
```bash
  yarn add @clientdb/core
```
# Core parts of clientdb
Clientdb is a suite of components that enable real-time web apps. Most of them can be used independently, but they're used together to cover all the aspects of building real-time applications.
## `@clientdb/core`
In-memory database for storing, modifying, and querying data. By itself, it is not synchronized with any server and it is not persisting any data offline.
## `@clientdb/sync`
Work in progress (https://github.com/acapela/clientdb/pull/10)
Sync engine consists of 2 parts:
Server - HTTP server with a socket that can connect to any database and can keep the in-memory database in sync with the server according to defined access permissions.
Client - Wrapper on top of an in-memory database that connects to sync-server and can keep the in-memory database in sync with the server.
Read more about sync engine - [engine/README.md](engine/README.md)
## `@clientdb/codegen` (Work in progress)
Set of dev-toolings for generating TypeScript types and synced client database with all relations, validations, etc. included.
---
## Tech Stack
The entire codebase is fully written in Typescript.
## Build Locally
Clone the project
```bash
  git clone git@github.com:acapela/clientdb.git
```
Install dependencies
```bash
  yarn install
```
Build the client-side db
```bash
  yarn core build
```
## Running Tests
To run tests, run the following command while in /core directory
```bash
  yarn test
```
## Used By
This project is used by the following companies:
- [Acapela](https://acapela.com)
## License
[Apache-2.0](https://choosealicense.com/licenses/apache-2.0/)