OpenWebRX+ Plugins Home
OpenWebRX+ Plugin collection.
There are two types of plugins as of now:
Every plugin has it’s own documentation.
Learn how to install and load the plugins.
Receiver Plugins
Name | Description |
---|---|
doppler | Track Doppler shift/effect of satellites (based on Sergey Osipov’s work) |
magic_key | set MagicKey without typing it in the browser’s address bar |
screenshot | take screenshot of the waterfall |
screen_reader | provide spoken notifications to users with Assistive Technology |
antenna_switcher | antenna switching functionality for Raspberry Pi devices (LZ2DMV) |
tune_checkbox | make the ‘Hold mouse wheel down to tune’ setting enabled by default (LZ2DMV) |
frequency_far_jump | jump to a frequency outside of the current profile, by typing it in the receiver’s frequency dial (LZ2DMV) |
(deprecated) add keyboard shortcuts to the receiver | |
colorful_spectrum | colorize the spectrum analyzer |
connect_notify | send/receive notifications on user connect/disconnect |
sort_profiles | sort profiles by NAME |
tune_checkbox | enable mouse-scroll to zoom by default (LZ2DMV) |
utils | this is utility plugin, required by many plugins |
notify | this is utility plugin, required by some plugins |
example | example plugin for developers |
example_theme | example theme plugin for developers |
Map Plugins
Name | Description |
---|---|
(deprecated) add Maidenhead (QTH) grid to the map |
Load Plugins
To load a plugin you need to create init.js
file inside your openwebrx
installation under htdocs/plugins/{type}
folder. The {type}
should be receiver
or map
.
The folder could be one of the these, depending on the installation of OWRX+ you have:
- /opt/openwebrx/htdocs
- /usr/lib/python3/dist-packages/htdocs
You can find the correct folder with this command:
find / -name openwebrx.js
Now create or edit the init.js
file. The easiest way is to use the provided templates:
Here is an example how to create the receiver/init.js
.
OWRX_FOLDER=$(dirname `find / -name openwebrx.js`) # find OWRX+ htdocs folder
mkdir -p "$OWRX_FOLDER/plugins/receiver" # create folder if it does not exist
cd "$OWRX_FOLDER/plugins/receiver" # go inside folder
wget https://0xaf.github.io/openwebrxplus-plugins/receiver/init.js.sample -O init.js # download template
${EDITOR-nano} init.js # start the editor
Raspberry Pi Images
If you are using the Raspberry Pi images, there is a caching service called varnish
that might (will) prevent your plugins from loading immediately after you edit the init.js
file.
To avoid weird issues, it is recommended to invalidate the cache after any changes to the plugins system by restarting the corresponding services:
sudo systemctl restart varnish nginx
Docker
If you’re using Docker images (openwebrxplus or openwebrxplus-softmbe), then you will need to bind-mount the plugins folder to your host system and follow the instructions above. More info can be found in the docker pages of the images.
Create plugins
If you’re a developer and want to create new plugins, you need to get familiar with OWRX+ JS code.
Then you might want to check the example plugin or the example theme plugin.
After you get the are familiar enough, you can check the code of the rest plugins.
You can develop your plugins locally and load them, similar to the remote plugins.
Local plugins should be in their own sub-folder under $OWRX_FOLDER/plugins/{type}/
and should be loaded by their (folder) name. i.e. Plugins.load('layer_qth_maidenhead');
.
Note that remote plugins are loaded with direct url to the .js
file. i.e. Plugins.load('https://0xaf.github.io/openwebrxplus-plugins/map/layer_qth_maidenhead/layer_qth_maidenhead.js');
.
Hosting your plugins on GitHub
If you want to host your plugins on Github, you will need to create Github Page over your repository, because direct links to a file in the repo will return wrong Content-Type and the browser will not load JS with wrong content-type. Finding the rest is up to you.
Support
Use these plugins at your own risk. No warranty at all.
For support, you can find me (LZ2SLL
) in the OWRX+ Telegram Chat or here.