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 🙏

© 2026 – Pkg Stats / Ryan Hefner

homebridge-netatmo-smart-schedules

v1.0.0

Published

Homebridge dynamic platform plugin that switches Netatmo heating schedules from date and weather rules.

Readme

homebridge-netatmo-smart-schedules

homebridge-netatmo-smart-schedules is a Homebridge dynamic platform plugin that switches an existing Netatmo heating schedule once per day using ordered date rules and Open-Meteo weather rules.

The plugin does not create schedules, edit schedules, or set temperatures directly. It only selects one existing Netatmo schedule and applies it when needed.

Features

  • Dynamic platform plugin for Homebridge
  • Netatmo OAuth2 refresh-token flow with cached access tokens
  • Automatic persistence of rotated Netatmo refresh tokens
  • Ordered date and weather rules
  • Daily evaluation in a configurable timezone
  • Open-Meteo forecast integration only
  • Skips Netatmo API schedule changes when the chosen schedule is already active
  • Unit tests with Vitest

Requirements

  • Node.js 20+
  • Homebridge 1.8+
  • Existing Netatmo heating schedules
  • Netatmo API credentials:
    • clientId
    • clientSecret
    • refreshToken

Install

npm install -g homebridge-netatmo-smart-schedules

Configuration

Add the platform to your Homebridge config.json.

Rules are evaluated in array order. The first matching rule wins. If no rule matches, defaultScheduleId is used.

Date Rules

Date rules support these optional matchers:

  • startDate
  • endDate
  • weekdays
  • months
  • monthDays

All configured matchers on the rule must pass.

Weather Rules

Weather rules use the nearest hourly Open-Meteo point for the evaluation time. They support these optional matchers:

  • minTemperature
  • maxTemperature
  • minCloudCover
  • maxCloudCover
  • minPrecipitationProbability
  • maxPrecipitationProbability
  • minPrecipitation
  • maxPrecipitation
  • afterSunriseMinutes
  • beforeSunsetMinutes

All configured matchers on the rule must pass.

Example

{
  "platforms": [
    {
      "platform": "NetatmoSmartSchedules",
      "name": "Netatmo Smart Schedules",
      "clientId": "your-netatmo-client-id",
      "clientSecret": "your-netatmo-client-secret",
      "refreshToken": "your-netatmo-refresh-token",
      "homeId": "01234567-89ab-cdef-0123-456789abcdef",
      "defaultScheduleId": "schedule-home",
      "latitude": 51.5072,
      "longitude": -0.1276,
      "timezone": "Europe/London",
      "evaluationHour": 5,
      "evaluationMinute": 0,
      "rules": [
        {
          "type": "date",
          "name": "Christmas break",
          "scheduleId": "schedule-holiday",
          "startDate": "2026-12-20",
          "endDate": "2027-01-03"
        },
        {
          "type": "weather",
          "name": "Cold and wet",
          "scheduleId": "schedule-winter",
          "maxTemperature": 4,
          "minPrecipitationProbability": 70
        },
        {
          "type": "weather",
          "name": "Bright spring day",
          "scheduleId": "schedule-light",
          "minTemperature": 12,
          "maxCloudCover": 35,
          "afterSunriseMinutes": 60,
          "beforeSunsetMinutes": 120
        }
      ]
    }
  ]
}

How It Works

  1. Homebridge launches the dynamic platform.
  2. The plugin refreshes the Netatmo access token only when needed.
  3. The plugin loads the configured home and verifies the referenced schedule IDs exist.
  4. The plugin fetches the daily Open-Meteo forecast for the configured coordinates and timezone.
  5. The first matching rule selects the schedule.
  6. If that schedule is already active, the plugin logs and stops.
  7. Otherwise, it switches the home to the chosen schedule.
  8. The plugin records the evaluation date and schedules the next daily run.

Development

npm install
npm run build
npm test

Notes

  • Netatmo refresh tokens can rotate. This plugin persists the latest token in Homebridge storage so daily runs continue working after refresh.
  • The plugin stores state in Homebridge user storage under homebridge-netatmo-smart-schedules.json.
  • Startup evaluates immediately unless the current local date has already been processed.

References