Skip to main content

FastAPI integration for botas – zero-boilerplate Bot Service bot hosting

Project description

botas logo

botas-fastapi

A lightweight, multi-language library for building Microsoft Teams bots — this is the FastAPI integration package.

Wraps botas with a FastAPI server for zero-boilerplate bot hosting.

Installation

pip install botas-fastapi

Quick start

from botas_fastapi import BotApp

app = BotApp()

@app.on("message")
async def on_message(ctx):
    await ctx.send(f"You said: {ctx.activity.text}")

app.start()

Manual FastAPI wiring

For full control over routes, middleware, and server lifecycle:

from botas import BotApplication
from botas_fastapi import bot_auth_dependency
from fastapi import Depends, FastAPI, Request

bot = BotApplication()

@bot.on("message")
async def on_message(ctx):
    await ctx.send(f"You said: {ctx.activity.text}")

app = FastAPI()

@app.post("/api/messages", dependencies=[Depends(bot_auth_dependency())])
async def messages(request: Request):
    body = await request.body()
    await bot.process_body(body.decode())
    return {}

API

BotApp

High-level wrapper that composes a BotApplication with a FastAPI + Uvicorn server.

Method Description
on(type, handler) Register a handler for an activity type (also works as a @decorator)
on_invoke(name, handler) Register a handler for an invoke activity by name (also works as a @decorator)
use(middleware) Add a middleware to the turn pipeline
start() Start the FastAPI/Uvicorn server

Options

BotApp accepts BotApplicationOptions plus these additional keyword arguments:

Option Default Description
port 3978 (or PORT env) HTTP listen port
path /api/messages Endpoint path for incoming activities
auth Auto (enabled when client_id is set) Enable/disable JWT auth middleware

Authentication options

Inherited from BotApplicationOptions — see the botas package README for the full list of authentication options and environment variables.

Documentation

License

MIT

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

botas_fastapi-0.3.80.tar.gz (6.3 kB view details)

Uploaded Source

Built Distribution

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

botas_fastapi-0.3.80-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file botas_fastapi-0.3.80.tar.gz.

File metadata

  • Download URL: botas_fastapi-0.3.80.tar.gz
  • Upload date:
  • Size: 6.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for botas_fastapi-0.3.80.tar.gz
Algorithm Hash digest
SHA256 672cb21f11a3eea1b0f935ecb087a40397ca4032a8a1c1320249770e762f6634
MD5 da8d8f354c588a110e41b1202576afe8
BLAKE2b-256 0c46ab6676a4d16d40a4eef0aa09c90c19832b5c603ec9cc2cbd6c9b4da464e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for botas_fastapi-0.3.80.tar.gz:

Publisher: CD.yml on rido-min/botas

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

File details

Details for the file botas_fastapi-0.3.80-py3-none-any.whl.

File metadata

  • Download URL: botas_fastapi-0.3.80-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for botas_fastapi-0.3.80-py3-none-any.whl
Algorithm Hash digest
SHA256 c2853c4eb38fc316e5e4bdc152faa1751c51f9624b5ece596f75a18aff95dc42
MD5 e45dcaed8e94cfba1a18b3787887dfc7
BLAKE2b-256 b5d94f92baa53e30596baa77a38abbad3ce9ba3f6b9f7d2c72b4c966b199b818

See more details on using hashes here.

Provenance

The following attestation bundles were made for botas_fastapi-0.3.80-py3-none-any.whl:

Publisher: CD.yml on rido-min/botas

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