summaryrefslogtreecommitdiff
path: root/data.c
diff options
context:
space:
mode:
authordefault <nobody@localhost>2022-09-23 23:09:09 +0200
committerdefault <nobody@localhost>2022-09-23 23:09:09 +0200
commitc181c57f5611a477f11b8be375263ef9fed638dd (patch)
treeec475f2cd6b91f1dbc103171f75d330c8d6a7ab4 /data.c
parentb4a4fa0b0d02747c231367dc7a609c96171b7066 (diff)
New function enqueue_input().
Diffstat (limited to 'data.c')
-rw-r--r--data.c29
1 files changed, 28 insertions, 1 deletions
diff --git a/data.c b/data.c
index 3f5d5e0..67b1802 100644
--- a/data.c
+++ b/data.c
@@ -709,6 +709,33 @@ int actor_get(snac *snac, char *actor, d_char **data)
}
+void enqueue_input(snac *snac, char *msg)
+/* enqueues an input message */
+{
+ xs *ntid = tid(0);
+ xs *fn = xs_fmt("%s/queue/%s.json", snac->basedir, ntid);
+ xs *tfn = xs_str_cat(fn, ".tmp");
+ FILE *f;
+
+ if ((f = fopen(tfn, "w")) != NULL) {
+ xs *qmsg = xs_dict_new();
+ xs *j;
+
+ qmsg = xs_dict_append(qmsg, "type", "input");
+ qmsg = xs_dict_append(qmsg, "object", msg);
+
+ j = xs_json_dumps_pp(qmsg, 4);
+
+ fwrite(j, strlen(j), 1, f);
+ fclose(f);
+
+ rename(tfn, fn);
+
+ snac_debug(snac, 2, xs_fmt("enqueue_input %s", fn));
+ }
+}
+
+
void enqueue_output(snac *snac, char *actor, char *msg, int retries)
/* enqueues an output message for an actor */
{
@@ -740,7 +767,7 @@ void enqueue_output(snac *snac, char *actor, char *msg, int retries)
rename(tfn, fn);
- snac_debug(snac, 2, xs_fmt("enqueue %s %s %d", actor, fn, retries));
+ snac_debug(snac, 2, xs_fmt("enqueue_output %s %s %d", actor, fn, retries));
}
}