summaryrefslogtreecommitdiff
path: root/data.c
diff options
context:
space:
mode:
authordefault <nobody@localhost>2022-10-11 08:16:58 +0200
committerdefault <nobody@localhost>2022-10-11 08:16:58 +0200
commite8fbc94089b70d9fdd7e3b25ad809dfea454770a (patch)
tree43522058393a703b4354a42747fd093f6e3c344f /data.c
parente493ff962f62ca2516c8ac79c1fd550f6b269fd9 (diff)
Unify enqueueing code.
Diffstat (limited to 'data.c')
-rw-r--r--data.c74
1 files changed, 37 insertions, 37 deletions
diff --git a/data.c b/data.c
index 893a91d..ac8c59b 100644
--- a/data.c
+++ b/data.c
@@ -892,34 +892,45 @@ d_char *history_list(snac *snac)
}
-void enqueue_input(snac *snac, char *msg, char *req, int retries)
-/* enqueues an input message */
+static int _enqueue_put(char *fn, char *msg)
+/* writes safely to the queue */
{
- 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 *tfn = xs_fmt("%s.tmp", fn);
+ int ret = 1;
+ xs *tfn = xs_fmt("%s.tmp", fn);
FILE *f;
if ((f = fopen(tfn, "w")) != NULL) {
- xs *qmsg = xs_dict_new();
- xs *rn = xs_number_new(retries);
- xs *j;
-
- qmsg = xs_dict_append(qmsg, "type", "input");
- qmsg = xs_dict_append(qmsg, "object", msg);
- qmsg = xs_dict_append(qmsg, "req", req);
- qmsg = xs_dict_append(qmsg, "retries", rn);
-
- j = xs_json_dumps_pp(qmsg, 4);
+ xs *j = xs_json_dumps_pp(msg, 4);
fwrite(j, strlen(j), 1, f);
fclose(f);
rename(tfn, fn);
-
- snac_debug(snac, 1, xs_fmt("enqueue_input %s", fn));
}
+ else
+ ret = 0;
+
+ return ret;
+}
+
+
+void enqueue_input(snac *snac, char *msg, char *req, int retries)
+/* enqueues an input message */
+{
+ 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", "input");
+ qmsg = xs_dict_append(qmsg, "object", msg);
+ qmsg = xs_dict_append(qmsg, "req", req);
+ qmsg = xs_dict_append(qmsg, "retries", rn);
+
+ _enqueue_put(fn, qmsg);
+
+ snac_debug(snac, 1, xs_fmt("enqueue_input %s", fn));
}
@@ -934,28 +945,17 @@ void enqueue_output(snac *snac, char *msg, char *actor, int retries)
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 *tfn = xs_fmt("%s.tmp", fn);
- FILE *f;
+ xs *qmsg = xs_dict_new();
+ xs *rn = xs_number_new(retries);
- if ((f = fopen(tfn, "w")) != NULL) {
- xs *qmsg = xs_dict_new();
- xs *rn = xs_number_new(retries);
- xs *j;
-
- qmsg = xs_dict_append(qmsg, "type", "output");
- qmsg = xs_dict_append(qmsg, "actor", actor);
- qmsg = xs_dict_append(qmsg, "object", msg);
- qmsg = xs_dict_append(qmsg, "retries", rn);
-
- j = xs_json_dumps_pp(qmsg, 4);
-
- fwrite(j, strlen(j), 1, f);
- fclose(f);
+ qmsg = xs_dict_append(qmsg, "type", "output");
+ qmsg = xs_dict_append(qmsg, "actor", actor);
+ qmsg = xs_dict_append(qmsg, "object", msg);
+ qmsg = xs_dict_append(qmsg, "retries", rn);
- rename(tfn, fn);
+ _enqueue_put(fn, qmsg);
- snac_debug(snac, 1, xs_fmt("enqueue_output %s %s %d", actor, fn, retries));
- }
+ snac_debug(snac, 1, xs_fmt("enqueue_output %s %s %d", actor, fn, retries));
}