mirror of
https://codeberg.org/grunfink/snac2.git
synced 2024-11-25 06:25:04 +00:00
Send notification emails through the queue.
This commit is contained in:
parent
ddce319a12
commit
084731fec2
3 changed files with 54 additions and 21 deletions
|
@ -626,8 +626,6 @@ d_char *msg_note(snac *snac, char *content, char *rcpts, char *in_reply_to, char
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
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 */
|
||||||
{
|
{
|
||||||
|
@ -670,7 +668,7 @@ void notify(snac *snac, char *type, char *utype, char *actor, char *msg)
|
||||||
|
|
||||||
xs *subject = xs_fmt("snac notify for @%s@%s",
|
xs *subject = xs_fmt("snac notify for @%s@%s",
|
||||||
xs_dict_get(snac->config, "uid"), xs_dict_get(srv_config, "host"));
|
xs_dict_get(snac->config, "uid"), xs_dict_get(srv_config, "host"));
|
||||||
xs *from = xs_fmt("snac-daemon@%s (snac daemon)", 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(
|
xs *header = xs_fmt(
|
||||||
"From: %s\n"
|
"From: %s\n"
|
||||||
"To: %s\n"
|
"To: %s\n"
|
||||||
|
@ -699,23 +697,7 @@ void notify(snac *snac, char *type, char *utype, char *actor, char *msg)
|
||||||
body = xs_str_cat(body, s1);
|
body = xs_str_cat(body, s1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* now write */
|
enqueue_email(snac, body, 0);
|
||||||
FILE *f;
|
|
||||||
|
|
||||||
if ((f = popen("/usr/sbin/sendmail -t", "w")) != NULL) {
|
|
||||||
fprintf(f, "%s\n", body);
|
|
||||||
|
|
||||||
if (fclose(f) == EOF) {
|
|
||||||
snac_log(snac, xs_fmt("fclose error in pipe to sendmail (errno: %d)", errno));
|
|
||||||
|
|
||||||
if ((f = fopen("/tmp/dead-letter", "w")) != NULL) {
|
|
||||||
fprintf(f, "%s\n", body);
|
|
||||||
fclose(f);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
snac_log(snac, xs_fmt("cannot pipe to sendmail (errno: %d)", errno));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -958,6 +940,35 @@ void process_queue(snac *snac)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
if (strcmp(type, "email") == 0) {
|
||||||
|
/* send this email */
|
||||||
|
char *msg = xs_dict_get(q_item, "message");
|
||||||
|
int retries = xs_number_get(xs_dict_get(q_item, "retries"));
|
||||||
|
FILE *f;
|
||||||
|
int ok = 0;
|
||||||
|
|
||||||
|
if ((f = popen("/usr/sbin/sendmail -t", "w")) != NULL) {
|
||||||
|
fprintf(f, "%s\n", msg);
|
||||||
|
|
||||||
|
if (fclose(f) != EOF)
|
||||||
|
ok = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ok)
|
||||||
|
snac_debug(snac, 1, xs_fmt("email message sent"));
|
||||||
|
else {
|
||||||
|
if (retries > queue_retry_max)
|
||||||
|
snac_log(snac, xs_fmt("process_queue email giving up (errno: %d)", errno));
|
||||||
|
else {
|
||||||
|
/* requeue */
|
||||||
|
snac_log(snac, xs_fmt(
|
||||||
|
"process_queue email requeue %d (errno: %d)", retries + 1, errno));
|
||||||
|
|
||||||
|
enqueue_email(snac, msg, retries + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -973,6 +984,8 @@ void post(snac *snac, char *msg)
|
||||||
enqueue_output(snac, msg, v, 0);
|
enqueue_output(snac, msg, v, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/** HTTP handlers */
|
/** HTTP handlers */
|
||||||
|
|
||||||
int activitypub_get_handler(d_char *req, char *q_path,
|
int activitypub_get_handler(d_char *req, char *q_path,
|
||||||
|
|
21
data.c
21
data.c
|
@ -980,6 +980,25 @@ void enqueue_output(snac *snac, char *msg, char *actor, int retries)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void enqueue_email(snac *snac, char *msg, int retries)
|
||||||
|
/* enqueues an email message to be sent */
|
||||||
|
{
|
||||||
|
int qrt = xs_number_get(xs_dict_get(srv_config, "queue_retry_minutes"));
|
||||||
|
xs *ntid = tid(retries * 60 * qrt);
|
||||||
|
xs *fn = xs_fmt("%s/queue/%s.json", snac->basedir, ntid);
|
||||||
|
xs *qmsg = xs_dict_new();
|
||||||
|
xs *rn = xs_number_new(retries);
|
||||||
|
|
||||||
|
qmsg = xs_dict_append(qmsg, "type", "email");
|
||||||
|
qmsg = xs_dict_append(qmsg, "message", msg);
|
||||||
|
qmsg = xs_dict_append(qmsg, "retries", rn);
|
||||||
|
|
||||||
|
_enqueue_put(fn, qmsg);
|
||||||
|
|
||||||
|
snac_debug(snac, 1, xs_fmt("enqueue_email %d", retries));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
d_char *queue(snac *snac)
|
d_char *queue(snac *snac)
|
||||||
/* returns a list with filenames that can be dequeued */
|
/* returns a list with filenames that can be dequeued */
|
||||||
{
|
{
|
||||||
|
@ -997,7 +1016,7 @@ d_char *queue(snac *snac)
|
||||||
time_t t2 = atol(bn + 1);
|
time_t t2 = atol(bn + 1);
|
||||||
|
|
||||||
if (t2 > t)
|
if (t2 > t)
|
||||||
snac_debug(snac, 2, xs_fmt("queue not yet time for %s", v));
|
snac_debug(snac, 2, xs_fmt("queue not yet time for %s [%ld]", v, t));
|
||||||
else {
|
else {
|
||||||
list = xs_list_append(list, v);
|
list = xs_list_append(list, v);
|
||||||
snac_debug(snac, 2, xs_fmt("queue ready for %s", v));
|
snac_debug(snac, 2, xs_fmt("queue ready for %s", v));
|
||||||
|
|
1
snac.h
1
snac.h
|
@ -91,6 +91,7 @@ d_char *history_list(snac *snac);
|
||||||
|
|
||||||
void enqueue_input(snac *snac, char *msg, char *req, int retries);
|
void enqueue_input(snac *snac, char *msg, char *req, int retries);
|
||||||
void enqueue_output(snac *snac, char *msg, char *actor, int retries);
|
void enqueue_output(snac *snac, char *msg, char *actor, int retries);
|
||||||
|
void enqueue_email(snac *snac, char *msg, int retries);
|
||||||
|
|
||||||
d_char *queue(snac *snac);
|
d_char *queue(snac *snac);
|
||||||
d_char *dequeue(snac *snac, char *fn);
|
d_char *dequeue(snac *snac, char *fn);
|
||||||
|
|
Loading…
Reference in a new issue