A demonstration of the Poe protocol using FastAPI
Reason this release was yanked:
Broken, use 0.0.31 instead
Project description
fastapi_poe
An implementation of the Poe protocol using FastAPI.
Write your own bot
This package can also be used as a base to write your own bot. You can inherit from
PoeBot
to make a bot:
import fastapi_poe as fp
class EchoBot(fp.PoeBot):
async def get_response(self, request: fp.QueryRequest):
last_message = request.query[-1].content
yield fp.PartialResponse(text=last_message)
if __name__ == "__main__":
fp.run(EchoBot(), allow_without_key=True)
Now, run your bot using python <filename.py>
.
- In a different terminal, run ngrok to make it publicly.
- Use the publicly accessible url to integrate your bot with poe
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__":
fp.run(EchoBot(), access_key=<key>)
Samples
Check out our starter code repository for some examples you can use to get started with bot development.
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
Hashes for fastapi_poe-0.0.29-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c6b64082d61e6c8f742e4e1dd146456c4196433282bff3f402e3ba9c77c553e7 |
|
MD5 | 71b76773bc66986f89de30fa502b134a |
|
BLAKE2b-256 | 86bacd7fd407d0e43553811731ad66d9ab3a4e5c56c78a076c2f39d2192fc343 |