2016-05-20 19:38:46 +02:00
|
|
|
# Webhooks for external integrations.
|
2019-02-02 23:53:55 +01:00
|
|
|
from typing import Any, Dict, Iterable
|
2017-11-16 00:43:10 +01:00
|
|
|
|
|
|
|
from django.http import HttpRequest, HttpResponse
|
|
|
|
|
2020-08-20 00:32:15 +02:00
|
|
|
from zerver.decorator import webhook_view
|
2017-10-31 04:25:48 +01:00
|
|
|
from zerver.lib.request import REQ, has_request_variables
|
2019-02-02 23:53:55 +01:00
|
|
|
from zerver.lib.response import json_success
|
2020-01-14 22:06:24 +01:00
|
|
|
from zerver.lib.webhooks.common import check_send_webhook_message
|
2017-05-02 01:00:50 +02:00
|
|
|
from zerver.models import UserProfile
|
2016-05-20 19:38:46 +02:00
|
|
|
|
2020-01-14 22:06:24 +01:00
|
|
|
|
2021-02-12 08:20:45 +01:00
|
|
|
@webhook_view("HelloWorld")
|
2016-05-20 19:38:46 +02:00
|
|
|
@has_request_variables
|
2018-03-13 23:36:11 +01:00
|
|
|
def api_helloworld_webhook(
|
2021-02-12 08:19:30 +01:00
|
|
|
request: HttpRequest,
|
|
|
|
user_profile: UserProfile,
|
2021-02-12 08:20:45 +01:00
|
|
|
payload: Dict[str, Iterable[Dict[str, Any]]] = REQ(argument_type="body"),
|
2018-03-13 23:36:11 +01:00
|
|
|
) -> HttpResponse:
|
2016-05-20 19:38:46 +02:00
|
|
|
|
|
|
|
# construct the body of the message
|
2021-02-12 08:20:45 +01:00
|
|
|
body = "Hello! I am happy to be here! :smile:"
|
2016-05-20 19:38:46 +02:00
|
|
|
|
|
|
|
# try to add the Wikipedia article of the day
|
2021-02-12 08:19:30 +01:00
|
|
|
body_template = (
|
2021-02-12 08:20:45 +01:00
|
|
|
"\nThe Wikipedia featured article for today is **[{featured_title}]({featured_url})**"
|
2021-02-12 08:19:30 +01:00
|
|
|
)
|
2017-08-24 17:31:04 +02:00
|
|
|
body += body_template.format(**payload)
|
2016-05-20 19:38:46 +02:00
|
|
|
|
2018-03-13 23:36:11 +01:00
|
|
|
topic = "Hello World"
|
|
|
|
|
2016-05-20 19:38:46 +02:00
|
|
|
# send the message
|
2018-03-13 23:36:11 +01:00
|
|
|
check_send_webhook_message(request, user_profile, topic, body)
|
2016-05-20 19:38:46 +02:00
|
|
|
|
|
|
|
return json_success()
|