157 lines
5.9 KiB
Protocol Buffer
157 lines
5.9 KiB
Protocol Buffer
|
syntax = "proto3";
|
||
|
|
||
|
package meshtastic;
|
||
|
|
||
|
option csharp_namespace = "Meshtastic.Protobufs";
|
||
|
option go_package = "git.janky.solutions/finn/matrix-meshtastic-bridge-go/meshtastic/protobufs";
|
||
|
option java_outer_classname = "ChannelProtos";
|
||
|
option java_package = "com.geeksville.mesh";
|
||
|
option swift_prefix = "";
|
||
|
|
||
|
/*
|
||
|
* This information can be encoded as a QRcode/url so that other users can configure
|
||
|
* their radio to join the same channel.
|
||
|
* A note about how channel names are shown to users: channelname-X
|
||
|
* poundsymbol is a prefix used to indicate this is a channel name (idea from @professr).
|
||
|
* Where X is a letter from A-Z (base 26) representing a hash of the PSK for this
|
||
|
* channel - so that if the user changes anything about the channel (which does
|
||
|
* force a new PSK) this letter will also change. Thus preventing user confusion if
|
||
|
* two friends try to type in a channel name of "BobsChan" and then can't talk
|
||
|
* because their PSKs will be different.
|
||
|
* The PSK is hashed into this letter by "0x41 + [xor all bytes of the psk ] modulo 26"
|
||
|
* This also allows the option of someday if people have the PSK off (zero), the
|
||
|
* users COULD type in a channel name and be able to talk.
|
||
|
* FIXME: Add description of multi-channel support and how primary vs secondary channels are used.
|
||
|
* FIXME: explain how apps use channels for security.
|
||
|
* explain how remote settings and remote gpio are managed as an example
|
||
|
*/
|
||
|
message ChannelSettings {
|
||
|
/*
|
||
|
* Deprecated in favor of LoraConfig.channel_num
|
||
|
*/
|
||
|
uint32 channel_num = 1 [deprecated = true];
|
||
|
|
||
|
/*
|
||
|
* A simple pre-shared key for now for crypto.
|
||
|
* Must be either 0 bytes (no crypto), 16 bytes (AES128), or 32 bytes (AES256).
|
||
|
* A special shorthand is used for 1 byte long psks.
|
||
|
* These psks should be treated as only minimally secure,
|
||
|
* because they are listed in this source code.
|
||
|
* Those bytes are mapped using the following scheme:
|
||
|
* `0` = No crypto
|
||
|
* `1` = The special "default" channel key: {0xd4, 0xf1, 0xbb, 0x3a, 0x20, 0x29, 0x07, 0x59, 0xf0, 0xbc, 0xff, 0xab, 0xcf, 0x4e, 0x69, 0x01}
|
||
|
* `2` through 10 = The default channel key, except with 1 through 9 added to the last byte.
|
||
|
* Shown to user as simple1 through 10
|
||
|
*/
|
||
|
bytes psk = 2;
|
||
|
|
||
|
/*
|
||
|
* A SHORT name that will be packed into the URL.
|
||
|
* Less than 12 bytes.
|
||
|
* Something for end users to call the channel
|
||
|
* If this is the empty string it is assumed that this channel
|
||
|
* is the special (minimally secure) "Default"channel.
|
||
|
* In user interfaces it should be rendered as a local language translation of "X".
|
||
|
* For channel_num hashing empty string will be treated as "X".
|
||
|
* Where "X" is selected based on the English words listed above for ModemPreset
|
||
|
*/
|
||
|
string name = 3;
|
||
|
|
||
|
/*
|
||
|
* Used to construct a globally unique channel ID.
|
||
|
* The full globally unique ID will be: "name.id" where ID is shown as base36.
|
||
|
* Assuming that the number of meshtastic users is below 20K (true for a long time)
|
||
|
* the chance of this 64 bit random number colliding with anyone else is super low.
|
||
|
* And the penalty for collision is low as well, it just means that anyone trying to decrypt channel messages might need to
|
||
|
* try multiple candidate channels.
|
||
|
* Any time a non wire compatible change is made to a channel, this field should be regenerated.
|
||
|
* There are a small number of 'special' globally known (and fairly) insecure standard channels.
|
||
|
* Those channels do not have a numeric id included in the settings, but instead it is pulled from
|
||
|
* a table of well known IDs.
|
||
|
* (see Well Known Channels FIXME)
|
||
|
*/
|
||
|
fixed32 id = 4;
|
||
|
|
||
|
/*
|
||
|
* If true, messages on the mesh will be sent to the *public* internet by any gateway ndoe
|
||
|
*/
|
||
|
bool uplink_enabled = 5;
|
||
|
|
||
|
/*
|
||
|
* If true, messages seen on the internet will be forwarded to the local mesh.
|
||
|
*/
|
||
|
bool downlink_enabled = 6;
|
||
|
|
||
|
/*
|
||
|
* Per-channel module settings.
|
||
|
*/
|
||
|
ModuleSettings module_settings = 7;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* This message is specifically for modules to store per-channel configuration data.
|
||
|
*/
|
||
|
message ModuleSettings {
|
||
|
/*
|
||
|
* Bits of precision for the location sent in position packets.
|
||
|
*/
|
||
|
uint32 position_precision = 1;
|
||
|
|
||
|
/*
|
||
|
* Controls whether or not the phone / clients should mute the current channel
|
||
|
* Useful for noisy public channels you don't necessarily want to disable
|
||
|
*/
|
||
|
bool is_client_muted = 2;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* A pair of a channel number, mode and the (sharable) settings for that channel
|
||
|
*/
|
||
|
message Channel {
|
||
|
/*
|
||
|
* How this channel is being used (or not).
|
||
|
* Note: this field is an enum to give us options for the future.
|
||
|
* In particular, someday we might make a 'SCANNING' option.
|
||
|
* SCANNING channels could have different frequencies and the radio would
|
||
|
* occasionally check that freq to see if anything is being transmitted.
|
||
|
* For devices that have multiple physical radios attached, we could keep multiple PRIMARY/SCANNING channels active at once to allow
|
||
|
* cross band routing as needed.
|
||
|
* If a device has only a single radio (the common case) only one channel can be PRIMARY at a time
|
||
|
* (but any number of SECONDARY channels can't be sent received on that common frequency)
|
||
|
*/
|
||
|
enum Role {
|
||
|
/*
|
||
|
* This channel is not in use right now
|
||
|
*/
|
||
|
DISABLED = 0;
|
||
|
|
||
|
/*
|
||
|
* This channel is used to set the frequency for the radio - all other enabled channels must be SECONDARY
|
||
|
*/
|
||
|
PRIMARY = 1;
|
||
|
|
||
|
/*
|
||
|
* Secondary channels are only used for encryption/decryption/authentication purposes.
|
||
|
* Their radio settings (freq etc) are ignored, only psk is used.
|
||
|
*/
|
||
|
SECONDARY = 2;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* The index of this channel in the channel table (from 0 to MAX_NUM_CHANNELS-1)
|
||
|
* (Someday - not currently implemented) An index of -1 could be used to mean "set by name",
|
||
|
* in which case the target node will find and set the channel by settings.name.
|
||
|
*/
|
||
|
int32 index = 1;
|
||
|
|
||
|
/*
|
||
|
* The new settings, or NULL to disable that channel
|
||
|
*/
|
||
|
ChannelSettings settings = 2;
|
||
|
|
||
|
/*
|
||
|
* TODO: REPLACE
|
||
|
*/
|
||
|
Role role = 3;
|
||
|
}
|