Skip to main content

Python port of the localtunnel.me Client | Expose localhost to the world!

Project description

LocalTunnel Python Client

PyPI version License Python Versions

Python port of the Localtunnel Client with enhancements

Expose your localhost to the 🌎 for easy testing and sharing:

  • 👷🏻‍♂️ Actively maintained

A Python client for LocalTunnel, enabling developers to expose their local servers to the internet with minimal setup. Designed for ease of use, flexibility, and lightweight integration, this library supports both CLI and programmatic APIs.


Overview

LocalTunnel provides a simple way to make a local development server accessible to anyone on the internet. Unlike similar tools like Ngrok, this library is lightweight, open-source, and Python-native, making it perfect for developers who prefer seamless integration into their Python projects.


Installation

Install using a package manager 📦:

via pip

pip install localtunnel-py

via uv

uv add localtunnel-py

via poetry

poetry add Localtunnel-py

For contributors or advanced users, clone the repository and install in editable mode:

git clone https://github.com/gweidart/localtunnel-py.git
cd localtunnel-py
pip install -e .

Features

  • Expose Local Servers Effortlessly:

    • Quickly share your local development server with a public URL.
    • Perfect for testing webhooks, sharing progress with team members, or debugging remotely.
  • Custom Subdomains:

    • Use a custom subdomain to make your server URL more predictable and user-friendly.
    • Example: https://my-custom-subdomain.loca.lt
  • Robust Retry Mechanisms:

    • Ensure tunnel connections are resilient with customizable retry strategies, including exponential backoff.
  • Monitoring and Lifecycle Management:

    • Built-in support for monitoring tunnels to handle unexpected disruptions.
    • Automatically recover or notify when a tunnel goes offline.
  • Flexible Header Transformations:

    • Modify request headers dynamically using HeaderTransformer.
  • Lightweight CLI Tool:

    • A simple command-line interface for quick setup and deployment.
  • Seamless Integration:

    • Import the library directly into your Python project and manage tunnels programmatically.
  • Extensive Logging:

    • Pretty printed logging with rich tracebacks.

Quick Start

Programmatic API

Here’s how to expose a local server programmatically:

import asyncio
from localtunnel.tunnel_manager import TunnelManager

async def main():
    manager = TunnelManager()
    manager.add_tunnel(port=8000, subdomain="my-subdomain")

    try:
        await manager.open_all()
        for tunnel in manager.tunnels:
            print(f"Tunnel open at URL: {tunnel.get_tunnel_url()}")

        # Keep running
        await asyncio.Event().wait()
    finally:
        await manager.close_all()

asyncio.run(main())

CLI Usage

Expose a local server directly from the command line:

lt --port 3002 -s my-subdomain

Available arguments:

Argument Description
-p, --port Local port to expose via the tunnel (required).
-s, --subdomain Optional subdomain for the tunnel.
-t, --host LocalTunnel server URL (default: https://localtunnel.me).
-m, --monitor Enable monitoring of the tunnel.

Advanced Usage

Create a new localtunnel

import asyncio
from localtunnel.tunnel_manager import TunnelManager

async def main():
    manager = TunnelManager()
    manager.add_tunnel(port=8000, subdomain="my-subdomain")

    try:
        await manager.open_all()
        for tunnel in manager.tunnels:
            print(f"Tunnel open at URL: {tunnel.get_tunnel_url()}")

        # Keep running
        await asyncio.Event().wait()
    finally:
        await manager.close_all()

asyncio.run(main())

Custom Header Transformations

Modify headers dynamically using HeaderTransformer:

from localtunnel.header_transformer import HeaderTransformerFactory

transformer = HeaderTransformerFactory.create_transformer(
    transformer_type="host", host="my-custom-host"
)
headers = {"Authorization": "Bearer token"}
transformed_headers = transformer.transform(headers)
print(transformed_headers)

Retry Strategies

Implement robust retry mechanisms for tunnel connections:

from localtunnel.utils import ExponentialBackoffRetryTemplate

retry_strategy = ExponentialBackoffRetryTemplate(base_delay=1.0, max_delay=10.0)
retry_strategy.retry(some_function, retries=5)

Managing Multiple Tunnels

Use TunnelManager to handle multiple tunnels seamlessly:

from localtunnel.tunnel_manager import TunnelManager

manager = TunnelManager()
manager.add_tunnel(port=8000, subdomain="app1")
manager.add_tunnel(port=8001, subdomain="app2")
await manager.open_all()

Troubleshooting

  • Issue: Tunnel connection drops frequently.

    • Solution: Enable monitoring with TunnelManager.
  • Issue: Custom subdomain not working.

    • Solution: Ensure the subdomain is available and correctly passed to add_tunnel().

Contributing

We welcome contributions! Here's how you can get involved:

  1. Fork the repository.
  2. Create a new branch for your feature or bugfix.
  3. Submit a pull request with a detailed description.

License

This project is licensed under the MIT License. See the LICENSE file for details.


Links and Acknowledgments

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

localtunnel_py-0.1.1.tar.gz (15.3 kB view details)

Uploaded Source

Built Distribution

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

localtunnel_py-0.1.1-py3-none-any.whl (14.7 kB view details)

Uploaded Python 3

File details

Details for the file localtunnel_py-0.1.1.tar.gz.

File metadata

  • Download URL: localtunnel_py-0.1.1.tar.gz
  • Upload date:
  • Size: 15.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for localtunnel_py-0.1.1.tar.gz
Algorithm Hash digest
SHA256 1f1af99be7e73b0ef8231cee55fd063d56a4bb54ed86b37e9958d1331d921bfc
MD5 a4f0f5661a09cb571ce31f536d10ccb6
BLAKE2b-256 20ddb7379df8a76c41993be5687a3d8f868897a44966ca5e6ffd75449f600c3e

See more details on using hashes here.

Provenance

The following attestation bundles were made for localtunnel_py-0.1.1.tar.gz:

Publisher: pypi-workflow.yaml on gweidart/localtunnel-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file localtunnel_py-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: localtunnel_py-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 14.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for localtunnel_py-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 661149529991f5fe0001af4a9a16067416b33781061736b5832199d4bad135e9
MD5 5e55179b7649fcd522aaac3a557ff498
BLAKE2b-256 9a83d711241bef430c9b6ac9b88c096180d43dc83f3aa4a88d63e651064916d1

See more details on using hashes here.

Provenance

The following attestation bundles were made for localtunnel_py-0.1.1-py3-none-any.whl:

Publisher: pypi-workflow.yaml on gweidart/localtunnel-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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