npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

mqtt-scripts

v1.2.2

Published

Node.js based script runner for use in MQTT based Smart Home environments

Downloads

84

Readme

mqtt-scripts

mqtt-smarthome NPM version dependencies Status Build Status Coverage Status XO code style License

mqtt-scripts is a Node.js based script runner for use in mqtt based smart home environments.

It's intentended to be used as the "logic layer" in your smart home, and offers a zero-boilerplate, straight forward scripting environment.

It follows the mqtt-smarthome architecture. Mqtt-scripts could be seen as something like "Node-RED without GUI"

Getting started

Prerequisites: mqtt-scripts needs Node.js >= 6.0.

  • Install mqtt-scripts globally:

sudo npm install -g mqtt-scripts

  • Create a folder from where mqtt-scripts will load the scripts:

mkdir -p /opt/mqtt-smarthome/scripts

  • Create a folder to install node modules that can be used in the scripts:

mkdir /opt/mqtt-smarthome/scripts/node_modules
(You can then just use npm install in the directory /opt/mqtt-smarthome/scripts)

  • Put some files in you script dir:
echo "log.info('my first script!')" > /opt/mqtt-smarthome/scripts/test1.js
echo "log.info 'get ma a coffee' > /opt/mqtt-smarthome/scripts/test1.coffee
  • Start mqtt-scripts

mqtt-scripts -d /opt/mqtt-smarthome/scripts

Command Line Options

If you're running multiple instances of mqtt-scripts you have to decide which one should handle variables and disable the variables on all other instances with the --disable-variable option.

Script Examples

Use hm2mqtt and hue2mqtt to control a hue lamp with a homematic remote control

link('hm//RC4:1/PRESS_CONT', 'hue//lights/Hobbyraum/bri_inc', -16);

subscribe('hm//RC4:2/PRESS_CONT', function () {
    if (!getValue('hue//lights/Hobbyraum')) {
        setValue('hue//lights/Hobbyraum', 1);
    } else {
        setValue('hue//lights/Hobbyraum/bri_inc', 16);
    }
});

link('hm//RC4:1/PRESS_SHORT', 'hue//lights/Hobbyraum', 0);
link('hm//RC4:2/PRESS_SHORT', 'hue//lights/Hobbyraum', 254);
link('hm//RC4:3/PRESS_CONT', 'hue//lights/Hobbyraum/ct_inc', -16);
link('hm//RC4:4/PRESS_CONT', 'hue//lights/Hobbyraum/ct_inc', 16);
link('hm//RC4:3/PRESS_SHORT', 'hue//lights/Hobbyraum/ct', 153);
link('hm//RC4:4/PRESS_SHORT', 'hue//lights/Hobbyraum/ct', 500);

retrieve fuel prices from tankerkoenig

var request =   require('request');
var cred =      require('./lib/credentials.js');

var url = 'https://creativecommons.tankerkoenig.de/json/detail.php';

var tankstellen = {
    'OMV': 'cb1f0588-d517-40f0-8ce3-3edadebea40d',
    'Shell': '4267c196-eea1-47be-96b7-d790b2fbd17a'
};

schedule('0/12 * * * *', function () {
    for (var topic in tankstellen) {
        getData(topic, tankstellen[topic]);
    }
});

function getData(topic, id) {
    request.get(url + '?id=' + id + '&apikey=' + cred.tankerkoenig.apikey, function (err, res) {
        if (err) {
            log.error(err);
            return;
        }
        var data = JSON.parse(res.body).station;
        setValue('$Tankstelle/' + topic + '/Diesel',    data.diesel);
        setValue('$Tankstelle/' + topic + '/E5',        data.e5);
        setValue('$Tankstelle/' + topic + '/Offen',     data.isOpen);
    });
}

Send a variables state changes to Pushover

var cred = require('./lib/credentials.js');

var pushoverNotifications = require('pushover-notifications');

var push = new pushoverNotifications( {
    user: cred.pushover.user,
    token: cred.pushover.token,
    onerror: function (error) {
        log.error(error);
    }
});

function pushover(msg) {
    if (typeof msg !== 'object' || typeof msg.message !== 'string') msg = {message: '' + msg};
    msg.title = msg.title || "Smart Home";
    msg.priority = msg.priority || 0;
    msg.device = msg.device || 'iphone5';
    push.send(msg, function(err, result) {
        if (err) {
            log.error(err);
        }
    });
}

subscribe('$Anwesenheit', {change: true}, function () {
    pushover({
        title:'Anwesenheit',
        message: getProp($Anwesenheit, 'logic_textual'),
        priority: -1
    });
});

API

Classes

Functions

Typedefs

log

Log to stdout/stderr. Messages are prefixed with a timestamp and the calling scripts path.

Kind: global class

log.debug()

Log a debug message

Kind: static method of log

| Type | | --- | | * |

log.info()

Log an info message

Kind: static method of log

| Type | | --- | | * |

log.warn()

Log a warning message

Kind: static method of log

| Type | | --- | | * |

log.error()

Log an error message

Kind: static method of log

| Type | | --- | | * |

subscribe(topic, [options], callback)

Subscribe to MQTT topic(s)

Kind: global function

| Param | Type | Description | | --- | --- | --- | | topic | string | Array.<string> | topic or array of topics to subscribe | | [options] | Object | string | function | Options object or as shorthand to options.condition a function or string | | [options.shift] | number | delay execution in seconds. Has to be positive | | [options.random] | number | random delay execution in seconds. Has to be positive | | [options.change] | boolean | if set to true callback is only called if val changed | | [options.retain] | boolean | if set to true callback is also called on retained messages | | [options.condition] | string | function | conditional function or condition string | | callback | subscribeCallback | |

schedule(pattern, [options], callback)

Schedule recurring and one-shot events

Kind: global function
See: sunSchedule for scheduling based on sun position.

| Param | Type | Description | | --- | --- | --- | | pattern | string | Date | Object | Array.<mixed> | pattern or array of patterns. May be cron style string, Date object or node-schedule object literal. See https://github.com/tejasmanohar/node-schedule/wiki | | [options] | Object | | | [options.random] | number | random delay execution in seconds. Has to be positive | | callback | function | is called with no arguments |

Example

// every full Hour.
schedule('0 * * * *', callback);

// Monday till friday, random between 7:30am an 8:00am
schedule('30 7 * * 1-5', {random: 30 * 60}, callback);

// once on 21. December 2018 at 5:30am
schedule(new Date(2018, 12, 21, 5, 30, 0), callback);

// every Sunday at 2:30pm
schedule({hour: 14, minute: 30, dayOfWeek: 0}, callback);

sunSchedule(pattern, [options], callback)

Schedule a recurring event based on sun position

Kind: global function
See: schedule for time based scheduling.

| Param | Type | Description | | --- | --- | --- | | pattern | string | Array.<string> | a suncalc event or an array of suncalc events. See https://github.com/mourner/suncalc | | [options] | Object | | | [options.shift] | number | delay execution in seconds. Allowed Range: -86400...86400 (+/- 24h) | | [options.random] | number | random delay execution in seconds. | | callback | function | is called with no arguments |

Example

// Call callback 15 minutes before sunrise
sunSchedule('sunrise', {shift: -900}, callback);

// Call callback random 0-15 minutes after sunset
sunSchedule('sunset', {random: 900}, callback);

publish(topic, payload, [options])

Publish a MQTT message

Kind: global function

| Param | Type | Default | Description | | --- | --- | --- | --- | | topic | string | Array.<string> | | topic or array of topics to publish to | | payload | string | Object | | the payload string. If an object is given it will be JSON.stringified | | [options] | Object | | the options to publish with | | [options.qos] | number | 0 | QoS Level | | [options.retain] | boolean | false | retain flag |

setValue(topic, val)

Set a value on one or more topics

Kind: global function

| Param | Type | Description | | --- | --- | --- | | topic | string | Array.<string> | topic or array of topics to set value on | | val | mixed | |

getValue(topic) ⇒ mixed

Kind: global function
Returns: mixed - the topics value

| Param | Type | | --- | --- | | topic | string |

getProp(topic, [...property]) ⇒ mixed

Get a specific property of a topic

Kind: global function
Returns: mixed - the topics properties value

| Param | Type | Description | | --- | --- | --- | | topic | string | | | [...property] | string | the property to retrieve. May be repeated for nested properties. If omitted the whole topic object is returned. |

Example

// returns the timestamp of a given topic
getProp('hm//Bewegungsmelder Keller/MOTION', 'ts');

now() ⇒ number

Kind: global function
Returns: number - ms since epoch

age(topic) ⇒ number

Kind: global function
Returns: number - seconds since last change

| Param | Type | | --- | --- | | topic | string |

link(source, target, [value])

Link topic(s) to other topic(s)

Kind: global function

| Param | Type | Description | | --- | --- | --- | | source | string | Array.<string> | topic or array of topics to subscribe | | target | string | Array.<string> | topic or array of topics to publish | | [value] | mixed | value to publish. If omitted the sources value is published. A function can be used to transform the value. |

combineBool(srcs, targets)

Combine topics through boolean or

Kind: global function

| Param | Type | Description | | --- | --- | --- | | srcs | Array.<string> | array of topics to subscribe | | targets | string | topic to publish |

combineMax(srcs, targets)

Publish maximum of combined topics

Kind: global function

| Param | Type | Description | | --- | --- | --- | | srcs | Array.<string> | array of topics to subscribe | | targets | string | topic to publish |

timer(src, target, time)

Publishes 1 on target for specific time after src changed to true

Kind: global function

| Param | Type | Description | | --- | --- | --- | | src | string | Array.<string> | topic or array of topics to subscribe | | target | string | topic to publish | | time | number | timeout in milliseconds |

subscribeCallback : function

Kind: global typedef

| Param | Type | Description | | --- | --- | --- | | topic | string | the topic that triggered this callback. +/status/# will be replaced by +//# | | val | mixed | the val property of the new state | | obj | object | new state - the whole state object (e.g. {"val": true, "ts": 12346345, "lc": 12346345} ) | | objPrev | object | previous state - the whole state object | | msg | object | the mqtt message as received from MQTT.js |

License

MIT © Sebastian Raff