kopia lustrzana https://github.com/Yakifo/amqtt
				
				
				
			
		
			
				
	
	
		
			42 wiersze
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			42 wiersze
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
| import logging
 | |
| import asyncio
 | |
| 
 | |
| from hbmqtt.client import MQTTClient
 | |
| 
 | |
| 
 | |
| 
 | |
| #
 | |
| # This sample shows how to publish messages to broker using different QOS
 | |
| # Debug outputs shows the message flows
 | |
| #
 | |
| 
 | |
| logger = logging.getLogger(__name__)
 | |
| 
 | |
| config = {
 | |
|     'will': {
 | |
|         'topic': '/will/client',
 | |
|         'message': b'Dead or alive',
 | |
|         'qos': 0x01,
 | |
|         'retain': True,
 | |
|     },
 | |
| }
 | |
| C = MQTTClient(config=config)
 | |
| #C = MQTTClient()
 | |
| 
 | |
| @asyncio.coroutine
 | |
| def test_coro():
 | |
|     yield from C.connect('mqtts://test.mosquitto.org/', cafile='mosquitto.org.crt')
 | |
|     tasks = [
 | |
|         asyncio.async(C.publish('a/b', b'TEST MESSAGE WITH QOS_0')),
 | |
|         asyncio.async(C.publish('a/b', b'TEST MESSAGE WITH QOS_1', qos=0x01)),
 | |
|         asyncio.async(C.publish('a/b', b'TEST MESSAGE WITH QOS_2', qos=0x02)),
 | |
|     ]
 | |
|     yield from asyncio.wait(tasks)
 | |
|     logger.info("messages published")
 | |
|     yield from C.disconnect()
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     formatter = "[%(asctime)s] {%(filename)s:%(lineno)d} %(levelname)s - %(message)s"
 | |
|     logging.basicConfig(level=logging.DEBUG, format=formatter)
 | |
|     asyncio.get_event_loop().run_until_complete(test_coro()) |