diff options
| author | Your Name <you@example.com> | 2026-05-19 14:25:18 +0530 |
|---|---|---|
| committer | Your Name <you@example.com> | 2026-05-19 14:25:18 +0530 |
| commit | e366ceb336550a72c76efea4c98a2a08cca27bce (patch) | |
| tree | 4b45ac6f6e97b6763f81aa6d4a9b968d23e41235 /tests/unit/stubs | |
| parent | 163b8badec9359373a8fc016c2b1fe9ee38e6406 (diff) | |
feat(mining): Bitcoin mining-for-bandwidth payment system
New modules:
- mining_payment.c/h: hashprice calc (nbits->difficulty->sat/GH/s/day),
share validation, client stats, allotment conversion (ms + bytes)
- stratum_client.c/h: SV1 upstream pool connection (subscribe/authorize/submit)
- stratum_proxy.c/h: Local SV1 TCP server for downstream miners, job broadcast
- sw_miner.c/h: Software SHA256d miner (ESP32 CPU fallback)
- asic_miner.c/h: ASIC detection stub (BM1366/BM1368 SPI)
Config:
- config.h/c: mining_payout_mode_t enum (auto/pool/upstream/proxy_only),
stratum pool settings, mining port, hashprice override, sandbox mint access
- Defaults fill nostr_seed_relays (8/8) and nostr_relays (4/4) with fast relays
Integration into existing modules:
- session.h/c: payment_method_t enum (CASHU/MINING/BYTES)
- firewall.h/c: firewall_set_mining_port(), firewall_set_sandbox_mint_access()
- tollgate_api.c: GET /mining/job, POST /mining/share, GET /mining/stats
- tollgate_client.h/c: TG_CLIENT_MINING state, mining discovery tag parsing
- tollgate_main.c: mining init in start_services(), stratum_client_tick() in loop
- captive_portal.c: tabbed Cashu/Mine UI with live hashrate polling
Unit tests (69 new assertions across 4 suites):
- test_mining_payment (23 tests): nbits->difficulty, hashprice, client stats, allotment
- test_stratum_proxy (21 tests): job set/get, stats, type validation
- test_session_payment_method (12 tests): PAYMENT_METHOD enum, bytes/cashu methods
- test_tollgate_client_mining (20 tests): mining tag parsing, discovery struct
- test_firewall_sandbox (16 tests): client grant/revoke, max clients, setters
Enhanced test stubs:
- BaseType_t/pdPASS in freertos/task.h
- lwip: sockets.h, etharp.h, prot/ip.h, prot/ip4.h, prot/tcp.h, netif.h
- dns_server.h, esp_wifi_ap_get_sta_list.h
Build fixes:
- cvm_server.c: replace esp_timer_get_time() with xTaskGetTickCount(),
fix process_relay_message() 3-arg call to 2-arg, add WS keepalive ping
- stratum_proxy.c: widen task_name buffer 16->20
- sw_miner.c: add missing #include esp_random.h
- nucula_src: save_proofs() moved to public in wallet.hpp
Nostr relay updates:
- nostr_seed_relays: +relay.anzenkodo.workers.dev, +nostr.koning-degraaf.nl,
+knostr.neutrine.com, +nostr.einundzwanzig.space (8/8 slots)
- nostr_relays: +relay.anzenkodo.workers.dev, +nostr.koning-degraaf.nl (4/4 slots)
Squash-merge of feature/mining-payment (5 commits: c75230e..9d98ba1)
Diffstat (limited to 'tests/unit/stubs')
| -rw-r--r-- | tests/unit/stubs/dns_server.h | 11 | ||||
| -rw-r--r-- | tests/unit/stubs/esp_wifi_ap_get_sta_list.h | 38 | ||||
| -rw-r--r-- | tests/unit/stubs/freertos/task.h | 7 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/etharp.h | 22 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/ip4_addr.h | 3 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/lwip_napt.h (renamed from tests/unit/stubs/lwip/napt.h) | 0 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/netif.h | 16 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/prot/ip.h | 20 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/prot/ip4.h | 6 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/prot/tcp.h | 13 | ||||
| -rw-r--r-- | tests/unit/stubs/lwip/sockets.h | 6 |
11 files changed, 140 insertions, 2 deletions
diff --git a/tests/unit/stubs/dns_server.h b/tests/unit/stubs/dns_server.h new file mode 100644 index 0000000..0a9450b --- /dev/null +++ b/tests/unit/stubs/dns_server.h | |||
| @@ -0,0 +1,11 @@ | |||
| 1 | #ifndef STUBS_DNS_SERVER_H | ||
| 2 | #define STUBS_DNS_SERVER_H | ||
| 3 | |||
| 4 | #include <stdint.h> | ||
| 5 | #include <stdbool.h> | ||
| 6 | |||
| 7 | static inline void dns_server_set_client_authenticated(uint32_t ip, bool auth) { | ||
| 8 | (void)ip; (void)auth; | ||
| 9 | } | ||
| 10 | |||
| 11 | #endif | ||
diff --git a/tests/unit/stubs/esp_wifi_ap_get_sta_list.h b/tests/unit/stubs/esp_wifi_ap_get_sta_list.h new file mode 100644 index 0000000..3e98032 --- /dev/null +++ b/tests/unit/stubs/esp_wifi_ap_get_sta_list.h | |||
| @@ -0,0 +1,38 @@ | |||
| 1 | #ifndef STUBS_ESP_WIFI_AP_GET_STA_LIST_H | ||
| 2 | #define STUBS_ESP_WIFI_AP_GET_STA_LIST_H | ||
| 3 | |||
| 4 | #include <stdint.h> | ||
| 5 | #include <string.h> | ||
| 6 | #include "esp_err.h" | ||
| 7 | |||
| 8 | #define ESP_WIFI_AP_MAX_STA 10 | ||
| 9 | |||
| 10 | typedef struct { | ||
| 11 | uint8_t mac[6]; | ||
| 12 | } wifi_sta_info_t; | ||
| 13 | |||
| 14 | typedef struct { | ||
| 15 | int num; | ||
| 16 | wifi_sta_info_t sta[ESP_WIFI_AP_MAX_STA]; | ||
| 17 | } wifi_sta_list_t; | ||
| 18 | |||
| 19 | typedef struct { | ||
| 20 | int num; | ||
| 21 | struct { | ||
| 22 | uint8_t mac[6]; | ||
| 23 | esp_ip4_addr_t ip; | ||
| 24 | } sta[ESP_WIFI_AP_MAX_STA]; | ||
| 25 | } wifi_sta_mac_ip_list_t; | ||
| 26 | |||
| 27 | static inline esp_err_t esp_wifi_ap_get_sta_list(wifi_sta_list_t *sta) { | ||
| 28 | memset(sta, 0, sizeof(*sta)); | ||
| 29 | return ESP_FAIL; | ||
| 30 | } | ||
| 31 | |||
| 32 | static inline esp_err_t esp_wifi_ap_get_sta_list_with_ip(const wifi_sta_list_t *sta_in, wifi_sta_mac_ip_list_t *out) { | ||
| 33 | (void)sta_in; | ||
| 34 | memset(out, 0, sizeof(*out)); | ||
| 35 | return ESP_FAIL; | ||
| 36 | } | ||
| 37 | |||
| 38 | #endif | ||
diff --git a/tests/unit/stubs/freertos/task.h b/tests/unit/stubs/freertos/task.h index 3855d41..ec96156 100644 --- a/tests/unit/stubs/freertos/task.h +++ b/tests/unit/stubs/freertos/task.h | |||
| @@ -6,14 +6,17 @@ | |||
| 6 | 6 | ||
| 7 | typedef void *TaskHandle_t; | 7 | typedef void *TaskHandle_t; |
| 8 | typedef void *SemaphoreHandle_t; | 8 | typedef void *SemaphoreHandle_t; |
| 9 | typedef int BaseType_t; | ||
| 10 | |||
| 11 | #define pdPASS 1 | ||
| 9 | 12 | ||
| 10 | static inline void vTaskDelete(TaskHandle_t t) { (void)t; } | 13 | static inline void vTaskDelete(TaskHandle_t t) { (void)t; } |
| 11 | static inline SemaphoreHandle_t xSemaphoreCreateMutex(void) { return (SemaphoreHandle_t)malloc(1); } | 14 | static inline SemaphoreHandle_t xSemaphoreCreateMutex(void) { return (SemaphoreHandle_t)malloc(1); } |
| 12 | static inline void vSemaphoreDelete(SemaphoreHandle_t s) { free(s); } | 15 | static inline void vSemaphoreDelete(SemaphoreHandle_t s) { free(s); } |
| 13 | static inline int xSemaphoreTake(SemaphoreHandle_t s, uint32_t blk) { (void)s; (void)blk; return 1; } | 16 | static inline int xSemaphoreTake(SemaphoreHandle_t s, uint32_t blk) { (void)s; (void)blk; return 1; } |
| 14 | static inline int xSemaphoreGive(SemaphoreHandle_t s) { (void)s; return 1; } | 17 | static inline int xSemaphoreGive(SemaphoreHandle_t s) { (void)s; return 1; } |
| 15 | static inline int xTaskCreate(void (*fn)(void*), const char *n, uint32_t st, void *p, uint32_t pri, TaskHandle_t *h) { | 18 | static inline BaseType_t xTaskCreate(void (*fn)(void*), const char *n, uint32_t st, void *p, uint32_t pri, TaskHandle_t *h) { |
| 16 | (void)fn; (void)n; (void)st; (void)p; (void)pri; (void)h; return 1; | 19 | (void)fn; (void)n; (void)st; (void)p; (void)pri; (void)h; return pdPASS; |
| 17 | } | 20 | } |
| 18 | 21 | ||
| 19 | #endif | 22 | #endif |
diff --git a/tests/unit/stubs/lwip/etharp.h b/tests/unit/stubs/lwip/etharp.h new file mode 100644 index 0000000..adc6b7b --- /dev/null +++ b/tests/unit/stubs/lwip/etharp.h | |||
| @@ -0,0 +1,22 @@ | |||
| 1 | #ifndef STUBS_LWIP_ETHARP_H | ||
| 2 | #define STUBS_LWIP_ETHARP_H | ||
| 3 | |||
| 4 | #include <stdint.h> | ||
| 5 | #include <stddef.h> | ||
| 6 | #include "lwip/ip4_addr.h" | ||
| 7 | |||
| 8 | struct eth_addr { | ||
| 9 | uint8_t addr[6]; | ||
| 10 | }; | ||
| 11 | |||
| 12 | struct netif; | ||
| 13 | |||
| 14 | typedef int err_t; | ||
| 15 | #define ERR_OK 0 | ||
| 16 | |||
| 17 | static inline err_t etharp_get_entry(ssize_t i, ip4_addr_t **ip, struct netif **netif, struct eth_addr **eth) { | ||
| 18 | (void)i; (void)ip; (void)netif; (void)eth; | ||
| 19 | return -1; | ||
| 20 | } | ||
| 21 | |||
| 22 | #endif | ||
diff --git a/tests/unit/stubs/lwip/ip4_addr.h b/tests/unit/stubs/lwip/ip4_addr.h index 174211b..9d92ff0 100644 --- a/tests/unit/stubs/lwip/ip4_addr.h +++ b/tests/unit/stubs/lwip/ip4_addr.h | |||
| @@ -3,6 +3,9 @@ | |||
| 3 | 3 | ||
| 4 | #include <stdint.h> | 4 | #include <stdint.h> |
| 5 | 5 | ||
| 6 | typedef uint32_t u32_t; | ||
| 7 | typedef uint16_t u16_t; | ||
| 8 | |||
| 6 | typedef struct { | 9 | typedef struct { |
| 7 | uint32_t addr; | 10 | uint32_t addr; |
| 8 | } ip4_addr_t; | 11 | } ip4_addr_t; |
diff --git a/tests/unit/stubs/lwip/napt.h b/tests/unit/stubs/lwip/lwip_napt.h index c6a5ca1..c6a5ca1 100644 --- a/tests/unit/stubs/lwip/napt.h +++ b/tests/unit/stubs/lwip/lwip_napt.h | |||
diff --git a/tests/unit/stubs/lwip/netif.h b/tests/unit/stubs/lwip/netif.h index 461a64e..9415539 100644 --- a/tests/unit/stubs/lwip/netif.h +++ b/tests/unit/stubs/lwip/netif.h | |||
| @@ -1,4 +1,20 @@ | |||
| 1 | #ifndef STUBS_LWIP_NETIF_H | 1 | #ifndef STUBS_LWIP_NETIF_H |
| 2 | #define STUBS_LWIP_NETIF_H | 2 | #define STUBS_LWIP_NETIF_H |
| 3 | 3 | ||
| 4 | #include <stdint.h> | ||
| 5 | #include <stddef.h> | ||
| 6 | |||
| 7 | struct pbuf { | ||
| 8 | void *payload; | ||
| 9 | uint16_t len; | ||
| 10 | }; | ||
| 11 | |||
| 12 | static inline uint32_t lwip_ntohl(uint32_t n) { | ||
| 13 | return ((n & 0xFF) << 24) | ((n & 0xFF00) << 8) | ((n >> 8) & 0xFF00) | ((n >> 24) & 0xFF); | ||
| 14 | } | ||
| 15 | |||
| 16 | static inline uint16_t lwip_ntohs(uint16_t n) { | ||
| 17 | return ((n & 0xFF) << 8) | ((n >> 8) & 0xFF); | ||
| 18 | } | ||
| 19 | |||
| 4 | #endif | 20 | #endif |
diff --git a/tests/unit/stubs/lwip/prot/ip.h b/tests/unit/stubs/lwip/prot/ip.h new file mode 100644 index 0000000..0770760 --- /dev/null +++ b/tests/unit/stubs/lwip/prot/ip.h | |||
| @@ -0,0 +1,20 @@ | |||
| 1 | #ifndef STUBS_LWIP_PROT_IP_H | ||
| 2 | #define STUBS_LWIP_PROT_IP_H | ||
| 3 | |||
| 4 | #include <stdint.h> | ||
| 5 | |||
| 6 | #define IP_PROTO_TCP 6 | ||
| 7 | #define IP_PROTO_UDP 17 | ||
| 8 | #define IP_HLEN 20 | ||
| 9 | |||
| 10 | struct ip_hdr { | ||
| 11 | uint8_t _proto; | ||
| 12 | union { | ||
| 13 | uint32_t addr; | ||
| 14 | } src; | ||
| 15 | union { | ||
| 16 | uint32_t addr; | ||
| 17 | } dest; | ||
| 18 | }; | ||
| 19 | |||
| 20 | #endif | ||
diff --git a/tests/unit/stubs/lwip/prot/ip4.h b/tests/unit/stubs/lwip/prot/ip4.h new file mode 100644 index 0000000..0f70170 --- /dev/null +++ b/tests/unit/stubs/lwip/prot/ip4.h | |||
| @@ -0,0 +1,6 @@ | |||
| 1 | #ifndef STUBS_LWIP_PROT_IP4_H | ||
| 2 | #define STUBS_LWIP_PROT_IP4_H | ||
| 3 | |||
| 4 | #include "ip.h" | ||
| 5 | |||
| 6 | #endif | ||
diff --git a/tests/unit/stubs/lwip/prot/tcp.h b/tests/unit/stubs/lwip/prot/tcp.h new file mode 100644 index 0000000..5841371 --- /dev/null +++ b/tests/unit/stubs/lwip/prot/tcp.h | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | #ifndef STUBS_LWIP_PROT_TCP_H | ||
| 2 | #define STUBS_LWIP_PROT_TCP_H | ||
| 3 | |||
| 4 | #include <stdint.h> | ||
| 5 | |||
| 6 | #define TCP_HLEN 20 | ||
| 7 | |||
| 8 | struct tcp_hdr { | ||
| 9 | uint16_t src; | ||
| 10 | uint16_t dest; | ||
| 11 | }; | ||
| 12 | |||
| 13 | #endif | ||
diff --git a/tests/unit/stubs/lwip/sockets.h b/tests/unit/stubs/lwip/sockets.h index 44f03ac..91bf8b2 100644 --- a/tests/unit/stubs/lwip/sockets.h +++ b/tests/unit/stubs/lwip/sockets.h | |||
| @@ -1,4 +1,10 @@ | |||
| 1 | #ifndef STUBS_LWIP_SOCKETS_H | 1 | #ifndef STUBS_LWIP_SOCKETS_H |
| 2 | #define STUBS_LWIP_SOCKETS_H | 2 | #define STUBS_LWIP_SOCKETS_H |
| 3 | 3 | ||
| 4 | #include <sys/socket.h> | ||
| 5 | #include <netinet/in.h> | ||
| 6 | #include <arpa/inet.h> | ||
| 7 | #include <unistd.h> | ||
| 8 | #include <string.h> | ||
| 9 | |||
| 4 | #endif | 10 | #endif |