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

@mangar2/opensensemap

v2.0.1

Published

sends data to opensensemap.org

Downloads

12

Readme

Abstract

Interface to the opensense map service . Use it to send data to opensense map .

Contents

Meta

| | | | --- | --- | | File | index.js | | Abstract | Interface to the opensense map service . Use it to send data to opensense map . | | Author | Volker Böhm | | Copyright | Copyright ( c ) 2020 Volker Böhm | | License | This software is licensed under the GNU LESSER GENERAL PUBLIC LICENSE Version 3 . It is furnished "as is" , without any support , and with no warranty , express or implied , as to its usefulness for any purpose . |

Type definitions

Sensor {Object}

| Name | Type | Description | | ---- | ---- | ------- | | name | string | name of the sensor | | | unit | string | unit of the sensor | | | topic | string | topic the sensor is matched to | | | id | string | opensensmap unique id | |

Sensors {Array.}

Global functions

prepare

prepare (config, opensenseMap) => {OpensenseMap}

Prepares the object

prepare Parameters

| Name | Type | Attribute | Default | Description | | ---------- | ------------ | ------------ | ------------ | ----------------- | | config | Object | | | automation configuration | | | opensenseMap | OpensenseMap | optional | null | existing automation class | |

prepare returns

| Type | Description | | ---- | ----------- | | OpensenseMap | the prepared automation object |

Class OpensenseMap

new OpensenseMap(config)

Creates a class with the ability to publish information to the opensensemap service

Example

const config =
{
  "station" : "your station name (optional)",
  "id" : "your station id",
  "host": "ingress.opensensemap.org",
  "port": 443,
  "sensors": [{
          "name": "temperature",
          "uint": "°C",
          "topic" : "topic/used/for/the/sensor",
          "id": "your sensor id"
   }]
}
const opensenseMap = new Opensensemap(config)

let result = await opensensemap.publish(
   new Message('topic/used/for/the/sensor', 2.61, 'test value' }
)

OpensenseMap Parameters

| Name | Type | Description | | ---------- | ------------ | ----------------- | | config | Object | configuration ( sensors , . . . ) | |

config properties

| Name | Type | Attribute | Default | Description | | ---------- | ------------ | ------------ | ------------ | ----------------- | | station | string | optional | | name of the station | | | id | string | | | sensebox id ( provided by open sens map ) | | | host | string | | | host of open sense map | | | port | port | optional | 443 | portnumer of open sense map ( usually 443 ) | | | sensors | Sensors | | | opensensemap sensor configuration | |

OpensenseMap Methods

getSubscriptions

getSubscriptions () => {Array.<string>}

Gets the subscriptions for the service

getSubscriptions returns

| Type | Description | | ---- | ----------- | | Array.<string> | array of subscriptions |

handleMessage

async handleMessage (message)

Publishes a value to opensensemap ( you need an account to do this ) Publish data provided as Message to opensensemap . You need an account on opensensemap . org The message topic is mapped to the sensor id provided in the config object . The message value it the value to publish

handleMessage Parameters

| Name | Type | Description | | ---------- | ------------ | ----------------- | | message | Message | the data to publish on the opensensemap | |

message properties

| Name | Type | Description | | ---------- | ------------ | ----------------- | | topic | string | the topic is used to select the sensor id from config | | | value | number | the value to publish to the sensor | |