A demonstration of the Poe protocol using FastAPI
Project description
fastapi_poe
An implementation of the Poe protocol using FastAPI.
To run it:
- Create a virtual environment (Python 3.7 or higher)
pip install .
python -m fastapi_poe
- In a different terminal, run ngrok to make it publicly accessible
Write your own bot
This package can also be used as a base to write your own bot. You can inherit from
fastapi_poe.PoeBot
to make a bot:
from fastapi_poe import PoeBot, run
from fastapi_poe.types import PartialResponse
class EchoBot(PoeBot):
async def get_response(self, request):
last_message = request.query[-1].content
yield PartialResponse(text=last_message)
if __name__ == "__main__":
run(EchoBot())
Enable authentication
Poe servers send requests containing Authorization HTTP header in the format "Bearer <access_key>"; the access key is configured in the bot settings page.
To validate that the request is from the Poe servers, you can either set the environment variable POE_ACCESS_KEY or pass the parameter access_key in the run function like:
if __name__ == "__main__":
run(EchoBot(), access_key=<key>)
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
fastapi_poe-0.0.22.tar.gz
(15.1 kB
view hashes)
Built Distribution
Close
Hashes for fastapi_poe-0.0.22-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0236ff6eb1a32c25bd687b3925422d646c8e5212146b6c8efc3b324eac9e32c2 |
|
MD5 | bd747b527e1391cb228e8a1c9251b6c4 |
|
BLAKE2b-256 | e8a65e798c1b95407fe41244c49e00b5225e9ee849d2149c1bb1196cfe25b8f5 |