FastAPI、Websocket どちらも初学者になります。
習作としてグループ内のチャットアプリを作成しています。
フロントエンド(React) <=> FastAPI <=> GraphQL API(Hasura) での実現を目指しているのですが、そのために gql.Client.subscribe(query) の結果をリアルタイムで返す必要があります。
https://gql.readthedocs.io/en/latest/transports/websockets.htmlに倣い実装を試みたのですが、print(result)ではなく、return result のように、graphql subscriptionの結果をリアルタイムでフロントエンドに返すにはどうすれば良いでしょうか?
python
#main.py app = FastAPI() graphql_query = (''' subscription { chats{ descriptions } } ''') @app.websocket("/ws") async def websocket_endpoint(): async with Client( transport=transport, #url省略 fetch_schema_from_transport=True, ) as session: async for result in session.subscribe(gql(graphql_query)): print(result) #<-この値を返したい if __name__ == "__main__": uvicorn.run("main:app", host="127.0.0.1", port=8000, log_level="info")
Python 3.9.2
uvicorn==0.15.0
gql==3.0.0b1
fastapi==0.70.0
####試行錯誤
いくつか試しましたが、どれも解決することができませんでした。
async for result in session.subscribe(gql(graphql_query)): return result
ERROR: ASGI callable returned without sending handshake.
async for result in session.subscribe(gql(graphql_query)): return await result
TypeError: object dict can't be used in 'await' expression
async for result in session.subscribe(gql(graphql_query)): yield result
TypeError: object async_generator can't be used in 'await' expression
検討のほどよろしくお願いいたします。
まだ回答がついていません
会員登録して回答してみよう