mirror of
https://github.com/l5yth/potato-mesh.git
synced 2026-05-01 02:52:41 +02:00
* web: implement a 'protocol' field across systems * web: address review feedback on multi-protocol support - Rebase on main (pick up coordinate-clearing bugfix from #654) - P1: prevent cross-protocol message merges on shared packet IDs - P2: exclude "ingestor" key when enforcing /api/nodes batch limit - Extract append_protocol_filter helper + PROTOCOL_CLAUSE constant to reduce cognitive complexity and deduplicate SQL fragment in queries.rb - Extract coerce_bool helper to reduce upsert_node cognitive complexity - Merge nested if in insert_message protocol update path (Sonar) - Add explicit UPDATE backfill in ensure_schema_upgrades so any pre-existing NULL/empty protocol rows are set to meshtastic on upgrade - Rename migration file to 20260328_ (correct year) - Expand protocol_spec.rb: filter tests for all 7 endpoints, cross-protocol non-merge test, batch limit test, Sonar constant fixes, ENV.fetch, P1 regression test * web: address review comments
51 lines
1.7 KiB
SQL
51 lines
1.7 KiB
SQL
-- Copyright © 2025-26 l5yth & contributors
|
|
--
|
|
-- Licensed under the Apache License, Version 2.0 (the "License");
|
|
-- you may not use this file except in compliance with the License.
|
|
-- You may obtain a copy of the License at
|
|
--
|
|
-- http://www.apache.org/licenses/LICENSE-2.0
|
|
--
|
|
-- Unless required by applicable law or agreed to in writing, software
|
|
-- distributed under the License is distributed on an "AS IS" BASIS,
|
|
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
-- See the License for the specific language governing permissions and
|
|
-- limitations under the License.
|
|
|
|
PRAGMA journal_mode=WAL;
|
|
|
|
CREATE TABLE IF NOT EXISTS nodes (
|
|
node_id TEXT PRIMARY KEY,
|
|
num INTEGER,
|
|
short_name TEXT,
|
|
long_name TEXT,
|
|
macaddr TEXT,
|
|
hw_model TEXT,
|
|
role TEXT,
|
|
public_key TEXT,
|
|
is_unmessagable BOOLEAN,
|
|
is_favorite BOOLEAN,
|
|
hops_away INTEGER,
|
|
snr REAL,
|
|
last_heard INTEGER,
|
|
first_heard INTEGER,
|
|
battery_level REAL,
|
|
voltage REAL,
|
|
channel_utilization REAL,
|
|
air_util_tx REAL,
|
|
uptime_seconds INTEGER,
|
|
position_time INTEGER,
|
|
location_source TEXT,
|
|
precision_bits INTEGER,
|
|
latitude REAL,
|
|
longitude REAL,
|
|
altitude REAL,
|
|
lora_freq INTEGER,
|
|
modem_preset TEXT,
|
|
protocol TEXT NOT NULL DEFAULT 'meshtastic'
|
|
);
|
|
|
|
CREATE INDEX IF NOT EXISTS idx_nodes_last_heard ON nodes(last_heard);
|
|
CREATE INDEX IF NOT EXISTS idx_nodes_hw_model ON nodes(hw_model);
|
|
CREATE INDEX IF NOT EXISTS idx_nodes_latlon ON nodes(latitude, longitude);
|