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

node-red-node-pi-gpiod

v0.4.0

Published

A node-red node for PiGPIOd

Downloads

1,081

Readme

node-red-node-pi-gpiod

An alternative pair of Node-RED nodes to interact with Pi GPIO using the PiGPIOd daemon that is now part of Raspbian.

The advantage is that it also talk to GPIO on a Pi that is remote as long as it is running the daemon, and also sharing pins works more cleanly as contention is handled by the multiple connections. This is also a good way to access GPIO when running Docker on a Pi as you can use the network connection to link out of the container to the PiGPIO daemon running on the host.

The disadvantage is that you must setup and run the PiGPIO daemon first.

Requirements

PiGPIOd must be running on the pi. The easiest way to ensure this is to add the following line to your Pi /etc/rc.local file.

/usr/bin/pigpiod

Note: By default this will expose the daemon on TCP port 8888, which is obviously a security vulnerability. If you don't want or need remote access then you can start it in local mode only, (-l option), or restrict permissions to certain ip addresses, (-n {ipaddr} option). For example:

/usr/bin/pigpiod -l
/usr/bin/pigpiod -n 192.168.1.10

See the instructions for more details.

Install

Run the following command in your Node-RED user directory - typically ~/.node-red

    npm install node-red-node-pi-gpiod

Usage

Note: the pin numbers refer the physical pin numbers on connector P1 as they are easier to locate.

Input node

Generates a msg.payload with either a 0 or 1 depending on the state of the input pin.

Outputs
  • msg.payload - number - the level of the pin (0 or 1)
  • msg.topic - string - pi/{the pin number}

You may also enable the input pullup resistor ↑ or the pulldown resistor ↓.

Output node

Can be used in Digital, PWM or Servo modes.

Input
  • msg.payload - number | string
  • Digital - 0, 1 - set pin low or high
  • PWM - 0 to 100 - level from 0 to 100%
  • Servo - 0 to 100, 50 is centred.

Hint: The range node can be used to scale inputs to the correct values.

Digital mode expects a msg.payload with either a 0 or 1 (or true or false), and will set the selected physical pin high or low depending on the value passed in.

The initial value of the pin at deploy time can also be set to 0 or 1.

When using PWM and Servo modes, the input value should be a number 0 - 100, and can be floating point.

In servo mode you can also preset the minimum and maximum pulse times as required by your servo in order to reach its full range. Minimum of 5mS, maximum of 25 mS - defaults to 10 and 20 mS respectively.