Skip to content

Commit

Permalink
radarr: Strengthen types using WildValue.
Browse files Browse the repository at this point in the history
  • Loading branch information
prah23 authored and timabbott committed Sep 1, 2022
1 parent c8750e5 commit 7e34484
Showing 1 changed file with 42 additions and 29 deletions.
71 changes: 42 additions & 29 deletions zerver/webhooks/radarr/view.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
from typing import Any, Dict

from django.http import HttpRequest, HttpResponse

from zerver.decorator import webhook_view
from zerver.lib.exceptions import UnsupportedWebhookEventType
from zerver.lib.request import REQ, has_request_variables
from zerver.lib.response import json_success
from zerver.lib.validator import WildValue, check_string, to_wild_value
from zerver.lib.webhooks.common import check_send_webhook_message, get_setup_webhook_message
from zerver.models import UserProfile

Expand All @@ -29,65 +28,79 @@
def api_radarr_webhook(
request: HttpRequest,
user_profile: UserProfile,
payload: Dict[str, Any] = REQ(argument_type="body"),
payload: WildValue = REQ(argument_type="body", converter=to_wild_value),
) -> HttpResponse:
body = get_body_for_http_request(payload)
subject = get_subject_for_http_request(payload)

check_send_webhook_message(request, user_profile, subject, body, payload["eventType"])
check_send_webhook_message(
request, user_profile, subject, body, payload["eventType"].tame(check_string)
)
return json_success(request)


def get_subject_for_http_request(payload: Dict[str, Any]) -> str:
if payload["eventType"] != "Test" and payload["eventType"] != "Health":
topic = RADARR_TOPIC_TEMPLATE.format(movie_title=payload["movie"]["title"])
elif payload["eventType"] == "Test":
def get_subject_for_http_request(payload: WildValue) -> str:
event_type = payload["eventType"].tame(check_string)
if event_type != "Test" and event_type != "Health":
topic = RADARR_TOPIC_TEMPLATE.format(
movie_title=payload["movie"]["title"].tame(check_string)
)
elif event_type == "Test":
topic = RADARR_TOPIC_TEMPLATE_TEST
elif payload["eventType"] == "Health":
topic = RADARR_TOPIC_TEMPLATE_HEALTH_CHECK.format(level=payload["level"])
elif event_type == "Health":
topic = RADARR_TOPIC_TEMPLATE_HEALTH_CHECK.format(level=payload["level"].tame(check_string))

return topic


def get_body_for_health_check_event(payload: Dict[str, Any]) -> str:
return RADARR_MESSAGE_TEMPLATE_HEALTH_CHECK.format(message=payload["message"])
def get_body_for_health_check_event(payload: WildValue) -> str:
return RADARR_MESSAGE_TEMPLATE_HEALTH_CHECK.format(
message=payload["message"].tame(check_string)
)


def get_body_for_movie_renamed_event(payload: Dict[str, Any]) -> str:
return RADARR_MESSAGE_TEMPLATE_MOVIE_RENAMED.format(movie_title=payload["movie"]["title"])
def get_body_for_movie_renamed_event(payload: WildValue) -> str:
return RADARR_MESSAGE_TEMPLATE_MOVIE_RENAMED.format(
movie_title=payload["movie"]["title"].tame(check_string)
)


def get_body_for_movie_imported_upgrade_event(payload: Dict[str, Any]) -> str:
def get_body_for_movie_imported_upgrade_event(payload: WildValue) -> str:
data = {
"movie_title": payload["movie"]["title"],
"new_quality": payload["movieFile"]["quality"],
"old_quality": payload["deletedFiles"][0]["quality"],
"movie_title": payload["movie"]["title"].tame(check_string),
"new_quality": payload["movieFile"]["quality"].tame(check_string),
"old_quality": payload["deletedFiles"][0]["quality"].tame(check_string),
}

return RADARR_MESSAGE_TEMPLATE_MOVIE_IMPORTED_UPGRADE.format(**data)


def get_body_for_movie_imported_event(payload: Dict[str, Any]) -> str:
return RADARR_MESSAGE_TEMPLATE_MOVIE_IMPORTED.format(movie_title=payload["movie"]["title"])
def get_body_for_movie_imported_event(payload: WildValue) -> str:
return RADARR_MESSAGE_TEMPLATE_MOVIE_IMPORTED.format(
movie_title=payload["movie"]["title"].tame(check_string)
)


def get_body_for_movie_grabbed_event(payload: Dict[str, Any]) -> str:
return RADARR_MESSAGE_TEMPLATE_MOVIE_GRABBED.format(movie_title=payload["movie"]["title"])
def get_body_for_movie_grabbed_event(payload: WildValue) -> str:
return RADARR_MESSAGE_TEMPLATE_MOVIE_GRABBED.format(
movie_title=payload["movie"]["title"].tame(check_string)
)


def get_body_for_http_request(payload: Dict[str, Any]) -> str:
if payload["eventType"] == "Test":
def get_body_for_http_request(payload: WildValue) -> str:
event_type = payload["eventType"].tame(check_string)
if event_type == "Test":
return get_setup_webhook_message("Radarr")
elif payload["eventType"] == "Health":
elif event_type == "Health":
return get_body_for_health_check_event(payload)
elif payload["eventType"] == "Rename":
elif event_type == "Rename":
return get_body_for_movie_renamed_event(payload)
elif payload["eventType"] == "Download" and "isUpgrade" in payload:
elif event_type == "Download" and "isUpgrade" in payload:
if payload["isUpgrade"]:
return get_body_for_movie_imported_upgrade_event(payload)
else:
return get_body_for_movie_imported_event(payload)
elif payload["eventType"] == "Grab":
elif event_type == "Grab":
return get_body_for_movie_grabbed_event(payload)
else:
raise UnsupportedWebhookEventType(payload["eventType"])
raise UnsupportedWebhookEventType(event_type)

0 comments on commit 7e34484

Please sign in to comment.