Gateways
By default, Nestipy use socketio as a Gateway. However, we can create our own adapter.
Firstly, we need to create a gateway class
Python
from typing import Annotated
from nestipy.ioc import WebSocketServer, WebSocketClient, SocketData
from nestipy.websocket import IoAdapter, Gateway, SubscribeMessage, Websocket
@Gateway()
class AppGateway:
server: Annotated[IoAdapter, WebSocketServer()]
@SubscribeMessage('user')
async def on_user(self, client: Annotated[Websocket, WebSocketClient()], data: Annotated[str, SocketData()]):
print(client.sid, data)
await self.server.emit('user', data, client.sid)
Now, use gateway as module provider.
Python
from nestipy.common.decorator import Module
@Module(
providers=[
AppGateway
]
)
class AppModule:
pass
After all, we need to tell Nestipy to use socketio as io adapater.
Python
import socketio
from nestipy.core.nestipy_factory import NestipyFactory
from nestipy.websocket import SocketIoAdapter
app = NestipyFactory.create(AppModule)
sio = socketio.AsyncServer(async_mode='asgi')
app.use_io_adapter(SocketIoAdapter(sio))
Gateway is marked as Injectable, it means you can inject it into controllers or other services within the same module. You can also inject it everywhere if it's defined as a provider in the root module.
A working example can be found here.
Support us
Nestipy is a project released under the MIT license, meaning it's open source and freely available for use and modification. Its development thrives with the generous contributions of these fantastic individuals.