A demonstration of the Poe protocol using aiohttp
Project description
aiohttp_poe
An implementation of the Poe protocol using aiohttp.
To run it:
- Create a virtual environment (Python 3.7 or higher)
pip install .
python -m aiohttp_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
aiohttp_poe.PoeBot
to make a bot:
from aiohttp_poe import PoeBot, run
class EchoBot(PoeBot):
async def get_response(self, query, request):
last_message = query["query"][-1]["content"]
yield self.text_event(last_message)
if __name__ == "__main__":
run(EchoBot())
Enable authentication
Poe servers send requests containing Authorization HTTP header in the format "Bearer <api_key>," where api_key is the API key configured in the bot settings. \
To validate the requests are from Poe Servers, you can either set the environment variable POE_API_KEY or pass the parameter api_key in the run function like:
if __name__ == "__main__":
run(EchoBot(), api_key=<key>)
For a more advanced example that exercises more of the Poe protocol, see Catbot.
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
aiohttp_poe-0.0.12.tar.gz
(5.1 kB
view hashes)
Built Distribution
Close
Hashes for aiohttp_poe-0.0.12-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 20b48a504ce8ed4387d95d722d0b8c1b3e5b1ba7def0c55d99009d85f347544d |
|
MD5 | 911f7f5f2dcadddc6bd481d6d8ad2cba |
|
BLAKE2b-256 | 7afdaf4ac0f5909bc95d69823603406696b67e9c7009567f7b6bc236815be9b9 |