Skip to content

Simple greedy script to update shelly devices which are not connected to the shelly.cloud/internet over-the-air (via private wifi)

Notifications You must be signed in to change notification settings

bjuretko/shelly-offline-ota-update

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Shelly Gen1 Offline Updater

Update shelly devices from a local network without internet access.

A typical use case is to run this script on local instance with internet access and access to the shelly devices, which are not connected to the internet (e.g. blocked by firewall). You do not need to have internet access and access to the shellys at the same time, as this script will download all current firmwares from https://api.shelly.cloud/files/firmware to the local folder ./fw. Afterwards you can switch to the shelly device network if needed to perform the update. This script will then wait for shelly device announcements and update the device if a newer firmware is available.

PRIVATE PROJECT, RUN AT OWN RISK. INTERRUPTION OF FIRMWARE UPGRADES MAY LEAD TO BRICKED DEVICES.

To automatically update all devices in the network, simply start the project with:

via npx

npx github:bjuretko/shelly-offline-ota-update

or from source:

npm install
npm start

Note that it may take some time as the application is waiting for shelly device announcements.

Setting OTA-Server IP Adress

Sometimes the IP to which the shellys shall connect cannot be determined automatically. This happens when you have a hostfile mapping your hostname to 127.0.0.1 or if you have several network interfaces.

You can provide the IP via the first commandline argument in this case:

node server.js 192.168.0.4

Using the script with login protected shelly

Shelly restricted by login can be updated by providing the login credentials via environment variable SHELLY_AUTH as a username:password string. Note that the credentials cannot be set individually for each device but is used for all devices.

SHELLY_AUTH="admin:thesecurepassword" node server.js 192.168.0.4

The credentials will be printed on the console and used for a unsecured network connection (http) to the devices.

Run with docker

You need network host due to mDNS, which is available on linux systems only.

docker run -it --rm -v "$(pwd):/app" --network host -w /app node:12-alpine npm run shelly-offline-ota-update

About

Simple greedy script to update shelly devices which are not connected to the shelly.cloud/internet over-the-air (via private wifi)

Topics

Resources

Stars

Watchers

Forks