Format with prettier

This commit is contained in:
Sacha Weatherstone 2022-03-09 18:51:46 +11:00
parent 7d6338319b
commit f92647ef24
60 changed files with 1261 additions and 1111 deletions

View file

@ -3,6 +3,7 @@ id: clients
title: Clients title: Clients
sidebar_label: Clients sidebar_label: Clients
--- ---
## Overview ## Overview
## Available Clients ## Available Clients

View file

@ -3,4 +3,5 @@ id: overview
title: Meshtastic Concepts title: Meshtastic Concepts
sidebar_label: Concepts Overview sidebar_label: Concepts Overview
--- ---
## Overview ## Overview

View file

@ -4,6 +4,7 @@ title: About Meshtastic
sidebar_label: About Meshtastic sidebar_label: About Meshtastic
slug: /about slug: /about
--- ---
:::info :::info
This section is new and is still being developed. If you'd like to contribute, please do! This section is new and is still being developed. If you'd like to contribute, please do!
::: :::
@ -25,6 +26,7 @@ When a receiving radio captures a packet, it checks to see if it has heard that
For each message a radio rebroadcasts, it marks the "hop limit" down by one. When a radio receives a packet with a hop limit of zero, it will not rebroadcast the message. For each message a radio rebroadcasts, it marks the "hop limit" down by one. When a radio receives a packet with a hop limit of zero, it will not rebroadcast the message.
## Who develops Meshtastic ## Who develops Meshtastic
<!--- FIXME add Github organization list/contributor list ---> <!--- FIXME add Github organization list/contributor list --->
Meshtastic is an open source project available on GitHub. Our generous volunteers donate their personal time to write and maintain this codebase. If you would like to contribute see our [GitHub](https://github.com/meshtastic), join our [Discord server](https://discord.com/invite/UQJ5QuM7vq), and read up on our [forum](https://meshtastic.discourse.group). Meshtastic is an open source project available on GitHub. Our generous volunteers donate their personal time to write and maintain this codebase. If you would like to contribute see our [GitHub](https://github.com/meshtastic), join our [Discord server](https://discord.com/invite/UQJ5QuM7vq), and read up on our [forum](https://meshtastic.discourse.group).

View file

@ -12,9 +12,9 @@ In order to compile a new version of Meshtastic that can use MapBox you will nee
This is fairly simple to do. This is fairly simple to do.
* Create an account at MapBox - Create an account at MapBox
* Copy the public token associated with that account to the clipboard - Copy the public token associated with that account to the clipboard
* Paste that into the file "…/src/main/res/values/mapbox-token.xml" - Paste that into the file "…/src/main/res/values/mapbox-token.xml"
## Examples of what can be achieved with MapBox ## Examples of what can be achieved with MapBox

View file

@ -112,7 +112,7 @@ SoftwareUpdateService UUID cb0b9a0b-a84c-4c0d-bdbb-442e3144ee30
Characteristics Characteristics
| UUID | properties | description | | UUID | properties | description |
| ------------------------------------ | ----------- | ----------------------------------------------------------------------------------------------------------------- | | ------------------------------------ | ----------- | -------------------------------------------------------------------------------------------------------------- |
| e74dd9c0-a301-4a6f-95a1-f0e1dbea8e1e | write,read | total image size, 32 bit, write this first, then read back to see if it was acceptable (0 mean not accepted) | | e74dd9c0-a301-4a6f-95a1-f0e1dbea8e1e | write,read | total image size, 32 bit, write this first, then read back to see if it was acceptable (0 mean not accepted) |
| e272ebac-d463-4b98-bc84-5cc1a39ee517 | write | data, variable sized, recommended 512 bytes, write one for each block of file | | e272ebac-d463-4b98-bc84-5cc1a39ee517 | write | data, variable sized, recommended 512 bytes, write one for each block of file |
| 4826129c-c22a-43a3-b066-ce8f0d5bacc6 | write | crc32, write last - writing this will complete the OTA operation, now you can read result | | 4826129c-c22a-43a3-b066-ce8f0d5bacc6 | write | crc32, write last - writing this will complete the OTA operation, now you can read result |

View file

@ -9,7 +9,7 @@ For any new apps that run on the device or via sister apps on phones/PCs they sh
If you are making a new app using meshtastic, please send in a pull request to add your 'portnum' to this master table. PortNums should be assigned in the following range: If you are making a new app using meshtastic, please send in a pull request to add your 'portnum' to this master table. PortNums should be assigned in the following range:
| Portnum | Usage | | Portnum | Usage |
| --- | --- | | ------- | ---------------------------------------------------------------------------------------------------------------------- |
| 0-63 | Core Meshtastic use, do not use for third party apps | | 0-63 | Core Meshtastic use, do not use for third party apps |
| 64-127 | Registered 3rd party apps, send in a pull request that adds a new entry to portnums.proto to register your application | | 64-127 | Registered 3rd party apps, send in a pull request that adds a new entry to portnums.proto to register your application |
| 256-511 | Use one of these portnums for your private applications that you do not want to register publicly | | 256-511 | Use one of these portnums for your private applications that you do not want to register publicly |

View file

@ -60,7 +60,7 @@ Considerations:
We have six predefined channels. These are the most common settings and have been proven to work well: We have six predefined channels. These are the most common settings and have been proven to work well:
| Channel setting | Alt Channel Name | Data-rate | SF / Symbols | Coding Rate | Bandwidth | Link Budget | | Channel setting | Alt Channel Name | Data-rate | SF / Symbols | Coding Rate | Bandwidth | Link Budget |
| :------------------------- | :--------------- | :------------------- | :----------- | :---------- | :-------- | :---------- | | :------------------ | :--------------- | :------------------ | :----------- | :---------- | :-------- | :---------- |
| Short Range / Fast | Short Fast | 18.89 kbps | 7 / 128 | 4/5 | 500 | 134dB | | Short Range / Fast | Short Fast | 18.89 kbps | 7 / 128 | 4/5 | 500 | 134dB |
| Short Range / Slow | Short Slow | 4.69 kbps | 7 / 128 | 4/5 | 125 | 140dB | | Short Range / Slow | Short Slow | 4.69 kbps | 7 / 128 | 4/5 | 125 | 140dB |
| Medium Range / Fast | Medium Fast | 1.2 kbps | 10 / 1024 | 4/6 | 250 | 146dB | | Medium Range / Fast | Medium Fast | 1.2 kbps | 10 / 1024 | 4/6 | 250 | 146dB |
@ -83,7 +83,7 @@ After applying the settings, you will need to restart the device. After your dev
Some example settings: Some example settings:
| Data-rate | SF / Symbols | Coding Rate | Bandwidth | Link Budget | Note | | Data-rate | SF / Symbols | Coding Rate | Bandwidth | Link Budget | Note |
| :--------- | :----------- | :---------- | :-------- | :---------- | :---------------------------------------------------------------------- | | :--------- | :----------- | :---------- | :-------- | :---------- | :----------------------------------------------------------------------- |
| 37.50 kbps | 6 / 64 | 4/5 | 500 | 129dB | Fastest possible speed | | 37.50 kbps | 6 / 64 | 4/5 | 500 | 129dB | Fastest possible speed |
| 3.125 kbps | 8 / 256 | 4/5 | 125 | 143dB | | | 3.125 kbps | 8 / 256 | 4/5 | 125 | 143dB | |
| 1.953 kbps | 8 / 256 | 4/8 | 125 | 143dB | | | 1.953 kbps | 8 / 256 | 4/8 | 125 | 143dB | |

View file

@ -3,8 +3,11 @@ id: docusaurus
title: Docusaurus title: Docusaurus
sidebar_label: Docusaurus sidebar_label: Docusaurus
--- ---
## Overview ## Overview
Meshtastic's documentation is set up using [Docusaurus](https://docusaurus.io). It is highly encouraged to look at [their documentation](https://docusaurus.io/docs) when looking for a solution to a problem with our docs. They most likely have thought of the use case you've discovered. Meshtastic's documentation is set up using [Docusaurus](https://docusaurus.io). It is highly encouraged to look at [their documentation](https://docusaurus.io/docs) when looking for a solution to a problem with our docs. They most likely have thought of the use case you've discovered.
## Known Issues ## Known Issues
- Admonitions within a `TabItem` component need to be completely unindented to show up correctly. - Admonitions within a `TabItem` component need to be completely unindented to show up correctly.

View file

@ -3,9 +3,12 @@ id: github
title: GitHub title: GitHub
sidebar_label: GitHub sidebar_label: GitHub
--- ---
## Overview ## Overview
All of Meshtastic's code and documentation is hosted on GitHub. If you would like to contribute to the project, having a GitHub account is an important step to doing so. All of Meshtastic's code and documentation is hosted on GitHub. If you would like to contribute to the project, having a GitHub account is an important step to doing so.
## Set up GitHub account ## Set up GitHub account
- Go to [github.com](https://github.com) - Go to [github.com](https://github.com)
- Click `Sign Up` - Click `Sign Up`

View file

@ -3,9 +3,11 @@ id: overview
title: Maintaining Documentation title: Maintaining Documentation
sidebar_label: Maintaining Documentation sidebar_label: Maintaining Documentation
--- ---
Meshtastic documentation is an important ingredient to the overall project. We want users to hit the ground running with the information they need right at their finger tips. This section will discuss the documentation software stack, file organization, and style guides. Meshtastic documentation is an important ingredient to the overall project. We want users to hit the ground running with the information they need right at their finger tips. This section will discuss the documentation software stack, file organization, and style guides.
## Software Stack ## Software Stack
All of our documentation resides on GitHub. Instructions for setting up your GitHub account are located [here](github). All of our documentation resides on GitHub. Instructions for setting up your GitHub account are located [here](github).
Our documentation is powered by [Docusaurus](https://docusaurus.io) — a documentation platform built on React that utilizes markdown files. Because markdown files are easy to edit, most content changes should be fairly simple. Instructions for setting up your instance of Docusaurus are located [here](docusaurus). Our documentation is powered by [Docusaurus](https://docusaurus.io) — a documentation platform built on React that utilizes markdown files. Because markdown files are easy to edit, most content changes should be fairly simple. Instructions for setting up your instance of Docusaurus are located [here](docusaurus).
@ -13,8 +15,9 @@ Our documentation is powered by [Docusaurus](https://docusaurus.io) — a docume
Another component that we use is [Vercel](https://vercel.com) — a platform for frontend frameworks and static sites. Instructions for setting up your instance of Vercel are located [here](vercel). Another component that we use is [Vercel](https://vercel.com) — a platform for frontend frameworks and static sites. Instructions for setting up your instance of Vercel are located [here](vercel).
## Documentation Organization ## Documentation Organization
| Section | File Path | Description | | Section | File Path | Description |
| :-----: | :-------: | :---------: | | :----------------------: | :------------------------------: | :---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
| About Meshtastic | `docs/about` | High level explanation of of Meshtastic. | | About Meshtastic | `docs/about` | High level explanation of of Meshtastic. |
| Meshtastic Software | `docs/software` | Current bulk of documentation running through each Meshtastic project. | | Meshtastic Software | `docs/software` | Current bulk of documentation running through each Meshtastic project. |
| Getting Started | `docs/getting-started` | Instructions on how to get the Meshtastic firmware onto a users device. | | Getting Started | `docs/getting-started` | Instructions on how to get the Meshtastic firmware onto a users device. |
@ -30,20 +33,27 @@ Another component that we use is [Vercel](https://vercel.com) — a platform for
Assuming you have the [prerequisites installed](serve-docs-locally#prerequisites), running a local instance of Docusaurus takes three steps: Assuming you have the [prerequisites installed](serve-docs-locally#prerequisites), running a local instance of Docusaurus takes three steps:
1. Fork/Clone the [meshtastic/Meshtastic](https://github.com/meshtastic/Meshtastic) repository and navigate to the root directory of the project. 1. Fork/Clone the [meshtastic/Meshtastic](https://github.com/meshtastic/Meshtastic) repository and navigate to the root directory of the project.
```bash title="Clone the project" ```bash title="Clone the project"
git clone https://github.com/meshtastic/Meshtastic.git git clone https://github.com/meshtastic/Meshtastic.git
``` ```
```bash title="Clone fork of the project" ```bash title="Clone fork of the project"
git clone https://github.com/[username]/Meshtastic.git git clone https://github.com/[username]/Meshtastic.git
``` ```
```bash title="Change Directory" ```bash title="Change Directory"
cd ~/Meshtastic cd ~/Meshtastic
``` ```
2. Install Dependencies 2. Install Dependencies
```bash title="Install dependencies using Yarn" ```bash title="Install dependencies using Yarn"
yarn install yarn install
``` ```
3. Run Docusaurus 3. Run Docusaurus
```bash title="Run node.js server" ```bash title="Run node.js server"
yarn start yarn start
``` ```
@ -54,4 +64,5 @@ Before submitting a pull request, it's helpful to run the following command to e
```bash title="Build Project" ```bash title="Build Project"
yarn build yarn build
``` ```
::: :::

View file

@ -3,16 +3,20 @@ id: serve-docs-locally
title: Setting up Local Documentation title: Setting up Local Documentation
sidebar_label: Serve Docs Locally sidebar_label: Serve Docs Locally
--- ---
:::note :::note
Some things won't display properly like logos or protobufs, this is not cause for concern. Some things won't display properly like logos or protobufs, this is not cause for concern.
::: :::
## Prerequisites ## Prerequisites
In order to set up your local environment, you will need to install: In order to set up your local environment, you will need to install:
- [Node & Node package manager (NPM)](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm) - [Node & Node package manager (NPM)](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm)
- [Yarn package manager](https://yarnpkg.com/getting-started/install) - [Yarn package manager](https://yarnpkg.com/getting-started/install)
## Getting Started ## Getting Started
### Fork the Meshtastic Repository ### Fork the Meshtastic Repository
Log into Github and create a fork of the [meshtastic/Meshtastic](https://github.com/meshtastic/Meshtastic) repository. Log into Github and create a fork of the [meshtastic/Meshtastic](https://github.com/meshtastic/Meshtastic) repository.
@ -28,16 +32,19 @@ git clone https://github.com/username/Meshtastic.git
``` ```
### Change directory to Local copy ### Change directory to Local copy
```bash title="Change Directory" ```bash title="Change Directory"
cd ~/Meshtastic cd ~/Meshtastic
``` ```
### Install Dependencies ### Install Dependencies
```bash title="Install dependencies using Yarn" ```bash title="Install dependencies using Yarn"
yarn install yarn install
``` ```
### Run Development Server ### Run Development Server
```bash title="Run node.js server" ```bash title="Run node.js server"
yarn start yarn start
``` ```
@ -48,4 +55,5 @@ Before submitting a pull request, it's helpful to run the following command to e
```bash title="Build Project" ```bash title="Build Project"
yarn build yarn build
``` ```
::: :::

View file

@ -3,21 +3,25 @@ id: style-guide-settings
title: Style Guide - Settings Pages title: Style Guide - Settings Pages
sidebar_label: Settings Pages sidebar_label: Settings Pages
--- ---
## Overview ## Overview
Setting pages should focus solely on settings and configuring the device. Hardware is often a related topic, however these pages should not attempt to explain attaching hardware. Mention that hardware is required and link to the appropriate page(s). Setting pages should focus solely on settings and configuring the device. Hardware is often a related topic, however these pages should not attempt to explain attaching hardware. Mention that hardware is required and link to the appropriate page(s).
## Layout ## Layout
### Overview ### Overview
This section should describe the group of settings and what they do for the device. This section should describe the group of settings and what they do for the device.
### Settings ### Settings
This section starts with an alphabetized table of settings, available values, and default values. This section starts with an alphabetized table of settings, available values, and default values.
Available values should be listed with tick marks `` surrounding the value. Available values should be listed with tick marks `` surrounding the value.
| Value Type | Example | | Value Type | Example |
| :--------: | :-----: | | :--------: | :-------------------------: |
| Boolean | `true`, `false` | | Boolean | `true`, `false` |
| List | `apple`, `banana`, `orange` | | List | `apple`, `banana`, `orange` |
| Range | `0`-`100` | | Range | `0`-`100` |
@ -25,19 +29,24 @@ Available values should be listed with tick marks `` surrounding the value.
After the table each setting is described in brief detail. If the available options for a setting need additional explanation, a table should be used to describe each available option. After the table each setting is described in brief detail. If the available options for a setting need additional explanation, a table should be used to describe each available option.
### Details ### Details
If additional details are needed, this optional section can explain that. These would include prerequisites, links to hardware guides, etc. If additional details are needed, this optional section can explain that. These would include prerequisites, links to hardware guides, etc.
### Examples ### Examples
This optional section can have examples of configurations needed where multiple settings are required to be set up for a specific use case. This optional section can have examples of configurations needed where multiple settings are required to be set up for a specific use case.
## Example Template ## Example Template
```markdown title="Template for Settings Pages" ```markdown title="Template for Settings Pages"
--- ---
id: unique-id id: unique-id
title: Title for Page title: Title for Page
sidebar_label: Label for Sidebar sidebar_label: Label for Sidebar
--- ---
<!--- Allows client-specific tabs to be used ---> <!--- Allows client-specific tabs to be used --->
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -48,22 +57,27 @@ import TabItem from '@theme/TabItem';
## Settings ## Settings
<!--- Table of settings in alphabetical order ---> <!--- Table of settings in alphabetical order --->
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :---------------------: | :-------------------------: | :-----: |
| my_setting_with_options | `apple`, `banana`, `orange` | `apple` | | my_setting_with_options | `apple`, `banana`, `orange` | `apple` |
<!--- H3 for each setting above (alphabetized) ---> <!--- H3 for each setting above (alphabetized) --->
### my_setting_with_options ### my_setting_with_options
<!--- description for what the setting does ---> <!--- description for what the setting does --->
<!--- if the setting has many options, insert a table describing what those variables do ---> <!--- if the setting has many options, insert a table describing what those variables do --->
| Value | Description | | Value | Description |
| :---: | :---------: | | :------: | :----------------------------: |
| `apple` | Description of apple (default) | | `apple` | Description of apple (default) |
| `banana` | Description of banana | | `banana` | Description of banana |
| `orange` | Description of orange | | `orange` | Description of orange |
<!--- Client tabs that were imported above ---> <!--- Client tabs that were imported above --->
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -88,8 +102,10 @@ import TabItem from '@theme/TabItem';
</Tabs> </Tabs>
## Details ## Details
<!--- Additional details about the settings IF NEEDED otherwise delete this h2 header ---> <!--- Additional details about the settings IF NEEDED otherwise delete this h2 header --->
## Examples ## Examples
<!--- Meant for examples where multiple settings are configured at the same time (WiFi type/SSID/password in a single command). If not needed, delete this h2 header ---> <!--- Meant for examples where multiple settings are configured at the same time (WiFi type/SSID/password in a single command). If not needed, delete this h2 header --->
``` ```

View file

@ -3,7 +3,9 @@ id: vercel
title: Vercel title: Vercel
sidebar_label: Vercel sidebar_label: Vercel
--- ---
## Overview ## Overview
Setting up a Vercel account is an optional step that can help you view your changes to the documentation in a server environment just like the actual docs. This can be helpful to include when submitting a pull request so that developers can review your changes and visually check that things look correct. Setting up a Vercel account is an optional step that can help you view your changes to the documentation in a server environment just like the actual docs. This can be helpful to include when submitting a pull request so that developers can review your changes and visually check that things look correct.
## Set up Vercel account ## Set up Vercel account

View file

@ -3,4 +3,5 @@ id: antenna
title: FAQs - Antenna title: FAQs - Antenna
sidebar_label: Antenna sidebar_label: Antenna
--- ---
## Overview ## Overview

View file

@ -3,6 +3,7 @@ id: channel
title: FAQs - Channel title: FAQs - Channel
sidebar_label: Channel sidebar_label: Channel
--- ---
## Overview ## Overview
### What is a Meshtastic Channel? ### What is a Meshtastic Channel?

View file

@ -3,6 +3,7 @@ id: client-android
title: FAQs - Android title: FAQs - Android
sidebar_label: Android sidebar_label: Android
--- ---
## Overview ## Overview
### What versions of Android does the Meshtastic Android App require? ### What versions of Android does the Meshtastic Android App require?

View file

@ -3,6 +3,7 @@ id: client-python-cli
title: FAQs - CLI title: FAQs - CLI
sidebar_label: CLI sidebar_label: CLI
--- ---
## Overview ## Overview
### How do I find out more about installing (and using) Meshtastic via command line? ### How do I find out more about installing (and using) Meshtastic via command line?

View file

@ -3,6 +3,7 @@ id: client-web
title: FAQs - Web title: FAQs - Web
sidebar_label: Web sidebar_label: Web
--- ---
## Overview ## Overview
### How do I access the network from my web browser? ### How do I access the network from my web browser?

View file

@ -3,4 +3,5 @@ id: mesh
title: FAQs - Mesh title: FAQs - Mesh
sidebar_label: Mesh sidebar_label: Mesh
--- ---
## Overview ## Overview

View file

@ -3,4 +3,5 @@ id: mqtt
title: FAQs - MQTT title: FAQs - MQTT
sidebar_label: MQTT sidebar_label: MQTT
--- ---
## Overview ## Overview

View file

@ -3,6 +3,7 @@ id: wifi
title: FAQs - WiFi title: FAQs - WiFi
sidebar_label: WiFi sidebar_label: WiFi
--- ---
## Overview ## Overview
### How do I turn on the WiFI radio? ### How do I turn on the WiFI radio?

View file

@ -3,7 +3,8 @@ id: clients
title: Meshtastic Clients title: Meshtastic Clients
sidebar_label: Meshtastic Clients sidebar_label: Meshtastic Clients
--- ---
import { DownloadCard } from '/src/pages/downloads/_components/DownloadCard.tsx'
import { DownloadCard } from '/src/pages/downloads/\_components/DownloadCard.tsx'
## Overview ## Overview
@ -20,14 +21,17 @@ To install/upgrade Meshtastic-python manually, see below:
```bash title="Install Meshtastic-python (includes CLI)" ```bash title="Install Meshtastic-python (includes CLI)"
pip install meshtastic pip install meshtastic
``` ```
```bash title="Upgrade Meshtastic-python (includes CLI)" ```bash title="Upgrade Meshtastic-python (includes CLI)"
pip install --upgrade meshtastic pip install --upgrade meshtastic
``` ```
:::note :::note
Some installations of python may require you to substitute 'pip3' for the 'pip' command. Some installations of python may require you to substitute 'pip3' for the 'pip' command.
::: :::
### Mobile Client Downloads ### Mobile Client Downloads
<ul <ul
style={{ style={{
position: "relative", position: "relative",

View file

@ -3,6 +3,7 @@ id: first-steps
title: First Steps title: First Steps
sidebar_label: First Steps sidebar_label: First Steps
--- ---
## Overview ## Overview
Congratulations! Your node should now be running Meshtastic and hopefully you've paired to a client on your mobile device, desktop, or browser. Congratulations! Your node should now be running Meshtastic and hopefully you've paired to a client on your mobile device, desktop, or browser.

View file

@ -3,6 +3,7 @@ id: flashing-firmware
title: Firmware Flashing Prerequisites title: Firmware Flashing Prerequisites
sidebar_label: Prerequisites sidebar_label: Prerequisites
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -146,7 +147,6 @@ With the latest versions of MacOS, the USB Serial driver is built-in. Do _NOT_ d
::: :::
</TabItem> </TabItem>
<TabItem value="windows"> <TabItem value="windows">

View file

@ -4,6 +4,7 @@ title: Getting Started
sidebar_label: Getting Started sidebar_label: Getting Started
slug: /getting-started slug: /getting-started
--- ---
import Link from '@docusaurus/Link'; import Link from '@docusaurus/Link';
## What is Meshtastic? ## What is Meshtastic?

View file

@ -4,6 +4,7 @@ title: Using Meshtastic Flasher
sidebar_label: Using Meshtastic Flasher sidebar_label: Using Meshtastic Flasher
pagination_next: getting-started/clients pagination_next: getting-started/clients
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -56,6 +57,7 @@ Navigate to `Device Manager > Ports (COM & LPT)`. You should see something like
</Tabs> </Tabs>
### Install using `pip` ### Install using `pip`
<Tabs <Tabs
groupId="operating-system" groupId="operating-system"
defaultValue="linux" defaultValue="linux"
@ -138,9 +140,9 @@ The Meshtastic Flasher will flash the latest firmware to esp32 and nrf52 devices
There are three steps: There are three steps:
* Click the "GET VERSIONS" button to get the versions available (from GitHub). - Click the "GET VERSIONS" button to get the versions available (from GitHub).
* Click the "DETECT DEVICE" button to determine the port and device variant connected. - Click the "DETECT DEVICE" button to determine the port and device variant connected.
* Click the "FLASH" button to flash the version selected, using the port selected to the device. - Click the "FLASH" button to flash the version selected, using the port selected to the device.
## Issues? ## Issues?
@ -152,6 +154,6 @@ The code can be found at the [Meshtastic-gui-installer repo](https://github.com/
The following are known limitations: The following are known limitations:
* Raspberry Pi is not available, since it is arm-based and there are no pre-built libraries for [PySide](https://wiki.qt.io/Qt_for_Python) - Raspberry Pi is not available, since it is arm-based and there are no pre-built libraries for [PySide](https://wiki.qt.io/Qt_for_Python)
* Ubuntu 20.04 is the version used for testing, it may work with other versions - Ubuntu 20.04 is the version used for testing, it may work with other versions
* see [README](https://github.com/meshtastic/Meshtastic-gui-installer/blob/master/README.md) for more details - see [README](https://github.com/meshtastic/Meshtastic-gui-installer/blob/master/README.md) for more details

View file

@ -10,6 +10,7 @@ The stock aerials provided bundled with the t-Beam and other boards are a 'mixed
Matching an aerial to the transceiver frequency is important, as is choosing an appropriate design. Matching an aerial to the transceiver frequency is important, as is choosing an appropriate design.
The aerial's design will affect: The aerial's design will affect:
- proportion of the signal which leaves the aerial (efficiency), - proportion of the signal which leaves the aerial (efficiency),
- directions in which it's transmitted, - directions in which it's transmitted,
- whether it will be affected by horizontal or vertical polarization, - whether it will be affected by horizontal or vertical polarization,
@ -41,6 +42,6 @@ While the LoRa devices we are using for Meshtastic are relatively low power radi
## Terminology / references ## Terminology / references
You could do a lot worse than reading the [Wikipedia entry for Antenna](https://en.wikipedia.org/wiki/Antenna_(radio)), along with the [Wikipedia entry for LoRa](https://en.wikipedia.org/wiki/LoRa). You could do a lot worse than reading the [Wikipedia entry for Antenna](<https://en.wikipedia.org/wiki/Antenna_(radio)>), along with the [Wikipedia entry for LoRa](https://en.wikipedia.org/wiki/LoRa).
Instead of listing the terms, let us recommend this superb [tutorial](https://www.youtube.com/watch?v=J3PBL9oLPX8) by Andreas Spiess (the 'guy with the Swiss accent'). Instead of listing the terms, let us recommend this superb [tutorial](https://www.youtube.com/watch?v=J3PBL9oLPX8) by Andreas Spiess (the 'guy with the Swiss accent').

View file

@ -6,6 +6,7 @@ slug: /hardware/non-aerial
--- ---
Unless you're using your devices in a vacuum, with clear line of sight between aerials the following will have an effect: Unless you're using your devices in a vacuum, with clear line of sight between aerials the following will have an effect:
- Weather (temperature, humidity, and air pressure), - Weather (temperature, humidity, and air pressure),
- Transmission power, bandwidth, spreading factor, and other associated channel factors, - Transmission power, bandwidth, spreading factor, and other associated channel factors,
- Number of nodes within reach of the mesh (affects retries consequent duty cycle hit), - Number of nodes within reach of the mesh (affects retries consequent duty cycle hit),
@ -17,6 +18,7 @@ Unless you're using your devices in a vacuum, with clear line of sight between a
### Environmental factors ### Environmental factors
For a bit of light reading on environmental research: For a bit of light reading on environmental research:
- [RF attenuation in vegetation](https://web.archive.org/web/20201216041455/https://www.itu.int/dms_pubrec/itu-r/rec/p/R-REC-P.833-9-201609-I!!PDF-E.pdf) (yes really); if you wander through the woods wondering how your RF is bouncing off leaves dependent on their variety, and wind speed … well you do, now. - [RF attenuation in vegetation](https://web.archive.org/web/20201216041455/https://www.itu.int/dms_pubrec/itu-r/rec/p/R-REC-P.833-9-201609-I!!PDF-E.pdf) (yes really); if you wander through the woods wondering how your RF is bouncing off leaves dependent on their variety, and wind speed … well you do, now.
- [RF attenuation with various building materials](https://www.ofcom.org.uk/__data/assets/pdf_file/0016/84022/building_materials_and_propagation.pdf). - [RF attenuation with various building materials](https://www.ofcom.org.uk/__data/assets/pdf_file/0016/84022/building_materials_and_propagation.pdf).
- This one by ITU again is very detailed in its [analysis of the drivers of attenuation](https://web.archive.org/web/20211005174833/https://www.itu.int/dms_pubrec/itu-r/rec/p/R-REC-P.2040-1-201507-I!!PDF-E.pdf) (I wasnt aware that all EMF radiation exhibits reflection / transmission characteristics akin to light hitting a material boundary. So, depending on the angle of incidence, material and the EMF wavelength, it will be reflected and / or transmitted through). - This one by ITU again is very detailed in its [analysis of the drivers of attenuation](https://web.archive.org/web/20211005174833/https://www.itu.int/dms_pubrec/itu-r/rec/p/R-REC-P.2040-1-201507-I!!PDF-E.pdf) (I wasnt aware that all EMF radiation exhibits reflection / transmission characteristics akin to light hitting a material boundary. So, depending on the angle of incidence, material and the EMF wavelength, it will be reflected and / or transmitted through).

View file

@ -19,6 +19,7 @@ The following ESP32 devices are supported:
:::caution :::caution
Supported but not encouraged: Supported but not encouraged:
- Lilygo TTGO T-Beam - version 0.7 -- Very old, no power management chip, difficulty with GPS module and is freqeuntly confused with other devices. - Lilygo TTGO T-Beam - version 0.7 -- Very old, no power management chip, difficulty with GPS module and is freqeuntly confused with other devices.
::: :::

View file

@ -21,7 +21,6 @@ sidebar_label: LILYGO® Lora
[<img alt="LILYGO® TTGO Lora V1" src="/img/hardware/lora-v1.png" style={{zoom:'25%'}} />](/img/hardware/lora-v1.png) [<img alt="LILYGO® TTGO Lora V1" src="/img/hardware/lora-v1.png" style={{zoom:'25%'}} />](/img/hardware/lora-v1.png)
## Lora V1.3 ## Lora V1.3
- ESP32 - Wifi & Bluetooth - ESP32 - Wifi & Bluetooth
@ -59,7 +58,6 @@ sidebar_label: LILYGO® Lora
[<img alt="LILYGO® TTGO Lora V2" src="/img/hardware/lora-v2.0.png" style={{zoom:'25%'}} />](/img/hardware/lora-v2.0.png) [<img alt="LILYGO® TTGO Lora V2" src="/img/hardware/lora-v2.0.png" style={{zoom:'25%'}} />](/img/hardware/lora-v2.0.png)
## Lora V2.1-1.6 ## Lora V2.1-1.6
- ESP32 - Wifi & Bluetooth - ESP32 - Wifi & Bluetooth

View file

@ -24,7 +24,6 @@ sidebar_label: LILYGO® T-Beam
[<img alt="LILYGO® TTGO T-Beam Meshtastic" src="/img/hardware/t-beam-meshtastic.png" style={{zoom:'25%'}} />](/img/hardware/t-beam-meshtastic.png) [<img alt="LILYGO® TTGO T-Beam Meshtastic" src="/img/hardware/t-beam-meshtastic.png" style={{zoom:'25%'}} />](/img/hardware/t-beam-meshtastic.png)
## T-Beam - v0.7 ## T-Beam - v0.7
:::note :::note
@ -50,7 +49,6 @@ This is an earlier version of the T-Beam board, and due to changes in the design
[<img alt="LILYGO TTGO T-Beam v0.7" src="/img/hardware/t-beam-v0.7.png" style={{zoom:'25%'}} />](/img/hardware/t-beam-v0.7.png) [<img alt="LILYGO TTGO T-Beam v0.7" src="/img/hardware/t-beam-v0.7.png" style={{zoom:'25%'}} />](/img/hardware/t-beam-v0.7.png)
[<img alt="LILYGO TTGO T-Beam v0.7 pinmap" src="/img/hardware/t-beam_v0.7_pinmap.jpeg" style={{zoom:'25%'}} />](/img/hardware/t-beam_v0.7_pinmap.jpeg) [<img alt="LILYGO TTGO T-Beam v0.7 pinmap" src="/img/hardware/t-beam_v0.7_pinmap.jpeg" style={{zoom:'25%'}} />](/img/hardware/t-beam_v0.7_pinmap.jpeg)
## T-Beam - V1.1 ## T-Beam - V1.1
- ESP32 - Wifi & Bluetooth - ESP32 - Wifi & Bluetooth
@ -71,7 +69,6 @@ This is an earlier version of the T-Beam board, and due to changes in the design
[<img alt="LILYGO® TTGO T-Beam v1.1" src="/img/hardware/t-beam-v1.1.png" style={{zoom:'35%'}} />](/img/hardware/t-beam-v1.1.png) [<img alt="LILYGO® TTGO T-Beam v1.1" src="/img/hardware/t-beam-v1.1.png" style={{zoom:'35%'}} />](/img/hardware/t-beam-v1.1.png)
[<img alt="LILYGO® TTGO T-Beam v1.1 pinmap" src="/img/hardware/t-beam_v1.1_pinmap.webp" style={{zoom:'35%'}} />](/img/hardware/t-beam_v1.1_pinmap.webp) [<img alt="LILYGO® TTGO T-Beam v1.1 pinmap" src="/img/hardware/t-beam_v1.1_pinmap.webp" style={{zoom:'35%'}} />](/img/hardware/t-beam_v1.1_pinmap.webp)
## T-Beam - M8N ## T-Beam - M8N
- ESP32 - Wifi & Bluetooth - ESP32 - Wifi & Bluetooth

View file

@ -3,6 +3,7 @@ id: licensing
title: Licensing & Commercial Projects Usage title: Licensing & Commercial Projects Usage
sidebar_label: Licensing sidebar_label: Licensing
--- ---
You are hereby granted a two-year non-exclusive license to use the Meshtastic® logo and trademark on your product/project. No fee is required for this usage, though if you wish keeping $1/unit set-aside so that it can eventually fund [meshtastic.org](https://meshtastic.org) it would be appreciated. You are hereby granted a two-year non-exclusive license to use the Meshtastic® logo and trademark on your product/project. No fee is required for this usage, though if you wish keeping $1/unit set-aside so that it can eventually fund [meshtastic.org](https://meshtastic.org) it would be appreciated.
We only ask that you include a line in your support text that states: We only ask that you include a line in your support text that states:

View file

@ -4,12 +4,13 @@ title: Legal
sidebar_label: Legal sidebar_label: Legal
slug: /legal slug: /legal
--- ---
## Disclaimers ## Disclaimers
This project is still pretty young but moving at a pretty good pace. Not all features are fully implemented in the current alpha builds. This project is still pretty young but moving at a pretty good pace. Not all features are fully implemented in the current alpha builds.
* We don't make these devices and they haven't been tested by UL or the FCC. If you use them, you are experimenting and we can't promise they won't burn your house down ;-) - We don't make these devices and they haven't been tested by UL or the FCC. If you use them, you are experimenting and we can't promise they won't burn your house down ;-)
* The encryption implementation is good but see this list of [caveats](/docs/developers/device/encryption#summary-of-strengthsweaknesses-of-our-current-implementation) to determine risks you might face. - The encryption implementation is good but see this list of [caveats](/docs/developers/device/encryption#summary-of-strengthsweaknesses-of-our-current-implementation) to determine risks you might face.
## Legal FAQ ## Legal FAQ

View file

@ -3,4 +3,5 @@ id: trademark
title: Trademark Rules & Brand Guidelines title: Trademark Rules & Brand Guidelines
sidebar_label: Trademark sidebar_label: Trademark
--- ---
Meshtastic® is a registered trademark of Geeksville Industries LLC. Meshtastic software components are released under various licenses, see GitHub for details. No warranty is provided - use at your own risk. Meshtastic® is a registered trademark of Geeksville Industries LLC. Meshtastic software components are released under various licenses, see GitHub for details. No warranty is provided - use at your own risk.

View file

@ -3,6 +3,7 @@ id: channel-advanced
title: Channel Settings - Advanced title: Channel Settings - Advanced
sidebar_label: Channel sidebar_label: Channel
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -17,7 +18,7 @@ Most users should not need to change these settings. The default [modem_config](
## Settings ## Settings
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :--------------: | :------------------------------------------------------------------------------------------------: | :---------------------------: |
| bandwidth | `10.4`, `15.6`, `20.8`, `31.25`, `41.7`, `62.5`, `125`, `250`, `500` | `125` | | bandwidth | `10.4`, `15.6`, `20.8`, `31.25`, `41.7`, `62.5`, `125`, `250`, `500` | `125` |
| channel_num | Depends on Region | Region Channel Number Default | | channel_num | Depends on Region | Region Channel Number Default |
| coding_rate | `5`, `6`, `7`, `8` | `5` | | coding_rate | `5`, `6`, `7`, `8` | `5` |
@ -276,6 +277,7 @@ Ensure that you are not exceeding your country's regulations.
```bash title="Set Default" ```bash title="Set Default"
meshtastic --ch-set tx_power 0 --ch-index 0 meshtastic --ch-set tx_power 0 --ch-index 0
``` ```
```bash title="Set to 2dBM" ```bash title="Set to 2dBM"
meshtastic --ch-set tx_power 2 --ch-index 0 meshtastic --ch-set tx_power 2 --ch-index 0
``` ```

View file

@ -3,6 +3,7 @@ id: gps
title: GPS Settings title: GPS Settings
sidebar_label: GPS sidebar_label: GPS
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -17,7 +18,7 @@ GPS is provided by either the device or your paired phone. More than likely, you
## Settings ## Settings
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :----------------------: | :-----------------------------------------------------------------------------------------------------------------------------------------------------------: | :-------------: |
| fixed_position | `true`, `false` | `false` | | fixed_position | `true`, `false` | `false` |
| gps_accept_2d | `true`, `false` | `false` | | gps_accept_2d | `true`, `false` | `false` |
| gps_attempt_time | `integer` (seconds) | `0` (see note) | | gps_attempt_time | `integer` (seconds) | `0` (see note) |
@ -43,6 +44,7 @@ If you wish to disable any GPS features, see below for more information.
If set, this node is at a fixed position. The device will generate GPS updates at the regular `gps_update_interval`, but use whatever the last lat/lon/alt it saved for the node. The lat/lon/alt can be set by an internal GPS or with the help of the mobile device's GPS. If set, this node is at a fixed position. The device will generate GPS updates at the regular `gps_update_interval`, but use whatever the last lat/lon/alt it saved for the node. The lat/lon/alt can be set by an internal GPS or with the help of the mobile device's GPS.
#### Set/Unset Fixed Position #### Set/Unset Fixed Position
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -57,15 +59,19 @@ If set, this node is at a fixed position. The device will generate GPS updates a
```bash title="Set Fixed Position - Current Location" ```bash title="Set Fixed Position - Current Location"
meshtastic --set fixed_position true meshtastic --set fixed_position true
``` ```
:::note :::note
The device will continue to acquire GPS coordinates according to the `gps_update_interval`, but will use the last saved coordinates as its fixed point. The device will continue to acquire GPS coordinates according to the `gps_update_interval`, but will use the last saved coordinates as its fixed point.
::: :::
```bash title="Set Fixed Position - User Defined" ```bash title="Set Fixed Position - User Defined"
meshtastic --setlat 37.8651 --setlon -119.5383 meshtastic --setlat 37.8651 --setlon -119.5383
``` ```
```bash title="Unset Fixed Position" ```bash title="Unset Fixed Position"
meshtastic --set fixed_position false meshtastic --set fixed_position false
``` ```
:::note :::note
It may take some time to see that the change has taken effect. The GPS location is updated according to the value specified on `gps_update_interval` and the mesh will be notified of the new position in relation to the `position_broadcast_secs` value. It may take some time to see that the change has taken effect. The GPS location is updated according to the value specified on `gps_update_interval` and the mesh will be notified of the new position in relation to the `position_broadcast_secs` value.
::: :::
@ -98,6 +104,7 @@ Configuring this setting is not yet available for the selected platform. If this
Determines whether the device should accept 2D GPS fixes. By default, only 3D fixes are accepted (during a 2D fix, altitude values are unreliable and will be excluded). Determines whether the device should accept 2D GPS fixes. By default, only 3D fixes are accepted (during a 2D fix, altitude values are unreliable and will be excluded).
#### Enable/Disable 2D GPS Fixes #### Enable/Disable 2D GPS Fixes
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -112,6 +119,7 @@ Determines whether the device should accept 2D GPS fixes. By default, only 3D fi
```bash title="Enable 2D GPS Fixes" ```bash title="Enable 2D GPS Fixes"
meshtastic --set gps_accept_2d true meshtastic --set gps_accept_2d true
``` ```
```bash title="Disable 2D GPS Fixes" ```bash title="Disable 2D GPS Fixes"
meshtastic --set gps_accept_2d false meshtastic --set gps_accept_2d false
``` ```
@ -145,6 +153,7 @@ Configuring this setting is not yet available for the selected platform. If this
Determines the amount of time that a GPS fix should be allowed to take. The default is every 30 seconds. If you increase this value, it will allow the device that amount of time in seconds to acquire coordinates. If the device is unable to get a fix, it will turn off until the next interval. GPS coordinates are updated every [`gps_update_interval`](#gps_update_interval) seconds. Determines the amount of time that a GPS fix should be allowed to take. The default is every 30 seconds. If you increase this value, it will allow the device that amount of time in seconds to acquire coordinates. If the device is unable to get a fix, it will turn off until the next interval. GPS coordinates are updated every [`gps_update_interval`](#gps_update_interval) seconds.
#### Change GPS attempt time frequency #### Change GPS attempt time frequency
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -159,6 +168,7 @@ Determines the amount of time that a GPS fix should be allowed to take. The defa
```bash title="Set GPS attempt time to default (30 seconds)" ```bash title="Set GPS attempt time to default (30 seconds)"
meshtastic --set gps_attempt_time 0 meshtastic --set gps_attempt_time 0
``` ```
```bash title="Set GPS attempt time to 45 seconds" ```bash title="Set GPS attempt time to 45 seconds"
meshtastic --set gps_attempt_time 45 meshtastic --set gps_attempt_time 45
``` ```
@ -192,7 +202,7 @@ Configuring this setting is not yet available for the selected platform. If this
Determines how the GPS coordinates are displayed on the OLED screen. Determines how the GPS coordinates are displayed on the OLED screen.
| Value | Description | | Value | Description |
| :---: | :---------: | | :-----------: | :----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
| GpsFormatDec | GPS coordinates are displayed in the normal decimal degrees format: DD.DDDDDD DDD.DDDDDD | | GpsFormatDec | GPS coordinates are displayed in the normal decimal degrees format: DD.DDDDDD DDD.DDDDDD |
| GpsFormatDMS | GPS coordinates are displayed in the degrees minutes seconds format: DD°MM'SS"C DDD°MM'SS"C, where C is the compass point representing the locations quadrant | | GpsFormatDMS | GPS coordinates are displayed in the degrees minutes seconds format: DD°MM'SS"C DDD°MM'SS"C, where C is the compass point representing the locations quadrant |
| GpsFormatUTM | GPS coordinates are displayed in Universal Transverse Mercator format: ZZB EEEEEE NNNNNNN, where Z is zone, B is band, E is easting, N is northing | | GpsFormatUTM | GPS coordinates are displayed in Universal Transverse Mercator format: ZZB EEEEEE NNNNNNN, where Z is zone, B is band, E is easting, N is northing |
@ -201,6 +211,7 @@ Determines how the GPS coordinates are displayed on the OLED screen.
| GpsFormatOSGR | GPS coordinates are displayed in Ordnance Survey Grid Reference (the National Grid System of the UK). Format: AB EEEEE NNNNN, where A is the east 100k square, B is the north 100k square, E is the easting, N is the northing | | GpsFormatOSGR | GPS coordinates are displayed in Ordnance Survey Grid Reference (the National Grid System of the UK). Format: AB EEEEE NNNNN, where A is the east 100k square, B is the north 100k square, E is the easting, N is the northing |
#### Specify GPS Screen Display #### Specify GPS Screen Display
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -245,6 +256,7 @@ Configuring this setting is not yet available for the selected platform. If this
Determines GPS maximum DOP accepted (dilution of precision) Set a rejection threshold for GPS readings based on their precision, relative to the GPS rated accuracy (which is typically ~3m) Solutions above this value will be treated as retryable errors! Useful range is between 1 - 64 (3m - <~200m) By default (if zero), accept all GPS readings Determines GPS maximum DOP accepted (dilution of precision) Set a rejection threshold for GPS readings based on their precision, relative to the GPS rated accuracy (which is typically ~3m) Solutions above this value will be treated as retryable errors! Useful range is between 1 - 64 (3m - <~200m) By default (if zero), accept all GPS readings
#### Change maximum GPS dilution of precision #### Change maximum GPS dilution of precision
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -259,9 +271,11 @@ Determines GPS maximum DOP accepted (dilution of precision) Set a rejection thre
```bash title="Set GPS max DOP to default (accept all GPS readings)" ```bash title="Set GPS max DOP to default (accept all GPS readings)"
meshtastic --set gps_max_dop 0 meshtastic --set gps_max_dop 0
``` ```
```bash title="Set GPS max DOP to 3m" ```bash title="Set GPS max DOP to 3m"
meshtastic --set gps_max_dop 1 meshtastic --set gps_max_dop 1
``` ```
```bash title="Set GPS max DOP to < ~200m" ```bash title="Set GPS max DOP to < ~200m"
meshtastic --set gps_max_dop 64 meshtastic --set gps_max_dop 64
``` ```
@ -291,6 +305,7 @@ Configuring this setting is not yet available for the selected platform. If this
</Tabs> </Tabs>
#### Specify GPS Screen Display #### Specify GPS Screen Display
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -339,7 +354,7 @@ This is independent of how our location is shared with other devices. For that s
::: :::
| Value | Description | | Value | Description |
| :---: | :---------: | | :-----------------: | :-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |
| GpsOpUnset | **Default**: operates the same as `GpsOpMobile`. | | GpsOpUnset | **Default**: operates the same as `GpsOpMobile`. |
| ~~GpsOpStationary~~ | Note: This mode was removed, because it is identical go `GpsOpMobile` with a `gps_update_interval` of once per day This node is mostly stationary, we should try to get location only once per day, Once we have that position we should turn the GPS to sleep mode This is the recommended configuration for stationary 'router' nodes | | ~~GpsOpStationary~~ | Note: This mode was removed, because it is identical go `GpsOpMobile` with a `gps_update_interval` of once per day This node is mostly stationary, we should try to get location only once per day, Once we have that position we should turn the GPS to sleep mode This is the recommended configuration for stationary 'router' nodes |
| GpsOpMobile | This node is mobile and we should get GPS position at a rate governed by `gps_update_interval` | | GpsOpMobile | This node is mobile and we should get GPS position at a rate governed by `gps_update_interval` |
@ -347,6 +362,7 @@ This is independent of how our location is shared with other devices. For that s
| GpsOpDisabled | GPS is always turned off - this mode is not recommended - use `GpsOpTimeOnly` instead. | | GpsOpDisabled | GPS is always turned off - this mode is not recommended - use `GpsOpTimeOnly` instead. |
#### Enable/Disable GPS #### Enable/Disable GPS
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -361,9 +377,11 @@ This is independent of how our location is shared with other devices. For that s
```bash title="Set GPS to default settings" ```bash title="Set GPS to default settings"
meshtastic --set gps_operation GpsOpUnset meshtastic --set gps_operation GpsOpUnset
``` ```
```bash title="Set GPS to only be used for time" ```bash title="Set GPS to only be used for time"
meshtastic --set gps_operation GpsOpTimeOnly meshtastic --set gps_operation GpsOpTimeOnly
``` ```
```bash title="Disable GPS Completely" ```bash title="Disable GPS Completely"
meshtastic --set gps_operation GpsOpDisabled meshtastic --set gps_operation GpsOpDisabled
``` ```
@ -401,6 +419,7 @@ Configuring this setting is not yet available for the selected platform. If this
Determines how often should the device should attempt to acquire a GPS position (in seconds). The length of time the device is allowed to attempt to acquire GPS coordinates each interval is set using [`gps_attempt_time`](#gps_attempt_time). The default is every 30 seconds. Determines how often should the device should attempt to acquire a GPS position (in seconds). The length of time the device is allowed to attempt to acquire GPS coordinates each interval is set using [`gps_attempt_time`](#gps_attempt_time). The default is every 30 seconds.
#### Specify GPS update interval #### Specify GPS update interval
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -415,6 +434,7 @@ Determines how often should the device should attempt to acquire a GPS position
```bash title="Set GPS update interval to default settings (every 30 seconds)" ```bash title="Set GPS update interval to default settings (every 30 seconds)"
meshtastic --set gps_update_interval 0 meshtastic --set gps_update_interval 0
``` ```
```bash title="Set GPS update interval to every 45 seconds" ```bash title="Set GPS update interval to every 45 seconds"
meshtastic --set gps_update_interval 45 meshtastic --set gps_update_interval 45
``` ```
@ -448,12 +468,13 @@ Configuring this setting is not yet available for the selected platform. If this
Determines whether location is shared with other nodes. See more details. Determines whether location is shared with other nodes. See more details.
| Value | Description | | Value | Description |
| :---: | :---------: | | :---------: | :--------------------------------------------------------------------------------------------------------------------------------------: |
| LocUnset | **Default**: operates the same as `LocEnabled` | | LocUnset | **Default**: operates the same as `LocEnabled` |
| LocEnabled | The device is sharing its location (or the paired phone's location) | | LocEnabled | The device is sharing its location (or the paired phone's location) |
| LocDisabled | The device is not sharing its location (if the unit has a GPS it will default to only get time - i.e. [`GpsOpTimeOnly`](#gps_operation)) | | LocDisabled | The device is not sharing its location (if the unit has a GPS it will default to only get time - i.e. [`GpsOpTimeOnly`](#gps_operation)) |
#### Disable Location Sharing #### Disable Location Sharing
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -504,6 +525,7 @@ How often our position is sent to the mesh (but only if it has changed significa
The GPS updates will be sent out every `position_broadcast_secs`, with either the actual GPS location, or an empty location if no GPS fix was achieved. This defaults to broadcast every 15 minutes. The GPS updates will be sent out every `position_broadcast_secs`, with either the actual GPS location, or an empty location if no GPS fix was achieved. This defaults to broadcast every 15 minutes.
#### Specify GPS position broadcast frequency #### Specify GPS position broadcast frequency
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -518,6 +540,7 @@ The GPS updates will be sent out every `position_broadcast_secs`, with either th
```bash title="Set GPS update interval to default settings (every 15 minutes)" ```bash title="Set GPS update interval to default settings (every 15 minutes)"
meshtastic --set position_broadcast_secs 0 meshtastic --set position_broadcast_secs 0
``` ```
```bash title="Set GPS update interval to every 60 seconds" ```bash title="Set GPS update interval to every 60 seconds"
meshtastic --set position_broadcast_secs 60 meshtastic --set position_broadcast_secs 60
``` ```
@ -559,7 +582,7 @@ As an example, if you configure your radio to use **Long Range / Fast**, if you
The table below is a summary computed values from the algorithm. The table below is a summary computed values from the algorithm.
| Long Name | Update every x-seconds | Update distance traveled (meters) | | Long Name | Update every x-seconds | Update distance traveled (meters) |
| :---: | :---------: | :---------: | | :-----------------: | :--------------------: | :-------------------------------: |
| Long Range / Slow | 88 | 150 | | Long Range / Slow | 88 | 150 |
| Long Range / Fast | 61 | 144 | | Long Range / Fast | 61 | 144 |
| Medium Range / Slow | 30 | 41 | | Medium Range / Slow | 30 | 41 |
@ -572,6 +595,7 @@ A person walking in a straight line will take about 90 seconds to travel 150 met
::: :::
#### Enable/Disable Smart Position Broadcast #### Enable/Disable Smart Position Broadcast
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -586,6 +610,7 @@ A person walking in a straight line will take about 90 seconds to travel 150 met
```bash title="Enable smart position broadcast" ```bash title="Enable smart position broadcast"
meshtastic --set position_broadcast_smart true meshtastic --set position_broadcast_smart true
``` ```
```bash title="Disable smart position broadcast" ```bash title="Disable smart position broadcast"
meshtastic --set position_broadcast_smart false meshtastic --set position_broadcast_smart false
``` ```
@ -619,19 +644,20 @@ Configuring this setting is not yet available for the selected platform. If this
Bit field of boolean configuration options for POSITION messages (bitwise OR of PositionFlags) Bit field of boolean configuration options for POSITION messages (bitwise OR of PositionFlags)
| Value | Description | | Value | Description |
| :---: | :---------: | | :-----------: | :---------------------------------------------------------: | ---- |
| POS_UNDEFINED | Required for compilation | | POS_UNDEFINED | Required for compilation |
| POS_ALTITUDE | Include an altitude value (if available) | | POS_ALTITUDE | Include an altitude value (if available) |
| POS_ALT_MSL | Altitude value is MSL | | POS_ALT_MSL | Altitude value is MSL |
| POS_GEO_SEP | Include geoidal separation | | POS_GEO_SEP | Include geoidal separation |
| POS_DOP | Include the DOP value ; PDOP used by default, see below | | POS_DOP | Include the DOP value ; PDOP used by default, see below |
| POS_HVDOP | If POS_DOP set, send separate HDOP / VDOP values instead of | PDOP | POS_HVDOP | If POS_DOP set, send separate HDOP / VDOP values instead of | PDOP |
| POS_BATTERY | Include battery level | | POS_BATTERY | Include battery level |
| POS_SATINVIEW | Include number of "satellites in view" | | POS_SATINVIEW | Include number of "satellites in view" |
| POS_SEQ_NOS | Include a sequence number incremented per packet | | POS_SEQ_NOS | Include a sequence number incremented per packet |
| POS_TIMESTAMP | Include positional timestamp (from GPS solution) | | POS_TIMESTAMP | Include positional timestamp (from GPS solution) |
#### Set/Unset Position Flags #### Set/Unset Position Flags
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -650,6 +676,7 @@ Include each flag desired from the table above separated by a single space.
```bash title="Set Position Flags" ```bash title="Set Position Flags"
meshtastic --pos-fields POS_ALTITUDE POS_ALT_MSL meshtastic --pos-fields POS_ALTITUDE POS_ALT_MSL
``` ```
```bash title="Unset Position Flags" ```bash title="Unset Position Flags"
meshtastic --pos-fields POS_UNDEFINED meshtastic --pos-fields POS_UNDEFINED
``` ```

View file

@ -3,6 +3,7 @@ id: ham
title: Licensed (HAM) Operation title: Licensed (HAM) Operation
sidebar_label: Licensed (HAM) Operation sidebar_label: Licensed (HAM) Operation
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -19,7 +20,7 @@ This written US only, may or may not be applicable elsewhere.
Meshtastic can be used by both unlicensed people and licensed operators. If you use Meshtastic with your ham radio license, there are additional privileges and restrictions to consider. Meshtastic can be used by both unlicensed people and licensed operators. If you use Meshtastic with your ham radio license, there are additional privileges and restrictions to consider.
| Privileges | Restrictions | | Privileges | Restrictions |
|:----------:|:------------:| | :-------------------------------------------------------------: | :-----------------------------------------------------------: |
| <ul><li>Additional Power</li><li>Higher gain antennas</li></ul> | <ul><li>Unencrypted</li><li>Identified with your ID</li></ul> | | <ul><li>Additional Power</li><li>Higher gain antennas</li></ul> | <ul><li>Unencrypted</li><li>Identified with your ID</li></ul> |
## Settings ## Settings
@ -37,6 +38,7 @@ By changing these settings, you are self certifying that you are licensed to ope
::: :::
#### Set HAM ID #### Set HAM ID
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -81,7 +83,7 @@ Configuring this setting is not yet available for the selected platform. If this
Toggling `set-ham` changes your device settings in the following ways. Toggling `set-ham` changes your device settings in the following ways.
| Setting | `set-ham` Default | Normal Default | | Setting | `set-ham` Default | Normal Default |
| :-----: | :-----------------: | :------------: | | :----------------------: | :---------------: | :---------------------------------------: |
| `is_licensed` (Protobuf) | `true` | `false` | | `is_licensed` (Protobuf) | `true` | `false` |
| `long_name` (Protobuf) | `id` | User Defined | | `long_name` (Protobuf) | `id` | User Defined |
| `psk` (Protobuf) | `""` | See [Channel Settings - psk](channel#psk) | | `psk` (Protobuf) | `""` | See [Channel Settings - psk](channel#psk) |

View file

@ -3,18 +3,16 @@ id: misc
title: Miscellaneous Settings title: Miscellaneous Settings
sidebar_label: Miscellaneous sidebar_label: Miscellaneous
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
## Overview ## Overview
## Settings ## Settings
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :-----------------------: | :------------------------------------: | :-----: |
| auto_screen_carousel_secs | `integer` (seconds) | `0` | | auto_screen_carousel_secs | `integer` (seconds) | `0` |
| debug_log_enabled | `true`, `false` | `false` | | debug_log_enabled | `true`, `false` | `false` |
| factory_reset | `true`, `false` | `false` | | factory_reset | `true`, `false` | `false` |
@ -22,7 +20,6 @@ import TabItem from '@theme/TabItem';
| hop_limit | `0`-`7` | `0` | | hop_limit | `0`-`7` | `0` |
| serial_disabled | `true`, `false` | `false` | | serial_disabled | `true`, `false` | `false` |
### auto_screen_carousel_secs ### auto_screen_carousel_secs
Automatically toggles to the next page on the screen like a carousel, based the specified interval in seconds. Potentially useful for devices without user buttons. Automatically toggles to the next page on the screen like a carousel, based the specified interval in seconds. Potentially useful for devices without user buttons.
@ -43,6 +40,7 @@ Automatically toggles to the next page on the screen like a carousel, based the
```bash title="Set auto_screen_carousel_secs to default" ```bash title="Set auto_screen_carousel_secs to default"
meshtastic --set auto_screen_carousel_secs 0 meshtastic --set auto_screen_carousel_secs 0
``` ```
```bash title="Set auto_screen_carousel_secs to 120 seconds" ```bash title="Set auto_screen_carousel_secs to 120 seconds"
meshtastic --set auto_screen_carousel_secs 120 meshtastic --set auto_screen_carousel_secs 120
``` ```
@ -91,6 +89,7 @@ By default we turn off logging as soon as an API client connects (to keep shared
```bash title="Enable debug log" ```bash title="Enable debug log"
meshtastic --set debug_log_enabled true meshtastic --set debug_log_enabled true
``` ```
```bash title="Disable debug log" ```bash title="Disable debug log"
meshtastic --set debug_log_enabled false meshtastic --set debug_log_enabled false
``` ```
@ -184,6 +183,7 @@ If true, radio should not try to be smart about what packets to queue to the pho
```bash title="Enable ignore_incoming" ```bash title="Enable ignore_incoming"
meshtastic --set ignore_incoming true meshtastic --set ignore_incoming true
``` ```
```bash title="Disable ignore_incoming" ```bash title="Disable ignore_incoming"
meshtastic --set ignore_incoming false meshtastic --set ignore_incoming false
``` ```
@ -232,6 +232,7 @@ If set, this will disable the SerialConsole by not initializing the StreamAPI.
```bash title="Enable serial" ```bash title="Enable serial"
meshtastic --set serial_disabled false meshtastic --set serial_disabled false
``` ```
```bash title="Disable serial" ```bash title="Disable serial"
meshtastic --set serial_disabled true meshtastic --set serial_disabled true
``` ```
@ -284,6 +285,7 @@ Meshtastic allows a maximum of 7 hops (this is a limit of the protocol). Setting
```bash title="Set hop_limit to default (3 hops)" ```bash title="Set hop_limit to default (3 hops)"
meshtastic --set hop_limit 0 meshtastic --set hop_limit 0
``` ```
```bash title="Set hop_limit to max (7 hops)" ```bash title="Set hop_limit to max (7 hops)"
meshtastic --set hop_limit 7 meshtastic --set hop_limit 7
``` ```

View file

@ -4,6 +4,7 @@ title: Device Settings
sidebar_label: Device Settings sidebar_label: Device Settings
slug: /settings slug: /settings
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -32,7 +33,9 @@ Whether you're using the upcoming [web interface](software/web/web-app-software)
## Examples ## Examples
At the bottom of each setting page, examples will be available displaying how to adjust settings using the various platforms available to interface with your device. The examples will look like this: At the bottom of each setting page, examples will be available displaying how to adjust settings using the various platforms available to interface with your device. The examples will look like this:
### Introducing Examples ### Introducing Examples
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"

View file

@ -16,7 +16,7 @@ For a description and more information on what exactly all of these mean, please
## Settings ## Settings
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :----------------------------: | :-------------------------------------------------------------------------------------------------------------------------------------------------------------: | :-------: |
| charge_current | `MAUnset`, `MA100`, `MA190`, `MA280`, `MA360`, `MA450`, `MA550`, `MA630`, `MA700`, `MA780`, `MA880`, `MA960`, `MA1000`, `MA1080`, `MA1160`, `MA1240`, `MA1320`: | `MAUnset` | | charge_current | `MAUnset`, `MA100`, `MA190`, `MA280`, `MA360`, `MA450`, `MA550`, `MA630`, `MA700`, `MA780`, `MA880`, `MA960`, `MA1000`, `MA1080`, `MA1160`, `MA1240`, `MA1320`: | `MAUnset` |
| is_always_powered | `true`, `false` | `false` | | is_always_powered | `true`, `false` | `false` |
| is_low_power | `true`, `false` | `false` | | is_low_power | `true`, `false` | `false` |
@ -65,6 +65,7 @@ Sets the current of the battery charger.
```bash title="Unset charge current" ```bash title="Unset charge current"
meshtastic --set charge_current MAUnset meshtastic --set charge_current MAUnset
``` ```
```bash title="Set charge current" ```bash title="Set charge current"
meshtastic --set charge_current MA100 meshtastic --set charge_current MA100
``` ```
@ -98,6 +99,7 @@ Configuring this setting is not yet available for the selected platform. If this
Circumvents the logic block for determining whether the device is powered or not. Useful for devices with finicky ADC issues on the battery sense pins. Circumvents the logic block for determining whether the device is powered or not. Useful for devices with finicky ADC issues on the battery sense pins.
#### Enable/Disable is_always_powered #### Enable/Disable is_always_powered
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -112,6 +114,7 @@ Circumvents the logic block for determining whether the device is powered or not
```bash title="Enable is_always_powered" ```bash title="Enable is_always_powered"
meshtastic --set is_always_powered true meshtastic --set is_always_powered true
``` ```
```bash title="Disable is_always_powered" ```bash title="Disable is_always_powered"
meshtastic --set is_always_powered false meshtastic --set is_always_powered false
``` ```
@ -149,6 +152,7 @@ You do **not** need to set this if you've set `is_router` (it is implied in that
::: :::
#### Enable/Disable is_low_power #### Enable/Disable is_low_power
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -163,6 +167,7 @@ You do **not** need to set this if you've set `is_router` (it is implied in that
```bash title="Enable is_low_power" ```bash title="Enable is_low_power"
meshtastic --set is_low_power true meshtastic --set is_low_power true
``` ```
```bash title="Disable is_low_power" ```bash title="Disable is_low_power"
meshtastic --set is_low_power false meshtastic --set is_low_power false
``` ```
@ -195,8 +200,8 @@ Configuring this setting is not yet available for the selected platform. If this
Are we operating as a router. Changes behavior in the following ways: The device will only sleep for critically low battery level (i.e. always tries to stay alive for the mesh) In the future routing decisions will preferentially route packets through nodes with this attribute (because assumed good line of sight). Are we operating as a router. Changes behavior in the following ways: The device will only sleep for critically low battery level (i.e. always tries to stay alive for the mesh) In the future routing decisions will preferentially route packets through nodes with this attribute (because assumed good line of sight).
#### Enable/Disable is_router #### Enable/Disable is_router
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -211,6 +216,7 @@ Are we operating as a router. Changes behavior in the following ways: The device
```bash title="Enable is_router" ```bash title="Enable is_router"
meshtastic --set is_router true meshtastic --set is_router true
``` ```
```bash title="Disable is_router" ```bash title="Disable is_router"
meshtastic --set is_router false meshtastic --set is_router false
``` ```
@ -244,6 +250,7 @@ Configuring this setting is not yet available for the selected platform. If this
Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of 3600. Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of 3600.
#### Configure ls_secs #### Configure ls_secs
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -258,6 +265,7 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set ls_secs to default (1 hour/3600 seconds)" ```bash title="Set ls_secs to default (1 hour/3600 seconds)"
meshtastic --set ls_secs 0 meshtastic --set ls_secs 0
``` ```
```bash title="Set ls_secs to 120 seconds" ```bash title="Set ls_secs to 120 seconds"
meshtastic --set ls_secs 120 meshtastic --set ls_secs 120
``` ```
@ -291,6 +299,7 @@ Configuring this setting is not yet available for the selected platform. If this
Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of two hours, use the MAXUINT or 4294967295 to disable. Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of two hours, use the MAXUINT or 4294967295 to disable.
#### Configure mesh_sds_timeout_secs #### Configure mesh_sds_timeout_secs
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -305,9 +314,11 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set mesh_sds_timeout_secs to default (2 hour/7200 seconds)" ```bash title="Set mesh_sds_timeout_secs to default (2 hour/7200 seconds)"
meshtastic --set mesh_sds_timeout_secs 0 meshtastic --set mesh_sds_timeout_secs 0
``` ```
```bash title="Set mesh_sds_timeout_secs to 120 seconds" ```bash title="Set mesh_sds_timeout_secs to 120 seconds"
meshtastic --set mesh_sds_timeout_secs 120 meshtastic --set mesh_sds_timeout_secs 120
``` ```
```bash title="Disable mesh_sds_timeout_secs (using MAXUINT)" ```bash title="Disable mesh_sds_timeout_secs (using MAXUINT)"
meshtastic --set mesh_sds_timeout_secs 4294967295 meshtastic --set mesh_sds_timeout_secs 4294967295
``` ```
@ -356,6 +367,7 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set min_wake_secs to default (10 seconds)" ```bash title="Set min_wake_secs to default (10 seconds)"
meshtastic --set min_wake_secs 0 meshtastic --set min_wake_secs 0
``` ```
```bash title="Set min_wake_secs to 120 seconds" ```bash title="Set min_wake_secs to 120 seconds"
meshtastic --set min_wake_secs 120 meshtastic --set min_wake_secs 120
``` ```
@ -389,6 +401,7 @@ Configuring this setting is not yet available for the selected platform. If this
If non-zero, the device will fully power off this many seconds after external power is removed. If non-zero, the device will fully power off this many seconds after external power is removed.
#### Enable/Disable on_battery_shutdown_after_secs #### Enable/Disable on_battery_shutdown_after_secs
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -403,6 +416,7 @@ If non-zero, the device will fully power off this many seconds after external po
```bash title="Disable on_battery_shutdown_after_secs" ```bash title="Disable on_battery_shutdown_after_secs"
meshtastic --set on_battery_shutdown_after_secs 0 meshtastic --set on_battery_shutdown_after_secs 0
``` ```
```bash title="Set device to shutdown after 120 seconds on battery" ```bash title="Set device to shutdown after 120 seconds on battery"
meshtastic --set on_battery_shutdown_after_secs 120 meshtastic --set on_battery_shutdown_after_secs 120
``` ```
@ -436,6 +450,7 @@ Configuring this setting is not yet available for the selected platform. If this
Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of two hours, use the MAXUINT or 4294967295 to disable. Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of two hours, use the MAXUINT or 4294967295 to disable.
#### Enable/Disable phone_sds_timeout_sec #### Enable/Disable phone_sds_timeout_sec
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -450,9 +465,11 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set phone_sds_timeout_sec to default (2 hours)" ```bash title="Set phone_sds_timeout_sec to default (2 hours)"
meshtastic --set phone_sds_timeout_sec 0 meshtastic --set phone_sds_timeout_sec 0
``` ```
```bash title="Disable phone_sds_timeout_sec" ```bash title="Disable phone_sds_timeout_sec"
meshtastic --set phone_sds_timeout_sec 4294967295 meshtastic --set phone_sds_timeout_sec 4294967295
``` ```
```bash title="Set phone_sds_timeout_sec to 120 seconds" ```bash title="Set phone_sds_timeout_sec to 120 seconds"
meshtastic --set phone_sds_timeout_sec 120 meshtastic --set phone_sds_timeout_sec 120
``` ```
@ -501,6 +518,7 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set phone_timeout_secs to default (15 minutes)" ```bash title="Set phone_timeout_secs to default (15 minutes)"
meshtastic --set phone_timeout_secs 0 meshtastic --set phone_timeout_secs 0
``` ```
```bash title="Set phone_timeout_secs to 120 seconds" ```bash title="Set phone_timeout_secs to 120 seconds"
meshtastic --set phone_timeout_secs 120 meshtastic --set phone_timeout_secs 120
``` ```
@ -549,6 +567,7 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set screen_on_secs to default (1 minute)" ```bash title="Set screen_on_secs to default (1 minute)"
meshtastic --set screen_on_secs 0 meshtastic --set screen_on_secs 0
``` ```
```bash title="Set screen_on_secs to 120 seconds" ```bash title="Set screen_on_secs to 120 seconds"
meshtastic --set screen_on_secs 120 meshtastic --set screen_on_secs 120
``` ```
@ -597,6 +616,7 @@ Power management state machine option. See the [power page](/docs/software/other
```bash title="Set sds_secs to default (1 year)" ```bash title="Set sds_secs to default (1 year)"
meshtastic --set sds_secs 0 meshtastic --set sds_secs 0
``` ```
```bash title="Set sds_secs to 120 seconds" ```bash title="Set sds_secs to 120 seconds"
meshtastic --set sds_secs 120 meshtastic --set sds_secs 120
``` ```
@ -645,6 +665,7 @@ This sets how often to send the database of node owner information with other no
```bash title="Set send_owner_interval to default (every 4 network pings)" ```bash title="Set send_owner_interval to default (every 4 network pings)"
meshtastic --set send_owner_interval 0 meshtastic --set send_owner_interval 0
``` ```
```bash title="Set send_owner_interval to every 10 network pings" ```bash title="Set send_owner_interval to every 10 network pings"
meshtastic --set send_owner_interval 10 meshtastic --set send_owner_interval 10
``` ```
@ -680,6 +701,7 @@ For instance the default interval of 4 will send the node owner information for
Wait number of seconds for Bluetooth - Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of 1 minute. Wait number of seconds for Bluetooth - Power management state machine option. See the [power page](/docs/software/other/power) for details. 0 for default of 1 minute.
#### Configure wait_bluetooth_secs #### Configure wait_bluetooth_secs
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -694,6 +716,7 @@ Wait number of seconds for Bluetooth - Power management state machine option. Se
```bash title="Set wait_bluetooth_secs to default (60 seconds)" ```bash title="Set wait_bluetooth_secs to default (60 seconds)"
meshtastic --set wait_bluetooth_secs 0 meshtastic --set wait_bluetooth_secs 0
``` ```
```bash title="Set wait_bluetooth_secs to 120 seconds" ```bash title="Set wait_bluetooth_secs to 120 seconds"
meshtastic --set wait_bluetooth_secs 120 meshtastic --set wait_bluetooth_secs 120
``` ```

View file

@ -3,18 +3,16 @@ id: router
title: Router Settings title: Router Settings
sidebar_label: Router sidebar_label: Router
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
## Overview ## Overview
## Settings ## Settings
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :-------: | :---------------: | :-----: |
| is_router | `true`, `false` | `false` | | is_router | `true`, `false` | `false` |
### is_router ### is_router
@ -22,6 +20,7 @@ import TabItem from '@theme/TabItem';
Are we operating as a router. Changes behavior in the following ways: The device will only sleep for critically low battery level (i.e. always tries to stay alive for the mesh) In the future routing decisions will preferentially route packets through nodes with this attribute (because assumed good line of sight) Are we operating as a router. Changes behavior in the following ways: The device will only sleep for critically low battery level (i.e. always tries to stay alive for the mesh) In the future routing decisions will preferentially route packets through nodes with this attribute (because assumed good line of sight)
#### Enable/Disable router mode #### Enable/Disable router mode
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -36,6 +35,7 @@ Are we operating as a router. Changes behavior in the following ways: The device
```bash title="Enable router mode" ```bash title="Enable router mode"
meshtastic --set is_router true meshtastic --set is_router true
``` ```
```bash title="Disable router mode" ```bash title="Disable router mode"
meshtastic --set is_router false meshtastic --set is_router false
``` ```
@ -64,13 +64,12 @@ Configuring this setting is not yet available for the selected platform. If this
</TabItem> </TabItem>
</Tabs> </Tabs>
## Details ## Details
Toggling `is_router` changes your device settings in the following ways. Toggling `is_router` changes your device settings in the following ways.
| Setting | `is_router` Default | Normal Default | | Setting | `is_router` Default | Normal Default |
| :-----: | :-----------------: | :------------: | | :-----------------------: | :-----------------: | :------------: |
| `send_owner_interval` | 2 | 4 | | `send_owner_interval` | 2 | 4 |
| `position_broadcast_secs` | 12 hours | 15 minutes | | `position_broadcast_secs` | 12 hours | 15 minutes |
| `wait_bluetooth_secs` | 1 | 60 | | `wait_bluetooth_secs` | 1 | 60 |
@ -79,5 +78,7 @@ Toggling `is_router` changes your device settings in the following ways.
| `ls_secs` | 1 day | 5 minutes | | `ls_secs` | 1 day | 5 minutes |
### Altered Behaviors ### Altered Behaviors
#### Screen Wake #### Screen Wake
#### Bluetooth #### Bluetooth

View file

@ -3,6 +3,7 @@ id: wifi
title: WiFi Settings title: WiFi Settings
sidebar_label: WiFi sidebar_label: WiFi
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -25,7 +26,7 @@ The first time your device restarts after enabling the WiFi access point, it wil
## Settings ## Settings
| Setting | Acceptable Values | Default | | Setting | Acceptable Values | Default |
| :-----: | :---------------: | :-----: | | :-----------: | :---------------: | :-----: |
| wifi_ap_mode | `true`, `false` | `false` | | wifi_ap_mode | `true`, `false` | `false` |
| wifi_password | string | `""` | | wifi_password | string | `""` |
| wifi_ssid | string | `""` | | wifi_ssid | string | `""` |
@ -39,6 +40,7 @@ The first time your device restarts after enabling the WiFi access point, it wil
A boolean value that toggles the [Software Access Point](#software-access-point) A boolean value that toggles the [Software Access Point](#software-access-point)
#### Enable/Disable Software Access Point #### Enable/Disable Software Access Point
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -53,6 +55,7 @@ A boolean value that toggles the [Software Access Point](#software-access-point)
```bash title="Enable SoftAP" ```bash title="Enable SoftAP"
meshtastic --set wifi_ap_mode true meshtastic --set wifi_ap_mode true
``` ```
```bash title="Disable SoftAP" ```bash title="Disable SoftAP"
meshtastic --set wifi_ap_mode false meshtastic --set wifi_ap_mode false
``` ```
@ -99,6 +102,7 @@ In [SoftAP](#software-access-point) mode, this is the password to access your de
```bash title="Set WiFi password" ```bash title="Set WiFi password"
meshtastic --set wifi_password mypassword meshtastic --set wifi_password mypassword
``` ```
```bash title="Set WiFi password (with spaces)" ```bash title="Set WiFi password (with spaces)"
meshtastic --set wifi_password "my password" meshtastic --set wifi_password "my password"
``` ```
@ -145,9 +149,11 @@ In [SoftAP](#software-access-point) mode, this is the SSID broadcast to access y
```bash title="Set WiFi network" ```bash title="Set WiFi network"
meshtastic --set wifi_ssid mynetwork meshtastic --set wifi_ssid mynetwork
``` ```
```bash title="Set WiFi network (with spaces)" ```bash title="Set WiFi network (with spaces)"
meshtastic --set wifi_ssid "my network" meshtastic --set wifi_ssid "my network"
``` ```
</TabItem> </TabItem>
<TabItem value="android"> <TabItem value="android">
@ -194,10 +200,10 @@ You should then be able to connect to the node using either the displayed IP add
You can also enable the SoftAP by following these directions: You can also enable the SoftAP by following these directions:
* Hold down the user button - Hold down the user button
* Press and release the reset button - Press and release the reset button
* Count to two - Count to two
* Let go of the user button - Let go of the user button
This will reboot the device with the SSID set to `meshtasticAdmin` and the password set to `12345678`. Using the Force SoftAP method, once you reboot, the SoftAP will be turned off. This will reboot the device with the SSID set to `meshtasticAdmin` and the password set to `12345678`. Using the Force SoftAP method, once you reboot, the SoftAP will be turned off.
@ -236,6 +242,7 @@ To disable WiFi completely, set `wifi_ap_mode` to `false`, and both `wifi_ssid`
## Examples ## Examples
### Enable WiFi (as client) ### Enable WiFi (as client)
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -253,9 +260,11 @@ To disable WiFi completely, set `wifi_ap_mode` to `false`, and both `wifi_ssid`
:::note :::note
If your `wifi_ssid` or `wifi_password` contain spaces, be sure to put quotation marks around the whole thing: If your `wifi_ssid` or `wifi_password` contain spaces, be sure to put quotation marks around the whole thing:
```bash title="Example with spaces" ```bash title="Example with spaces"
meshtastic --set wifi_ssid "my wifi ssid" --set wifi_password "my wifi password" meshtastic --set wifi_ssid "my wifi ssid" --set wifi_password "my wifi password"
``` ```
::: :::
</TabItem> </TabItem>
<TabItem value="android"> <TabItem value="android">
@ -284,6 +293,7 @@ Configuring this setting is not yet available for the selected platform. If this
In the above example, the device will join a network with the SSID `mywifissid` and the password `mywifipassword`. In the above example, the device will join a network with the SSID `mywifissid` and the password `mywifipassword`.
### Enable WiFi (as SoftAP) ### Enable WiFi (as SoftAP)
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -301,13 +311,13 @@ In the above example, the device will join a network with the SSID `mywifissid`
:::note :::note
If your `wifi_ssid` or `wifi_password` contain spaces, be sure to put quotation marks around the whole thing: If your `wifi_ssid` or `wifi_password` contain spaces, be sure to put quotation marks around the whole thing:
```bash title="Example with spaces" ```bash title="Example with spaces"
meshtastic --set wifi_ssid "my wifi ssid" --set wifi_password "my wifi password" meshtastic --set wifi_ssid "my wifi ssid" --set wifi_password "my wifi password"
``` ```
::: :::
</TabItem> </TabItem>
<TabItem value="android"> <TabItem value="android">
@ -335,6 +345,7 @@ Configuring this setting is not yet available for the selected platform. If this
In the above example, the device will broadcast a network with the SSID `mywifissid` and the password `mywifipassword`. In the above example, the device will broadcast a network with the SSID `mywifissid` and the password `mywifipassword`.
### Disable WiFi Completely ### Disable WiFi Completely
<Tabs <Tabs
groupId="settings" groupId="settings"
defaultValue="cli" defaultValue="cli"
@ -350,7 +361,6 @@ In the above example, the device will broadcast a network with the SSID `mywifis
meshtastic --set wifi_ap_mode false --set wifi_ssid "" --set wifi_password "" meshtastic --set wifi_ap_mode false --set wifi_ssid "" --set wifi_password ""
``` ```
</TabItem> </TabItem>
<TabItem value="android"> <TabItem value="android">

View file

@ -44,5 +44,6 @@ GLOBAL OPTIONS:
--help, -h show help (default: false) --help, -h show help (default: false)
--version, -v print the version (default: false) --version, -v print the version (default: false)
``` ```
Further information is available on the project's GitHub [Readme.md](https://github.com/lmatte7/meshtastic-go/blob/main/README.md). Further information is available on the project's GitHub [Readme.md](https://github.com/lmatte7/meshtastic-go/blob/main/README.md).
The latest executables can be downloaded from [GitHub](https://github.com/lmatte7/meshtastic-go/releases/latest). The latest executables can be downloaded from [GitHub](https://github.com/lmatte7/meshtastic-go/releases/latest).

View file

@ -7,8 +7,9 @@ sidebar_label: Community apps
The Meshtastic ecosystem is highly extensible, and a number of community projects have been made to fit different people's needs. If you wish to create your own application or module, please read the information in the developers section, and tell us about your project on the forum. The Meshtastic ecosystem is highly extensible, and a number of community projects have been made to fit different people's needs. If you wish to create your own application or module, please read the information in the developers section, and tell us about your project on the forum.
Current community projects: Current community projects:
* [Meshtastic module for ATAK](/docs/software/community/community-atak) (Android Team Awareness Kit)
* [PyGUI](/docs/software/community/community-pygui) - Platform independent graphical user interface for Meshtastic devices - [Meshtastic module for ATAK](/docs/software/community/community-atak) (Android Team Awareness Kit)
* [Go CLI](/docs/software/community/community-go) - A command line interface using Go that requires no pre-requisites to be installed - [PyGUI](/docs/software/community/community-pygui) - Platform independent graphical user interface for Meshtastic devices
- [Go CLI](/docs/software/community/community-go) - A command line interface using Go that requires no pre-requisites to be installed
Support for these projects should be sought from their respective authors. Support for these projects should be sought from their respective authors.

View file

@ -11,7 +11,7 @@ This table is derived from the [protobufs](/docs/developers/protobufs/api#critic
::: :::
| Name | Number | Description | | Name | Number | Description |
| ---- | ------ | ----------- | | ------------------- | ------ | ----------------------------------------------------------------------------------------------------------------------- |
| TxWatchdog | 1 | A software bug was detected while trying to send LoRa | | TxWatchdog | 1 | A software bug was detected while trying to send LoRa |
| SleepEnterWait | 2 | A software bug was detected on entry to sleep | | SleepEnterWait | 2 | A software bug was detected on entry to sleep |
| NoRadio | 3 | No LoRa radio hardware could be found | | NoRadio | 3 | No LoRa radio hardware could be found |

View file

@ -4,6 +4,7 @@ title: Licensed (HAM) Operation
sidebar_label: Licensed (HAM) Operation sidebar_label: Licensed (HAM) Operation
slug: /software/device/ham slug: /software/device/ham
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -17,13 +18,13 @@ Having a ham radio license grants you addition privilages and restrictions.
# Additional privilages # Additional privilages
* Additional power - Additional power
* Higher gain antennas - Higher gain antennas
# Restrictions # Restrictions
* Unencrypted - Unencrypted
* Identified with your ID - Identified with your ID
# Let's do it! # Let's do it!

View file

@ -11,26 +11,26 @@ Long battery life is one of the main goals of this project. Based on initial mea
From lower to higher power consumption. From lower to higher power consumption.
- Super-Deep-Sleep (SDS) - Everything is off, CPU, radio, Bluetooth, and GPS. It only wakes due to timer or button press. We enter this mode only after no radio comms for a few hours - used to put the device into what is effectively "off" mode. - Super-Deep-Sleep (SDS) - Everything is off, CPU, radio, Bluetooth, and GPS. It only wakes due to timer or button press. We enter this mode only after no radio comms for a few hours - used to put the device into what is effectively "off" mode.
* onEntry: setBluetoothOn(false), call doDeepSleep - onEntry: setBluetoothOn(false), call doDeepSleep
* onExit: (standard bootup code, starts in DARK) - onExit: (standard bootup code, starts in DARK)
- Deep-Sleep (DS) - CPU is off, radio is on, Bluetooth and GPS are off. Note: This mode is never used currently, because it only saves 1.5mA vs Light-Sleep - (Not currently used). - Deep-Sleep (DS) - CPU is off, radio is on, Bluetooth and GPS are off. Note: This mode is never used currently, because it only saves 1.5mA vs Light-Sleep - (Not currently used).
- Light-Sleep (LS) - CPU is suspended (RAM stays alive), radio is on, Bluetooth is off, and GPS is off. Note: currently GPS is not turned off during light sleep, but there is a TODO item to fix this. - Light-Sleep (LS) - CPU is suspended (RAM stays alive), radio is on, Bluetooth is off, and GPS is off. Note: currently GPS is not turned off during light sleep, but there is a TODO item to fix this.
* NOTE: On NRF52 platforms (because CPU current draw is so low), light-sleep state is never used. - NOTE: On NRF52 platforms (because CPU current draw is so low), light-sleep state is never used.
* onEntry: setBluetoothOn(false), setGPSPower(false), doLightSleep() - onEntry: setBluetoothOn(false), setGPSPower(false), doLightSleep()
* onIdle: (if we wake because our led blink timer has expired) blink the led then go back to sleep until we sleep for ls_secs - onIdle: (if we wake because our led blink timer has expired) blink the led then go back to sleep until we sleep for ls_secs
* onExit: setGPSPower(true), start trying to get GPS lock: gps.startLock(), once lock arrives service.sendPosition(BROADCAST) - onExit: setGPSPower(true), start trying to get GPS lock: gps.startLock(), once lock arrives service.sendPosition(BROADCAST)
- No Bluetooth (NB) - CPU is running, radio is on, GPS is on, Bluetooth is off, and screen is off. - No Bluetooth (NB) - CPU is running, radio is on, GPS is on, Bluetooth is off, and screen is off.
* onEntry: setBluetoothOn(false) - onEntry: setBluetoothOn(false)
* onExit: - onExit:
- Running Dark (DARK) - Everything is on except screen. - Running Dark (DARK) - Everything is on except screen.
* onEntry: setBluetoothOn(true) - onEntry: setBluetoothOn(true)
* onExit: - onExit:
- Serial API usage (SERIAL) - Screen is on, device doesn't sleep, and Bluetooth is off. - Serial API usage (SERIAL) - Screen is on, device doesn't sleep, and Bluetooth is off.
* onEntry: setBluetooth off, screen on - onEntry: setBluetooth off, screen on
* onExit: - onExit:
- Full On (ON) - Everything is on, can eventually timeout and transition to a lower power state. - Full On (ON) - Everything is on, can eventually timeout and transition to a lower power state.
* onEntry: setBluetoothOn(true), screen.setOn(true) - onEntry: setBluetoothOn(true), screen.setOn(true)
* onExit: screen->setOn(false) - onExit: screen->setOn(false)
- Has Power (POWER) - Screen is on, device doesn't sleep, Bluetooth on, and will stay in this state as long as we have power. - Has Power (POWER) - Screen is on, device doesn't sleep, Bluetooth on, and will stay in this state as long as we have power.
* onEntry: setBluetooth off, screen on - onEntry: setBluetooth off, screen on
* onExit: - onExit:

View file

@ -16,5 +16,5 @@ An alpha MacOS application is available in the beta TestFlight app for MacOS cur
Code from two previous community projects is also available. Code from two previous community projects is also available.
* https://github.com/jeksys/Meshtastic-iOS - https://github.com/jeksys/Meshtastic-iOS
* https://github.com/thepoweroftwo/meshtastic-ios - https://github.com/thepoweroftwo/meshtastic-ios

View file

@ -4,24 +4,21 @@ title: Connecting to a device
sidebar_label: Connecting sidebar_label: Connecting
--- ---
```tsx ```tsx
import type React from 'React'; import type React from "React";
import { IHTTPConnection } from '@meshtastic/meshtasticjs'; import { IHTTPConnection } from "@meshtastic/meshtasticjs";
export const Connection = (): JSX.Element => { export const Connection = (): JSX.Element => {
const connection = new IHTTPConnection(); const connection = new IHTTPConnection();
const connect = (): void => { const connect = (): void => {
void connection.connect({ void connection.connect({
address: '10.0.0.10', address: "10.0.0.10",
fetchInterval: 3000, fetchInterval: 3000,
}); });
} };
return <button onClick={connect}>Connect Bluetooth</button>; return <button onClick={connect}>Connect Bluetooth</button>;
}; };
``` ```

View file

@ -27,9 +27,13 @@ const connection = client.createHTTPConnection();
connection.connect("192.168.x.x"); connection.connect("192.168.x.x");
const restartDevice: Promise<void> = connection.restartDevice(); const restartDevice: Promise<void> = connection.restartDevice();
const getStatistics: Promise<void | Types.WebSPIFFSResponse> = connection.getStatistics(); const getStatistics: Promise<void | Types.WebSPIFFSResponse> =
const getNetworks: Promise<void | Types.WebNetworkResponse> = connection.getNetworks(); connection.getStatistics();
const getSPIFFS: Promise<void | Types.WebSPIFFSResponse> = connection.getSPIFFS(); const getNetworks: Promise<void | Types.WebNetworkResponse> =
const deleteSPIFFS: Promise<void | Types.WebSPIFFSResponse> = connection.deleteSPIFFS(); connection.getNetworks();
const getSPIFFS: Promise<void | Types.WebSPIFFSResponse> =
connection.getSPIFFS();
const deleteSPIFFS: Promise<void | Types.WebSPIFFSResponse> =
connection.deleteSPIFFS();
const blinkLED: Promise<void | any> = connection.blinkLED(); const blinkLED: Promise<void | any> = connection.blinkLED();
``` ```

View file

@ -7,11 +7,13 @@ sidebar_label: Overview
There are a number of modules that have been integrated into the device firmware. These can be turned on using the Meshtastic python command line program. Please note that these modules require the device to be rebooted once they have been enabled for them to start running. There are a number of modules that have been integrated into the device firmware. These can be turned on using the Meshtastic python command line program. Please note that these modules require the device to be rebooted once they have been enabled for them to start running.
These modules are currently integrated into the firmware: These modules are currently integrated into the firmware:
* Range test - Allows automated testing of communication range of nodes
* External notifications - Allows a speaker, LED or other device to indicate when a message has been received - Range test - Allows automated testing of communication range of nodes
* Canned messages - Device can be used without the phone to send a message by choosing a predefined text - External notifications - Allows a speaker, LED or other device to indicate when a message has been received
* Serial - Allows messages to be sent across the mesh by sending strings across a serial port - Canned messages - Device can be used without the phone to send a message by choosing a predefined text
- Serial - Allows messages to be sent across the mesh by sending strings across a serial port
These modules are currently in development: These modules are currently in development:
* Store and forward - Allows a node to store messages and resend them to nodes that have intermittent connection to the mesh
* Environment measurement - Allows a node to measure it's local environment and report across the mesh - Store and forward - Allows a node to store messages and resend them to nodes that have intermittent connection to the mesh
- Environment measurement - Allows a node to measure it's local environment and report across the mesh

View file

@ -16,6 +16,7 @@ sudo pip install --upgrade pip
git clone https://github.com/meshtastic/esp32-arduino-lib-builder git clone https://github.com/meshtastic/esp32-arduino-lib-builder
cd esp32-arduino-lib-builder cd esp32-arduino-lib-builder
``` ```
Install esp-idf (needed if you want to `make menuconfig`, `build.sh` will install it automatically if needed): Install esp-idf (needed if you want to `make menuconfig`, `build.sh` will install it automatically if needed):
```bash ```bash

View file

@ -3,6 +3,7 @@ id: python-standalone
title: Meshtastic-python standalone executable title: Meshtastic-python standalone executable
sidebar_label: Standalone sidebar_label: Standalone
--- ---
import Tabs from '@theme/Tabs'; import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem'; import TabItem from '@theme/TabItem';
@ -10,7 +11,6 @@ There are standalone executable files for Mac, Windows and Ubuntu. A single file
They can be found on the [Releases](https://github.com/meshtastic/Meshtastic-python/releases) page. They can be found on the [Releases](https://github.com/meshtastic/Meshtastic-python/releases) page.
<Tabs <Tabs
groupId="operating-system" groupId="operating-system"
defaultValue="windows" defaultValue="windows"
@ -21,15 +21,15 @@ They can be found on the [Releases](https://github.com/meshtastic/Meshtastic-pyt
]}> ]}>
<TabItem value="ubuntu"> <TabItem value="ubuntu">
* Download meshtastic_ubuntu - Download meshtastic_ubuntu
* Run the following command to make the file executable and rename it 'meshtastic': - Run the following command to make the file executable and rename it 'meshtastic':
``` ```
chmod +x meshtastic_ubuntu && mv meshtastic_ubuntu meshtastic chmod +x meshtastic_ubuntu && mv meshtastic_ubuntu meshtastic
``` ```
* To run the cli: - To run the cli:
``` ```
./meshtastic ./meshtastic
@ -42,15 +42,15 @@ Copy (or move) this binary somewhere in your path.
</TabItem> </TabItem>
<TabItem value="macos"> <TabItem value="macos">
* Download meshtastic_mac - Download meshtastic_mac
* Run the following command to make the file executable and to rename it 'meshtastic': - Run the following command to make the file executable and to rename it 'meshtastic':
``` ```
chmod +x meshtastic_mac && mv meshtastic_mac meshtastic chmod +x meshtastic_mac && mv meshtastic_mac meshtastic
``` ```
* Try to run it: - Try to run it:
``` ```
./meshtastic ./meshtastic
@ -61,9 +61,9 @@ chmod +x meshtastic_mac && mv meshtastic_mac meshtastic
"meshtastic" can't be opened because Apple cannot check it for malicious software. "meshtastic" can't be opened because Apple cannot check it for malicious software.
::: :::
* To fix, go into "System Preferences", "Security & Privacy", "General" tab, and click on the "Allow Anyway" button. - To fix, go into "System Preferences", "Security & Privacy", "General" tab, and click on the "Allow Anyway" button.
* Try to run it again: - Try to run it again:
``` ```
./meshtastic ./meshtastic
@ -75,7 +75,7 @@ You may get a dialog that says:
Click "Open". Click "Open".
::: :::
* Now when you want to run it, you can simply run: - Now when you want to run it, you can simply run:
``` ```
./meshtastic ./meshtastic
@ -88,11 +88,11 @@ Copy (or move) this binary somewhere in your path.
</TabItem> </TabItem>
<TabItem value="windows"> <TabItem value="windows">
* Download meshtastic_windows - Download meshtastic_windows
* Rename to meshtastic.exe - Rename to meshtastic.exe
* To run, open a windows command prompt, navigate to the location of the executable and run: - To run, open a windows command prompt, navigate to the location of the executable and run:
``` ```
meshtastic.exe meshtastic.exe

View file

@ -5,6 +5,7 @@ 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:
```python ```python
import meshtastic import meshtastic
import meshtastic.serial_interface import meshtastic.serial_interface
@ -32,6 +33,7 @@ interface.close()
``` ```
Another example using Python 3 code to send a message to the mesh when WiFi is enabled: Another example using Python 3 code to send a message to the mesh when WiFi is enabled:
```python ```python
import time import time
import meshtastic import meshtastic
@ -55,8 +57,8 @@ interface.close()
Note: Be sure to change the IP address in the code above to a valid IP address for your setup. Note: Be sure to change the IP address in the code above to a valid IP address for your setup.
You can get and update settings like this: You can get and update settings like this:
```python ```python
import meshtastic import meshtastic
import meshtastic.serial_interface import meshtastic.serial_interface
@ -71,7 +73,6 @@ ourNode.writeConfig()
interface.close() interface.close()
``` ```
For the rough notes/implementation plan see [TODO](https://github.com/meshtastic/Meshtastic-python/blob/master/TODO.md). See the API for full details of how to use the library. For the rough notes/implementation plan see [TODO](https://github.com/meshtastic/Meshtastic-python/blob/master/TODO.md). See the API for full details of how to use the library.
## A note to developers of this lib ## A note to developers of this lib
@ -79,6 +80,7 @@ For the rough notes/implementation plan see [TODO](https://github.com/meshtastic
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 don't change formatting on lines you haven't changed. 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 don't change formatting on lines you haven't changed.
If you need to build a new release you'll need: If you need to build a new release you'll need:
```bash title="Command" ```bash title="Command"
apt install pandoc apt install pandoc
sudo pip3 install markdown pandoc webencodings pyparsing twine autopep8 sudo pip3 install markdown pandoc webencodings pyparsing twine autopep8

View file

@ -4,7 +4,6 @@ title: Information for developers of the web interface
sidebar_label: Development sidebar_label: Development
--- ---
## Considerations ## Considerations
We have a total of 458,752 bytes (448KB) available on the SPIFFS (Serial Peripheral Interface Flash File System) -- the on-board storage of the ESP32. Of that space, let's not use more than half of that (224KB) in order to leave space for other uses. We have a total of 458,752 bytes (448KB) available on the SPIFFS (Serial Peripheral Interface Flash File System) -- the on-board storage of the ESP32. Of that space, let's not use more than half of that (224KB) in order to leave space for other uses.
@ -17,9 +16,9 @@ Static files can be placed in the /data folder. All files should be compressed i
As an example, this would mean we will have files such as: As an example, this would mean we will have files such as:
* style.css.gz - style.css.gz
* meshtastic.js.gz - meshtastic.js.gz
* meshtasticlogo.png.gz - meshtasticlogo.png.gz
Unless otherwise stated, files in the `/data` folder of the source code will be stored in `/static` on the device. Unless otherwise stated, files in the `/data` folder of the source code will be stored in `/static` on the device.
@ -41,8 +40,8 @@ If a file is uploaded in a .gz format, the .gz extension will be stripped prior
An experimental file system browser with upload and delete capability is available by going to either: An experimental file system browser with upload and delete capability is available by going to either:
* http://meshtastic.local/static - http://meshtastic.local/static
* https://meshtastic.local/static - https://meshtastic.local/static
There are known issues with uploading files with large file sizes. There are known issues with uploading files with large file sizes.

View file

@ -8,7 +8,8 @@
"start": "docusaurus start", "start": "docusaurus start",
"build": "docusaurus build", "build": "docusaurus build",
"serve": "docusaurus serve", "serve": "docusaurus serve",
"clear": "docusaurus clear" "clear": "docusaurus clear",
"format": "prettier --write 'docs/**/*.md'"
}, },
"dependencies": { "dependencies": {
"@docusaurus/core": "^2.0.0-beta.17", "@docusaurus/core": "^2.0.0-beta.17",
@ -37,6 +38,7 @@
"@tsconfig/docusaurus": "^1.0.4", "@tsconfig/docusaurus": "^1.0.4",
"@types/node": "^17.0.21", "@types/node": "^17.0.21",
"@types/w3c-web-serial": "^1.0.2", "@types/w3c-web-serial": "^1.0.2",
"prettier": "^2.5.1",
"typescript": "^4.6.2" "typescript": "^4.6.2"
} }
} }

View file

@ -5930,6 +5930,11 @@ prepend-http@^2.0.0:
resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897" resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897"
integrity sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc= integrity sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc=
prettier@^2.5.1:
version "2.5.1"
resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.5.1.tgz#fff75fa9d519c54cf0fce328c1017d94546bc56a"
integrity sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==
pretty-error@^4.0.0: pretty-error@^4.0.0:
version "4.0.0" version "4.0.0"
resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-4.0.0.tgz#90a703f46dd7234adb46d0f84823e9d1cb8f10d6" resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-4.0.0.tgz#90a703f46dd7234adb46d0f84823e9d1cb8f10d6"