The GW1000 driver is a WeeWX driver that supports the Ecowitt GW1000 WiFi Gateway via the GW1000 API.
The GW1000 driver utilises the GW1000 API thus using a pull methodology for obtaining data from the GW1000 rather than the push methodology used by current drivers. This has the advantage of giving the user more control over when the data is obtained from the GW1000 plus also giving access to a greater range of metrics.
The GW1000 driver can be operated as a traditional WeeWX driver where it is the source of loop data or it can be operated as a WeeWX service where it is used to augment loop data produced by another driver.
The GW1000 driver requires WeeWX v3.7.0 or greater and will operate under Python2 or Python 3.
Note: Symbolic names are used below to refer to file locations on the WeeWX system. Symbolic names allow a common name to be used to refer to a directory that may be different from system to system. The following symbolic name is used below:
- $BIN_ROOT. The path to the directory where WeeWX executables are located. This directory varies depending on WeeWX installation method. Refer to where to find things in the WeeWX User's Guide for further information.
-
If the GW1000 driver is to be installed on a fresh WeeWX installation install WeeWX and configure it to use the simulator.
-
If installing the driver using the wee_extension utility (the recommended method):
-
download the GW1000 driver extension package:
$ wget -P /var/tmp https://github.com/gjr80/weewx-gw1000/releases/download/v0.1.0b5/gw1000-0.1.0b5.tar.gz
-
install the GW1000 driver extension:
$ wee_extension --install=/var/tmp/gw1000-0.1.0b5.tar.gz
Note: Depending on your system/installation the above command may need to be prefixed with sudo.
-
skip to step 4
-
-
If installing manually:
-
download the GW1000 driver extension package:
$ wget -P /var/tmp https://github.com/gjr80/weewx-gw1000/releases/download/v0.1.0b5/gw1000-0.1.0b5.tar.gz
-
extract the contents of the GW1000 driver extension package:
$ tar -xzf /var/tmp/gw1000-0.1.0b5.tar.gz -C /var/tmp
-
copy the file gw1000.py to the $BIN_ROOT/user directory:
$ cp /var/tmp/gw1000/bin/user/gw1000.py $BIN_ROOT/user
-
add the following stanza to weewx.conf:
[GW1000] # This section is for the GW1000 # The driver itself driver = user.gw1000
-
add the following stanza to weewx.conf:
[Accumulator] [[lightning_strike_count]] extractor = sum [[lightning_last_det_time]] extractor = last
Note: If an [Accumulator] stanza already exists in weewx.conf just add the child settings.
-
-
Test the GW1000 driver by running the driver file directly using the --test-driver command line option:
$ PYTHONPATH=/home/weewx/bin python -m user.gw1000 --test-driver
for setup.py installs or for package installs use:
$ PYTHONPATH=/usr/share/weewx python -m user.gw1000 --test-driver
Note: If necessary you can specify the GW1000 IP address and port using the --ip-address and --port command line options. Refer to the GW1000 driver help using --help for further information.
You should observe loop packets being emitted on a regular basis. Once finished press ctrl-c to exit.
Note: You will only see loop packets and not archive records when running the driver directly. This is because you are seeing output directly from the driver and not WeeWX.
-
Configure the driver:
$ wee_config --reconfigure --driver=user.gw1000
Note: Depending on your system/installation the above command may need to be prefixed with sudo.
-
You may chose to run WeeWX directly to observe the loop packets and archive records being generated by WeeWX.
-
Once satisfied that the GW1000 driver is operating correctly you can start the WeeWX daemon:
$ sudo /etc/init.d/weewx start
or
$ sudo service weewx start
or
$ sudo systemctl start weewx
-
Install WeeWX and configure it to use either the simulator or another driver of your choice.
-
If installing the driver using the wee_extension utility (the recommended method) install the GW1000 driver extension using the wee_extension utility as per Installation as a WeeWX driver step 2 above.
-
If installing the driver manually install the GW1000 driver manually as per Installation as a WeeWX driver step 3 above.
-
Edit weewx.conf and under the [Engine] [[Services]] stanza add an entry user.gw1000.Gw1000Service to the data_services option. It should look something like:
[Engine] [[Services]] .... data_services = user.gw1000.Gw1000Service
-
Test the GW1000 service by running the driver file directly using the --test-service command line option:
$ PYTHONPATH=/home/weewx/bin python -m user.gw1000 --test-service
for setup.py installs or for package installs use:
$ PYTHONPATH=/usr/share/weewx python -m user.gw1000 --test-service
Note: If necessary you can specify the GW1000 IP address and port using the --ip-address and --port command line options. Refer to the GW1000 driver help using --help for further information.
You should observe loop packets being emitted on a regular basis. Some, but not necessarily all, loop packets should include GW1000 data. Once finished press ctrl-c to exit.
Note: When the driver file is run directly with the --test-service command line option a series of simulated loop packets are emitted every 10 seconds to simulate a running WeeWX instance. The GW1000 is polled and the GW1000 data added to the loop packets when available. As the default GW1000 poll interval is 60 seconds not all loop packets will be augmented with GW1000 data.
Note: You will only see loop packets and not archive records when running the service directly. This is because you are seeing the direct output of the driver and the GW1000 service and not WeeWX.
-
You may chose to run WeeWX directly to observe the loop packets and archive records being generated by WeeWX. Note that depending on the frequency of the loop packets emitted by the in-use driver and the polling interval of the GW1000 service not all loop packets may include GW1000 data; however, provided that the GW1000 polling interval is less than the frequency of the loop packets emitted by the in-use driver each archive record should contain GW1000 data.
-
Once satisfied that the GW1000 service is operating correctly you can start the WeeWX daemon:
$ sudo /etc/init.d/weewx restart
or
$ sudo service weewx restart
or
$ sudo systemctl restart weewx