MeshCore CLI Commands Reference
CLI Commands
This document provides an overview of CLI commands that can be sent to MeshCore Repeaters, Room Servers and Sensors.
Navigation
- Operational
- Neighbors
- Statistics
- Logging
- Information
- Configuration
- Radio
- System
- Routing
- ACL
- Region Management
- Region Examples
- GPS
- Sensors
- Bridge
---
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
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
Parameters:
pubkey_prefix: The public key of the node to remove from the neighbors list. This can be a short prefix or the full key. All neighbors matching the provided prefix will be removed.
Note: You can remove all neighbors by sending a space character as the prefix. The space indicates an empty prefix, which matches all existing neighbors.
---
Discover zero hop neighbors
Usage:
discover.neighbors
---
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 radioset radio ,,,
Parameters:
freq: Frequency in MHzbw: Bandwidth in kHzsf: 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 txset tx
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.
---
View or change the boosted receive gain mode
Usage:
get radio.rxgainset radio.rxgain
Parameters:
state:on|off
Default: off
Note: Only available on SX1262 and SX1268 based boards.
---
Change the radio parameters for a set duration
Usage:
tempradio ,,,,
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 freqset freq
Parameters:
frequency: Frequency in MHz
Default: 869.525
Note: Requires reboot to apply
Serial Only: set freq
---
View or change this node's rx boosted gain mode (SX12xx only, v1.14.1+)
Usage:
get radio.rxgainset radio.rxgain
Parameters:
state:on|off
Default: on
Temporary Note: If you upgraded from an older version to 1.14.1 without erasing flash, this setting is off because of #2118
---
System
View or change this node's name
Usage:
get nameset 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 latset lat
Set by build flag: ADVERT_LAT
Default: 0
Parameters:
degrees: Latitude in degrees
---
View or change this node's longitude
Usage:
get lonset lon
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.keyset prv.key
Parameters:
private_key: Private key in hex format (64 hex characters)
Serial Only:
get prv.key: Yesset prv.key: No
Note: Requires reboot to take effect after setting
---
Change this node's admin password
Usage:
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.passwordset guest.password
Parameters:
password: Guest password
Set by build flag: ROOM_PASSWORD (Room Server only)
Default:
---
View or change this node's owner info
Usage:
get owner.infoset owner.info
Parameters:
text: Owner information text
Default:
Note: | characters are translated to newlines
Note: Requires firmware 1.12.+
---
Fine-tune the battery reading
Usage:
get adc.multiplierset adc.multiplier
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:
powersavingpowersaving onpowersaving off
Parameters:
on: enable power savingoff: 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 repeatset repeat
Parameters:
state:on|off
Default: on
---
View or change this node's advert path hash size
Usage:
get path.hash.modeset path.hash.mode
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.detectset loop.detect
Parameters:
state:off: no loop detection is performedminimal: 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 txdelayset txdelay
Parameters:
value: Transmit delay factor (0-2)
Default: 0.5
---
View or change the retransmit delay factor for direct traffic
Usage:
get direct.txdelayset direct.txdelay
Parameters:
value: Direct transmit delay factor (0-2)
Default: 0.2
---
[Experimental] View or change the processing delay for received traffic
Usage:
get rxdelayset rxdelay
Parameters:
value: Receive delay base (0-20)
Default: 0.0
---
View or change the duty cycle limit
Usage:
get dutycycleset dutycycle
Parameters:
value: Duty cycle percentage (1-100)
Default: 50% (equivalent to airtime factor 1.0)
Examples:
set dutycycle 100— no duty cycle limitset dutycycle 50— 50% duty cycle (default)set dutycycle 10— 10% duty cycleset dutycycle 1— 1% duty cycle (strictest EU requirement)
Note: Added in firmware v1.15.0
---
View or change the airtime factor (duty cycle limit)
Deprecated as of firmware v1.15.0. Use
get/set dutycycleinstead.
Usage:
get afset af
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% dutyaf = 2→ ~33% dutyaf = 3→ ~25% dutyaf = 9→ ~10% duty
You 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.threshset int.thresh
Parameters:
value: Interference threshold value
Default: 0.0
---
View or change the AGC Reset Interval
Usage:
get agc.reset.intervalset agc.reset.interval
Parameters:
value: Interval in seconds rounded down to a multiple of 4 (17 becomes 16). 0 to disable.
Default: 0.0
---
Enable or disable Multi-Acks support
Usage:
get multi.acksset multi.acks
Parameters:
state:0(disable) or1(enable)
Default: 0
---
View or change the flood advert interval
Usage:
get flood.advert.intervalset flood.advert.interval
Parameters:
hours: Interval in hours (3-168)
Default: 12 (Repeater) - 0 (Sensor)
---
View or change the zero-hop advert interval
Usage:
get advert.intervalset advert.interval
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.maxset flood.max
Parameters:
value: Maximum flood hop count (0-64)
Default: 64
---
ACL
Add, update or remove permissions for a companion
Usage:
setperm
Parameters:
pubkey: Companion public keypermissions:0: Guest1: Read-only2: Read-write3: 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.onlyset allow.read.only
Parameters:
state:on(enable) oroff(disable)
Default: off
---
Region Management (v1.10.+)
Bulk-load region lists
Usage:
region loadregion load [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
Parameters:
name: Region name (or*for wildcard)
Note: Setting on wildcard * allows packets without region transport codes
---
Block a region
Usage:
region denyf
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
Parameters:
name: Region name (or*for wildcard)
---
View or change the home region for this node
Usage:
region homeregion home
Parameters:
name: Region name
---
View or change the default scope region for this node
Usage:
region defaultregion default {name|}
Parameters:
name: Region name, or to reset/clear
---
Create a new region
Usage:
region put [parent_name]
Parameters:
name: Region nameparent_name: Parent region name (optional, defaults to wildcard)
---
Remove a region
Usage:
region remove
Parameters:
name: Region name
Note: Must remove all child regions before the region can be removed
---
View all regions
Usage:
region list
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
#Europewith 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
#Europeregion 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
#NorthAmericahierarchy - 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:
gpsgps
Parameters:
state:on|off
Default: off
Note: Output format:
offwhen the GPS hardware is disabledon, {active|deactivated}, {fix|no fix}, {sat count} satswhen the GPS hardware is 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 advertgps advert
Parameters:
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: =\n
---
View or change thevalue of a sensor
Usage:
sensor getsensor set
Parameters:
key: Sensor setting namevalue: 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.enabledset bridge.enabled
Parameters:
state:on|off
Default: off
---
Add a delay to packets routed through this bridge
Usage:
get bridge.delayset bridge.delay
Parameters:
ms: Delay in milliseconds (0-10000)
Default: 500
---
View or change the source of packets bridged to the external interface
Usage:
get bridge.sourceset bridge.source
Parameters:
source:logRx: bridges received packetslogTx: bridges transmitted packets
Default: logTx
---
View or change the speed of the bridge (RS-232 only)
Usage:
get bridge.baudset bridge.baud
Parameters:
rate: Baud rate (9600,19200,38400,57600, or115200)
Default: 115200
---
View or change the channel used for bridging (ESPNow only)
Usage:
get bridge.channelset bridge.channel
Parameters:
channel: Channel number (1-14)
---
Set the ESP-Now secret
Usage:
get bridge.secretset bridge.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.
---
No comments to display
No comments to display