Forward and reverse proxy using apache or nginx
Project description
Table of contents
Intro
forevd
is a forward and reverse proxy that helps deliver authentication and, optionally,
authorization as a sidecar.
This project was created to help eliminate any need to add authentication into your application code.
Dependencies
At the moment, forevd
, runs using Apache, so you will need to have httpd or docker image of it
available at runtime.
- Apache
- nginx (TBD)
Running forevd
The following proivides some details on how to run forevd
. The way the options work are that
anything provided immediately on the CLI, are "global" defaults; if you then provide config
(optionally files), via the --locations
, --ldap
or --oidc
options, then those will override
the CLI options, of, e.g. --backend
and --location
Config Files
You can optionally provide config files for more complicated setups; this section provides soem
examples, which can be found in the etc
directory.
The config files use Jinja2 templating via environment variables, so, instead of putting values in
directly, you can use the form {{ ENV_VAR_NAME }}
to have the environment varibale injected at
runtime.
The following command line options support files: --locations
, --ldap
or --oidc
, via the @
symbol, similar to curl
's command line option --data
, for example, --oidc @etc/oidc.yaml
Locations Config
This config allows you to provide much more control over each "location" or "endpoint" to your reverse proxy. For example, using different backends for different URLs or adding authorization. The format of the file is a dictionary of locations, or endpoints, and their correspondign data.
Example
The following adds LDAP group and static user authorization to /
- path: /
authz:
join_type: "any"
ldap:
url: "ldaps://127.0.0.1/DC=foo,DC=example,DC=com"
bind-dn: "foo"
bind-pw: "{{ LDAP_BINDID_PASSWORD }}"
groups:
- "CN=foobar,OU=groups,DC=example,DC=com"
users:
- erick.bourgeois
Let's break this down a bit:
- the high level keys are endpoints
- the next level is authorization config
- the
join_type
key word tellsforevd
how to "combine" or join the two different authorizations, values are:any
: if any of the authorization types match, allow connection throughall
: all of the authorization types must match to allow connection through
OIDC Config
This is useful for adding any other global OIDC config; there are required fields for the auth to
work, e.g. ClientID
and ClientSecret
.
Example
ProviderMetadataUrl: "https://{{ OIDC_PROVIDER_NAME }}.us.auth0.com/.well-known/openid-configuration"
RedirectURI: "https://erick-pro.jeb.ca:8080/secure/redirect_uri"
ClientId: "{{ OIDC_CLIENT_ID }}"
ClientSecret: "{{ OIDC_CLIENT_SECRET }}"
Scope: '"openid profile"'
PKCEMethod: S256
RemoteUserClaim: nickname
LDAP Config
This is used for global LDAP config, e.g. setting cache information for mod_ldap
. Note: The LDAP
prefix is stripped, as it's redundant and it's added as part of the config generation.
Example
SharedCacheSize: 500000
CacheEntries: 1024
CacheTTL: 600
OpCacheEntries: 1024
OpCacheTTL: 600
Mutual TLS
The following command provides termination of mTLS on /
and passes connections to a backend at
http://0.0.0.0:8080
forevd --debug --listen 0.0.0.0:8080 \
--ca-cert $PWD/../certs/ca/ca-cert.pem
--cert $PWD/../certs/server.crt
--cert-key $PWD/../certs/server.key
--backend http://localhost:8081
--location /
--mtls require
--server-name example.com
--var-dir /var/tmp/apache
Authorization
To add authorization, it's recommended you use a config file for the --locations
command line.
There is currently support for LDAP group lookup and static user names.
See Locations Example for more detail.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file forevd-0.1.9.tar.gz
.
File metadata
- Download URL: forevd-0.1.9.tar.gz
- Upload date:
- Size: 12.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 17a8a02a60458f1c9ac10d06564efdb754ba077b009749c4817a355854f290fb |
|
MD5 | 6e53a80349ea7f9bf2717f9f67db1d42 |
|
BLAKE2b-256 | 5148beec8086b2ddea791ba2e0c4b1d7844f8b504e89b426ebb413bf82fd606c |
File details
Details for the file forevd-0.1.9-py3-none-any.whl
.
File metadata
- Download URL: forevd-0.1.9-py3-none-any.whl
- Upload date:
- Size: 13.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b06788aed920c4988360fc08d0ed21a645daf0a75a002d2a0257b07676b33e48 |
|
MD5 | 9ecd5f74ce036a7f0bc2fb242e015f2c |
|
BLAKE2b-256 | d2e190b166c6772b52ee3cad2ba1bfbbece3e0222dc03f0facddc3e60d5e6634 |