This document provides an overview of CLI commands that can be sent to MeshCore Repeaters, Room Servers and Sensors.
Usage:
rebootUsage:
clkrebootUsage:
clock syncUsage:
clockUsage:
time <epoch_seconds>Parameters:
epoch_seconds: Unix epoch timeUsage:
advertUsage:
advert.zerohopUsage:
start otaUsage:
eraseSerial Only: Yes
Warning: This is destructive!
Usage:
neighborsNote: The output of this command is limited to the 8 most recent adverts.
Note: Each line is encoded as {pubkey-prefix}:{timestamp}:{snr*4}
Usage:
neighbor.remove <pubkey_prefix>Parameters:
pubkey_prefix: The public key of the node to remove from the neighbors listUsage:
discover.neighborsUsage: clear stats
Usage:
stats-coreSerial Only: Yes
Usage: stats-radio
Serial Only: Yes
Usage: stats-packets
Serial Only: Yes
Usage: log start
Usage: log stop
Usage: log erase
Usage: log
Serial Only: Yes
Usage: ver
Usage: board
Usage:
get radioset radio <freq>,<bw>,<sf>,<cr>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
Usage:
get txset 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.
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
Usage:
get freqset freq <frequency>Parameters:
frequency: Frequency in MHzDefault: 869.525
Note: Requires reboot to apply
Serial Only: set freq <frequency>
Usage:
get radio.rxgainset radio.rxgain <state>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
Usage:
get radio.fem.rxgainset radio.fem.rxgain <state>Parameters:
state: on |
off |
Notes:
radio.rxgain, which controls the radio chip receive gain mode.Usage:
get nameset name <name>Parameters:
name: Node nameSet 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.
Usage:
get latset lat <degrees>Set by build flag: ADVERT_LAT
Default: 0
Parameters:
degrees: Latitude in degreesUsage:
get lonset lon <degrees>Set by build flag: ADVERT_LON
Default: 0
Parameters:
degrees: Longitude in degreesUsage:
get prv.keyset prv.key <private_key>Parameters:
private_key: Private key in hex format (64 hex characters)Serial Only:
get prv.key: Yesset prv.key: NoNote: Requires reboot to take effect after setting
Usage:
password <new_password>Parameters:
new_password: New admin passwordSet 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.
Usage:
get guest.passwordset guest.password <password>Parameters:
password: Guest passwordSet by build flag: ROOM_PASSWORD (Room Server only)
Default: <blank>
Usage:
get owner.infoset owner.info <text>Parameters:
text: Owner information textDefault: <blank>
Note: | characters are translated to newlines
Note: Requires firmware 1.12+
Usage:
get adc.multiplierset 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
Usage: get public.key
Usage: ver
Usage: get role
Usage:
powersavingpowersaving onpowersaving offParameters:
on: enable power savingoff: disable power savingDefault: off
Note: When enabled, device enters sleep mode between radio transmissions
Usage:
get repeatset repeat <state>Parameters:
state: on |
off |
Default: on
Usage:
get path.hash.modeset 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 propagation 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 supported. Consider your install base of firmware >=1.14 has reached a criticality for effective network flooding before implementing higher ID/hash sizes.
Usage:
get loop.detectset loop.detect <state>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 (probably 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.
Usage:
get txdelayset txdelay <value>Parameters:
value: Transmit delay factor (0-2)Default: 0.5
Note: When multiple nearby repeaters all hear the same flood packet, each waits a random amount of time before retransmitting to avoid simultaneous collisions. This factor scales the size of that random window. Higher values reduce collision risk at the cost of added latency. 0 disables the window entirely.
Usage:
get direct.txdelayset direct.txdelay <value>Parameters:
value: Direct transmit delay factor (0-2)Default: 0.2
Note: Same collision-avoidance random window as txdelay, but applied to direct (non-flood, routed) traffic. The default is lower because direct packets are addressed to a specific next hop, so far fewer nodes compete to retransmit them.
Usage:
get rxdelayset rxdelay <value>Parameters:
value: Receive delay base (0-20)Default: 0.0
Note: When enabled, repeaters that received a flood packet with a weak signal are held in a delay queue before processing, while those that received it with a strong signal process it immediately. This gives strong-signal paths forwarding priority. By the time weak-signal nodes process their copy, the packet may have already propagated and will be suppressed as a duplicate, reducing redundant retransmissions.
Usage:
get dutycycleset dutycycle <value>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
Deprecated as of firmware v1.15.0. Use
get/set dutycycleinstead.
Usage:
get afset 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% 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
Usage:
get int.threshset int.thresh <value>Parameters:
value: Interference threshold valueDefault: 0.0
Usage:
get cadset cad <on|off>Description: When enabled, the radio performs a hardware Channel Activity Detection scan before transmitting and defers if the channel is busy. Runs independently of int.thresh — either, both, or none may be active.
Parameters:
on|off: Enable or disable hardware CADDefault: off
Usage:
get agc.reset.intervalset agc.reset.interval <value>Parameters:
value: Interval in seconds rounded down to a multiple of 4 (17 becomes 16). 0 to disable.Default: 0.0
Usage:
get radio.watchdogset radio.watchdog <minutes>Parameters:
minutes: 0 to disable, or 1-120 minutesDefault: 5
Note: On quiet meshes, increasing this can reduce false recoveries when no traffic is expected.
Usage:
get multi.acksset multi.acks <state>Parameters:
state: 0 (disable) or 1 (enable)Default: 0
Usage:
get flood.advert.intervalset flood.advert.interval <hours>Parameters:
hours: Interval in hours (3-168)Default: 12 (Repeater) - 0 (Sensor)
Usage:
get advert.intervalset advert.interval <minutes>Parameters:
minutes: Interval in minutes rounded down to the nearest multiple of 2 (61 becomes 60) (60-240)Default: 0
Usage:
get flood.maxset flood.max <value>Parameters:
value: Maximum flood hop count (0-64)Default: 64
Usage:
get flood.max.unscopedset flood.max.unscoped <value>Parameters:
value: Maximum flood hop count (0-64) for a packet without a scope (no region set)Default: 0xFF - indicates it hasn’t been set, will track flood.max until it is.
Note: An alternative to region denyf *, setting flood.max.unscoped to a lower value such as 3 would allow for local unscoped messages to propagate, while preventing noisy neighbors from flooding a local region.
Usage:
setperm <pubkey> <permissions>Parameters:
pubkey: Companion public keypermissions:
0: Guest1: Read-only2: Read-write3: AdminNote: Removes the entry when permissions is omitted
Usage:
get aclSerial Only: Yes
Usage:
get allow.read.onlyset allow.read.only <state>Parameters:
state: on (enable) or off (disable)Default: off
Usage:
region loadregion load <name> [flood_flag]Parameters:
name: A name of a region. * represents the wildcard regionNote: 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)
Usage:
region saveUsage:
region allowf <name>Parameters:
name: Region name (or * for wildcard)Note: Setting on wildcard * allows packets without region transport codes
Usage:
region denyf <name>Parameters:
name: Region name (or * for wildcard)Note: Setting on wildcard * drops packets without region transport codes
Usage:
region get <name>Parameters:
name: Region name (or * for wildcard)Usage:
region homeregion home <name>Parameters:
name: Region nameUsage:
region defaultregion default {name|<null>}Parameters:
name: Region name, or Usage:
region put <name> [parent_name]Parameters:
name: Region nameparent_name: Parent region name (optional, defaults to wildcard)Note: In firmware v1.15.0 and later, region put enables flooding for that region by default (you do not need a separate region allowf <name> after each put). On v1.14.0 and earlier, new regions may still require region allowf for flooding—see region allowf.
Usage:
region def <token> [<token> ...]Parameters (tokens): Space-separated. A logical cursor starts at the wildcard *.
name — Create name as a child of the current cursor (equivalent to region put name with the cursor as parent). Cursor moves to name.name|jump (or name,jump) — Create name as a child of the current cursor, then move the cursor to jump (must already exist on the node, or have been created earlier in this command). jump is not the parent of name; use this form to pop back up and start another branch.Behavior: Each created region defaults to flood-allowed (same as region put). The reply is the resulting region tree (same format as bare region); review it before running region save to persist. On error, the reply is Err - ... and any regions placed before the failure remain on the node, just like a partial chain of region put.
Existing regions: region def does not clear the existing tree — if a name already exists, its parent is updated to the current cursor; otherwise a new region is created. To start from scratch, region remove the unwanted regions first.
Limits: Repeater serial accepts one line up to 160 characters. For larger trees, split across multiple region def commands; the cursor resets to * between commands, so lead the next command with child|ancestor to reposition. Each token splits at most once on | — region def a|b|c|d is not a flat-list shorthand; see the flat-list example below.
Example — linear chain (each token becomes a child of the previous):
region def a b c d e
region save
Example — branched tree (equivalent to region put a, region put b a, region put c b, region put d c, region put e b, region put f e):
region def a b c d|b e f
region save
Example — error and partial state:
region def a b c|nope d
The reply is Err - unknown jump: nope. a, b, and c were placed before the failure; d was not. Run region to inspect, then re-run with a corrected jump or repair with region remove / region put.
Example — flat list (each region a child of *). Use |* after each token to pop the cursor back to the root before the next token:
region def a|* b|* c|* d|* e|* f
region save
Usage:
region remove <name>Parameters:
name: Region nameNote: Must remove all child regions before the region can be removed
Usage:
region list <filter>Serial Only: Yes
Parameters:
filter: allowed |
denied |
Note: Requires firmware 1.12+
Usage:
regionSerial Only: For firmware older than 1.12.0
Example 1: Using F Flag with Named Public Region
region load
#Europe F
<blank line to end region load>
region save
Explanation:
#Europe with flooding enabledExample 2: Using Wildcard with F Flag
region load
* F
<blank line to end region load>
region save
Explanation:
* with flooding enabledExample 3: Using Wildcard Without F Flag
region load
*
<blank line to end region load>
region save
Explanation:
* without floodingExample 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:
#Europe region with flooding enabled#UK, #France)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:
* with flooding enabled#NorthAmerica hierarchyUsage:
gpsgps <state>Parameters:
state: on |
off |
Default: off
Note: Output format:
off when the GPS hardware is disabledon, {active|deactivated}, {fix|no fix}, {sat count} sats when the GPS hardware is enabledUsage:
gps syncUsage:
gps setlocUsage:
gps advertgps advert <policy>Parameters:
policy: none |
share |
prefs |
none: don’t include location in advertsshare: share gps location (from SensorManager)prefs: location stored in node’s lat and lon settingsDefault: prefs
Usage: sensor list [start]
Parameters:
start: Optional starting index (defaults to 0)Note: Output format: <var_name>=<value>\n
Usage:
sensor get <key>sensor set <key> <value>Parameters:
key: Sensor setting namevalue: The value to set the sensor toUsage: get bridge.type
Usage:
get bridge.enabledset bridge.enabled <state>Parameters:
state: on |
off |
Default: off
Usage:
get bridge.delayset bridge.delay <ms>Parameters:
ms: Delay in milliseconds (0-10000)Default: 500
Usage:
get bridge.sourceset bridge.source <source>Parameters:
source:
logRx: bridges received packetslogTx: bridges transmitted packetsDefault: logTx
Note: For MQTT bridges, use
mqtt.rxandmqtt.txinstead ofbridge.source. These provide independent per-direction control and support both RX and TX simultaneously.bridge.sourcestill works as a convenience alias for MQTT (settingbridge.source rxsetsmqtt.rx on+mqtt.tx off, and vice versa), butmqtt.rx/mqtt.txare preferred.
Usage:
get mqtt.rxset mqtt.rx <on|off>Parameters:
on: uplink received (RX) packets to MQTT brokersoff: disable RX packet uplinkingDefault: on
Usage:
get mqtt.txset mqtt.tx <on|off|advert>Parameters:
on: uplink all transmitted (TX) packets to MQTT brokersadvert: uplink only this node’s own advert packets (self-originated advertisements only — forwarded adverts from other nodes are filtered out)off: disable TX packet uplinkingDefault: advert
Note:
mqtt.rxandmqtt.txtake effect immediately — no restart required. Both can be enabled simultaneously.
MQTT observer builds add WiFi connectivity and MQTT packet uplinking to repeater and room server firmware.
Usage:
set radio 910.525,62.5,7,5
set tx 22
set name MyObserver
set mqtt.iata SEA
set wifi.ssid YourWiFiNetwork
set wifi.pwd YourWiFiPassword
reboot
Optional receive-only observer:
set repeat off
Verify:
get bridge.enabled
get mqtt.rx
get mqtt.tx
get mqtt.origin
get mqtt.iata
get mqtt1.preset
get mqtt2.preset
get mqtt.status
get wifi.status
Usage:
get mqtt.presetsget mqtt.presets <start>Parameters:
start: Optional index returned as next:<idx> when the preset list is paginatedAvailable presets include: analyzer-us, analyzer-eu, meshmapper, meshrank, waev, meshomatic, cascadiamesh, tennmesh, nashmesh, chimesh, meshat.se, eastidahomesh, dutchmeshcore-1, dutchmeshcore-2, coloradomesh, custom, none
Usage:
get mqttN.presetset mqttN.preset <preset>Parameters:
N: Slot number (1-6)preset: Preset name, such as dutchmeshcore-1, dutchmeshcore-2, meshmapper, meshrank, custom, or noneDutchMeshCore presets:
set mqttN.preset dutchmeshcore-1: Use wss://collector1.dutchmeshcore.nl:443/mqttset mqttN.preset dutchmeshcore-2: Use wss://collector2.dutchmeshcore.nl:443/mqttDefault for this firmware: Slot 1 and slot 2 are DutchMeshCore presets. Slot 1 is dutchmeshcore-1, slot 2 is dutchmeshcore-2, and slots 3-6 are none.
Usage:
get mqttN.serverset mqttN.server <hostname-or-url>get mqttN.portset mqttN.port <port>get mqttN.usernameset mqttN.username <username>get mqttN.passwordset mqttN.password <password>get mqttN.tokenset mqttN.token <token>get mqttN.topicset mqttN.topic <template>get mqttN.audienceset mqttN.audience <audience>set mqttN.audienceParameters:
N: Slot number (1-6)port: Port number (1-65535)token: Per-slot token, used by presets such as meshranktemplate: Custom topic template; only applies when the slot preset is customaudience: JWT audience for custom broker Ed25519 JWT authenticationNotes:
custom.set mqttN.audience without a value clears the audience and returns the slot to username/password authentication.Usage:
set mqtt3.preset meshrank
set mqtt3.token <meshrank_token>
Note: MeshRank requires a token and receives packet data only.
Usage:
set mqtt3.preset custom
set mqtt3.server your-broker.example.com
set mqtt3.port 1883
set mqtt3.username your-username
set mqtt3.password your-password
JWT custom broker example:
set mqtt3.preset custom
set mqtt3.server wss://my-broker.example.com:443/mqtt
set mqtt3.port 443
set mqtt3.audience my-broker.example.com
Custom topic example:
set mqtt3.preset custom
set mqtt3.server my-broker.local
set mqtt3.port 1883
set mqtt3.topic mynetwork/{device}/{type}
Topic placeholders:
{iata}: IATA airport code configured by set mqtt.iata{device}: Device public key{token}: Per-slot token from mqttN.token{type}: Message type: status, packets, or rawDefault custom topic: meshcore/{iata}/{device}/{type}
Usage:
get mqtt.originset mqtt.origin <name>get mqtt.iataset mqtt.iata <code>get mqtt.statusset mqtt.status <on|off>get mqtt.packetsset mqtt.packets <on|off>get mqtt.rawset mqtt.raw <on|off>get mqtt.intervalset mqtt.interval <minutes>get mqtt.ownerset mqtt.owner <64-hex-char-public-key>get mqtt.emailset mqtt.email <email>Parameters:
code: IATA airport code; auto-uppercasedminutes: Status publish interval (1-60)Serial Only:
get mqtt.owner: Yesget mqtt.email: YesDefaults:
mqtt.status: onmqtt.packets: onmqtt.raw: offmqtt.interval: 5 minutesUsage:
get wifi.ssidset wifi.ssid <ssid>get wifi.pwdset wifi.pwd <password>get wifi.statusget wifi.powersaveset wifi.powersave <none|min|max>Parameters:
none: No WiFi power savingmin: Minimum WiFi power savingmax: Maximum WiFi power savingDefault: none
Usage:
get timezoneset timezone <string>get timezone.offsetset timezone.offset <offset>Parameters:
string: IANA timezone (Europe/Amsterdam), abbreviation (CET), or UTC offset (UTC+1)offset: Fallback offset in hours (-12 to +14)Usage:
pio run -e Heltec_v3_repeater_observer_mqtt
pio run -e heltec_v4_repeater_observer_mqtt
pio run -e Station_G2_repeater_observer_mqtt
pio run -e LilyGo_TLora_V2_1_1_6_repeater_observer_mqtt
pio run -e LilyGo_TLora_V2_1_1_6_room_server_observer_mqtt
Build flags:
WITH_MQTT_BRIDGE=1: Enable MQTT bridge supportWITH_SNMP=1: Enable optional SNMP monitoring on supported observer buildsSome MQTT observer builds use larger app partitions for MQTT, TLS, and certificate bundle support. When a board’s partition table changes, flash the merged firmware (*-merged.bin) the first time so the bootloader and partition table are written together.
| Environment | Partition table | Flash size | App slot size | Notes |
|---|---|---|---|---|
LilyGo_T3S3_sx1262_repeater_observer_mqtt |
min_spiffs.csv |
4 MB | 1.875 MB | Changed from default |
LilyGo_T3S3_sx1262_room_server_observer_mqtt |
min_spiffs.csv |
4 MB | 1.875 MB | Changed from default |
LilyGo_TLora_V2_1_1_6_repeater_observer_mqtt |
min_spiffs.csv |
4 MB | 1.875 MB | TTGO LoRa32 V1.0; observer env omits sensor_base |
LilyGo_TLora_V2_1_1_6_room_server_observer_mqtt |
min_spiffs.csv |
4 MB | 1.875 MB | Same as repeater observer |
Station_G2_repeater_observer_mqtt |
default_16MB.csv |
16 MB | 6.25 MB | 16 MB flash board |
Station_G2_room_server_observer_mqtt |
default_16MB.csv |
16 MB | 6.25 MB | 16 MB flash board |
Merged firmware example:
pio run -t mergebin -e LilyGo_T3S3_sx1262_repeater_observer_mqtt
esptool.py write_flash 0x0 .pio/build/LilyGo_T3S3_sx1262_repeater_observer_mqtt/firmware-merged.bin
Note: If the partition layout changes, stored settings in NVS are typically wiped or invalidated. Expect to reconfigure admin preferences, WiFi, MQTT slots, device name, and related settings.
| Type | Topic |
|---|---|
| Status | meshcore/{IATA}/{DEVICE_PUBLIC_KEY}/status |
| Packets | meshcore/{IATA}/{DEVICE_PUBLIC_KEY}/packets |
| Raw | meshcore/{IATA}/{DEVICE_PUBLIC_KEY}/raw |
Note: {DEVICE_PUBLIC_KEY} is the device public key as 64 hexadecimal characters.
WiFi issues:
get wifi.ssid
get wifi.pwd
get wifi.status
set wifi.powersave none
reboot
No MQTT messages appearing:
get bridge.enabled
set bridge.enabled on
get mqtt.rx
set mqtt.rx on
get mqtt.tx
get mqtt.status
get mqtt1.preset
get mqtt2.preset
get mqtt.iata
Timezone issues:
get timezone
set timezone Europe/Amsterdam
set timezone.offset 1
Usage:
get bridge.baudset bridge.baud <rate>Parameters:
rate: Baud rate (9600, 19200, 38400, 57600, or 115200)Default: 115200
Usage:
get bridge.channelset bridge.channel <channel>Parameters:
channel: Channel number (1-14)Usage:
get bridge.secretset bridge.secret <secret>Parameters:
secret: ESP-NOW bridge secret, up to 15 charactersDefault: Varies by board
Usage: get bootloader.ver
Usage: get pwrmgt.support
Usage: get pwrmgt.source
Note: Returns an error on boards without power management support.
Usage: get pwrmgt.bootreason
Note: Returns an error on boards without power management support.
Usage: get pwrmgt.bootmv
Note: Returns an error on boards without power management support.
SNMP observer builds expose read-only SNMP v2c monitoring for radio statistics, MQTT connectivity, memory usage, and WiFi RSSI.
Usage:
get snmpset snmp <on|off>Default: off
Note: Restart required after changing.
Usage:
get snmp.communityset snmp.community <string>Default: public
Note: Restart required after changing.
Usage:
snmpwalk -v2c -c public <device-ip> 1.3.6.1.4.1.99999
Note: The SNMP agent listens on UDP port 161 and uses the private enterprise subtree 1.3.6.1.4.1.99999.