NAME

anyevent-mqtt-sub - Perl script for subscribing to an MQTT topic

VERSION

version 1.141990

SYNOPSIS

anyevent-mqtt-sub [options] topic1 [topic2] [topic3] ...

DESCRIPTION

This script subscribes to one or more MQTT topics and prints any messages that it receives to stdout.

OPTIONS

-help

Print a brief help message.

-man

Print the manual page.

-host A.B.C.D

The host running the MQTT service. The default is 127.0.0.1.

-port NNNNN

The port of the running MQTT service. The default is 1883.

-qos N

The QoS level for the published message. The default is 0 (MQTT_QOS_AT_MOST_ONCE).

-verbose

Include more verbose output. Without this option the script only outputs errors and received messages one per line in the form:

topic message

With one -verbose options, publish messages are printed in a form of a summary of the header fields and the payload in hex dump and text form.

With two -verbose options, summaries are printed for all messages sent and received.

-keepalive NNN

The keep alive timer value. Defaults to 120 seconds. For simplicity, it is also currently used as the connection/subscription timeout.

-count NNN

Read the specificed number of MQTT messages and then exit. Default is 0 - read forever.

-one or -1

Short for -count 1. Read one message and exit.

--no-retain

Ignore retained messages. That is, wait for new messages rather than processing existing retained messages.

--code CODE

Use CODE for callback. The caller is responsible for ensuring that the code to be executed is safe - i.e. not "system('rm -rf /');". The code will be called with the following arguments in @_:

The topic of the received message.
The message payload.
The Net::MQTT::Message object for the message.
A condvar that can be emitted to quit the subscribe loop.
The AnyEvent::MQTT object.
An empty hash reference that can be used as a stash.

For example:

my ($topic, $payload, $message, $quitcv, $mqtt, $stash) = @_;
print STDERR $topic, ': ', $payload, "\n";
$quitcv->send if ($stash->{'count'}++ > 10);

If a callback is provided with this option then the builtin callback is no longer called.

SEE ALSO

AnyEvent::MQTT(3)

DISCLAIMER

This is not official IBM code. I work for IBM but I'm writing this in my spare time (with permission) for fun.

AUTHOR

Mark Hindess <soft-cpan@temporalanomaly.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Mark Hindess.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.