--- mqtt/example/Attic/cmds.c 2011/11/22 13:00:33 1.1.2.6 +++ mqtt/example/Attic/cmds.c 2011/12/06 12:36:45 1.1.2.16 @@ -1,4 +1,5 @@ #include +#include #include #include #include @@ -8,52 +9,129 @@ int main() { mqtt_msg_t *m; - mqtt_subscr_t s[4]; - int i; + mqtt_subscr_t s[4], *ss; + mqtthdr_connflgs_t flg; + u_short ka, msgID; + int i, len; + char cid[BUFSIZ], user[BUFSIZ], pass[BUFSIZ], topic[BUFSIZ], message[BUFSIZ]; + struct mqtthdr *hdr; + u_char *qoses; m = mqtt_msgAlloc(0); /* conn* */ printf("connect=%d/%d\n", m->msg_len, mqtt_msgCONNECT(m, "MRYN", "aaaaa", NULL, "bbb", NULL, 0, 0, 0)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + flg = mqtt_readCONNECT(m, &ka, cid, sizeof cid, user, sizeof user, pass, sizeof pass, + topic, sizeof topic, message, sizeof message); + printf("read connect flags:: clean=%d will=%d qos=%d retain=%d pass=%d user=%d\n", + flg.clean_sess, flg.will_flg, flg.will_qos, flg.will_retain, flg.password, flg.username); + if (flg.reserved) { + printf("Error:: mqtt_readCONNECT() #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); + return 1; + } + printf("++> KA=%d sec, ConnID=%s User=%s Pass=%s Will_Topic=%s Will_Message=%s\n", ka, + cid, user, pass, topic, message); printf("connack=%d/%d\n", m->msg_len, mqtt_msgCONNACK(m, 1)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read connack=%d\n", mqtt_readCONNACK(m)); + getchar(); /* pub* */ printf("publish=%d/%d\n", m->msg_len, mqtt_msgPUBLISH(m, "AAA/bbb/CCC/ddd", 7, 0, 2, 0, "OLE!!!", 7)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + len = sizeof message; + hdr = mqtt_readPUBLISH(m, topic, sizeof topic, &msgID, message, &len); + if (!hdr) { + printf("Error:: mqtt_readPUBLISH() #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); + return 2; + } + printf("read publish: dup=%d qos=%d retain=%d\n", hdr->mqtt_msg.dup, hdr->mqtt_msg.qos, hdr->mqtt_msg.retain); + printf("++> topic=%s MessageID=%d DATA=(%d)%s\n", topic, msgID, len, message); printf("puback=%d/%d\n", m->msg_len, mqtt_msgPUBACK(m, 10)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read puback=%d\n", mqtt_readPUBACK(m)); printf("pubrec=%d/%d\n", m->msg_len, mqtt_msgPUBREC(m, 11)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read pubrec=%d\n", mqtt_readPUBREC(m)); printf("pubrel=%d/%d\n", m->msg_len, mqtt_msgPUBREL(m, 12)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read pubrel=%d\n", mqtt_readPUBREL(m)); printf("pubcomp=%d/%d\n", m->msg_len, mqtt_msgPUBCOMP(m, 13)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read pubcomp=%d\n", mqtt_readPUBCOMP(m)); + getchar(); /* sub* */ memset(s, 0, sizeof s); - s[0].sub_sb.sb.l = 3; - s[0].sub_data = "a/b"; - s[0].sub_qos = MQTT_QOS_ACK; - s[1].sub_sb.sb.l = 3; - s[1].sub_data = "c/d"; - s[1].sub_qos = MQTT_QOS_ONCE; - s[2].sub_sb.sb.l = 7; - s[2].sub_data = "x/y/z/Q"; - s[2].sub_qos = MQTT_QOS_EXACTLY; + s[0].sub_topic._size = 3; + s[0].sub_topic._base = "a/b"; + s[0].sub_ret = MQTT_QOS_ACK; + s[1].sub_topic._size = 3; + s[1].sub_topic._base = "c/d"; + s[1].sub_ret = MQTT_QOS_ONCE; + s[2].sub_topic._size = 7; + s[2].sub_topic._base = "x/y/z/Q"; + s[2].sub_ret = MQTT_QOS_EXACTLY; printf("subscribe=%d/%d\n", m->msg_len, mqtt_msgSUBSCRIBE(m, s, 10, 0, 0)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + hdr = mqtt_readSUBSCRIBE(m, &msgID, &ss); + if (!hdr) { + printf("Error:: mqtt_readSUBSCRIBE() #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); + return 3; + } + printf("read subscribe: dup=%d qos=%d retain=%d\n", hdr->mqtt_msg.dup, hdr->mqtt_msg.qos, hdr->mqtt_msg.retain); + printf("++> MessageID=%d\n", msgID); + for (i = 0; ss[i].sub_topic._base; i++) + printf(" >>> QoS=%d Topic(%d)=%s\n", ss[i].sub_ret, ss[i].sub_topic._size, ss[i].sub_topic._base); + mqtt_subFree(&ss); printf("suback=%d/%d\n", m->msg_len, mqtt_msgSUBACK(m, s, 10)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read suback=%d\n", (len = mqtt_readSUBACK(m, &msgID, &qoses))); + for (i = 0; i < len; i++) + printf(" >>> QoS=%d\n", qoses[i]); + free(qoses); + printf("unsubscribe=%d/%d\n", m->msg_len, mqtt_msgUNSUBSCRIBE(m, s, 10, 0, 1)); + for (i = 0; i < m->msg_len; i++) + printf("%d\n", ((u_char*) m->msg_base)[i]); + hdr = mqtt_readUNSUBSCRIBE(m, &msgID, &ss); + if (!hdr) { + printf("Error:: mqtt_readUNSUBSCRIBE() #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); + return 3; + } + printf("read unsubscribe: dup=%d qos=%d retain=%d\n", hdr->mqtt_msg.dup, hdr->mqtt_msg.qos, hdr->mqtt_msg.retain); + printf("++> MessageID=%d\n", msgID); + for (i = 0; ss[i].sub_topic._base; i++) + printf(" >>> Topic(%d)=%s\n", ss[i].sub_topic._size, ss[i].sub_topic._base); + mqtt_subFree(&ss); + printf("unsuback=%d/%d\n", m->msg_len, mqtt_msgUNSUBACK(m, 10)); + for (i = 0; i < m->msg_len; i++) + printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read unsuback=%d\n", mqtt_readUNSUBACK(m)); + getchar(); + + /* ping* */ + printf("pingreq=%d/%d\n", m->msg_len, mqtt_msgPINGREQ(m)); + for (i = 0; i < m->msg_len; i++) + printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read pingreq=%d\n", mqtt_readPINGREQ(m)); + printf("pingresp=%d/%d\n", m->msg_len, mqtt_msgPINGRESP(m)); + for (i = 0; i < m->msg_len; i++) + printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read pingresp=%d\n", mqtt_readPINGRESP(m)); + + printf("disconnect=%d/%d\n", m->msg_len, mqtt_msgDISCONNECT(m)); + for (i = 0; i < m->msg_len; i++) + printf("%d\n", ((u_char*) m->msg_base)[i]); + printf("read disconnect=%d\n", mqtt_readDISCONNECT(m)); mqtt_msgFree(&m, 42); return 0;