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 🙏

© 2025 – Pkg Stats / Ryan Hefner

grovestreams-api

v0.2.3

Published

A node.js module to interface with the GroveStreams API

Downloads

17

Readme

node-grovestreams-api

A node.js module to interface with the GroveStreams API.

Note well: GroveStreams' full API is comprehensive. This module implements only those calls needed by the associated 'indicator' driver in The Thing system. You are welcome to submit pull requests to add more functionality!

For a detailed example in using this API, please take a look at indicator-grovestreams-sensor.js in The Thing System repository for the steward.

Before Starting

You will need a GroveStreams account with at least one organization:

  • If you do not already have a GroveStreams account:

  • Login to your GroveStreams account. If you do not have any associated organizations (workspaces), you'll be asked to create one.

    • Select 'Yes' and follow the directions to create one (by providing a name)
  • Retrieve the 'Secret API Key' by clicking on the padlock icon near the upper-right corner:

    • Select the 'Feed Put API Key (with auto-registration rights)
    • Click on 'View Secret Key'
    • After closing the 'API Secret Key' window, click on 'Edit'and ensure that the API key has permission to:
      • component/*/feed: GET, PUT, POST
      • component: GET, PUT, POST
      • component_folder: GET, PUT, POST
      • org_user: GET
      • unit: GET, PUT, POST
  • Retrieve the 'Organization UID' by clicking on the tools icon to the right of the padlock icon:

    • Select 'View Organization UID'

API

Load

var GroveStreams = require('grovestreams-api');

Login to cloud

NB: this call requires the GET permission for org_user, component, component_folder, and unit.

var organizationUID = '...'
  , secretAPIKey    = '...'
  , client
  ;

client = new GroveStreams.ClientAPI({ clientID     : organizationUID
                                    , clientSecret : secretAPIKey }).login(function(err, users, components, units) {
  if (!!err) return console.log('login error: ' + err.message);

  // examine list of users components, and units
}).on('error', function(err) {
  console.log('background error: ' + err.message);
});

The non-error parameters given to the login callback contain objects defining the users, components (with streams), and units associated with the identified organization.

Create a component

NB: this call requires the GET and PUT permissions for component.

If the uid property isn/t present, it will be automatically-generated; regardless, it is returned to the callback on success.

// the name property is mandatory
client.addComponent(componentID, properties, function(err, componentUID) {
  if (!!err) return console.log('addComponent error: ' + err.message);

  // record componentUID
  // client.components[componentUID] has all the information on the component
});

Create a new unit

NB: this call requires the PUT permission for unit.

// the symbol property is mandatory
client.addUnit(componentUID, streamID, properties, function(err, unitUID) {
  if (!!err) return console.log('addUnit error: ' + err.message);

  // client.units[unitUID] has all the information on the measuring unit
});

Create a new stream in a component

NB: this call requires the GET and POST permissions for component.

// the name, valueType, and unit properties are mandatory
client.addStream(componentUID, streamID, properties, function(err, streamUID) {
  if (!!err) return console.log('addStream error: ' + err.message);

  // client.streams[streamUID] has all the information on the stream
  // furthermore client.components.stream[] includes the new stream
});

Upload a batch of samples for a stream

NB: this call requires the POST permission for component/*/feed.

var samples = { component: [ { componentUid : componentUID
                             , stream       : [ { streamUid : streamUID
                               // more than ome sample may be present per stream, just fill-in the two arrays
                                                , data      : [ data ]
                                                , time      : [ sampleTime ]
                                                }
                                              ]
                             }

                             // more than ome component may be present per batch...
                           ]
              };

client.addSamples(samples, function(err, result) {
  if (!!err) return console.log('addSamples error: ' + err.message);

  // result is null
});

Upload a sample for a stream

NB: this call requires the POST permission for component/*/feed.

client.addSample(componentUID, streamUID, data, sampleTime, function(err, result) {
  if (!!err) return console.log('addSample error: ' + err.message);

  // result is null
});