kore

Kore is a web application platform for writing scalable, concurrent web based processes in C or Python.
Commits | Files | Refs | README | LICENSE | git clone https://git.kore.io/kore.git

commit 0281fb7b99604665820a6a60513ae27e84355fb4
parent 064f2095b0f13c1fa67144a11483c131c8761aff
Author: Joris Vink <joris@coders.se>
Date:   Mon,  6 Jul 2015 21:16:22 +0200

Update the msg->dst member accordingly when sending.

This way the worker will always receive a message with
the correct destination set instead of KORE_MSG_WORKER_ALL.

Diffstat:
src/msg.c | 12++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)

diff --git a/src/msg.c b/src/msg.c @@ -153,25 +153,33 @@ msg_recv_data(struct netbuf *nb) { struct connection *c; struct msg_type *type; + u_int16_t destination; struct kore_msg *msg = (struct kore_msg *)nb->buf; if ((type = msg_type_lookup(msg->id)) != NULL) { if (worker == NULL && msg->dst != KORE_MSG_PARENT) fatal("received parent msg for non parent dst"); + if (worker != NULL && msg->dst != worker->id) + fatal("received message for incorrect worker"); + type->cb(msg, nb->buf + sizeof(*msg)); } if (worker == NULL && type == NULL) { + destination = msg->dst; TAILQ_FOREACH(c, &connections, list) { if (c == nb->owner) continue; if (c->proto != CONN_PROTO_MSG || c->hdlr_extra == NULL) continue; - if (msg->dst != KORE_MSG_WORKER_ALL && - *(u_int8_t *)c->hdlr_extra != msg->dst) + if (destination != KORE_MSG_WORKER_ALL && + *(u_int8_t *)c->hdlr_extra != destination) continue; + /* This allows the worker to receive the correct id. */ + msg->dst = *(u_int8_t *)c->hdlr_extra; + net_send_queue(c, nb->buf, nb->s_off, NULL, NETBUF_LAST_CHAIN); net_send_flush(c);