Skip to content
This repository has been archived by the owner on Jan 5, 2023. It is now read-only.

lyft/tinywebdis

 
 

Repository files navigation

tinywebdis

Webdis replacement using TurboLua.

requirements

  • luajit
  • luarocks 5.1
  • redis
  • gcc (to build TurboLua)

... install both with you package manager (when you're using linux).

install

E.g. if you're on a fresh Ubuntu

  1. just install git and make

  2. git clone --recursive https://github.com/markuman/tinywebdis

  3. make ubuntu

  4. make start

     $ make
     arch                           Install system dependencies on arch linux
     install                        Install turbowebdis dependencies locally
     start                          Start turbowebdis
     stop                           Stop turbowebdis
     tabularasa                     Tabula rasa
     ubuntu                         Install system dependencies on ubuntu
     uninstall                      Uninstall turbo dependencies
    

curl examples

$ curl -w '\n' http://127.0.0.1:1234/get/foo
{"get": 42 }

$ curl -w '\n' http://127.0.0.1:1234/set/foo/gnupower
{"set": "OK" }

$ curl -w '\n' http://127.0.0.1:1234/get/foo
{"get": "gnupower" }

$ curl -w '\n' http://127.0.0.1:1234/type/foo
{"type": "string" }

$ curl -w '\n' http://127.0.0.1:1234/type/mylist
{"type": "list" }

$ curl -w '\n' http://127.0.0.1:1234/llen/mylist
{"llen": 4 }

$ curl -w '\n' http://127.0.0.1:1234/lrange/mylist/0/-1
{ "lrange":[ "hello", "oi", "oi", "a"]  }

$ curl -w '\n' http://127.0.0.1:1234/keys/*
{ "keys":[ "mylist", "a:c", "foo", "a:b", "string"]  }

$ curl -w '\n' http://127.0.0.1:8000/rpush/tinywebdis/redis
{"rpush": 3 }

curl -w '\n' http://127.0.0.1:8000/llen/tinywebdis
{"llen": 3 }

curl -w '\n' http://127.0.0.1:8000/lrange/tinywebdis/0/-1
{ "lrange":[ "lua", "dyad", "redis"] }
jsonp support
curl -w '\n' http://127.0.0.1:8888/get/foo?callback=myfunc
myfunc({"get":"gnupower"})

HTML JQUERY CORS example

You can send a json object to turbowebdis like this.

{
    "auth": "foobar",
    "db": "0",
    "command": [
        "SET",
        "SOME",
        "VALUE"
    ]
}

The key/value pairs auth and/or db are not a must have. When they are missed, the default values from config.lua file are taken.
db should be a string. But you can pass it as a number too. Turbowebdis will take care of it.
See json_example.html as a standalone example (open the file directly in your webbrowser).

TurboWebdis, TinyWebdis & CherryWebdis

Go here for detailed install instructions: Installation

  • TurboWebdis is currently the main version (and the fastest).
  • TinyWebdis is currently not maintained but stable (and the tiniest installation).
  • CherryWebdis is maybe the easiest to install version (but incomplete!)

Alternatively

About

tinywebdis - a lean webdis replacement using turbo.lua

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Lua 44.7%
  • Makefile 22.3%
  • HTML 21.5%
  • Shell 11.5%