This is a small server for use with Nginx's auth_request module.
It's meant for a quick and simple auto-auth - basically, the first login will create and save a user in redis. Subsequent logins will actually auth against the stored password hash.
It requires Nginx compiled with Lua support, such as found in OpenResty. It also requires the following lua modules:
- luaposix
- etlua
- luafilesystem
Just git clone this repository somewhere.
From there, you can install the needed lua modules however you regularly do.
If you install them into a folder named lua_modules, then the script
bin/redis-auth-server will use (and only use) modules found under that
folder. For example, after cloning you could run:
luarocks install --tree lua_modules luaposix
luarocks install --tree lua_modules etlua
luarocks install --tree lua_modules luafilesystemMake a copy of etc/config.lua.example to etc/config.lua and edit
as-needed, then run bin/redis-auth-server.
By default, all temp files, compiled config files, etc are placed at
$HOME/.redis-auth-server - this can be changed by setting the work_dir
variable in etc/config.lua
To run as a service, there's an example systemd unit file at
misc/redis-auth-server.service:
sudo cp misc/redis-auth-server.service /etc/systemd/system/redis-auth-server.service
# edit /etc/systemd/system/redis-auth-server.service as needed
sudo systemctl daemon-reload
sudo systemctl enable redis-auth-server.service
sudo systemctl start redis-auth-server.serviceReleased under an MIT-style license. See the file LICENSE for details.
The file resty/redis.lua also has an MIT-style license, see the file
LICENSE-lua-resty-redis for details.