socketsundso: A WebSocket JSON API Framework based on FastAPI, pydantic and starlette
Project description
socketsundso
Warning: This project is in very early development.
What's all this then?
This is an opionated framework for creating WebSocket APIs based on FastAPI, Starlette and pydantic. FastAPI offers nice validation (powered by pydantic) for HTTP endpoints. This framework tries to make it easy to use all these goodies when develooping a JSON based websocket API.
Concept
The whole idea is based around the concept of a simple json based protocol. Messages between client and server can be categorized by a type or event and contain some data. For HTTP the type/event will mostly be conveyed via path or querystring. When using WebSockets you could also use the path for this but this would mean opening a new socket for every type of event. Seems unnecassery when you already have a perfectly working connection established.
Message Format
The basic message format is as follows
{
type: str,
...
}
Seems simple. Doesn't it? Well here comes the magic: Let's assume we want to build something similar to a chat application where users can send messages. So we would have an event called message. In our application we can simply define a handler for it and this awesome framework will call the handler whenever it receives a message with the type 'message'.
@on_event
def on_message(self, message: str) -> None:
print('Hey i just received a message:')
print(message)
When registering a handler like above, socketsundso will create a pydantic model specifically for messages for this handler. This model is similar to this:
class Message(BaseModel):
type: typing.Literal('message'),
message: str
class Config:
extra = 'forbid'
The response will also be validated through a model. But since it's hard to guess what you want in your output you have to give a response_model. Otherwise socketsundso will just make sure there is a type in the response. For more information take a look at the documentation.
Documentation
The documentation is located at https://socketsundso.dingensundso.de. You can also find some examples in examples/
Roadmap
Things that should/will/propably won't be implemented soon:
- validation of incoming data (based on type signatures of handlers)
- tests!!!
- response_model
- don't require handlers to be async
- nice and shiny documentation
- more and better examples
- some crazy scheme to make money with this (maybe add a cryptominer to some file deep within?)
- some kind of license
- make it compatible with older python versions (at least 3.9, maybe even 3.7)
- more and better tests
- more and better documentation
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
File details
Details for the file socketsundso-0.0.5.tar.gz
.
File metadata
- Download URL: socketsundso-0.0.5.tar.gz
- Upload date:
- Size: 17.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.27.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b088152cd0b8ade43b99e63257cd41e8798f165fec9b2375a4065517117f9fdf |
|
MD5 | 13936ee18cecbf4f185459c2fa767cd4 |
|
BLAKE2b-256 | 62688260c021d5aae126a8dadc78440705f73cf8dd31e31d44e2b507edc980ed |
File details
Details for the file socketsundso-0.0.5-py3-none-any.whl
.
File metadata
- Download URL: socketsundso-0.0.5-py3-none-any.whl
- Upload date:
- Size: 10.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.27.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1f1f24a2a0e10565066859128dcca3b0f6219a467503acc8e8241edb4fb62e41 |
|
MD5 | 69fc81228111a4c4ec470369b78e12c3 |
|
BLAKE2b-256 | 67f422ffb3d33b217c0d32e47e158a88a924a6551c0cd8409ee212a6a8a1426a |