wip send/recv
authorEugene Crosser <crosser@average.org>
Tue, 26 Mar 2019 08:35:08 +0000 (09:35 +0100)
committerEugene Crosser <crosser@average.org>
Tue, 26 Mar 2019 08:35:08 +0000 (09:35 +0100)
src/psmb_socket.c

index d18ad57c506327fbfb03078fdc6fd1b1d44ae07c..634be8e4b3bfa7358f7fbf05268ed0cc76875871 100644 (file)
@@ -150,6 +150,7 @@ psmb_result_t psmb_open(psmb_ctx_t *ctx)
                errno = sverr;
                return (psmb_result_t){PSMB_ERROR};
        }
+       /* TODO: set non-blocking */
        return (psmb_result_t){PSMB_OK};
 }
 
@@ -192,14 +193,72 @@ static psmb_result_t psmb_sub_unsub(psmb_ctx_t *ctx, char *channel, int option)
        return (psmb_result_t){PSMB_OK};
 }
 
-psmb_result_t psmb_subscribe(psmb_ctx_t *ctx, char *channel) {
+psmb_result_t psmb_subscribe(psmb_ctx_t *ctx, char *channel)
+{
        return psmb_sub_unsub(ctx, channel, IPV6_ADD_MEMBERSHIP);
 }
 
-psmb_result_t psmb_unsubscribe(psmb_ctx_t *ctx, char *channel) {
+psmb_result_t psmb_unsubscribe(psmb_ctx_t *ctx, char *channel)
+{
        return psmb_sub_unsub(ctx, channel, IPV6_DROP_MEMBERSHIP);
 }
 
+psmb_result_t psmb_ev_rd(psmb_ctx_t *ctx)
+{
+       char buf[MAXBUFLEN];
+       char cmsgbuf[MAXBUFLEN];
+       struct iovec iov[1];
+       iov[0].iov_base=buf;
+       iov[0].iov_len=sizeof(buf);
+       struct cmsghdr *cmsg;
+       struct msghdr message;
+       message.msg_name=&their_addr;
+message.msg_namelen=sizeof(their_addr);
+message.msg_iov=iov;
+message.msg_iovlen=1;
+message.msg_control=cmsgbuf;
+message.msg_controllen=MAXBUFLEN;
+
+       if ((numbytes = recvmsg(sockfd, &message, 0)) == -1) {
+               /* error */ ;
+       }
+       for (cmsg = CMSG_FIRSTHDR(&message); cmsg != NULL; cmsg = CMSG_NXTHDR(&message, cmsg)) {
+               if (cmsg->cmsg_level != IPPROTO_IP || cmsg->cmsg_type != IP_PKTINFO)
+                       continue;
+               struct in_pktinfo *pi = CMSG_DATA(cmsg);
+               addr = pi->ipi_spec_dst.s_addr;
+       }
+       
+
+       return (psmb_result_t){PSMB_OK};
+}
+
+psmb_result_t psmb_ev_wr(psmb_ctx_t *ctx)
+{
+       sock_opt_addr.s_addr = addr;
+       setsockopt(sockfd, IPPROTO_IP, IP_MULTICAST_IF, &sock_opt_addr, sizeof(sock_opt_addr));
+       sendto(sockfd, buffer, len, 0, (struct sockaddr *)&destination, sizeof destination);
+
+       return (psmb_result_t){PSMB_OK};
+}
+
+psmb_result_t psmb_ev_ex(psmb_ctx_t *ctx)
+{
+       return (psmb_result_t){PSMB_OK};
+}
+
+psmb_result_t psmb_publish(psmb_ctx_t *ctx, char *channel,
+       void *data, size_t size)
+{
+       return (psmb_result_t){PSMB_OK};
+}
+
+psmb_result_t psmb_get_message(psmb_ctx_t *ctx, char **channel,
+       void **data, size_t *size)
+{
+       return (psmb_result_t){PSMB_OK};
+}
+
 bool psmb_success(psmb_result_t result)
 {
        return !(result.code & PSMB_ERROR);