diff options
Diffstat (limited to 'main/tollgate_main.c')
| -rw-r--r-- | main/tollgate_main.c | 32 |
1 files changed, 31 insertions, 1 deletions
diff --git a/main/tollgate_main.c b/main/tollgate_main.c index 33e5b90..561fc3f 100644 --- a/main/tollgate_main.c +++ b/main/tollgate_main.c | |||
| @@ -31,6 +31,11 @@ | |||
| 31 | #include "sync_manager.h" | 31 | #include "sync_manager.h" |
| 32 | #include "beacon_price.h" | 32 | #include "beacon_price.h" |
| 33 | #include "market.h" | 33 | #include "market.h" |
| 34 | #include "stratum_client.h" | ||
| 35 | #include "stratum_proxy.h" | ||
| 36 | #include "sw_miner.h" | ||
| 37 | #include "asic_miner.h" | ||
| 38 | #include "mining_payment.h" | ||
| 34 | 39 | ||
| 35 | #define MAX_STA_RETRY 5 | 40 | #define MAX_STA_RETRY 5 |
| 36 | static const char *TAG = "tollgate_main"; | 41 | static const char *TAG = "tollgate_main"; |
| @@ -190,7 +195,6 @@ static void start_services(void) | |||
| 190 | session_manager_init(); | 195 | session_manager_init(); |
| 191 | 196 | ||
| 192 | const tollgate_config_t *cfg = tollgate_config_get(); | 197 | const tollgate_config_t *cfg = tollgate_config_get(); |
| 193 | |||
| 194 | mint_health_init(cfg->accepted_mints, cfg->accepted_mint_count); | 198 | mint_health_init(cfg->accepted_mints, cfg->accepted_mint_count); |
| 195 | mint_health_start(); | 199 | mint_health_start(); |
| 196 | 200 | ||
| @@ -199,6 +203,11 @@ static void start_services(void) | |||
| 199 | } else { | 203 | } else { |
| 200 | nucula_wallet_init(cfg->mint_url); | 204 | nucula_wallet_init(cfg->mint_url); |
| 201 | } | 205 | } |
| 206 | |||
| 207 | if (cfg->mining_enabled) { | ||
| 208 | firewall_set_mining_port(cfg->mining_port); | ||
| 209 | firewall_set_sandbox_mint_access(cfg->mining_sandbox_mint_access); | ||
| 210 | } | ||
| 202 | lightning_payout_init(&cfg->payout); | 211 | lightning_payout_init(&cfg->payout); |
| 203 | 212 | ||
| 204 | dns_server_start(ap_ip_info.ip, upstream_dns); | 213 | dns_server_start(ap_ip_info.ip, upstream_dns); |
| @@ -223,6 +232,26 @@ static void start_services(void) | |||
| 223 | cvm_server_start(); | 232 | cvm_server_start(); |
| 224 | } | 233 | } |
| 225 | 234 | ||
| 235 | if (cfg2->mining_enabled) { | ||
| 236 | ESP_LOGI(TAG, "Mining subsystem enabled, initializing..."); | ||
| 237 | mining_payment_init(); | ||
| 238 | stratum_client_init(); | ||
| 239 | stratum_proxy_init(cfg2->mining_port); | ||
| 240 | |||
| 241 | if (cfg2->mining_payout_mode != MINING_PAYOUT_UPSTREAM) { | ||
| 242 | stratum_client_start(); | ||
| 243 | } | ||
| 244 | |||
| 245 | asic_miner_init(); | ||
| 246 | if (asic_miner_is_present()) { | ||
| 247 | asic_miner_start(); | ||
| 248 | ESP_LOGI(TAG, "ASIC miner started"); | ||
| 249 | } else { | ||
| 250 | sw_miner_start(); | ||
| 251 | ESP_LOGI(TAG, "Software miner started (no ASIC)"); | ||
| 252 | } | ||
| 253 | } | ||
| 254 | |||
| 226 | s_services_running = true; | 255 | s_services_running = true; |
| 227 | if (s_services_mutex) xSemaphoreGive(s_services_mutex); | 256 | if (s_services_mutex) xSemaphoreGive(s_services_mutex); |
| 228 | ESP_LOGI(TAG, "=== TollGate services started ==="); | 257 | ESP_LOGI(TAG, "=== TollGate services started ==="); |
| @@ -392,5 +421,6 @@ void app_main(void) | |||
| 392 | tollgate_client_tick(); | 421 | tollgate_client_tick(); |
| 393 | lightning_payout_tick(); | 422 | lightning_payout_tick(); |
| 394 | market_tick(); | 423 | market_tick(); |
| 424 | stratum_client_tick(); | ||
| 395 | } | 425 | } |
| 396 | } | 426 | } |