Skip to content

Latest commit

 

History

History
168 lines (139 loc) · 4.75 KB

README.md

File metadata and controls

168 lines (139 loc) · 4.75 KB

alt text smolDB

A JSON document-based database that relies on key based access to achieve O(1) access time.

smolDB is a document database with key-based access and reference resolution, all documents are on-disk, human-readable, and can be accessed through a REST API, making them very easy for debugging.

However, the database does not support any advanced queries, sharding, or support for storage distribution.

Get started quickly with the API via docker:

docker run -p 8080:8080 nishank02/smoldb:latest

key principles

  • Quick access — key-based retrieval in O(1) time
  • Simple to troubleshoot — all documents are stored as human-readable JSON files
  • Easy to deploy — a single executable with no external dependencies no need for language-specific drivers!

endpoints

GET /

# check the heath of the database
curl localhost:8080/

# example output on 200 OK
# > {"message":["smolDB is working fine!"]}

GET /keys

# get all files in database index
curl localhost:8080/keys

# example output on 200 OK
# > {"files":["test","test2","test3"]}

POST /regenerate

# manually regenerate index
# shouldn't need to be done as each operation should update index on its own
curl -X POST localhost:8080/regenerate

# example output on 200 OK
# > regenerated index

GET /key/:key

# get document with key `test`
curl localhost:8080/key/test

# example output on 200 OK (found key)
# > {"example_field": "example_value"}
# example output on 404 NotFound (key not found)
# > key 'test' not found

PUT /key/:key

# creates document `test` if it doesn't exist
# otherwise, replaces content of `key` with given
curl -X PUT -H "Content-Type: application/json" \
            -d '{"key1":"value"}' localhost:8080/key/test

# example output on 200 OK (create/update success)
# > create 'test' successful

DELETE /key/:key

# deletes document `test`
curl -X DELETE localhost:8080/key/test

# example output on 200 OK (delete success)
# > delete 'test' successful
# example output on 404 NotFound (key not found)
# > key 'test' doest not exist

GET /key/:key/field/:field

# get `example_field` of document `test`
curl localhost:8080/key/test/field/example_field

# example output on 200 OK (found field)
# > "example_value"
# example output on 400 BadRequest (field not found)
# > err key 'test' does not have field 'example_field'
# example output on 404 NotFound (key not found)
# > key 'test' not found

PATCH /key/:key/field/:field

# update `field` of document `test` with content
# if field doesnt exist, create it
curl -X PATCH -H "Content-Type: application/json" \
              -d '{"nested":"json!"}' \
              localhost:8080/key/test/field/example_field

# example output on 200 OK (found field)
# > patch field 'example_field' of key 'key' successful
# example output on 404 NotFound (key not found)
# > key 'test' not found

commands

smoldb help  # shows a list of commands
smoldb start # start a smoldb server on :8080 using folder `db`
smoldb shell # start an interactive smoldb shell

smoldb start

This command starts a new smoldb server which listens for requests port :8080 and uses the default folder db.

You can change the directory with the --dir <value>, -d <value> flag.

# e.g.
smoldb --dir some/folder start # start a smoldb server using folder `some/folder`
smoldb -d . start              # start a smoldb shell in the current directory

You can also change the port the server is hosted on with the --p <value>, -p <value> flag.

# e.g.
smoldb start --port 8081  # start a smoldb server on port 8081
smoldb -d . start -p 8080 # start a smoldb server on port 8080 using current directory

smoldb shell

This command starts a new smoldb interactive shell using the defailt folder db. The interactive shell is more like a quick tool to explore the database by allowing easy viewing of the database index, lookup of documents, and deletion of documents.

Similar to the smoldb server, you can change the directory with the --dir <value>, -d <value> flag.

# e.g.
smoldb -d . shell # start a smoldb shell using current directory

reference resolution

You can refer to other documents by using a reference of the form REF::<key>. For example, with the following two JSONs:

ref.json

{
  "key": "REF::nested"
}

nested.json

{
  "nestedKey": "nestedVal"
}

You end up with the following:

{
   "key": {
      "nestedKey": "nestedVal"
   }
}

building smolDB from scratch

  • Run git clone https://github.com/themillenniumfalcon/smolDB
  • Run make build
  • For cross-platform builds, run make build-all (optional)