Added internals for Telegram notifications.

This commit is contained in:
default 2023-02-07 07:37:23 +01:00
parent f6d51357af
commit 2db57c9df9
3 changed files with 75 additions and 29 deletions

View file

@ -771,13 +771,8 @@ xs_dict *msg_note(snac *snac, xs_str *content, xs_val *rcpts, xs_str *in_reply_t
void notify(snac *snac, char *type, char *utype, char *actor, char *msg) void notify(snac *snac, char *type, char *utype, char *actor, char *msg)
/* notifies the user of relevant events */ /* notifies the user of relevant events */
{ {
char *email = xs_dict_get(snac->config, "email");
char *object = NULL; char *object = NULL;
/* no email address? done */
if (xs_is_null(email) || *email == '\0')
return;
if (strcmp(type, "Create") == 0) { if (strcmp(type, "Create") == 0) {
/* only notify of notes specifically for us */ /* only notify of notes specifically for us */
xs *rcpts = recipient_list(snac, msg, 0); xs *rcpts = recipient_list(snac, msg, 0);
@ -804,21 +799,8 @@ void notify(snac *snac, char *type, char *utype, char *actor, char *msg)
} }
} }
snac_debug(snac, 1, xs_fmt("notify(%s, %s, %s)", type, utype, actor)); /* prepare message body */
xs *body = xs_str_new(NULL);
/* prepare message */
xs *subject = xs_fmt("snac notify for @%s@%s",
xs_dict_get(snac->config, "uid"), xs_dict_get(srv_config, "host"));
xs *from = xs_fmt("snac-daemon <snac-daemon@%s>", xs_dict_get(srv_config, "host"));
xs *header = xs_fmt(
"From: %s\n"
"To: %s\n"
"Subject: %s\n"
"\n",
from, email, subject);
xs *body = xs_str_new(header);
if (strcmp(utype, "(null)") != 0) { if (strcmp(utype, "(null)") != 0) {
xs *s1 = xs_fmt("Type : %s + %s\n", type, utype); xs *s1 = xs_fmt("Type : %s + %s\n", type, utype);
@ -839,7 +821,35 @@ void notify(snac *snac, char *type, char *utype, char *actor, char *msg)
body = xs_str_cat(body, s1); body = xs_str_cat(body, s1);
} }
enqueue_email(body, 0); /* email */
char *email = xs_dict_get(snac->config, "email");
if (!xs_is_null(email) && *email != '\0') {
snac_debug(snac, 1, xs_fmt("email notify %s %s %s", type, utype, actor));
xs *subject = xs_fmt("snac notify for @%s@%s",
xs_dict_get(snac->config, "uid"), xs_dict_get(srv_config, "host"));
xs *from = xs_fmt("snac-daemon <snac-daemon@%s>", xs_dict_get(srv_config, "host"));
xs *header = xs_fmt(
"From: %s\n"
"To: %s\n"
"Subject: %s\n"
"\n",
from, email, subject);
xs *email_body = xs_fmt("%s%s", header, body);
enqueue_email(email_body, 0);
}
/* telegram */
char *bot = xs_dict_get(snac->config, "telegram_bot");
char *chat_id = xs_dict_get(snac->config, "telegram_chat_id");
if (!xs_is_null(bot) && !xs_is_null(chat_id) && *bot && *chat_id)
enqueue_telegram(body, bot, chat_id);
} }
@ -1178,17 +1188,40 @@ void process_queue_item(xs_dict *q_item)
retries++; retries++;
if (retries > queue_retry_max) if (retries > queue_retry_max)
srv_log(xs_fmt("process_queue email giving up (errno: %d)", errno)); srv_log(xs_fmt("email giving up (errno: %d)", errno));
else { else {
/* requeue */ /* requeue */
srv_log(xs_fmt( srv_log(xs_fmt(
"process_queue email requeue #%d (errno: %d)", retries, errno)); "email requeue #%d (errno: %d)", retries, errno));
enqueue_email(msg, retries); enqueue_email(msg, retries);
} }
} }
} }
else else
if (strcmp(type, "telegram") == 0) {
/* send this via telegram */
char *bot = xs_dict_get(q_item, "bot");
char *msg = xs_dict_get(q_item, "message");
xs *chat_id = xs_dup(xs_dict_get(q_item, "chat_id"));
int status = 0;
/* chat_id must start with a - */
if (!xs_startswith(chat_id, "-"))
chat_id = xs_str_wrap_i("-", chat_id, NULL);
xs *url = xs_fmt("https:/" "/api.telegram.org/bot%s/sendMessage", bot);
xs *body = xs_fmt("{\"chat_id\":%s,\"text\":\"%s\"}", chat_id, msg);
xs *headers = xs_dict_new();
headers = xs_dict_append(headers, "content-type", "application/json");
xs *rsp = xs_http_request("POST", url, headers,
body, strlen(body), &status, NULL, NULL, 0);
srv_debug(0, xs_fmt("telegram post %d", status));
}
else
if (strcmp(type, "purge") == 0) { if (strcmp(type, "purge") == 0) {
srv_log(xs_dup("purge start")); srv_log(xs_dup("purge start"));
@ -1210,12 +1243,8 @@ void process_queue(void)
while (xs_list_iter(&p, &fn)) { while (xs_list_iter(&p, &fn)) {
xs *q_item = dequeue(fn); xs *q_item = dequeue(fn);
if (q_item == NULL) { if (q_item != NULL)
srv_log(xs_fmt("process_queue q_item error")); job_post(q_item);
continue;
}
job_post(q_item);
} }
} }

16
data.c
View file

@ -1420,6 +1420,22 @@ void enqueue_email(xs_str *msg, int retries)
} }
void enqueue_telegram(const xs_str *msg, const char *bot, const char *chat_id)
/* enqueues a message to be sent via Telegram */
{
xs *qmsg = _new_qmsg("telegram", msg, 0);
char *ntid = xs_dict_get(qmsg, "ntid");
xs *fn = xs_fmt("%s/queue/%s.json", srv_basedir, ntid);
qmsg = xs_dict_append(qmsg, "bot", bot);
qmsg = xs_dict_append(qmsg, "chat_id", chat_id);
qmsg = _enqueue_put(fn, qmsg);
srv_debug(1, xs_fmt("enqueue_email %s %s", bot, chat_id));
}
void enqueue_message(snac *snac, xs_dict *msg) void enqueue_message(snac *snac, xs_dict *msg)
/* enqueues an output message */ /* enqueues an output message */
{ {

1
snac.h
View file

@ -128,6 +128,7 @@ void enqueue_input(snac *snac, xs_dict *msg, xs_dict *req, int retries);
void enqueue_output(snac *snac, xs_dict *msg, xs_str *inbox, int retries); void enqueue_output(snac *snac, xs_dict *msg, xs_str *inbox, int retries);
void enqueue_output_by_actor(snac *snac, xs_dict *msg, xs_str *actor, int retries); void enqueue_output_by_actor(snac *snac, xs_dict *msg, xs_str *actor, int retries);
void enqueue_email(xs_str *msg, int retries); void enqueue_email(xs_str *msg, int retries);
void enqueue_telegram(const xs_str *msg, const char *bot, const char *chat_id);
void enqueue_message(snac *snac, char *msg); void enqueue_message(snac *snac, char *msg);
xs_list *user_queue(snac *snac); xs_list *user_queue(snac *snac);