-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
55 lines (47 loc) · 1.62 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
from fastapi import FastAPI, Request
from fastapi.staticfiles import StaticFiles
from fastapi_utils.timing import add_timing_middleware, record_timing
import socketio
from core.socket_io import sio
from routes.ws_no_prefix import NoPrefixNamespace
from db.connections import connect, close
from db.mongodb import get_database, AsyncIOMotorClient
from fastapi import Depends
import logging
logging.basicConfig(level=logging.INFO)
logger = logging.getLogger(__name__)
app = FastAPI()
add_timing_middleware(app, record=logger.info, prefix="app", exclude="untimed")
logger = logging.getLogger(__name__)
sio.register_namespace(NoPrefixNamespace("/"))
sio_asgi_app = socketio.ASGIApp(socketio_server=sio, other_asgi_app=app)
app.add_route("/socket.io/", route=sio_asgi_app, methods=["GET", "POST", "OPTIONS"])
app.add_websocket_route("/socket.io/", route=sio_asgi_app)
app.add_event_handler("startup", connect)
app.add_event_handler("shutdown", close)
@app.get("/hello")
async def hello(
db: AsyncIOMotorClient = Depends(get_database)
):
logging.warning(f'Writing to db')
doc = {
"_id": 2,
"name": {
"first" : "Mohamed",
"last" :"Hosam"
},
}
r = await db.test_collection.insert_one(doc)
logging.warning(f'Done')
return {"message": "Hello World"}
@app.get("/")
async def root(
request: Request,
db: AsyncIOMotorClient = Depends(get_database)
):
logging.warning(f'I got a database {db}')
record_timing(request, note="Database start")
d = await db.test_collection.find_one({"_id": 1} )
record_timing(request, note="Database done")
return {"message": d}
app.mount("/static", StaticFiles(directory="static"), name="static")