version 1.1.2.2, 2011/12/20 16:04:34
|
version 1.1.2.5, 2012/01/05 10:01:20
|
Line 19 Usage(void)
|
Line 19 Usage(void)
|
" Syntax: mqtt_pub [options] <connect_to_broker[:port]> <ConnectID> <topic> <value_for_publish>\n\n" |
" Syntax: mqtt_pub [options] <connect_to_broker[:port]> <ConnectID> <topic> <value_for_publish>\n\n" |
"\t-f\t\t\t'value_for_publish' is file name instead text\n" |
"\t-f\t\t\t'value_for_publish' is file name instead text\n" |
"\t-q <QoS>\t\tQoS level (0-at most 1, 1-at least 1, 2-exactly 1)\n" |
"\t-q <QoS>\t\tQoS level (0-at most 1, 1-at least 1, 2-exactly 1)\n" |
|
"\t-m <message_id>\t\tMessage ID for publish message\n" |
"\t-d\t\t\tSend duplicate message\n" |
"\t-d\t\t\tSend duplicate message\n" |
"\t-r\t\t\tRetain message from broker\n\n" |
"\t-r\t\t\tRetain message from broker\n\n" |
"\t-C\t\t\tNot clear before connect!!!\n" |
"\t-C\t\t\tNot clear before connect!!!\n" |
Line 49 cleanArgs(struct tagArgs * __restrict args)
|
Line 50 cleanArgs(struct tagArgs * __restrict args)
|
static int |
static int |
Publish(int sock) |
Publish(int sock) |
{ |
{ |
return 0; | int siz = 0; |
| struct pollfd pfd; |
| struct mqtthdr *hdr; |
| |
| siz = mqtt_msgPUBLISH(args->msg, AIT_GET_STR(&args->Publish), args->MsgID, args->Dup, |
| args->QoS, args->Retain, AIT_GET_PTR2(&args->Value), AIT_LEN(&args->Value)); |
| if (siz == -1) { |
| printf("Error:: msgPUBLISH #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); |
| return -1; |
| } |
| |
| siz = send(sock, args->msg->msg_base, siz, 0); |
| if (siz == -1) { |
| printf("Error:: send() #%d - %s\n", errno, strerror(errno)); |
| return -1; |
| } else |
| ioVERBOSE(3) printf("Sended PUBLISH %d bytes\n", siz); |
| |
| /* QoS == MQTT_QOS_ONCE, no wait for reply */ |
| if (args->QoS == MQTT_QOS_ONCE) |
| return 0; |
| |
| pfd.fd = sock; |
| pfd.events = POLLIN | POLLPRI; |
| switch (poll(&pfd, 1, args->ka * 1000)) { |
| case -1: |
| printf("Error:: poll() #%d - %s\n", errno, strerror(errno)); |
| return -1; |
| case 0: |
| ioVERBOSE(3) printf("Timeout reached (%d) ...\n", args->ka * 1000); |
| return -1; |
| } |
| if (pfd.revents & (POLLERR | POLLHUP | POLLNVAL)) |
| return -1; |
| |
| siz = recv(sock, args->msg->msg_base, args->msg->msg_len, 0); |
| if (siz == -1) { |
| printf("Error:: recv() #%d - %s\n", errno, strerror(errno)); |
| return -1; |
| } else |
| ioVERBOSE(3) printf("Received %d bytes\n", siz); |
| if (!siz) |
| return -1; |
| |
| /* QoS == MQTT_QOS_ACK, wait for PUBACK */ |
| if (args->QoS == MQTT_QOS_ACK) |
| return mqtt_readPUBACK(args->msg); |
| |
| /* QoS == MQTT_QOS_EXACTLY */ |
| if (mqtt_readPUBREC(args->msg) != args->MsgID) { |
| printf("Error:: Message not delivered\n"); |
| return -1; |
| } |
| |
| siz = mqtt_msgPUBREL(args->msg, args->MsgID); |
| if (siz == -1) { |
| printf("Error:: msgPUBLISH #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); |
| return -1; |
| } |
| |
| siz = send(sock, args->msg->msg_base, siz, 0); |
| if (siz == -1) { |
| printf("Error:: send() #%d - %s\n", errno, strerror(errno)); |
| return -1; |
| } else |
| ioVERBOSE(3) printf("Sended PUBLISH %d bytes\n", siz); |
| |
| pfd.events = POLLIN | POLLPRI; |
| switch (poll(&pfd, 1, args->ka * 1000)) { |
| case -1: |
| printf("Error:: poll() #%d - %s\n", errno, strerror(errno)); |
| return -1; |
| case 0: |
| ioVERBOSE(3) printf("Timeout reached (%d) ...\n", args->ka * 1000); |
| return -1; |
| } |
| if (pfd.revents & (POLLERR | POLLHUP | POLLNVAL)) |
| return -1; |
| |
| siz = recv(sock, args->msg->msg_base, args->msg->msg_len, 0); |
| if (siz == -1) { |
| printf("Error:: recv() #%d - %s\n", errno, strerror(errno)); |
| return -1; |
| } else |
| ioVERBOSE(3) printf("Received %d bytes\n", siz); |
| if (!siz) |
| return -1; |
| |
| return mqtt_readPUBCOMP(args->msg); |
} |
} |
|
|
|
|
Line 80 main(int argc, char **argv)
|
Line 169 main(int argc, char **argv)
|
AIT_SET_STR(&args->Pass, ""); |
AIT_SET_STR(&args->Pass, ""); |
|
|
args->ka = MQTT_KEEPALIVE; |
args->ka = MQTT_KEEPALIVE; |
while ((ch = getopt(argc, argv, "T:U:P:p:q:drCW:M:fvh")) != -1) | while ((ch = getopt(argc, argv, "T:U:P:p:q:drCW:M:m:fvh")) != -1) |
switch (ch) { |
switch (ch) { |
case 'T': |
case 'T': |
args->ka = (u_short) strtol(optarg, NULL, 0); |
args->ka = (u_short) strtol(optarg, NULL, 0); |
Line 101 main(int argc, char **argv)
|
Line 190 main(int argc, char **argv)
|
AIT_FREE_VAL(&args->Pass); |
AIT_FREE_VAL(&args->Pass); |
AIT_SET_STR(&args->Pass, optarg); |
AIT_SET_STR(&args->Pass, optarg); |
break; |
break; |
|
case 'm': |
|
args->MsgID = (u_short) strtol(optarg, NULL, 0); |
|
break; |
case 'p': |
case 'p': |
port = (u_short) strtol(optarg, NULL, 0); |
port = (u_short) strtol(optarg, NULL, 0); |
break; |
break; |
Line 158 main(int argc, char **argv)
|
Line 250 main(int argc, char **argv)
|
Usage(); |
Usage(); |
return 1; |
return 1; |
} |
} |
|
if (args->QoS && !args->MsgID) |
|
args->MsgID = MQTT_DEFAULT_MSGID; |
ioVERBOSE(1) printf("Connecting to %s:%d ...\n", io_n2addr(&args->addr, &val), io_n2port(&args->addr)); |
ioVERBOSE(1) printf("Connecting to %s:%d ...\n", io_n2addr(&args->addr, &val), io_n2port(&args->addr)); |
|
|
if ((sock = InitClient()) == -1) { |
if ((sock = InitClient()) == -1) { |
Line 166 main(int argc, char **argv)
|
Line 260 main(int argc, char **argv)
|
return 2; |
return 2; |
} |
} |
|
|
|
if (args->isFile && !OpenFile()) { |
|
args->free(args); |
|
free(args); |
|
return 3; |
|
} |
|
|
printf("Connected ... "); |
printf("Connected ... "); |
switch ((ret = try2Connect(sock))) { | switch ((ret = ConnectClient(sock))) { |
case -1: |
case -1: |
printf(">> FAILED!\n"); |
printf(">> FAILED!\n"); |
break; |
break; |
Line 192 main(int argc, char **argv)
|
Line 292 main(int argc, char **argv)
|
} |
} |
|
|
if (ret == MQTT_RETCODE_ACCEPTED) { |
if (ret == MQTT_RETCODE_ACCEPTED) { |
ret = Publish(sock); | ret = !(Publish(sock) == args->MsgID); |
shutdown(sock, SHUT_RDWR); | CloseClient(sock); |
} else | } else { |
ret = 3; | close(sock); |
| ret = 4; |
| } |
|
|
close(sock); | CloseFile(); |
args->free(args); |
args->free(args); |
free(args); |
free(args); |
return ret; |
return ret; |