Authentication Registration & TLS#
Louie authentication is a fairly standard web stack of containers:
Reverse proxy - Caddy container: HTTP routing, TLS
Backend services - Louie, API containers: JWT-based services
OAuth2 provider - Graphistry server: Accounts, database
Settings locations#
Environment variables:
/var/louie/data/custom.envWeb (Caddy reverse proxy):
/var/louie/data/CaddyfileAccounts (Graphistry): https://hub.graphistry.com or self-hosted Graphistry server
Steps#
Note: The application requires authentication to load.
1. Setup Authentication#
Connect to a Graphistry for accounts and authentication. This can be either a Graphistry Hub or a self-hosted Graphistry server. Louie is an OAuth2 client of Graphistry, letting it inherit the security capabilities and key infrastructure of your Graphistry server such as SSO and databases.
If Using Graphistry Hub (Default):
Create a free or paid Hub account at graphistry.com/get-started.
Contact staff for additional steps.
If self-hosting Graphistry:
See instructions below.
2. Set Your Louie URL#
Include the protocol in the custom.env file:
OA2_REDIRECT_URL_BASE='https://your.louie-server.xyz'
You must also set OA2_HOST, OA2_CLIENT_ID, and OA2_CLIENT_SECRET, which steps below will cover.
3. Setup DNS & TLS#
Configure custom DNS and TLS in /var/louie/data/Caddyfile, similar to the Graphistry server’s Caddy configuration.
4. Restart Caddy and Louie#
cd /var/louie
./dc up -d --force-recreate caddy louie api
5. Notify Graphistry Server Administrator#
Provide the following information:
OA2_REDIRECT_URL_BASEsettingOrganization name
Usernames
They will give you the remaining OA2_* pairing settings.
Configuring Private Graphistry Servers as OAuth2 Provider for Louie#
Skip this section if using Graphistry Hub.
Louie user authentication is handled from a Graphistry server, such as via Graphistry Hub or a self-hosted Graphistry server. Graphistry server accounts support username/pass, SSO, and API keys.
If using Graphistry Hub (https://www.graphistry.com/get-started):#
Notify Graphistry staff with your:
OA2_REDIRECT_URL_BASE (previous slide)
Graphistry Hub org name
Graphistry Hub username(s)
If self-hosting Graphistry:#
Configure your self-hosted Graphistry to be an OAuth2 provider for Louie
TODO(tcook): add screenshots
Steps:#
Access Graphistry Server Administration Panel.
Create a New OAuth2 Client:
Set User to admin ID (typically
1).Set Redirect URIs to your Louie server URL.
Set Confidential and Authorization Code grant type.
Provide a name (e.g., “Louie OAuth2 Client”).
Set Algorithm to
HS256(HMAC with SHA-256).
Save the Client ID & Client Secret:
The client secret will be hashed and inaccessible after saving, so make sure to record it.
Update Louie Configuration:
In
/var/louie/data/custom.env, set:OA2_HOST='https://your.graphistry-server.xyz' OA2_CLIENT_ID='your_client_id' OA2_CLIENT_SECRET='your_client_secret'
Restart the Louie Server:
cd /var/louie ./dc up -d --force-recreate caddy louie
Ensure that the Louie server URL is correctly set and that it matches the redirect URIs configured in the OAuth2 client.