2020-11-18 21:20:35 +01:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2022 Espressif Systems (Shanghai) CO LTD
|
2022-10-11 16:31:57 +02:00
|
|
|
*
|
2020-11-18 21:20:35 +01:00
|
|
|
* SPDX-License-Identifier: Unlicense OR CC0-1.0
|
2022-10-11 16:31:57 +02:00
|
|
|
*/
|
2020-11-18 21:20:35 +01:00
|
|
|
|
2022-10-11 16:31:57 +02:00
|
|
|
/*
|
2020-11-18 21:20:35 +01:00
|
|
|
* Modem console example
|
2022-10-11 16:31:57 +02:00
|
|
|
*
|
2020-11-18 21:20:35 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
#include "esp_console.h"
|
|
|
|
#include "argtable3/argtable3.h"
|
|
|
|
#include "esp_log.h"
|
|
|
|
#include "esp_http_client.h"
|
|
|
|
|
|
|
|
static const char *TAG = "modem_console_httpget";
|
|
|
|
|
|
|
|
static esp_err_t http_event_handler(esp_http_client_event_t *evt)
|
|
|
|
{
|
|
|
|
switch (evt->event_id) {
|
|
|
|
case HTTP_EVENT_ERROR:
|
|
|
|
ESP_LOGD(TAG, "HTTP_EVENT_ERROR");
|
|
|
|
break;
|
|
|
|
case HTTP_EVENT_ON_CONNECTED:
|
|
|
|
ESP_LOGD(TAG, "HTTP_EVENT_ON_CONNECTED");
|
|
|
|
break;
|
|
|
|
case HTTP_EVENT_HEADER_SENT:
|
|
|
|
ESP_LOGD(TAG, "HTTP_EVENT_HEADER_SENT");
|
|
|
|
break;
|
|
|
|
case HTTP_EVENT_ON_HEADER:
|
|
|
|
ESP_LOGD(TAG, "HTTP_EVENT_ON_HEADER, key=%s, value=%s", evt->header_key, evt->header_value);
|
|
|
|
break;
|
|
|
|
case HTTP_EVENT_ON_DATA:
|
|
|
|
ESP_LOGD(TAG, "HTTP_EVENT_ON_DATA, len=%d", evt->data_len);
|
|
|
|
if ((bool)evt->user_data &&
|
|
|
|
!esp_http_client_is_chunked_response(evt->client)) {
|
|
|
|
ESP_LOG_BUFFER_HEXDUMP(TAG, evt->data, evt->data_len, ESP_LOG_INFO);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case HTTP_EVENT_ON_FINISH:
|
|
|
|
ESP_LOGD(TAG, "HTTP_EVENT_ON_FINISH");
|
|
|
|
break;
|
|
|
|
case HTTP_EVENT_DISCONNECTED:
|
|
|
|
ESP_LOGI(TAG, "HTTP_EVENT_DISCONNECTED");
|
|
|
|
break;
|
2022-01-28 19:48:08 +07:00
|
|
|
default: break;
|
2020-11-18 21:20:35 +01:00
|
|
|
}
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct {
|
|
|
|
struct arg_str *host;
|
|
|
|
struct arg_lit *hex;
|
|
|
|
struct arg_end *end;
|
|
|
|
} http_args;
|
|
|
|
|
|
|
|
static int do_http_client(int argc, char **argv)
|
|
|
|
{
|
|
|
|
int nerrors = arg_parse(argc, argv, (void **)&http_args);
|
|
|
|
if (nerrors != 0) {
|
|
|
|
arg_print_errors(stderr, http_args.end, argv[0]);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
esp_http_client_config_t config = {
|
|
|
|
.event_handler = http_event_handler,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (http_args.host->count > 0) {
|
|
|
|
config.url = http_args.host->sval[0];
|
|
|
|
} else {
|
|
|
|
config.url = "http://httpbin.org/get";
|
|
|
|
}
|
|
|
|
|
|
|
|
if (http_args.hex->count > 0) {
|
|
|
|
// show hex data from http-get
|
|
|
|
config.user_data = (void *)true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
esp_http_client_handle_t client = esp_http_client_init(&config);
|
|
|
|
|
|
|
|
esp_err_t err = esp_http_client_perform(client);
|
|
|
|
if (err == ESP_OK) {
|
2021-11-04 11:41:11 +01:00
|
|
|
uint64_t content_length = esp_http_client_get_content_length(client);
|
|
|
|
ESP_LOGI(TAG, "HTTP GET Status = %d, content_length = %lld",
|
|
|
|
esp_http_client_get_status_code(client), content_length);
|
2020-11-18 21:20:35 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
ESP_LOGE(TAG, "HTTP GET request failed: %s", esp_err_to_name(err));
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void modem_console_register_http(void)
|
|
|
|
{
|
|
|
|
http_args.host = arg_str0(NULL, NULL, "<host>", "address or host-name to send GET request (defaults to http://httpbin.org/get)");
|
|
|
|
http_args.hex = arg_litn("p", "print-hex", 0, 1, "print hex output"),
|
|
|
|
http_args.end = arg_end(1);
|
|
|
|
const esp_console_cmd_t http_cmd = {
|
|
|
|
.command = "httpget",
|
|
|
|
.help = "http get command to test data mode",
|
|
|
|
.hint = NULL,
|
|
|
|
.func = &do_http_client,
|
|
|
|
.argtable = &http_args
|
|
|
|
};
|
|
|
|
ESP_ERROR_CHECK(esp_console_cmd_register(&http_cmd));
|
2022-01-28 19:48:08 +07:00
|
|
|
}
|