forked from Azure/azure-iot-sdks
-
Notifications
You must be signed in to change notification settings - Fork 1
/
iothub_client_sample_amqp.py
executable file
·116 lines (90 loc) · 3.69 KB
/
iothub_client_sample_amqp.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#!/usr/bin/env python
# Copyright (c) Microsoft. All rights reserved.
# Licensed under the MIT license. See LICENSE file in the project root for
# full license information.
import random
import time
from iothub_client import *
timeout = 241000
minimumPollingTime = 9
receiveContext = 0
avgWindSpeed = 10.0
message_count = 5
received_count = 0
# global counters
receive_callbacks = 0
send_callbacks = 0
# transport protocol
Protocol = IoTHubTransportProvider.AMQP
# String containing Hostname, Device Id & Device Key in the format:
# "HostName=<host_name>;DeviceId=<device_id>;SharedAccessKey=<device_key>"
connectionString = "[device connection string]"
msgTxt = "{\"deviceId\": \"myFirstDevice\",\"windSpeed\": %.2f}"
def receive_message_callback(message, counter):
global receive_callbacks
buffer = message.get_bytearray()
size = len(buffer)
print "Received Message [%d]:" % counter
print " Data: <<<%s>>> & Size=%d" % (buffer[:size], size)
mapProperties = message.properties()
keyValuePair = mapProperties.get_internals()
print " Properties: %s" % keyValuePair
counter += 1
receive_callbacks += 1
print " Total calls received: %d" % receive_callbacks
return IoTHubMessageDispositionResult.ACCEPTED
def send_confirmation_callback(message, result, userContext):
global send_callbacks
print "Confirmation[%d] received for message with result = %s" % (userContext, result)
mapProperties = message.properties()
keyValuePair = mapProperties.get_internals()
print " Properties: %s" % keyValuePair
send_callbacks += 1
print " Total calls confirmed: %d" % send_callbacks
def iothub_client_init():
# prepare iothub client
iotHubClient = IoTHubClient(connectionString, Protocol)
iotHubClient.set_message_callback(receive_message_callback, receiveContext)
return iotHubClient
def print_last_message_time(iotHubClient):
try:
print "Actual time : %s" % time.localtime()
lastMessage = iotHubClient.get_last_message_receive_time()
print "Last Message: %s" % time.localtime(lastMessage)
except IoTHubClientError as e:
if e.result == IoTHubClientResult.INDEFINITE_TIME:
print "No message received"
else:
print e
def iothub_client_sample_run():
try:
iotHubClient = iothub_client_init()
while True:
# send a few messages every minute
print "IoTHubClient sending %d messages" % message_count
for i in xrange(0, message_count):
msgTxtFormatted = msgTxt % (
avgWindSpeed + (random.random() * 4 + 2))
message = IoTHubMessage(bytearray(msgTxtFormatted))
propMap = message.properties()
propText = "PropMsg_%d" % i
propMap.add("Property", propText)
iotHubClient.send_event_async(
message, send_confirmation_callback, i)
print "IoTHubClient.send_event_async accepted message [%d] for transmission to IoT Hub." % i
# Wait for Commands or exit
print "IoTHubClient waiting for commands, press Ctrl-C to exit"
n = 0
while n < 6:
status = iotHubClient.get_send_status()
print "Send status: %s" % status
time.sleep(10)
n += 1
except (IoTHubClientError, IoTHubMessageError, IoTHubMapError) as e:
print "Unexpected error %s from IoTHub" % e
return
except KeyboardInterrupt:
print "IoTHubClient sample stopped"
print_last_message_time(iotHubClient)
print "Starting the IoTHubClient sample using protocol %s..." % Protocol
iothub_client_sample_run()