--- mqtt/inc/mqttd.h 2011/12/09 09:53:54 1.1.2.3 +++ mqtt/inc/mqttd.h 2012/06/01 10:39:48 1.2.2.12 @@ -2,34 +2,68 @@ #define __MQTTD_H +#define API_SERVER_SIDE +#include + + +struct tagStore { + u_short st_msgid; + + mqtt_subscr_t st_subscr; + + SLIST_ENTRY(tagStore) st_node; +}; + +struct tagPkt { + ait_val_t *pkt_data; + + SLIST_ENTRY(tagPkt) pkt_node; +}; + struct tagSession { - pthread_t sess_tid; - mqtt_msg_t *sess_buf; + /* server dispatcher */ + mqtt_srv_t *sess_srv; - int sess_sock; - io_sockaddr_t sess_addr; - struct timeval sess_ka; + /* client network settings */ + int sess_sock; + u_short sess_ka; + /* client send retry in miliseconds, if client not receive message */ + u_int sess_retry; + /* message work buffer */ + mqtt_msg_t *sess_buf; - char sess_cid[MAX_CONNID]; - char sess_user[MAX_CRED]; - char sess_pass[MAX_CRED]; + /* authentication user info */ + char sess_cid[MAX_CONNID]; + char sess_user[MAX_CRED]; + char sess_pass[MAX_CRED]; + char sess_addr[64]; - char clear; + /* connect flags */ + char sess_clean; struct { - char flag; - char qos; - char retain; - char *topic; - char *msg; + char flag; + char qos; + char retain; + char *topic; + char *msg; } sess_will; - TAILQ_ENTRY(tagSession) sess_node; -}; + /* session subscriptions & send pubs */ + SLIST_HEAD(tStore, tagStore) sess_subscr; + SLIST_HEAD(tPkt, tagPkt) sess_sndpkt; + TAILQ_ENTRY(tagSession) sess_node; +}; typedef TAILQ_HEAD(, tagSession) sessions_t; extern sessions_t Sessions; +extern sched_root_task_t *root; +extern cfg_root_t cfg; + + +/* function prototypes */ +void *startSession(sched_task_t *task); #endif