The super small and simple nginx microservice/api maker!
Neh
The super small and simple nginx microservice/api maker!
Ever wanted a quick webhook or a small API without writing an entire server?
Introducing Neh, a simple program executor for nginx.
With Neh you can:
END_REQUEST
to Neh on file descriptor #4And all of that with just two lines in your config!
Check out my blog post for more information!
Keep in mind that Neh is in alpha and should not be run in production
Make sure your location directive of choice looks like this:
location /hooks/test {
set $execute_file /home/user/script.sh; # The path to the script you want to execute
content_by_lua_file /usr/lib/neh/neh.lua; # The path to Neh
}
Then create the script file:
cd
cat <<EOF > ./script.sh
#!/bin/bash
echo Hello world!
EOF
chmod +x ./script.sh
Quickly reload your nginx config and checking if its correct sudo nginx -t && sudo systemctl reload nginx
Now if you go to http://example.com/hooks/test you will see: Hello world!
.
Congratz! You just set up your first Neh!
Just make sure that www-data
or whatever user is running your nginx instance can access the script!
You can install it through this simple oneliner:
curl https://raw.githubusercontent.com/oap-bram/neh/master/install.sh | sh
You can also inspect the install file if you want to.
Here are some more examples of what you can do with Neh.
I wrote an elaborate blog post with a nice example too with GitHub hooks, so check it out there!
With the following script, Neh transform a sent image into a blurred one. (Given you have ImageMagick installed on your system)
#!/bin/bash
convert - -blur 0x10 - # Convert data from stdin, blur and write to stdout
You can post the file as following:
curl https://example.com/your/endpoint --data-binary @./image.jpg -o ./blurred.jpg
With the following script, Neh get's some random bits and returns them as a response
#!/bin/bash
dd if=/dev/urandom bs=1K count=1 2>/dev/null
Or if you want a random (md5) hash:
dd if=/dev/urandom bs=1K count=1 2>/dev/null | md5sum | cut -d ' ' -f1
headers_fd = IO.sysopen('/proc/self/fd/3', 'w')
headers = IO.new(headers_fd)
headers << "Content-Type: text/html\n"
headers.flush
print '<h1>Hello world</h1>'
print '<p>This is a webpage</p>'
#!/usr/bin/env python
import sys
with open("/tmp/file.txt", "a") as file:
for line in sys.stdin:
file.write(line)
You can then write to the endpoint using the following curl:
curl -sL https://example.com/your/endpoint --data-binary '{"hello": "world"}'
Do you have some cool implementations? Please share them with me by sending me a friendly message!
For debugging you can tail your nginx error.log
usually found at /var/log/nginx/error.log
.
If you want to debug /usr/lib/neh/neh.lua
use the included print version and/or take a look at the openresty docs.
I had some trouble installing it on some of my servers because of an error relating to posix.ctype
.
It has to do with some libraries not linking properly on some distros. Apply the solution here.
Feel free to open a pull request or an issue if you want! If this gets out of hand I'll setup some structure using GitHub.
I could use all the help you can throw at me, so if you can help with the above let me know!
See the LICENSE for more details.
Sheep by MHD AZMI DWIPRANATA from the Noun Project