Skip to content

javiergayala/MMM-mqtt

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MMM-mqtt

This is an extension for the MagicMirror². It provides the ability to subscribe to MQTT topics and display them.

Installation

  1. Ensure that you have the necessary libraries/clients for mqtt installed on the computer that will be running this extension. (For example, running sudo apt-get install mosquitto mosquitto-clients on Debian-based distributions.)
  2. Navigate into your MagicMirror's modules folder and execute git clone https://github.com/javiergayala/MMM-mqtt.git. A new folder will appear, likely called MMM-mqtt. Navigate into it.
  3. Execute npm install to install the node dependencies.

Using the module

To use this module, add this to the modules array in the config/config.js file:

modules: [
	{
		module: 'MMM-mqtt',
		position: 'top_right',	// This can be any of the regions. Best results in left or right regions.
		header: 'Living Room Temperature', // This is optional
		config: {
			// See 'Configuration options' for more information.
		}
	}
]

Configuration options

The following options can be configured:

Option Description
mqttServer Connection string for the server to connect to (e.g. mqtt://localhost) See: Server URL
loadingText Text to display while waiting for data to load
topic MQTT Topic to subscribe to on the server (sensors/temperature/livingroom)
showTitle Boolean to show/hide a title (default: false)
title Title to show if showTitle is true
interval Refresh interval, not including MQTT subscription deliveries. (default: 300000)
postText Text to append after the data received from MQTT (default: '')
mode Possible values: send or receive (default: receive)
roundValue Rounds displayed value to specified decimals (default: false)
decimals number of decimals to round with roundValue (default: 2)

Server URL

The server URL can be configured with all options supported by URL.parse. The format used is

   mqtt:    //    user   :   pass   @ some.host.com : 1883
| protocol |  | username | password |   hostname    | port |

Supported protocols include:

  • mqtt
  • mqtts

Mode

By default the module will receive MQTT messages from the configured topic and display these. MMM-mqtt can also be used to broadcast local MagicMirror² notifications from modules to an MQTT topic. A sending module doesn't have to be displayed. A sample minimal config for sending:

{
	module: "MMM-mqtt",
	config: {
		mqttServer: "mqtts://localhost:8883",
		topic: "home/living/magicmirror",
		mode: "send"
	}
}

Dependencies

  • mqtt (installed via npm install)

Contributing Guidelines

Contributions of all kinds are welcome, not only in the form of code but also with regards bug reports and documentation.

Please keep the following in mind:

  • Bug Reports: Make sure you're running the latest version. If the issue(s) still persist: please open a clearly documented issue with a clear title.
  • Minor Bug Fixes: Please send a pull request with a clear explanation of the issue or a link to the issue it solves.
  • Major Bug Fixes: please discuss your approach in an GitHub issue before you start to alter a big part of the code.
  • New Features: please please discuss in a GitHub issue before you start to alter a big part of the code. Without discussion upfront, the pull request will not be accepted / merged.

The MIT License (MIT)

Copyright © 2016 Javier G. Ayala

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

The software is provided “as is”, without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software.

About

This is an extension for the MagicMirror² (https://github.com/MichMich/MagicMirror). It provides the ability to subscribe to MQTT topics and display them.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published