import uuid
from typing import TYPE_CHECKING
import sentry_sdk
from sentry_sdk.utils import logger
if TYPE_CHECKING:
from typing import Optional
from sentry_sdk._types import Event, MonitorConfig
def _create_check_in_event(
monitor_slug: "Optional[str]" = None,
check_in_id: "Optional[str]" = None,
status: "Optional[str]" = None,
duration_s: "Optional[float]" = None,
monitor_config: "Optional[MonitorConfig]" = None,
) -> "Event":
options = sentry_sdk.get_client().options
check_in_id = check_in_id or uuid.uuid4().hex
check_in: "Event" = {
"type": "check_in",
"monitor_slug": monitor_slug,
"check_in_id": check_in_id,
"status": status,
"duration": duration_s,
"environment": options.get("environment", None),
"release": options.get("release", None),
}
if monitor_config:
check_in["monitor_config"] = monitor_config
return check_in
def capture_checkin(
monitor_slug: "Optional[str]" = None,
check_in_id: "Optional[str]" = None,
status: "Optional[str]" = None,
duration: "Optional[float]" = None,
monitor_config: "Optional[MonitorConfig]" = None,
) -> str:
check_in_event = _create_check_in_event(
monitor_slug=monitor_slug,
check_in_id=check_in_id,
status=status,
duration_s=duration,
monitor_config=monitor_config,
)
sentry_sdk.capture_event(check_in_event)
logger.debug(
f"[Crons] Captured check-in ({check_in_event.get('check_in_id')}): {check_in_event.get('monitor_slug')} -> {check_in_event.get('status')}"
)
return check_in_event["check_in_id"]