2023-10-03 15:29:56 +00:00
|
|
|
import os
|
2023-10-04 21:43:07 +00:00
|
|
|
from importlib import import_module
|
2023-10-03 15:29:56 +00:00
|
|
|
from os.path import exists
|
2023-10-14 12:59:43 +00:00
|
|
|
|
2023-10-03 15:29:56 +00:00
|
|
|
from ariadne import load_schema_from_path, make_executable_schema
|
|
|
|
from starlette.applications import Starlette
|
2024-04-10 13:18:52 +00:00
|
|
|
from ariadne.asgi import GraphQL
|
|
|
|
|
2024-04-09 18:11:17 +00:00
|
|
|
from starlette.routing import Route
|
2024-01-25 09:25:52 +00:00
|
|
|
|
2024-04-18 10:48:29 +00:00
|
|
|
from services.logger import root_logger as logger
|
2023-11-22 12:09:24 +00:00
|
|
|
from services.rediscache import redis
|
2023-12-17 17:13:17 +00:00
|
|
|
from services.schema import resolvers
|
2024-04-08 06:30:57 +00:00
|
|
|
from services.sentry import start_sentry
|
|
|
|
from settings import DEV_SERVER_PID_FILE_NAME, MODE
|
|
|
|
|
|
|
|
import_module("resolvers")
|
|
|
|
schema = make_executable_schema(load_schema_from_path("inbox.graphql"), resolvers)
|
|
|
|
|
|
|
|
|
|
|
|
async def start():
|
|
|
|
if MODE == "development":
|
|
|
|
if not exists(DEV_SERVER_PID_FILE_NAME):
|
|
|
|
# pid file management
|
|
|
|
with open(DEV_SERVER_PID_FILE_NAME, "w", encoding="utf-8") as f:
|
|
|
|
f.write(str(os.getpid()))
|
2024-04-18 10:48:29 +00:00
|
|
|
logger.info(f"process started in {MODE} mode")
|
2024-04-08 06:30:57 +00:00
|
|
|
|
|
|
|
# main starlette app object with ariadne mounted in root
|
|
|
|
app = Starlette(
|
|
|
|
on_startup=[
|
|
|
|
redis.connect,
|
|
|
|
start_sentry,
|
|
|
|
start,
|
|
|
|
],
|
|
|
|
on_shutdown=[redis.disconnect],
|
|
|
|
debug=True,
|
2024-04-09 18:11:17 +00:00
|
|
|
routes=[
|
2024-04-10 13:18:52 +00:00
|
|
|
Route("/", GraphQL(schema, debug=True)),
|
2024-04-09 18:11:17 +00:00
|
|
|
],
|
2024-04-08 06:30:57 +00:00
|
|
|
)
|