Skip to main content

HomeLab Everywhere — Expose homelab services to the internet with built-in SSO

Project description

HLE Client

PyPI Python License CI

HomeLab Everywhere — Expose homelab services to the internet with built-in SSO authentication and WebSocket support.

One command: hle expose --service http://localhost:8080

Your local service gets a public URL like myapp-x7k.hle.world with automatic HTTPS and SSO protection.

Install

pip (or pipx)

pip install hle-client
# or
pipx install hle-client

Curl installer

curl -fsSL https://get.hle.world | sh

Installs via pipx (preferred), uv, or pip-in-venv. Supports --version:

curl -fsSL https://get.hle.world | sh -s -- --version 2604.2

Homebrew

brew install hle-world/tap/hle-client

Quick Start

  1. Sign up at hle.world and create an API key in the dashboard.

  2. Save your API key:

hle auth login

This opens the dashboard in your browser. Copy your key and paste it at the prompt. The key is saved to ~/.config/hle/config.toml.

  1. Expose a service:
hle expose --service http://localhost:8080

CLI Usage

hle expose

Expose a local service to the internet.

hle expose --service http://localhost:8080              # Basic usage
hle expose --service http://localhost:8080 --label ha   # Custom subdomain label
hle expose --service http://localhost:3000 --auth none  # Disable SSO
hle expose --service http://localhost:8080 --no-websocket  # Disable WS proxying
hle expose --service http://localhost:8080 --allow user@gmail.com  # Allow a specific user
hle expose --service http://localhost:8080 --allow google:user@gmail.com --allow github:dev@co.com

Options:

  • --service — Local service URL (required)
  • --label — Service label for the subdomain (e.g. haha-x7k.hle.world)
  • --auth — Auth mode: sso (default) or none
  • --allow — Allow an email to access the tunnel (repeatable). Format: email or provider:email
  • --websocket/--no-websocket — Enable/disable WebSocket proxying (default: enabled)
  • --verify-ssl — Enable SSL certificate verification for the local service (default: off, accepts self-signed)
  • --upstream-basic-auth USER:PASS — Inject Basic Auth into requests forwarded to the local service
  • --forward-host — Forward the browser's Host header to the local service
  • --api-key — API key (also reads HLE_API_KEY env var, then config file)

hle auth

Manage your API key.

hle auth login                              # Save key (opens dashboard)
hle auth login --api-key hle_xxx            # Save key non-interactively
hle auth status                             # Show current key source
hle auth logout                             # Remove saved key

hle tunnels

List your active tunnels.

hle tunnels

hle access

Manage per-tunnel email allow-lists for SSO access.

hle access list myapp-x7k                            # List access rules
hle access add myapp-x7k friend@example.com           # Allow an email
hle access add myapp-x7k dev@co.com --provider github # Require GitHub SSO
hle access remove myapp-x7k 42                        # Remove rule by ID

hle pin

Manage PIN-based access control for tunnels.

hle pin set myapp-x7k       # Set a PIN (prompts for 4-8 digit PIN)
hle pin status myapp-x7k    # Check PIN status
hle pin remove myapp-x7k    # Remove PIN

hle share

Create and manage temporary share links.

hle share create myapp-x7k                         # 24h link (default)
hle share create myapp-x7k --duration 1h           # 1-hour link
hle share create myapp-x7k --max-uses 5            # Limited uses
hle share create myapp-x7k --label "demo"          # Label for reference
hle share list myapp-x7k                           # List share links
hle share revoke myapp-x7k 42                      # Revoke a link

hle basic-auth

Manage HTTP Basic Auth access control for tunnels.

hle basic-auth set myapp-x7k       # Set credentials (prompts for username & password)
hle basic-auth status myapp-x7k    # Check Basic Auth status
hle basic-auth remove myapp-x7k    # Remove Basic Auth

Global Options

hle --version    # Show version
hle --debug ...  # Enable debug logging

Configuration

The HLE client stores configuration in ~/.config/hle/config.toml:

api_key = "hle_your_key_here"

API key resolution order:

  1. --api-key CLI flag
  2. HLE_API_KEY environment variable
  3. ~/.config/hle/config.toml

Development

git clone https://github.com/hle-world/hle-client.git
cd hle-client
uv venv && source .venv/bin/activate
uv pip install -e ".[dev]"

# Run tests
pytest

# Lint
ruff check src/ tests/
ruff format --check src/ tests/

License

MIT — see LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hle_client-2604.2.tar.gz (61.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hle_client-2604.2-py3-none-any.whl (29.6 kB view details)

Uploaded Python 3

File details

Details for the file hle_client-2604.2.tar.gz.

File metadata

  • Download URL: hle_client-2604.2.tar.gz
  • Upload date:
  • Size: 61.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for hle_client-2604.2.tar.gz
Algorithm Hash digest
SHA256 1ca9027b8de10870daf5043f8cd8f0a7f9167956b098d3cc8e875b24a6f9f893
MD5 2bf44dfea515e0161cd8367a4c511273
BLAKE2b-256 9f96f211458a6d8706df4a57ef39fcf5db539d5a05d14a480be72750b2acef9e

See more details on using hashes here.

File details

Details for the file hle_client-2604.2-py3-none-any.whl.

File metadata

  • Download URL: hle_client-2604.2-py3-none-any.whl
  • Upload date:
  • Size: 29.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for hle_client-2604.2-py3-none-any.whl
Algorithm Hash digest
SHA256 09d38cc825d03379f7be2418725065b4eccb0384d0a28cd388694a80fe9c227e
MD5 a4961ed17df2978312d705d0ddab032b
BLAKE2b-256 61d1c8cdb385523512ecc37ce822392afb6be15912716a1083a3da1e6a9cc9e5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page