mirror of
https://github.com/meshtastic/meshtastic.git
synced 2025-01-13 15:01:19 -08:00
re-org of python docs; migrate docs out of python repo README into this repo
This commit is contained in:
parent
032eec88b3
commit
c2e6c96616
|
@ -203,7 +203,8 @@ brew services restart mosquitto
|
||||||
```
|
```
|
||||||
|
|
||||||
3. Do a quick test of server, start a subscriber on a topic:
|
3. Do a quick test of server, start a subscriber on a topic:
|
||||||
# Note: this will wait until you press control-c (publish a message, see below)
|
|
||||||
|
Note: this will wait until you press control-c (publish a message, see below)
|
||||||
|
|
||||||
```
|
```
|
||||||
mosquitto_sub -t test/hello
|
mosquitto_sub -t test/hello
|
||||||
|
|
|
@ -1,127 +1,425 @@
|
||||||
---
|
---
|
||||||
id: python-cli
|
id: python-cli
|
||||||
title: Command line interface
|
title: meshtastic command line interface guide
|
||||||
sidebar_label: CLI usage
|
sidebar_label: meshtastic cli
|
||||||
---
|
---
|
||||||
|
|
||||||
This section covers installing a "meshtastic" command line executable, which displays packets sent over the network as JSON and lets you see serial debugging information from the Meshtastic devices. The source code for this tool is also a good [example](https://github.com/meshtastic/Meshtastic-python/blob/master/meshtastic/__main__.py) of a 'complete' application that uses the Meshtastic python API.
|
# Meshtastic CLI Guide
|
||||||
|
|
||||||
:::note
|
The python pip package installs a "meshtastic" command line executable, which displays packets sent over the network as JSON and lets you see serial debugging information from the meshtastic devices. This command is not run inside of python, you run it from your operating system shell prompt directly. If when you type "meshtastic" it doesn't find the command and you are using Windows: Check that the python "scripts" directory is in your path.
|
||||||
The `meshtastic` command is not run within python but is a script run from your operating system shell prompt. When you type "meshtastic" and the prompt is unable to find the command in Windows, check that the python "scripts" directory [is in your path](https://datatofish.com/add-python-to-windows-path/).
|
|
||||||
:::
|
|
||||||
|
|
||||||
To display a list of the available commands:
|
## Optional Arguments
|
||||||
```bash
|
|
||||||
|
### -h or --help
|
||||||
|
|
||||||
|
Shows a help message that describes the arguments.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
meshtastic -h
|
meshtastic -h
|
||||||
```
|
```
|
||||||
:::note
|
|
||||||
Because of the growing nature of this project, not all commands may appear when using the help command with `meshtastic -h`.
|
|
||||||
:::
|
|
||||||
|
|
||||||
## Getting a list of User Preferences
|
### --port PORT
|
||||||
|
|
||||||
You can get a list of user preferences by running '--get' with an invalid attribute such as 'all'.
|
The port the Meshtastic device is connected to, i.e. /dev/ttyUSB0 or COM4. if unspecified, meshtastic will try to find it. Important to use when multiple devices are connected to ensure you call the command for the correct device.
|
||||||
```bash
|
|
||||||
meshtastic --get all
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --info
|
||||||
|
meshtastic --port COM4 --info
|
||||||
```
|
```
|
||||||
|
|
||||||
## Changing settings
|
### --host HOST
|
||||||
|
|
||||||
You can also use this tool to set any of the device parameters which are stored in persistent storage. For instance, here's how to set the device
|
The hostname/ipaddr of the device to connect to (over TCP).
|
||||||
to keep the Bluetooth link alive for eight hours (any usage of the Bluetooth protocol from your phone will reset this timer)
|
|
||||||
|
|
||||||
```bash title="Expected Output"
|
**Usage**
|
||||||
# You should see a result similar to this:
|
|
||||||
mydir$ meshtastic --set wait_bluetooth_secs 28800
|
``` shell
|
||||||
Connected to radio...
|
meshtastic --host HOST
|
||||||
Setting preference wait_bluetooth_secs to 28800
|
|
||||||
Writing modified preferences to device...
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Or to set a node at a fixed position and never power up the GPS.
|
### --seriallog SERIALLOG
|
||||||
|
|
||||||
```bash
|
Logs device serial output to either 'stdout', 'none' or a filename to append to.
|
||||||
meshtastic --setlat 25.2 --setlon -16.8 --setalt 120
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --seriallog
|
||||||
```
|
```
|
||||||
|
|
||||||
Or to configure an ESP32 based board to join a Wifi network as a station:
|
### --info
|
||||||
|
|
||||||
```bash
|
Read and display the radio config information.
|
||||||
meshtastic --set wifi_ap_mode false --set wifi_ssid mywifissid --set wifi_password mywifipsw
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --info
|
||||||
```
|
```
|
||||||
|
|
||||||
Or to configure an ESP32 to run as a Wifi access point:
|
### --nodes
|
||||||
|
|
||||||
```bash
|
Prints a node list in a pretty, formatted table.
|
||||||
meshtastic --set wifi_ap_mode true --set wifi_ssid mywifissid --set wifi_password mywifipsw
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --nodes
|
||||||
```
|
```
|
||||||
|
|
||||||
:::note
|
### --qr
|
||||||
For a full list of preferences which can be set (and their documentation) can be found in the [protobufs](/docs/developers/protobufs/api#radioconfiguserpreferences).
|
|
||||||
:::
|
|
||||||
|
|
||||||
### Changing channel settings
|
Displays the QR code that corresponds to the current channel.
|
||||||
|
|
||||||
The channel settings can also be changed, either by using a standard (shareable) meshtastic URL or you can set particular channel parameter (for advanced users).
|
**Usage**
|
||||||
|
|
||||||
:::warning
|
``` shell
|
||||||
Meshtastic encodes the radio channel and PSK in the channel's URL. All nodes must connect to the channel again by using the URL provided after a change in this section by performing the `--info` switch. Please refer to [Multiple Channel Support](../device/device-channels).
|
meshtastic --qr
|
||||||
:::
|
|
||||||
|
|
||||||
```bash
|
|
||||||
meshtastic --ch-set name mychan --ch-index 1 --ch-set channel_num 4 --info
|
|
||||||
```
|
```
|
||||||
|
|
||||||
You can even set the channel preshared key to a particular AES128 or AES256 sequence.
|
### --get GET
|
||||||
|
|
||||||
```bash
|
Gets a preferences field.
|
||||||
meshtastic --ch-index 1 --ch-set psk 0x1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b --info
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --get modem_config
|
||||||
```
|
```
|
||||||
|
|
||||||
Use `--ch-set psk none --ch-index 0` to turn off encryption.
|
### --set SET SET
|
||||||
|
|
||||||
Use `--ch-set psk random --ch-index 0` will assign a new (high quality) random AES256 key to the primary channel (similar to what the Android app does when making new channels).
|
Sets a preferences field.
|
||||||
|
|
||||||
Use `--ch-set psk default --ch-index 0` to restore the standard 'default' (minimally secure, because it is in the source code for anyone to read) AES128 key.
|
**Usage**
|
||||||
|
|
||||||
All `ch-set` commands need to have the `ch-index` parameter specified:
|
``` shell
|
||||||
|
meshtastic --set region Unset
|
||||||
```bash
|
|
||||||
meshtastic --ch-index 1 --ch-set name mychan --ch-set channel_num 4 --info
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Ham radio support
|
### --seturl SETURL
|
||||||
|
|
||||||
Meshtastic is designed to be used without a radio operator license. If you do have a license you can set your operator ID and turn off encryption with:
|
Set a channel URL.
|
||||||
|
|
||||||
```bash title="Expected Output"
|
**Usage**
|
||||||
# You should see a result similar to this:
|
|
||||||
mydir$ meshtastic --port /dev/ttyUSB1 --set-ham KI1345
|
``` shell
|
||||||
Connected to radio
|
meshtastic --seturl https://www.meshtastic.org/c/GAMiIE67C6zsNmlWQ-KE1tKt0fRKFciHka-DShI6G7ElvGOiKgZzaGFyZWQ=
|
||||||
Setting Ham ID to KI1345 and turning off encryption
|
|
||||||
Writing modified channels to device
|
|
||||||
```
|
```
|
||||||
|
|
||||||
## FAQ/common problems
|
### --ch-index CH_INDEX
|
||||||
|
|
||||||
This is a collection of common questions and answers from our friendly forum.
|
Set the specified channel index
|
||||||
|
|
||||||
### Permission denied: ‘/dev/ttyUSB0’
|
**Usage**
|
||||||
|
|
||||||
As previously discussed on the [forum](https://meshtastic.discourse.group/t/question-on-permission-denied-dev-ttyusb0/590/3?u=geeksville)
|
``` shell
|
||||||
|
meshtastic --ch-index 1 --ch-disable
|
||||||
This indicates an OS permission problem for access by your user to the USB serial port. Typically this is fixed by the following.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
sudo usermod -a -G dialout <username>
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Mac OS Big Sur
|
### --ch-add CH_ADD
|
||||||
|
|
||||||
There is a problem with Big Sur and pyserial. The workaround is to install a newer version of pyserial:
|
Add a secondary channel, you must specify a channel name.
|
||||||
|
|
||||||
```bash
|
**Usage**
|
||||||
pip3 install -U --pre pyserial
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-add testing-channel
|
||||||
|
```
|
||||||
|
### --ch-del
|
||||||
|
|
||||||
|
Delete the ch-index channel.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-index 1 --ch-del
|
||||||
```
|
```
|
||||||
|
|
||||||
Afterwards you can use the meshtastic python client again on MacOS.
|
### --ch-enable
|
||||||
|
|
||||||
|
Enable the specified channel.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-index 1 --ch-enable
|
||||||
|
```
|
||||||
|
|
||||||
|
### --ch-disable
|
||||||
|
|
||||||
|
Disable the specified channel.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-index 1 --ch-disable
|
||||||
|
```
|
||||||
|
|
||||||
|
### --ch-set CH_SET CH_SET
|
||||||
|
|
||||||
|
Set a channel parameter.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-set id 1234 --ch-index 0
|
||||||
|
```
|
||||||
|
|
||||||
|
### --ch-longslow
|
||||||
|
|
||||||
|
Change to the standard long-range (but slow) channel.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-longslow
|
||||||
|
```
|
||||||
|
|
||||||
|
### --ch-shortfast
|
||||||
|
|
||||||
|
Change to the standard fast (but short range) channel.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ch-shortfast
|
||||||
|
```
|
||||||
|
|
||||||
|
### --set-owner SET_OWNER
|
||||||
|
|
||||||
|
Set device owner name.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --dest \!28979058 --set-owner "MeshyJohn"
|
||||||
|
```
|
||||||
|
|
||||||
|
### --set-ham SET_HAM
|
||||||
|
|
||||||
|
Set licensed Ham ID and turn off encryption.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --set-ham KI1345
|
||||||
|
```
|
||||||
|
|
||||||
|
### --dest DEST
|
||||||
|
|
||||||
|
The destination node id for any sent commands
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --dest \!28979058 --set-owner "MeshyJohn"
|
||||||
|
```
|
||||||
|
|
||||||
|
### --sendtext SENDTEXT
|
||||||
|
|
||||||
|
Send a text message. Can specify a channel index ('--ch-index') or a destination ('--dest')
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --sendtext "Hello Mesh!"
|
||||||
|
```
|
||||||
|
|
||||||
|
### --sendping
|
||||||
|
|
||||||
|
Send a ping message (which requests a reply).
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --sendping
|
||||||
|
```
|
||||||
|
|
||||||
|
### --reboot
|
||||||
|
|
||||||
|
Tell the destination node to reboot.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --dest \!28979058 --reboot
|
||||||
|
```
|
||||||
|
|
||||||
|
### --reply
|
||||||
|
|
||||||
|
Reply to received messages.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --reply
|
||||||
|
```
|
||||||
|
|
||||||
|
### --gpio-wrb GPIO_WRB GPIO_WRB
|
||||||
|
|
||||||
|
Set a particular GPIO # to 1 or 0.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --gpio-wrb 4 1 --dest \!28979058
|
||||||
|
```
|
||||||
|
|
||||||
|
### --gpio-rd GPIO_RD
|
||||||
|
|
||||||
|
Read from a GPIO mask.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --gpio-rd 0x10 --dest \!28979058
|
||||||
|
```
|
||||||
|
|
||||||
|
### --gpio-watch GPIO_WATCH
|
||||||
|
|
||||||
|
Start watching a GPIO mask for changes.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --gpio-watch 0x10 --dest \!28979058
|
||||||
|
```
|
||||||
|
|
||||||
|
### --no-time
|
||||||
|
|
||||||
|
Suppress sending the current time to the mesh.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --port /dev/ttyUSB0 --no-time
|
||||||
|
```
|
||||||
|
|
||||||
|
### --setalt SETALT
|
||||||
|
|
||||||
|
Set device altitude (allows use without GPS).
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --setalt 120
|
||||||
|
```
|
||||||
|
|
||||||
|
### --setlat SETLAT
|
||||||
|
|
||||||
|
Set device latitude (allows use without GPS).
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --setlat 25.2
|
||||||
|
```
|
||||||
|
|
||||||
|
### --setlon SETLON
|
||||||
|
|
||||||
|
Set device longitude (allows use without GPS).
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --setlon -16.8
|
||||||
|
```
|
||||||
|
|
||||||
|
### --debug
|
||||||
|
|
||||||
|
Show API library debug log messages.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --debug --info
|
||||||
|
```
|
||||||
|
|
||||||
|
### --test
|
||||||
|
|
||||||
|
Run stress test against all connected Meshtastic devices.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --test
|
||||||
|
```
|
||||||
|
|
||||||
|
### --ble BLE
|
||||||
|
|
||||||
|
BLE mac address to connect to (BLE is not yet supported for this tool).
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --ble "83:38:92:32:37:48"
|
||||||
|
```
|
||||||
|
|
||||||
|
### --noproto
|
||||||
|
|
||||||
|
Don't start the API, just function as a dumb serial terminal. Probably not very helpful from the command line. Used more for testing/internal needs.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --noproto
|
||||||
|
```
|
||||||
|
|
||||||
|
### --version
|
||||||
|
|
||||||
|
Show program's version number and exit.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --version
|
||||||
|
```
|
||||||
|
|
||||||
|
### --configure
|
||||||
|
|
||||||
|
Configure all of the radio configuration from a yaml file.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --configure example_config.yaml
|
||||||
|
```
|
||||||
|
|
||||||
|
### --export-config
|
||||||
|
|
||||||
|
Export the configuration of the device. (to be consumed by the '--configure' command)
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --export-config
|
||||||
|
```
|
||||||
|
|
||||||
|
### --support
|
||||||
|
|
||||||
|
Print out info that would be helpful supporting any issues.
|
||||||
|
|
||||||
|
**Usage**
|
||||||
|
|
||||||
|
``` shell
|
||||||
|
meshtastic --support
|
||||||
|
```
|
||||||
|
|
||||||
|
## Deprecated Arguments
|
||||||
|
|
||||||
|
### --setchan
|
||||||
|
|
||||||
|
Deprecated - use "--ch-set param value" instead.
|
||||||
|
|
||||||
|
### --set-router
|
||||||
|
|
||||||
|
Deprecated - use "--set is_router true" instead.
|
||||||
|
|
||||||
|
### --unset-router
|
||||||
|
|
||||||
|
Deprecated - use "--set is_router false" instead.
|
||||||
|
|
116
docs/software/python/development.md
Normal file
116
docs/software/python/development.md
Normal file
|
@ -0,0 +1,116 @@
|
||||||
|
---
|
||||||
|
id: python-development
|
||||||
|
title: Meshtastic-python Development
|
||||||
|
sidebar_label: Meshtastic-python development
|
||||||
|
---
|
||||||
|
|
||||||
|
## A note to developers of this lib
|
||||||
|
|
||||||
|
We use the visual-studio-code default python formatting conventions (autopep8). So if you use that IDE you should be able to use "Format Document" and not generate unrelated diffs. If you use some other editor, please do not change formatting on lines you have not changed yourself.
|
||||||
|
|
||||||
|
If you need to build a new release you will need:
|
||||||
|
|
||||||
|
```
|
||||||
|
apt install pandoc
|
||||||
|
sudo pip3 install markdown pdoc3 webencodings pyparsing twine autopep8 pylint pytest pytest-cov
|
||||||
|
```
|
||||||
|
|
||||||
|
For development, you will probably want to run:
|
||||||
|
|
||||||
|
```
|
||||||
|
pip3 install -r requirements.txt
|
||||||
|
```
|
||||||
|
|
||||||
|
To lint, run:
|
||||||
|
|
||||||
|
```
|
||||||
|
pylint meshtastic
|
||||||
|
```
|
||||||
|
|
||||||
|
To test, first install this code locally, then run pytest:
|
||||||
|
|
||||||
|
```
|
||||||
|
pip3 install .
|
||||||
|
pytest
|
||||||
|
```
|
||||||
|
|
||||||
|
Possible options for testing:
|
||||||
|
|
||||||
|
- For more verbosity, add "-v" or even "-vv" like this:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest -vv
|
||||||
|
```
|
||||||
|
|
||||||
|
- To run just unit tests:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest
|
||||||
|
# or (more verbosely)
|
||||||
|
pytest -m unit
|
||||||
|
# or
|
||||||
|
make
|
||||||
|
```
|
||||||
|
|
||||||
|
- To run just integration tests:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest -m int
|
||||||
|
```
|
||||||
|
|
||||||
|
- To run the smoke test with only one device connected serially (aka smoke1):
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest -m smoke1
|
||||||
|
```
|
||||||
|
|
||||||
|
CAUTION: Running smoke1 will reset values on the device, including the region to 1 (US).
|
||||||
|
Be sure to hit the reset button on the device after the test is completed.
|
||||||
|
|
||||||
|
- To run the smoke test with only two device connected serially (aka smoke2):
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest -m smoke2
|
||||||
|
```
|
||||||
|
|
||||||
|
- To run the wifi smoke test:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest -m smokewifi
|
||||||
|
```
|
||||||
|
|
||||||
|
- To run a specific test:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest -msmoke1 meshtastic/tests/test_smoke1.py::test_smoke1_info
|
||||||
|
# or to run a specific smoke2 test
|
||||||
|
pytest -m smoke2 meshtastic/tests/test_smoke2.py::test_smoke2_info
|
||||||
|
# or to run a specific smoke_wifi test
|
||||||
|
pytest -m smokewifi meshtastic/tests/test_smoke_wifi.py::test_smokewifi_info
|
||||||
|
```
|
||||||
|
|
||||||
|
- To add another classification of tests such as "unit" or "smoke1", see [pytest.ini](pytest.ini).
|
||||||
|
|
||||||
|
- To see the unit test code coverage:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest --cov=meshtastic
|
||||||
|
# or if want html coverage report
|
||||||
|
pytest --cov-report html --cov=meshtastic
|
||||||
|
# or
|
||||||
|
make cov
|
||||||
|
```
|
||||||
|
|
||||||
|
- To see slowest unit tests, you can run:
|
||||||
|
|
||||||
|
```
|
||||||
|
pytest --durations=0
|
||||||
|
# or
|
||||||
|
make slow
|
||||||
|
```
|
||||||
|
|
||||||
|
See the [docs](https://meshtastic-python.vercel.app/meshtastic/index.html) or you can generate them locally by running:
|
||||||
|
|
||||||
|
```
|
||||||
|
bin/regen-docs.sh
|
||||||
|
```
|
|
@ -6,7 +6,7 @@ sidebar_label: Installation
|
||||||
import Tabs from '@theme/Tabs';
|
import Tabs from '@theme/Tabs';
|
||||||
import TabItem from '@theme/TabItem';
|
import TabItem from '@theme/TabItem';
|
||||||
|
|
||||||
This small library provides a command line interface for Meshtastic nodes and provides an easy API for sending and receiving messages over mesh radios, in addition to changing user settings. Using the command line is currently the most powerful w. Events are delivered using a publish-subscribe model, and you can subscribe to only the message types you are interested in.
|
This library provides a command line interface for Meshtastic nodes and provides an easy API for sending and receiving messages over mesh radios, in addition to changing user settings. Using the command line is currently the most powerful. Events are delivered using a publish-subscribe model, and you can subscribe to only the message types you are interested in.
|
||||||
|
|
||||||
[Full documentation](https://meshtastic.github.io/Meshtastic-python) for the library, including examples, is available.
|
[Full documentation](https://meshtastic.github.io/Meshtastic-python) for the library, including examples, is available.
|
||||||
|
|
||||||
|
@ -117,7 +117,7 @@ Some newer boards may require the drivers for the [CH9102](http://www.wch.cn/dow
|
||||||
pip3 -V
|
pip3 -V
|
||||||
```
|
```
|
||||||
* If this does not return a version, install [pip](https://pip.pypa.io/en/stable/installing/)
|
* If this does not return a version, install [pip](https://pip.pypa.io/en/stable/installing/)
|
||||||
|
|
||||||
* Install pytap2
|
* Install pytap2
|
||||||
```bash
|
```bash
|
||||||
sudo pip3 install --upgrade pytap2
|
sudo pip3 install --upgrade pytap2
|
||||||
|
@ -179,12 +179,12 @@ Wifi connection is currently under development and may not be working properly j
|
||||||
```
|
```
|
||||||
pkg install python
|
pkg install python
|
||||||
```
|
```
|
||||||
* Upgrade pip and installed meshtastic and its dependencies
|
* Upgrade pip and installed meshtastic and some of its dependencies
|
||||||
```
|
```
|
||||||
pip install --upgrade pip pygatt pytap2 wheel mesthtastic
|
pip install --upgrade pip pygatt pytap2 wheel mesthtastic
|
||||||
```
|
```
|
||||||
|
|
||||||
:::note
|
:::note
|
||||||
Be aware that the Meshtastic CLI is not able to control the nodes over USB through termux, but you can control devices over Wifi using the `--host x.x.x.x` option with the device IP address. However, only ESP32 devices can use Wifi currently.
|
Be aware that the Meshtastic CLI is not able to control the nodes over USB through termux, but you can control devices over Wifi using the `--host x.x.x.x` option with the device IP address. However, only ESP32 devices can use Wifi currently.
|
||||||
:::
|
:::
|
||||||
</TabItem>
|
</TabItem>
|
||||||
|
|
134
docs/software/python/uses.md
Normal file
134
docs/software/python/uses.md
Normal file
|
@ -0,0 +1,134 @@
|
||||||
|
---
|
||||||
|
id: python-uses
|
||||||
|
title: Uses of the meshtastic command line interface tool
|
||||||
|
sidebar_label: Uses
|
||||||
|
---
|
||||||
|
|
||||||
|
This section covers using the "meshtastic" command line executable, which displays packets sent over the network as JSON and lets you see serial debugging information from the Meshtastic devices.
|
||||||
|
|
||||||
|
:::note
|
||||||
|
The `meshtastic` command is not run within python but is a script run from your operating system shell prompt. When you type "meshtastic" and the prompt is unable to find the command in Windows, check that the python "scripts" directory [is in your path](https://datatofish.com/add-python-to-windows-path/).
|
||||||
|
:::
|
||||||
|
|
||||||
|
## Getting a list of User Preferences
|
||||||
|
|
||||||
|
You can get a list of user preferences by running '--get' with an invalid attribute such as 'all'.
|
||||||
|
```bash
|
||||||
|
meshtastic --get all
|
||||||
|
```
|
||||||
|
|
||||||
|
## Changing settings
|
||||||
|
|
||||||
|
You can also use this tool to set any of the device parameters which are stored in persistent storage. For instance, here's how to set the device
|
||||||
|
to keep the Bluetooth link alive for eight hours (any usage of the Bluetooth protocol from your phone will reset this timer)
|
||||||
|
|
||||||
|
```bash title="Expected Output"
|
||||||
|
# You should see a result similar to this:
|
||||||
|
mydir$ meshtastic --set wait_bluetooth_secs 28800
|
||||||
|
Connected to radio...
|
||||||
|
Setting preference wait_bluetooth_secs to 28800
|
||||||
|
Writing modified preferences to device...
|
||||||
|
```
|
||||||
|
|
||||||
|
Or to set a node at a fixed position and never power up the GPS.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
meshtastic --setlat 25.2 --setlon -16.8 --setalt 120
|
||||||
|
```
|
||||||
|
|
||||||
|
Or to configure an ESP32 based board to join a Wifi network as a station:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
meshtastic --set wifi_ap_mode false --set wifi_ssid mywifissid --set wifi_password mywifipsw
|
||||||
|
```
|
||||||
|
|
||||||
|
Or to configure an ESP32 to run as a Wifi access point:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
meshtastic --set wifi_ap_mode true --set wifi_ssid mywifissid --set wifi_password mywifipsw
|
||||||
|
```
|
||||||
|
|
||||||
|
:::note
|
||||||
|
For a full list of preferences which can be set (and their documentation) can be found in the [protobufs](/docs/developers/protobufs/api#radioconfiguserpreferences).
|
||||||
|
:::
|
||||||
|
|
||||||
|
### Changing channel settings
|
||||||
|
|
||||||
|
The channel settings can also be changed, either by using a standard (shareable) meshtastic URL or you can set particular channel parameter (for advanced users).
|
||||||
|
|
||||||
|
:::warning
|
||||||
|
Meshtastic encodes the radio channel and PSK in the channel's URL. All nodes must connect to the channel again by using the URL provided after a change in this section by performing the `--info` switch. Please refer to [Multiple Channel Support](../device/device-channels).
|
||||||
|
:::
|
||||||
|
|
||||||
|
```bash
|
||||||
|
meshtastic --ch-set name mychan --ch-index 1 --ch-set channel_num 4 --info
|
||||||
|
```
|
||||||
|
|
||||||
|
You can even set the channel preshared key to a particular AES128 or AES256 sequence.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
meshtastic --ch-index 1 --ch-set psk 0x1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b --info
|
||||||
|
```
|
||||||
|
|
||||||
|
Use `--ch-set psk none --ch-index 0` to turn off encryption.
|
||||||
|
|
||||||
|
Use `--ch-set psk random --ch-index 0` will assign a new (high quality) random AES256 key to the primary channel (similar to what the Android app does when making new channels).
|
||||||
|
|
||||||
|
Use `--ch-set psk default --ch-index 0` to restore the standard 'default' (minimally secure, because it is in the source code for anyone to read) AES128 key.
|
||||||
|
|
||||||
|
All `ch-set` commands need to have the `ch-index` parameter specified:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
meshtastic --ch-index 1 --ch-set name mychan --ch-set channel_num 4 --info
|
||||||
|
```
|
||||||
|
|
||||||
|
### Ham radio support
|
||||||
|
|
||||||
|
Meshtastic is designed to be used without a radio operator license. If you do have a license you can set your operator ID and turn off encryption with:
|
||||||
|
|
||||||
|
```bash title="Expected Output"
|
||||||
|
# You should see a result similar to this:
|
||||||
|
mydir$ meshtastic --port /dev/ttyUSB1 --set-ham KI1345
|
||||||
|
Connected to radio
|
||||||
|
Setting Ham ID to KI1345 and turning off encryption
|
||||||
|
Writing modified channels to device
|
||||||
|
```
|
||||||
|
|
||||||
|
## Changing the preshared key:
|
||||||
|
|
||||||
|
You can set the channel preshared key to a particular AES128 or AES256 sequence.
|
||||||
|
|
||||||
|
```
|
||||||
|
meshtastic --ch-set psk 0x1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b1a1a1a1a2b2b2b2b --info
|
||||||
|
```
|
||||||
|
|
||||||
|
Use "--ch-set psk none" to turn off encryption.
|
||||||
|
|
||||||
|
Use "--ch-set psk random" will assign a new (high quality) random AES256 key to the primary channel (similar to what the Android app does when making new channels).
|
||||||
|
|
||||||
|
Use "--ch-set psk default" to restore the standard 'default' (minimally secure, because it is in the source code for anyone to read) AES128 key.
|
||||||
|
|
||||||
|
All "ch-set" commands will default to the primary channel at index 0, but can be applied to other channels with the "ch-index" parameter.
|
||||||
|
|
||||||
|
|
||||||
|
## FAQ/common problems
|
||||||
|
|
||||||
|
This is a collection of common questions and answers from our friendly forum.
|
||||||
|
|
||||||
|
### Permission denied: ‘/dev/ttyUSB0’
|
||||||
|
|
||||||
|
As previously discussed on the [forum](https://meshtastic.discourse.group/t/question-on-permission-denied-dev-ttyusb0/590/3?u=geeksville)
|
||||||
|
|
||||||
|
This indicates an OS permission problem for access by your user to the USB serial port. Typically this is fixed by the following.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo usermod -a -G dialout <username>
|
||||||
|
```
|
||||||
|
|
||||||
|
### Mac OS Big Sur
|
||||||
|
|
||||||
|
There is a problem with Big Sur and pyserial. The workaround is to install a newer version of pyserial:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
pip3 install -U --pre pyserial
|
||||||
|
```
|
|
@ -1,7 +1,7 @@
|
||||||
---
|
---
|
||||||
id: python-usage
|
id: python-using-library
|
||||||
title: Meshtastic-python usage
|
title: using the Meshtastic-python library
|
||||||
sidebar_label: Python usage
|
sidebar_label: Using the meshtastic Python library
|
||||||
---
|
---
|
||||||
|
|
||||||
An example using Python 3 code to send a message to the mesh, get and set a radio configuration preference:
|
An example using Python 3 code to send a message to the mesh, get and set a radio configuration preference:
|
|
@ -51,7 +51,9 @@ module.exports = {
|
||||||
"Meshtastic-python": [
|
"Meshtastic-python": [
|
||||||
"software/python/python-installation",
|
"software/python/python-installation",
|
||||||
"software/python/python-cli",
|
"software/python/python-cli",
|
||||||
"software/python/python-usage",
|
"software/python/python-uses",
|
||||||
|
"software/python/python-using-library",
|
||||||
|
"software/python/python-development",
|
||||||
{
|
{
|
||||||
type: "link",
|
type: "link",
|
||||||
label: "API Docs",
|
label: "API Docs",
|
||||||
|
|
Loading…
Reference in a new issue