[build-system] requires = ["setuptools>=64", "setuptools_scm>=8"] build-backend = "setuptools.build_meta" [project] name = "pipecat-ai" dynamic = ["version"] description = "An open source framework for voice (and multimodal) assistants" license = { text = "BSD 2-Clause License" } readme = "README.md" requires-python = ">=3.10" keywords = ["webrtc", "audio", "video", "ai"] classifiers = [ "Development Status :: 5 - Production/Stable", "Intended Audience :: Developers", "License :: OSI Approved :: BSD License", "Topic :: Communications :: Conferencing", "Topic :: Multimedia :: Sound/Audio", "Topic :: Multimedia :: Video", "Topic :: Scientific/Engineering :: Artificial Intelligence" ] dependencies = [ "aiohttp~=3.11.10", "audioop-lts~=0.2.1; python_version>='3.13'", "loguru~=0.7.3", "Markdown~=3.7", "numpy~=2.1.3", "numba~=0.61.0rc1", "Pillow~=11.0.0", "protobuf~=5.29.1", "pydantic~=2.10.3", "pyloudnorm~=0.1.1", "resampy~=0.4.3", "tenacity~=9.0.0" ] [project.urls] Source = "https://github.com/pipecat-ai/pipecat" Website = "https://pipecat.ai" [project.optional-dependencies] anthropic = [ "anthropic~=0.40.0" ] assemblyai = [ "assemblyai~=0.34.0" ] aws = [ "boto3~=1.35.27" ] azure = [ "azure-cognitiveservices-speech~=1.41.1", "openai~=1.59.0" ] canonical = [ "aiofiles~=24.1.0" ] cartesia = [ "cartesia~=1.0.13", "websockets~=13.1" ] cerebras = [ "openai~=1.59.0" ] daily = [ "daily-python~=0.14.2" ] deepgram = [ "deepgram-sdk~=3.7.7" ] elevenlabs = [ "websockets~=13.1" ] fal = [ "fal-client~=0.4.1" ] fish = [ "ormsgpack~=1.7.0", "websockets~=13.1" ] gladia = [ "websockets~=13.1" ] google = [ "google-generativeai~=0.8.3", "google-cloud-texttospeech~=2.21.1" ] grok = [ "openai~=1.59.0" ] groq = [ "openai~=1.59.0" ] gstreamer = [ "pygobject~=3.48.2" ] fireworks = [ "openai~=1.59.0" ] krisp = [ "pipecat-ai-krisp~=0.3.0" ] koala = [ "pvkoala~=2.0.2" ] langchain = [ "langchain~=0.3.12", "langchain-community~=0.3.12", "langchain-openai~=0.2.12" ] livekit = [ "livekit~=0.17.5", "livekit-api~=0.7.1" ] lmnt = [ "lmnt~=1.1.4" ] local = [ "pyaudio~=0.2.14" ] moondream = [ "einops~=0.8.0", "timm~=1.0.8", "transformers~=4.44.0" ] nim = [ "openai~=1.59.0" ] noisereduce = [ "noisereduce~=3.0.3" ] openai = [ "openai~=1.59.0", "websockets~=13.1", "python-deepcompare~=1.0.1" ] openpipe = [ "openpipe~=4.40.0" ] playht = [ "pyht~=0.1.9", "websockets~=13.1" ] riva = [ "nvidia-riva-client~=2.17.0" ] silero = [ "onnxruntime~=1.20.1" ] simli = [ "simli-ai~=0.1.7"] soundfile = [ "soundfile~=0.12.1" ] together = [ "openai~=1.59.0" ] websocket = [ "websockets~=13.1", "fastapi~=0.115.0" ] whisper = [ "faster-whisper~=1.1.0" ] [tool.setuptools.packages.find] # All the following settings are optional: where = ["src"] [tool.pytest.ini_options] pythonpath = ["src"] [tool.setuptools_scm] local_scheme = "no-local-version" fallback_version = "0.0.0-dev" [tool.ruff] exclude = ["*_pb2.py"] line-length = 100 [tool.ruff.lint] select = [ "D", # Docstring rules "I", # Import rules ] [tool.ruff.lint.pydocstyle] convention = "google"