Last piece to connect client to provider: actually downloading the image and displaying it

This commit is contained in:
2026-04-05 19:34:45 -04:00
parent 9269e3b873
commit 58948bdfb6
8 changed files with 346 additions and 76 deletions
+58 -38
View File
@@ -32,15 +32,19 @@ static bool resolve_provider_ip(char *out_ip, size_t out_ip_len)
{
esp_ip4_addr_t addr = {};
err = mdns_query_a(CONFIG_CALENDINK_PROVIDER_MDNS_HOSTNAME, 5000, &addr);
if (err == ESP_OK)
constexpr int kMaxRetries = 3;
for (int attempt = 1; attempt <= kMaxRetries; attempt++)
{
snprintf(out_ip, out_ip_len, IPSTR, IP2STR(&addr));
ESP_LOGI(TAG, "Provider resolved: %s", out_ip);
return true;
err = mdns_query_a(CONFIG_CALENDINK_PROVIDER_MDNS_HOSTNAME, 5000, &addr);
if (err == ESP_OK)
{
snprintf(out_ip, out_ip_len, IPSTR, IP2STR(&addr));
ESP_LOGI(TAG, "Provider resolved: %s (attempt %d)", out_ip, attempt);
return true;
}
ESP_LOGW(TAG, "mDNS attempt %d/%d failed: %s", attempt, kMaxRetries,
esp_err_to_name(err));
}
ESP_LOGW(TAG, "mDNS resolution failed: %s", esp_err_to_name(err));
}
fallback:
@@ -57,13 +61,15 @@ fallback:
// ── Provider Communication Test ─────────────────────────────────────────────
void test_provider_communication(void)
bool test_provider_communication(uint8 *out_buffer, size_t buffer_size)
{
bool success = false;
// 1. Resolve Provider IP
char provider_ip[16] = {};
if (!resolve_provider_ip(provider_ip, sizeof(provider_ip)))
{
return;
return false;
}
uint16_t provider_port = CONFIG_CALENDINK_PROVIDER_PORT;
@@ -74,7 +80,7 @@ void test_provider_communication(void)
if (err != ESP_OK)
{
ESP_LOGE(TAG, "Failed to get WiFi MAC: %s", esp_err_to_name(err));
return;
return false;
}
char mac_str[18] = {};
@@ -84,59 +90,73 @@ void test_provider_communication(void)
ESP_LOGI(TAG, "Client MAC: %s", mac_str);
// 3. Register with Provider: POST /api/devices/register
// This may return "already_registered" — that's fine, we continue regardless.
{
char *url =
http_build_url(provider_ip, provider_port, "/api/devices/register");
if (url == nullptr)
if (url != nullptr)
{
return;
char json_body[64] = {};
snprintf(json_body, sizeof(json_body), "{\"mac\":\"%s\"}", mac_str);
http_text_response_t resp = {};
err = http_post_json(url, json_body, &resp);
if (err == ESP_OK)
{
ESP_LOGI(TAG, "Register response (%d): %s", resp.status_code,
resp.body ? resp.body : "(empty)");
}
else
{
ESP_LOGW(TAG, "Register request failed: %s (continuing anyway)",
esp_err_to_name(err));
}
free(resp.body);
free(url);
}
char json_body[64] = {};
snprintf(json_body, sizeof(json_body), "{\"mac\":\"%s\"}", mac_str);
http_text_response_t resp = {};
err = http_post_json(url, json_body, &resp);
if (err == ESP_OK)
{
ESP_LOGI(TAG, "Register response (%d): %s", resp.status_code,
resp.body ? resp.body : "(empty)");
}
else
{
ESP_LOGE(TAG, "Register request failed: %s", esp_err_to_name(err));
}
free(resp.body);
free(url);
}
// 4. Fetch screen image: GET /api/devices/screen.png?mac=XX:XX:XX:XX:XX:XX
// 4. Fetch screen bitmap: GET /api/devices/screen.bin?mac=XX:XX:XX:XX:XX:XX
{
char path[80] = {};
snprintf(path, sizeof(path), "/api/devices/screen.png?mac=%s", mac_str);
snprintf(path, sizeof(path), "/api/devices/screen.bin?mac=%s", mac_str);
char *url = http_build_url(provider_ip, provider_port, path);
if (url == nullptr)
{
return;
return false;
}
http_binary_response_t resp = {};
err = http_get_binary(url, &resp);
if (err == ESP_OK)
if (err == ESP_OK && resp.status_code == 200)
{
ESP_LOGI(TAG, "Screen image response (%d): %zu bytes", resp.status_code,
resp.data_len);
ESP_LOGI(TAG, "Screen bitmap response: %zu bytes", resp.data_len);
if (resp.data != nullptr && resp.data_len > 0)
{
size_t copy_size = (resp.data_len < buffer_size) ? resp.data_len : buffer_size;
memcpy(out_buffer, resp.data, copy_size);
success = true;
// Debug: log first 10 bytes (should be 0xFF for white top-left pixels)
ESP_LOGI(TAG, "First 10 bytes: %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X",
out_buffer[0], out_buffer[1], out_buffer[2], out_buffer[3],
out_buffer[4], out_buffer[5], out_buffer[6], out_buffer[7],
out_buffer[8], out_buffer[9]);
}
}
else
{
ESP_LOGE(TAG, "Screen image request failed: %s", esp_err_to_name(err));
ESP_LOGE(TAG, "Screen bitmap request failed: %s (status %d)",
esp_err_to_name(err), resp.status_code);
}
free(resp.data);
free(url);
}
return success;
}