format: {time:YYYY-MM-DD HH:mm:ss} [{level}] | {name} | {message}
{name} is:
- Uvicorn: log from uvicorn server (#228B22)
- Service: log from class of `app.service` (blue)
- Fetcher: log from fetchers (magenta)
- Task: log from `app.tasks` (#FFD700)
- System: log from `system_logger` (red)
- Normal: log from `log(name)` (#FFC1C1)
- Default: the module name of caller
if you are writing services or tasks, you can just call `logger.`, we will pack it with name `Service` or `Task`
if you want to print fetcher logs, system-related logs, or normal logs, use `logger = (fetcher_logger / system_logger / log)(name)`
22 lines
622 B
Python
22 lines
622 B
Python
from __future__ import annotations
|
|
|
|
from datetime import datetime, timedelta
|
|
|
|
from app.dependencies.scheduler import get_scheduler
|
|
from app.service.beatmapset_update_service import get_beatmapset_update_service
|
|
from app.utils import bg_tasks
|
|
|
|
SCHEDULER_INTERVAL_MINUTES = 2
|
|
|
|
|
|
@get_scheduler().scheduled_job(
|
|
"interval",
|
|
id="update_beatmaps",
|
|
minutes=SCHEDULER_INTERVAL_MINUTES,
|
|
next_run_time=datetime.now() + timedelta(minutes=1),
|
|
)
|
|
async def beatmapset_update_job():
|
|
service = get_beatmapset_update_service()
|
|
bg_tasks.add_task(service.add_missing_beatmapsets)
|
|
await service._update_beatmaps()
|