upleb.uk

Public git repos — served from a NIP-34 GRASP relay at git.upleb.uk

summaryrefslogtreecommitdiff
path: root/main/sync_manager.h
diff options
context:
space:
mode:
authorYour Name <you@example.com>2026-05-19 02:31:19 +0530
committerYour Name <you@example.com>2026-05-19 02:32:41 +0530
commit81f2dc52dc42d01c89dff45a5407ec40b8863052 (patch)
tree15018c2438639ca89dc6d33a5144c10d0b1c2af0 /main/sync_manager.h
parent75688d55b3c8d13c8c9a50da9668ec408f684cb3 (diff)
feat: local Nostr relay with relay selection, sync, and integration tests
Local Nostr relay (NIP-01) on port 4869 with LittleFS 4MB storage. All events published locally first, then synced to public relays via REQ-diff. Relay selection via NIP-11 HTTP probing with NIP-77 scoring and auto-failover. Components: - wisp_relay: 16-file local relay (ws_server, storage_engine, sub_manager, broadcaster, relay_validator, router, handlers, rate_limiter, nip11, deletion, flash_monitor, relay_types) - esp_littlefs: LittleFS VFS integration (git submodule) - negentropy: for future NIP-77 binary sync (git submodule) New source files: - local_relay.c/h: thin wrapper for relay init/start/publish - relay_selector.c/h: NIP-11 probe + scoring + auto-failover - sync_manager.c/h: REQ-diff sync (primary 30min, fallback 6h) Bug fixes: - config.c: use-after-free (cJSON_Delete before seed_relays/sync parsing) - local_relay: moved init to app_main for boot-time start (not gated on STA IP) Flash layout: 4MB LittleFS partition at 0x500000 for relay_store Test results (Board B, live hardware): - Smoke: ping + HTTP 4869 + NIP-11: PASS - NIP-11 info document: 10/11 PASS - WS pub/sub (connect, REQ/EOSE, EVENT/OK, CLOSE, concurrent): 6/6 PASS - Unit tests (relay_validator + relay_selector): 13/13 PASS Hardware test make targets in physical-router-test-automation/: - make relay-build, relay-flash-b, relay-test-smoke/nip11/pubsub/sync/full
Diffstat (limited to 'main/sync_manager.h')
-rw-r--r--main/sync_manager.h26
1 files changed, 26 insertions, 0 deletions
diff --git a/main/sync_manager.h b/main/sync_manager.h
new file mode 100644
index 0000000..1ba5a7d
--- /dev/null
+++ b/main/sync_manager.h
@@ -0,0 +1,26 @@
1#ifndef SYNC_MANAGER_H
2#define SYNC_MANAGER_H
3
4#include "esp_err.h"
5#include "relay_selector.h"
6#include "freertos/FreeRTOS.h"
7#include "freertos/semphr.h"
8#include <stdbool.h>
9
10typedef struct {
11 relay_selector_t *selector;
12 bool running;
13 bool sync_in_progress;
14 uint32_t last_negentropy_sync;
15 uint32_t last_reqdiff_sync;
16 SemaphoreHandle_t lock;
17} sync_manager_t;
18
19esp_err_t sync_manager_init(sync_manager_t *mgr, relay_selector_t *selector);
20void sync_manager_start(sync_manager_t *mgr);
21void sync_manager_stop(sync_manager_t *mgr);
22
23esp_err_t sync_manager_do_negentropy_sync(sync_manager_t *mgr);
24esp_err_t sync_manager_do_reqdiff_sync(sync_manager_t *mgr);
25
26#endif