Trusted-CGI
Lightweight self-hosted lambda/applications/cgi/serverless-functions engine.
Idea behind
The idea came from the past: CGI. At the beginning of the Internet, people have been making a simple script that receives incoming bytes over STDIN (standard input) and writes to STDOUT (standard output). The application server (aka CGI server), accepts clients, invokes scripts and redirects socket input/output to the script. There are a lot of details here but this is a brief explanation.
After more than 20 years the world spin around and arrived at the beginning: serverless functions/lambda and so on. It is almost CGI, except scripts became docker containers, and we need many more servers to do the same things as before.
So let’s cut the corners a bit: we have a trusted developer (our self, company workers - means it’s not arbitrary clients), so we don’t need a heavy restriction for the application, so let’s throw away docker and another heavy staff.
Docs and features
- Manifest - main and mandatory entrypoint for the lambda
- Actions - arbitrary actions that could be invoked by UI or by scheduler
- Scheduler - cron-like scheduling system to automatically call actions by time
- Aliases - permanent links and aliases/links
- Security - security and restrictions
- GIT repo - using GIT repo as a function
High-level components diagram
Why I did it?
Because I want to write small handlers that will be 99% of the time just do nothing. I am already paying for the cheapest Digital Ocean (thanks guys for your existence) and do not want to pay additionally to Lambda providers like Google/Amazon/Azure.
I also tried self-hosted solutions based on k3s but it too heavy for 1GB server (yep, it is, don’t believe in marketing).
So, ‘cause I am a developer I decided to make my own wheels ;-)
Installation
Actions
If function contains Makefile and installed make, it is possible to invoke targets over UI/API (called Actions). Useful for installing dependencies or building.
URL
Each function contains at least one URL: <base URL>/a/<UID>
and any number of unique aliases/links <base URL>/l/<LINK NAME>
.
Links are useful to make a public links and dynamically migrate between real implementations (functions). For ex: you made a GitHub hook processor in Python language, than changed your mind and switched to PHP function. Instead of updating link in GitHub repo (that could be a hassle if you spread it everywhere) you can change just a link.
Important! Security settings and restrictions will be used from new functions.
Templates
Embedded
Python 3
Host requirements:
- make
- python3
- python3-venv
Node
Host requirements:
PHP
Host requirements:
Nim lang
Host requirements:
Development
Embedding UI
```shell script make clean make embed_ui `
TODO
- Upload/download tarball
- CLI control
from Hacker News https://ift.tt/2XNGM4y
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.