mirror of
https://github.com/meshcore-dev/MeshCore.git
synced 2026-03-29 19:30:00 +00:00
977 lines
19 KiB
Markdown
977 lines
19 KiB
Markdown
# CLI Commands
|
|
|
|
This document provides an overview of CLI commands that can be sent to MeshCore Repeaters, Room Servers and Sensors.
|
|
|
|
## Navigation
|
|
|
|
- [Operational](#operational)
|
|
- [Neighbors](#neighbors-repeater-only)
|
|
- [Statistics](#statistics)
|
|
- [Logging](#logging)
|
|
- [Information](#info)
|
|
- [Configuration](#configuration)
|
|
- [Radio](#radio)
|
|
- [System](#system)
|
|
- [Routing](#routing)
|
|
- [ACL](#acl)
|
|
- [Region Management](#region-management-v110)
|
|
- [Region Examples](#region-examples)
|
|
- [GPS](#gps-when-gps-support-is-compiled-in)
|
|
- [Sensors](#sensors-when-sensor-support-is-compiled-in)
|
|
- [Bridge](#bridge-when-bridge-support-is-compiled-in)
|
|
|
|
---
|
|
|
|
## Operational
|
|
|
|
### Reboot the node
|
|
**Usage:**
|
|
- `reboot`
|
|
|
|
---
|
|
|
|
### Reset the clock and reboot
|
|
**Usage:**
|
|
- `clkreboot`
|
|
|
|
---
|
|
|
|
### Sync the clock with the remote device
|
|
**Usage:**
|
|
- `clock sync`
|
|
|
|
---
|
|
|
|
### Display current time in UTC
|
|
**Usage:**
|
|
- `clock`
|
|
|
|
---
|
|
|
|
### Set the time to a specific timestamp
|
|
**Usage:**
|
|
- `time <epoch_seconds>`
|
|
|
|
**Parameters:**
|
|
- `epoch_seconds`: Unix epoch time
|
|
|
|
---
|
|
|
|
### Send a flood advert
|
|
**Usage:**
|
|
- `advert`
|
|
|
|
---
|
|
|
|
### Send a zero-hop advert
|
|
**Usage:**
|
|
- `advert.zerohop`
|
|
|
|
---
|
|
|
|
### Start an Over-The-Air (OTA) firmware update
|
|
**Usage:**
|
|
- `start ota`
|
|
|
|
---
|
|
|
|
### Erase/Factory Reset
|
|
**Usage:**
|
|
- `erase`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
**Warning:** _**This is destructive!**_
|
|
|
|
---
|
|
|
|
## Neighbors (Repeater Only)
|
|
|
|
### List nearby neighbors
|
|
**Usage:**
|
|
- `neighbors`
|
|
|
|
**Note:** The output of this command is limited to the 8 most recent adverts.
|
|
|
|
**Note:** Each line is encoded as `{pubkey-prefix}:{timestamp}:{snr*4}`
|
|
|
|
---
|
|
|
|
### Remove a neighbor
|
|
**Usage:**
|
|
- `neighbor.remove <pubkey_prefix>`
|
|
|
|
**Parameters:**
|
|
- `pubkey_prefix`: The public key of the node to remove from the neighbors list
|
|
|
|
---
|
|
|
|
## Statistics
|
|
|
|
### Clear Stats
|
|
**Usage:** `clear stats`
|
|
|
|
---
|
|
|
|
### System Stats - Battery, Uptime, Queue Length and Debug Flags
|
|
**Usage:**
|
|
- `stats-core`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
---
|
|
|
|
### Radio Stats - Noise floor, Last RSSI/SNR, Airtime, Receive errors
|
|
**Usage:** `stats-radio`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
---
|
|
|
|
### Packet stats - Packet counters: Received, Sent
|
|
**Usage:** `stats-packets`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
---
|
|
|
|
## Logging
|
|
|
|
### Begin capture of rx log to node storage
|
|
**Usage:** `log start`
|
|
|
|
---
|
|
|
|
### End capture of rx log to node storage
|
|
**Usage:** `log stop`
|
|
|
|
---
|
|
|
|
### Erase captured log
|
|
**Usage:** `log erase`
|
|
|
|
---
|
|
|
|
### Print the captured log to the serial terminal
|
|
**Usage:** `log`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
---
|
|
|
|
## Info
|
|
|
|
### Get the Version
|
|
**Usage:** `ver`
|
|
|
|
---
|
|
|
|
### Show the hardware name
|
|
**Usage:** `board`
|
|
|
|
---
|
|
|
|
## Configuration
|
|
|
|
### Radio
|
|
|
|
#### View or change this node's radio parameters
|
|
**Usage:**
|
|
- `get radio`
|
|
- `set radio <freq>,<bw>,<sf>,<cr>`
|
|
|
|
**Parameters:**
|
|
- `freq`: Frequency in MHz
|
|
- `bw`: Bandwidth in kHz
|
|
- `sf`: Spreading factor (5-12)
|
|
- `cr`: Coding rate (5-8)
|
|
|
|
**Set by build flag:** `LORA_FREQ`, `LORA_BW`, `LORA_SF`, `LORA_CR`
|
|
|
|
**Default:** `869.525,250,11,5`
|
|
|
|
**Note:** Requires reboot to apply
|
|
|
|
---
|
|
|
|
#### View or change this node's transmit power
|
|
**Usage:**
|
|
- `get tx`
|
|
- `set tx <dbm>`
|
|
|
|
**Parameters:**
|
|
- `dbm`: Power level in dBm (1-22)
|
|
|
|
**Set by build flag:** `LORA_TX_POWER`
|
|
|
|
**Default:** Varies by board
|
|
|
|
**Notes:** This setting only controls the power level of the LoRa chip. Some nodes have an additional power amplifier stage which increases the total output. Refer to the node's manual for the correct setting to use. **Setting a value too high may violate the laws in your country.**
|
|
|
|
---
|
|
|
|
#### Change the radio parameters for a set duration
|
|
**Usage:**
|
|
- `tempradio <freq>,<bw>,<sf>,<cr>,<timeout_mins>`
|
|
|
|
**Parameters:**
|
|
- `freq`: Frequency in MHz (300-2500)
|
|
- `bw`: Bandwidth in kHz (7.8-500)
|
|
- `sf`: Spreading factor (5-12)
|
|
- `cr`: Coding rate (5-8)
|
|
- `timeout_mins`: Duration in minutes (must be > 0)
|
|
|
|
**Note:** This is not saved to preferences and will clear on reboot
|
|
|
|
---
|
|
|
|
#### View or change this node's frequency
|
|
**Usage:**
|
|
- `get freq`
|
|
- `set freq <frequency>`
|
|
|
|
**Parameters:**
|
|
- `frequency`: Frequency in MHz
|
|
|
|
**Default:** `869.525`
|
|
|
|
**Note:** Requires reboot to apply
|
|
**Serial Only:** `set freq <frequency>`
|
|
|
|
### System
|
|
|
|
#### View or change this node's name
|
|
**Usage:**
|
|
- `get name`
|
|
- `set name <name>`
|
|
|
|
**Parameters:**
|
|
- `name`: Node name
|
|
|
|
**Set by build flag:** `ADVERT_NAME`
|
|
|
|
**Default:** Varies by board
|
|
|
|
**Note:** Max length varies. If a location is set, the max length is 24 bytes; 32 otherwise. Emoji and unicode characters may take more than one byte.
|
|
|
|
---
|
|
|
|
#### View or change this node's latitude
|
|
**Usage:**
|
|
- `get lat`
|
|
- `set lat <degrees>`
|
|
|
|
**Set by build flag:** `ADVERT_LAT`
|
|
|
|
**Default:** `0`
|
|
|
|
**Parameters:**
|
|
- `degrees`: Latitude in degrees
|
|
|
|
---
|
|
|
|
#### View or change this node's longitude
|
|
**Usage:**
|
|
- `get lon`
|
|
- `set lon <degrees>`
|
|
|
|
**Set by build flag:** `ADVERT_LON`
|
|
|
|
**Default:** `0`
|
|
|
|
**Parameters:**
|
|
- `degrees`: Longitude in degrees
|
|
|
|
---
|
|
|
|
#### View or change this node's identity (Private Key)
|
|
**Usage:**
|
|
- `get prv.key`
|
|
- `set prv.key <private_key>`
|
|
|
|
**Parameters:**
|
|
- `private_key`: Private key in hex format (64 hex characters)
|
|
|
|
**Serial Only:**
|
|
- `get prv.key`: Yes
|
|
- `set prv.key`: No
|
|
|
|
**Note:** Requires reboot to take effect after setting
|
|
|
|
---
|
|
|
|
#### Change this node's admin password
|
|
**Usage:**
|
|
- `password <new_password>`
|
|
|
|
**Parameters:**
|
|
- `new_password`: New admin password
|
|
|
|
**Set by build flag:** `ADMIN_PASSWORD`
|
|
|
|
**Default:** `password`
|
|
|
|
**Note:** Command reply echoes the updated password for confirmation.
|
|
|
|
**Note:** Any node using this password will be added to the admin ACL list.
|
|
|
|
---
|
|
|
|
#### View or change this node's guest password
|
|
**Usage:**
|
|
- `get guest.password`
|
|
- `set guest.password <password>`
|
|
|
|
**Parameters:**
|
|
- `password`: Guest password
|
|
|
|
**Set by build flag:** `ROOM_PASSWORD` (Room Server only)
|
|
|
|
**Default:** `<blank>`
|
|
|
|
---
|
|
|
|
#### View or change this node's owner info
|
|
**Usage:**
|
|
- `get owner.info`
|
|
- `set owner.info <text>`
|
|
|
|
**Parameters:**
|
|
- `text`: Owner information text
|
|
|
|
**Default:** `<blank>`
|
|
|
|
**Note:** `|` characters are translated to newlines
|
|
|
|
**Note:** Requires firmware 1.12.+
|
|
|
|
---
|
|
|
|
#### Fine-tune the battery reading
|
|
**Usage:**
|
|
- `get adc.multiplier`
|
|
- `set adc.multiplier <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: ADC multiplier (0.0-10.0)
|
|
|
|
**Default:** `0.0` (value defined by board)
|
|
|
|
**Note:** Returns "Error: unsupported by this board" if hardware doesn't support it
|
|
|
|
---
|
|
|
|
#### View this node's public key
|
|
**Usage:** `get public.key`
|
|
|
|
---
|
|
|
|
#### View this node's configured role
|
|
**Usage:** `get role`
|
|
|
|
---
|
|
|
|
#### View or change this node's power saving flag (Repeater Only)
|
|
**Usage:**
|
|
- `powersaving`
|
|
- `powersaving on`
|
|
- `powersaving off`
|
|
|
|
**Parameters:**
|
|
- `on`: enable power saving
|
|
- `off`: disable power saving
|
|
|
|
**Default:** `on`
|
|
|
|
**Note:** When enabled, device enters sleep mode between radio transmissions
|
|
|
|
---
|
|
|
|
### Routing
|
|
|
|
#### View or change this node's repeat flag
|
|
**Usage:**
|
|
- `get repeat`
|
|
- `set repeat <state>`
|
|
|
|
**Parameters:**
|
|
- `state`: `on`|`off`
|
|
|
|
**Default:** `on`
|
|
|
|
---
|
|
|
|
#### View or change this node's advert path hash size
|
|
**Usage:**
|
|
- `get path.hash.mode`
|
|
- `set path.hash.mode <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Path hash size (0-2)
|
|
- `0`: 1 Byte hash size (256 unique ids)[64 max flood]
|
|
- `1`: 2 Byte hash size (65,536 unique ids)[32 max flood]
|
|
- `2`: 3 Byte hash size (16,777,216 unique ids)[21 max flood]
|
|
- `3`: DO NOT USE (Reserved)
|
|
|
|
**Default:** `0`
|
|
|
|
**Note:** the 'path.hash.mode' sets the low-level ID/hash encoding size used when the repeater adverts. This setting has no impact on what packet ID/hash size this repeater forwards, all sizes should be forwarded on firmware >= 1.14. This feature was added in firmware 1.14
|
|
|
|
**Temporary Note:** adverts with ID/hash sizes of 2 or 3 bytes may have limited flood propogation in your network while this feature is new as v1.13.0 firmware and older will drop packets with multibyte path ID/hashes as only 1-byte hashes are suppored. Consider your install base of firmware >=1.14 has reached a criticality for effective network flooding before implementing higher ID/hash sizes.
|
|
|
|
---
|
|
|
|
#### View or change this node's loop detection
|
|
**Usage:**
|
|
- `get loop.detect`
|
|
- `set loop.detect <state>`
|
|
|
|
**Parameters:**
|
|
- `state`:
|
|
- `off`: no loop detection is performed
|
|
- `minimal`: packets are dropped if repeater's ID/hash appears 4 or more times (1-byte), 2 or more (2-byte), 1 or more (3-byte)
|
|
- `moderate`: packets are dropped if repeater's ID/hash appears 2 or more times (1-byte), 1 or more (2-byte), 1 or more (3-byte)
|
|
- `strict`: packets are dropped if repeater's ID/hash appears 1 or more times (1-byte), 1 or more (2-byte), 1 or more (3-byte)
|
|
|
|
**Default:** `off`
|
|
|
|
**Note:** When it is enabled, repeaters will now reject flood packets which look like they are in a loop. This has been happening recently in some meshes when there is just a single 'bad' repeater firmware out there (prob some forked or custom firmware). If the payload is messed with, then forwarded, the same packet ends up causing a packet storm, repeated up to the max 64 hops. This feature was added in firmware 1.14
|
|
|
|
**Example:** If preference is `loop.detect minimal`, and a 1-byte path size packet is received, the repeater will see if its own ID/hash is already in the path. If it's already encoded 4 times, it will reject the packet. If the packet uses 2-byte path size, and repeater's own ID/hash is already encoded 2 times, it rejects. If the packet uses 3-byte path size, and the repeater's own ID/hash is already encoded 1 time, it rejects.
|
|
|
|
---
|
|
|
|
#### View or change the retransmit delay factor for flood traffic
|
|
**Usage:**
|
|
- `get txdelay`
|
|
- `set txdelay <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Transmit delay factor (0-2)
|
|
|
|
**Default:** `0.5`
|
|
|
|
---
|
|
|
|
#### View or change the retransmit delay factor for direct traffic
|
|
**Usage:**
|
|
- `get direct.txdelay`
|
|
- `set direct.txdelay <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Direct transmit delay factor (0-2)
|
|
|
|
**Default:** `0.2`
|
|
|
|
---
|
|
|
|
#### [Experimental] View or change the processing delay for received traffic
|
|
**Usage:**
|
|
- `get rxdelay`
|
|
- `set rxdelay <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Receive delay base (0-20)
|
|
|
|
**Default:** `0.0`
|
|
|
|
---
|
|
|
|
#### View or change the airtime factor (duty cycle limit)
|
|
**Usage:**
|
|
- `get af`
|
|
- `set af <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Airtime factor (0-9). After each transmission, the repeater enforces a silent period of approximately the on-air transmission time multiplied by the value. This results in a long-term duty cycle of roughly 1 divided by (1 plus the value). For example:
|
|
- `af = 1` → ~50% duty
|
|
- `af = 2` → ~33% duty
|
|
- `af = 3` → ~25% duty
|
|
- `af = 9` → ~10% duty
|
|
Yyou are responsible for choosing a value that is appropriate for your jurisdiction and channel plan (for example EU 868 Mhz 10% duty cycle regulation).
|
|
|
|
**Default:** `1.0`
|
|
|
|
---
|
|
|
|
#### View or change the local interference threshold
|
|
**Usage:**
|
|
- `get int.thresh`
|
|
- `set int.thresh <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Interference threshold value
|
|
|
|
**Default:** `0.0`
|
|
|
|
---
|
|
|
|
#### View or change the AGC Reset Interval
|
|
**Usage:**
|
|
- `get agc.reset.interval`
|
|
- `set agc.reset.interval <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Interval in seconds rounded down to a multiple of 4 (17 becomes 16)
|
|
|
|
**Default:** `0.0`
|
|
|
|
---
|
|
|
|
#### Enable or disable Multi-Acks support
|
|
**Usage:**
|
|
- `get multi.acks`
|
|
- `set multi.acks <state>`
|
|
|
|
**Parameters:**
|
|
- `state`: `0` (disable) or `1` (enable)
|
|
|
|
**Default:** `0`
|
|
|
|
---
|
|
|
|
#### View or change the flood advert interval
|
|
**Usage:**
|
|
- `get flood.advert.interval`
|
|
- `set flood.advert.interval <hours>`
|
|
|
|
**Parameters:**
|
|
- `hours`: Interval in hours (3-168)
|
|
|
|
**Default:** `12` (Repeater) - `0` (Sensor)
|
|
|
|
---
|
|
|
|
#### View or change the zero-hop advert interval
|
|
**Usage:**
|
|
- `get advert.interval`
|
|
- `set advert.interval <minutes>`
|
|
|
|
**Parameters:**
|
|
- `minutes`: Interval in minutes rounded down to the nearest multiple of 2 (61 becomes 60) (60-240)
|
|
|
|
**Default:** `0`
|
|
|
|
---
|
|
|
|
#### Limit the number of hops for a flood message
|
|
**Usage:**
|
|
- `get flood.max`
|
|
- `set flood.max <value>`
|
|
|
|
**Parameters:**
|
|
- `value`: Maximum flood hop count (0-64)
|
|
|
|
**Default:** `64`
|
|
|
|
---
|
|
|
|
### ACL
|
|
|
|
#### Add, update or remove permissions for a companion
|
|
**Usage:**
|
|
- `setperm <pubkey> <permissions>`
|
|
|
|
**Parameters:**
|
|
- `pubkey`: Companion public key
|
|
- `permissions`:
|
|
- `0`: Guest
|
|
- `1`: Read-only
|
|
- `2`: Read-write
|
|
- `3`: Admin
|
|
|
|
**Note:** Removes the entry when `permissions` is omitted
|
|
|
|
---
|
|
|
|
#### View the current ACL
|
|
**Usage:**
|
|
- `get acl`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
---
|
|
|
|
#### View or change this room server's 'read-only' flag
|
|
**Usage:**
|
|
- `get allow.read.only`
|
|
- `set allow.read.only <state>`
|
|
|
|
**Parameters:**
|
|
- `state`: `on` (enable) or `off` (disable)
|
|
|
|
**Default:** `off`
|
|
|
|
---
|
|
|
|
### Region Management (v1.10.+)
|
|
|
|
#### Bulk-load region lists
|
|
**Usage:**
|
|
- `region load`
|
|
- `region load <name> [flood_flag]`
|
|
|
|
**Parameters:**
|
|
- `name`: A name of a region. `*` represents the wildcard region
|
|
|
|
**Note:** `flood_flag`: Optional `F` to allow flooding
|
|
|
|
**Note:** Indentation creates parent-child relationships (max 8 levels)
|
|
|
|
**Note:** `region load` with an empty name will not work remotely (it's interactive)
|
|
|
|
---
|
|
|
|
#### Save any changes to regions made since reboot
|
|
**Usage:**
|
|
- `region save`
|
|
|
|
---
|
|
|
|
#### Allow a region
|
|
**Usage:**
|
|
- `region allowf <name>`
|
|
|
|
**Parameters:**
|
|
- `name`: Region name (or `*` for wildcard)
|
|
|
|
**Note:** Setting on wildcard `*` allows packets without region transport codes
|
|
|
|
---
|
|
|
|
#### Block a region
|
|
**Usage:**
|
|
- `region denyf <name>`
|
|
|
|
**Parameters:**
|
|
- `name`: Region name (or `*` for wildcard)
|
|
|
|
**Note:** Setting on wildcard `*` drops packets without region transport codes
|
|
|
|
---
|
|
|
|
#### Show information for a region
|
|
**Usage:**
|
|
- `region get <name>`
|
|
|
|
**Parameters:**
|
|
- `name`: Region name (or `*` for wildcard)
|
|
|
|
---
|
|
|
|
#### View or change the home region for this node
|
|
**Usage:**
|
|
- `region home`
|
|
- `region home <name>`
|
|
|
|
**Parameters:**
|
|
- `name`: Region name
|
|
|
|
---
|
|
|
|
#### Create a new region
|
|
**Usage:**
|
|
- `region put <name> [parent_name]`
|
|
|
|
**Parameters:**
|
|
- `name`: Region name
|
|
- `parent_name`: Parent region name (optional, defaults to wildcard)
|
|
|
|
---
|
|
|
|
#### Remove a region
|
|
**Usage:**
|
|
- `region remove <name>`
|
|
|
|
**Parameters:**
|
|
- `name`: Region name
|
|
|
|
**Note:** Must remove all child regions before the region can be removed
|
|
|
|
---
|
|
|
|
#### View all regions
|
|
**Usage:**
|
|
- `region list <filter>`
|
|
|
|
**Serial Only:** Yes
|
|
|
|
**Parameters:**
|
|
- `filter`: `allowed`|`denied`
|
|
|
|
**Note:** Requires firmware 1.12.+
|
|
|
|
---
|
|
|
|
#### Dump all defined regions and flood permissions
|
|
**Usage:**
|
|
- `region`
|
|
|
|
**Serial Only:** For firmware older than 1.12.0
|
|
|
|
---
|
|
|
|
### Region Examples
|
|
|
|
**Example 1: Using F Flag with Named Public Region**
|
|
```
|
|
region load
|
|
#Europe F
|
|
<blank line to end region load>
|
|
region save
|
|
```
|
|
|
|
**Explanation:**
|
|
- Creates a region named `#Europe` with flooding enabled
|
|
- Packets from this region will be flooded to other nodes
|
|
|
|
---
|
|
|
|
**Example 2: Using Wildcard with F Flag**
|
|
```
|
|
region load
|
|
* F
|
|
<blank line to end region load>
|
|
region save
|
|
```
|
|
|
|
**Explanation:**
|
|
- Creates a wildcard region `*` with flooding enabled
|
|
- Enables flooding for all regions automatically
|
|
- Applies only to packets without transport codes
|
|
|
|
---
|
|
|
|
**Example 3: Using Wildcard Without F Flag**
|
|
```
|
|
region load
|
|
*
|
|
<blank line to end region load>
|
|
region save
|
|
```
|
|
**Explanation:**
|
|
- Creates a wildcard region `*` without flooding
|
|
- This region exists but doesn't affect packet distribution
|
|
- Used as a default/empty region
|
|
|
|
---
|
|
|
|
**Example 4: Nested Public Region with F Flag**
|
|
```
|
|
region load
|
|
#Europe F
|
|
#UK
|
|
#London
|
|
#Manchester
|
|
#France
|
|
#Paris
|
|
#Lyon
|
|
<blank line to end region load>
|
|
region save
|
|
```
|
|
|
|
**Explanation:**
|
|
- Creates `#Europe` region with flooding enabled
|
|
- Adds nested child regions (`#UK`, `#France`)
|
|
- All nested regions inherit the flooding flag from parent
|
|
|
|
---
|
|
|
|
**Example 5: Wildcard with Nested Public Regions**
|
|
```
|
|
region load
|
|
* F
|
|
#NorthAmerica
|
|
#USA
|
|
#NewYork
|
|
#California
|
|
#Canada
|
|
#Ontario
|
|
#Quebec
|
|
<blank line to end region load>
|
|
region save
|
|
```
|
|
|
|
**Explanation:**
|
|
- Creates wildcard region `*` with flooding enabled
|
|
- Adds nested `#NorthAmerica` hierarchy
|
|
- Enables flooding for all child regions automatically
|
|
- Useful for global networks with specific regional rules
|
|
|
|
---
|
|
### GPS (When GPS support is compiled in)
|
|
|
|
#### View or change GPS state
|
|
**Usage:**
|
|
- `gps`
|
|
- `gps <state>`
|
|
|
|
**Parameters:**
|
|
- `state`: `on`|`off`
|
|
|
|
**Default:** `off`
|
|
|
|
**Note:** Output format: `{status}, {fix}, {sat count}` (when enabled)
|
|
|
|
---
|
|
|
|
#### Sync this node's clock with GPS time
|
|
**Usage:**
|
|
- `gps sync`
|
|
|
|
---
|
|
|
|
#### Set this node's location based on the GPS coordinates
|
|
**Usage:**
|
|
- `gps setloc`
|
|
|
|
---
|
|
|
|
#### View or change the GPS advert policy
|
|
**Usage:**
|
|
- `gps advert`
|
|
- `gps advert <policy>`
|
|
|
|
**Parameters:**
|
|
- `policy`: `none`|`share`|`prefs`
|
|
- `none`: don't include location in adverts
|
|
- `share`: share gps location (from SensorManager)
|
|
- `prefs`: location stored in node's lat and lon settings
|
|
|
|
**Default:** `prefs`
|
|
|
|
---
|
|
|
|
### Sensors (When sensor support is compiled in)
|
|
|
|
#### View the list of sensors on this node
|
|
**Usage:** `sensor list [start]`
|
|
|
|
**Parameters:**
|
|
- `start`: Optional starting index (defaults to 0)
|
|
|
|
**Note:** Output format: `<var_name>=<value>\n`
|
|
|
|
---
|
|
|
|
#### View or change thevalue of a sensor
|
|
**Usage:**
|
|
- `sensor get <key>`
|
|
- `sensor set <key> <value>`
|
|
|
|
**Parameters:**
|
|
- `key`: Sensor setting name
|
|
- `value`: The value to set the sensor to
|
|
|
|
---
|
|
|
|
### Bridge (When bridge support is compiled in)
|
|
|
|
#### View the compiled bridge type
|
|
**Usage:** `get bridge.type`
|
|
|
|
---
|
|
|
|
#### View or change the bridge enabled flag
|
|
**Usage:**
|
|
- `get bridge.enabled`
|
|
- `set bridge.enabled <state>`
|
|
|
|
**Parameters:**
|
|
- `state`: `on`|`off`
|
|
|
|
**Default:** `off`
|
|
|
|
---
|
|
|
|
#### Add a delay to packets routed through this bridge
|
|
**Usage:**
|
|
- `get bridge.delay`
|
|
- `set bridge.delay <ms>`
|
|
|
|
**Parameters:**
|
|
- `ms`: Delay in milliseconds (0-10000)
|
|
|
|
**Default:** `500`
|
|
|
|
---
|
|
|
|
#### View or change the source of packets bridged to the external interface
|
|
**Usage:**
|
|
- `get bridge.source`
|
|
- `set bridge.source <source>`
|
|
|
|
**Parameters:**
|
|
- `source`:
|
|
- `logRx`: bridges received packets
|
|
- `logTx`: bridges transmitted packets
|
|
|
|
**Default:** `logTx`
|
|
|
|
---
|
|
|
|
#### View or change the speed of the bridge (RS-232 only)
|
|
**Usage:**
|
|
- `get bridge.baud`
|
|
- `set bridge.baud <rate>`
|
|
|
|
**Parameters:**
|
|
- `rate`: Baud rate (`9600`, `19200`, `38400`, `57600`, or `115200`)
|
|
|
|
**Default:** `115200`
|
|
|
|
---
|
|
|
|
#### View or change the channel used for bridging (ESPNow only)
|
|
**Usage:**
|
|
- `get bridge.channel`
|
|
- `set bridge.channel <channel>`
|
|
|
|
**Parameters:**
|
|
- `channel`: Channel number (1-14)
|
|
|
|
---
|
|
|
|
#### Set the ESP-Now secret
|
|
**Usage:**
|
|
- `get bridge.secret`
|
|
- `set bridge.secret <secret>`
|
|
|
|
**Parameters:**
|
|
- `secret`: ESP-NOW bridge secret, up to 15 characters
|
|
|
|
**Default:** Varies by board
|
|
|
|
---
|
|
|
|
#### View the bootloader version (nRF52 only)
|
|
**Usage:** `get bootloader.ver`
|
|
|
|
---
|
|
|
|
#### View power management support
|
|
**Usage:** `get pwrmgt.support`
|
|
|
|
---
|
|
|
|
#### View the current power source
|
|
**Usage:** `get pwrmgt.source`
|
|
|
|
**Note:** Returns an error on boards without power management support.
|
|
|
|
---
|
|
|
|
#### View the boot reset and shutdown reasons
|
|
**Usage:** `get pwrmgt.bootreason`
|
|
|
|
**Note:** Returns an error on boards without power management support.
|
|
|
|
---
|
|
|
|
#### View the boot voltage
|
|
**Usage:** `get pwrmgt.bootmv`
|
|
|
|
**Note:** Returns an error on boards without power management support.
|
|
|
|
---
|