WebSocket client for SlimFaas — lets Jobs and virtual functions receive async requests and publish/subscribe events without exposing an HTTP port.
Project description
slimfaas-client
Python client to connect Jobs or virtual functions to SlimFaas via WebSocket. Lets any process receive async requests and publish/subscribe events without exposing an HTTP port.
Requirements
- Python ≥ 3.10
- UV as package manager
Installation
uv add slimfaas-client
# or from source
uv pip install -e .
Quick start
import asyncio
from slimfaas_client import (
SlimFaasClient, SlimFaasClientConfig,
SubscribeEventConfig, FunctionVisibility,
AsyncRequest, PublishEvent,
)
async def handle_request(req: AsyncRequest) -> int:
"""Called when SlimFaas sends an async-function request.
Return an HTTP status code (200 = success, 500 = error, 202 = long processing)."""
print(f"{req.method} {req.path}{req.query}")
print(f"Body: {req.body}")
return 200
async def handle_event(evt: PublishEvent) -> None:
"""Called when SlimFaas publishes a publish-event."""
print(f"Event '{evt.event_name}': {evt.body}")
async def main():
config = SlimFaasClientConfig(
function_name="my-job",
subscribe_events=[
SubscribeEventConfig(name="order-created"),
SubscribeEventConfig(name="order-updated"),
],
default_visibility=FunctionVisibility.PUBLIC,
number_parallel_request=5,
)
async with SlimFaasClient("ws://slimfaas:5003/ws", config) as client:
client.on_async_request(handle_request)
client.on_publish_event(handle_event)
await client.run_forever()
asyncio.run(main())
Full configuration
from slimfaas_client import (
SlimFaasClientConfig, SubscribeEventConfig, PathVisibilityConfig,
FunctionVisibility, FunctionTrust,
)
config = SlimFaasClientConfig(
function_name="my-job",
# SlimFaas/DependsOn
depends_on=["other-function"],
# SlimFaas/SubscribeEvents — each entry may override visibility individually
subscribe_events=[
SubscribeEventConfig(name="my-event", visibility=FunctionVisibility.PUBLIC),
SubscribeEventConfig(name="internal-event"), # inherits default_visibility
],
# SlimFaas/DefaultVisibility
default_visibility=FunctionVisibility.PUBLIC, # or PRIVATE
# SlimFaas/PathsStartWithVisibility
paths_start_with_visibility=[
PathVisibilityConfig(path="/admin", visibility=FunctionVisibility.PRIVATE),
],
# SlimFaas/Configuration
configuration='{"key": "value"}',
# SlimFaas/ReplicasStartAsSoonAsOneFunctionRetrieveARequest
replicas_start_as_soon_as_one_function_retrieve_a_request=True,
# SlimFaas/NumberParallelRequest
number_parallel_request=10,
# SlimFaas/NumberParallelRequestPerPod
number_parallel_request_per_pod=5,
# SlimFaas/DefaultTrust
default_trust=FunctionTrust.TRUSTED, # or UNTRUSTED
)
Sync streaming (HTTP-over-WebSocket)
from slimfaas_client import SyncRequest
async def handle_sync(req: SyncRequest) -> None:
body = b'{"status": "ok"}'
await req.response.start(200, {"Content-Type": ["application/json"]})
await req.response.write(body)
await req.response.complete()
client.on_sync_request(handle_sync)
Long-running requests (status 202)
Return 202 to acknowledge the request without completing it yet,
then call send_callback when done:
async def handle_long(req: AsyncRequest) -> int:
asyncio.create_task(process_in_background(req))
return 202 # "I'll handle it — will call back"
async def process_in_background(req: AsyncRequest) -> None:
await asyncio.sleep(10)
await client.send_callback(req.element_id, 200)
Dependency injection
The handlers are plain async functions, so you can close over any dependency you resolved from your DI framework:
# Example with a database session from SQLAlchemy
from sqlalchemy.ext.asyncio import AsyncSession
async def make_handler(session: AsyncSession):
async def handle_request(req: AsyncRequest) -> int:
await session.execute(...) # use the injected session
return 200
return handle_request
client.on_async_request(await make_handler(db_session))
Automatic reconnection
The client reconnects automatically after a disconnection. Configure the delay between attempts:
client = SlimFaasClient("ws://...", config, reconnect_delay=10.0)
Important rules
-
function_namemust not match an existing Kubernetes Deployment name. SlimFaas will reject the registration with aSlimFaasRegistrationError. -
All clients sharing the same
function_namemust have the exact same configuration. Mismatches are rejected on connection.
Development
uv sync --extra dev
uv run pytest
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file slimfaas_client-0.70.0.tar.gz.
File metadata
- Download URL: slimfaas_client-0.70.0.tar.gz
- Upload date:
- Size: 59.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b697dd947f351f725f7faa3978aca25dc042ed96081a45b9715074fe3d89a3d7
|
|
| MD5 |
6784a45aa90e84636243a8613db916ff
|
|
| BLAKE2b-256 |
788389cc7da4808063387f9b4c0f23e7365c8ebe82fc0b7bb90e72fb3a2971d8
|
File details
Details for the file slimfaas_client-0.70.0-py3-none-any.whl.
File metadata
- Download URL: slimfaas_client-0.70.0-py3-none-any.whl
- Upload date:
- Size: 12.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b1906435f70ecd73cd0bb7ced0c54c62c3c4bc39d15cf4e4c771c5022310a9f2
|
|
| MD5 |
abc58c50fd1f54a55c369b81f56b269c
|
|
| BLAKE2b-256 |
4b9e3c34638fda4c0aa45b302675d2dc673e615f90ee7fdc86ebd2184ff06646
|