Skip to main content

Async Python library for FreeSWITCH Event Socket Layer (ESL) - Build high-performance telephony applications with asyncio

Project description

Genesis

Build badge License badge Pypi Version badge Pypi python version badge Pypi wheel badge

Genesis is a Python library designed to build asynchronous applications that interact with FreeSWITCH through the Event Socket Layer (ESL).

Features

  • Asynchronous by Design: Built with asyncio for high-performance, non-blocking I/O.
  • Inbound, Outbound, and Consumer Modes: Supports all major ESL modes for comprehensive FreeSWITCH integration.
  • Decorator-Based Event Handling: A simple and intuitive way to handle FreeSWITCH events.
  • OpenTelemetry Support: Built-in instrumentation for tracing connections and commands.
  • Extensible and Customizable: Easily extend and customize the library to fit your needs.

Installation

Install Genesis using pip:

pip install genesis

For better asyncio performance on Unix (Linux and macOS), use the optional uvloop extra: pip install genesis[uvloop]. See the Installation Guide for details.

Quickstart

Inbound Socket Mode

import asyncio
from genesis import Inbound

async def uptime():
    async with Inbound("127.0.0.1", 8021, "ClueCon") as client:
        return await client.send("uptime")

async def main():
    response = await uptime()
    print(response)

asyncio.run(main())

Consumer Mode

import asyncio
from genesis import Consumer

app = Consumer("127.0.0.1", 8021, "ClueCon")

@app.handle("HEARTBEAT")
async def handler(event):
    await asyncio.sleep(0.001)
    print(event)

asyncio.run(app.start())

Outbound Socket Mode

import asyncio
from genesis import Outbound

async def handler(session):
    await session.answer()
    await session.playback('ivr/ivr-welcome')
    await session.hangup()

app = Outbound(handler, "127.0.0.1", 5000)

asyncio.run(app.start())

Documentation

Full documentation is available on the documentation website.

To preview the docs locally, install Hugo and run:

hugo server --source docs --disableFastRender

Running Tests

Install development dependencies with Poetry and execute the test suite using tox:

poetry install
tox

How to Contribute

Contributions are welcome! Whether it's improving documentation, suggesting new features, or fixing bugs, your help is appreciated.

Please read our Contributing Guide and Code of Conduct to get started.

Contributors

Vitor
Vitor Hugo
RL/
RL
Dongwoon
Dongwoon Kim

License

This project is licensed under the MIT License - see the LICENSE.md file for details.

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

genesis-2026.5.20.tar.gz (44.3 kB view details)

Uploaded Source

Built Distribution

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

genesis-2026.5.20-py3-none-any.whl (59.7 kB view details)

Uploaded Python 3

File details

Details for the file genesis-2026.5.20.tar.gz.

File metadata

  • Download URL: genesis-2026.5.20.tar.gz
  • Upload date:
  • Size: 44.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.10.2 Linux/6.17.0-1013-azure

File hashes

Hashes for genesis-2026.5.20.tar.gz
Algorithm Hash digest
SHA256 a94862f70488d4b6461130603757e3e3135fa218c3d2c2366618882cd9e7a3a6
MD5 d9fb65067396590bb39a815020f8da4a
BLAKE2b-256 6e0b3600f8999dcbb7b24e06cc512e45a5644861b3fe7ae48e6b767730e29dbb

See more details on using hashes here.

File details

Details for the file genesis-2026.5.20-py3-none-any.whl.

File metadata

  • Download URL: genesis-2026.5.20-py3-none-any.whl
  • Upload date:
  • Size: 59.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.4.1 CPython/3.10.2 Linux/6.17.0-1013-azure

File hashes

Hashes for genesis-2026.5.20-py3-none-any.whl
Algorithm Hash digest
SHA256 bf5c477969b960cf9f55ed0cdfad9379ae95d77073f3be926065e53b1ceb7d34
MD5 50a8cb4dc3c368b232354ab4fab1c0de
BLAKE2b-256 7c87fad3285f5da238329fef8e1cc23abf27b17b9a9bad75272eae66f45c0a4b

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