2017-01-04 18:54:07 +02:00
|
|
|
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
#ifndef ESP_MDNS_H_
|
|
|
|
#define ESP_MDNS_H_
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-08-31 19:06:54 +02:00
|
|
|
#include <esp_netif.h>
|
2017-12-07 14:21:40 +01:00
|
|
|
#include "esp_event.h"
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2017-12-07 14:21:40 +01:00
|
|
|
#define MDNS_TYPE_A 0x0001
|
|
|
|
#define MDNS_TYPE_PTR 0x000C
|
|
|
|
#define MDNS_TYPE_TXT 0x0010
|
|
|
|
#define MDNS_TYPE_AAAA 0x001C
|
|
|
|
#define MDNS_TYPE_SRV 0x0021
|
|
|
|
#define MDNS_TYPE_OPT 0x0029
|
|
|
|
#define MDNS_TYPE_NSEC 0x002F
|
|
|
|
#define MDNS_TYPE_ANY 0x00FF
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-06-03 16:56:12 +02:00
|
|
|
/**
|
|
|
|
* @brief Asynchronous query handle
|
|
|
|
*/
|
|
|
|
typedef struct mdns_search_once_s mdns_search_once_t;
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief mDNS enum to specify the ip_protocol type
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
MDNS_IP_PROTOCOL_V4,
|
|
|
|
MDNS_IP_PROTOCOL_V6,
|
|
|
|
MDNS_IP_PROTOCOL_MAX
|
|
|
|
} mdns_ip_protocol_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief mDNS basic text item structure
|
|
|
|
* Used in mdns_service_add()
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2019-05-03 16:31:11 +02:00
|
|
|
const char * key; /*!< item key name */
|
|
|
|
const char * value; /*!< item value string */
|
2017-12-07 14:21:40 +01:00
|
|
|
} mdns_txt_item_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief mDNS query linked list IP item
|
|
|
|
*/
|
|
|
|
typedef struct mdns_ip_addr_s {
|
2019-08-31 19:06:54 +02:00
|
|
|
esp_ip_addr_t addr; /*!< IP address */
|
2017-12-07 14:21:40 +01:00
|
|
|
struct mdns_ip_addr_s * next; /*!< next IP, or NULL for the last IP in the list */
|
|
|
|
} mdns_ip_addr_t;
|
|
|
|
|
2019-08-31 19:06:54 +02:00
|
|
|
typedef enum mdns_if_internal {
|
|
|
|
MDNS_IF_STA = 0,
|
|
|
|
MDNS_IF_AP = 1,
|
|
|
|
MDNS_IF_ETH = 2,
|
|
|
|
MDNS_IF_MAX
|
|
|
|
} mdns_if_t;
|
|
|
|
|
2017-12-07 14:21:40 +01:00
|
|
|
/**
|
|
|
|
* @brief mDNS query result structure
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
|
|
|
typedef struct mdns_result_s {
|
2017-12-07 14:21:40 +01:00
|
|
|
struct mdns_result_s * next; /*!< next result, or NULL for the last result in the list */
|
|
|
|
|
2019-08-31 19:06:54 +02:00
|
|
|
mdns_if_t tcpip_if; /*!< interface index */
|
2021-04-21 15:34:22 +08:00
|
|
|
uint32_t ttl; /*!< time to live */
|
2019-08-31 19:06:54 +02:00
|
|
|
|
2017-12-07 14:21:40 +01:00
|
|
|
mdns_ip_protocol_t ip_protocol; /*!< ip_protocol type of the interface (v4/v6) */
|
|
|
|
// PTR
|
|
|
|
char * instance_name; /*!< instance name */
|
2021-04-21 15:34:22 +08:00
|
|
|
char * service_type; /*!< service type */
|
|
|
|
char * proto; /*!< srevice protocol */
|
2017-12-07 14:21:40 +01:00
|
|
|
// SRV
|
|
|
|
char * hostname; /*!< hostname */
|
|
|
|
uint16_t port; /*!< service port */
|
|
|
|
// TXT
|
|
|
|
mdns_txt_item_t * txt; /*!< txt record */
|
2021-06-15 20:13:00 +08:00
|
|
|
uint8_t *txt_value_len; /*!< array of txt value len of each record */
|
2017-12-07 14:21:40 +01:00
|
|
|
size_t txt_count; /*!< number of txt items */
|
|
|
|
// A and AAAA
|
2019-12-19 10:31:02 +01:00
|
|
|
mdns_ip_addr_t * addr; /*!< linked list of IP addresses found */
|
2017-01-04 18:54:07 +02:00
|
|
|
} mdns_result_t;
|
|
|
|
|
2021-08-05 16:59:04 +08:00
|
|
|
typedef void (*mdns_query_notify_t)(mdns_search_once_t *search);
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
|
|
|
* @brief Initialize mDNS on given interface
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK on success
|
2019-03-22 08:49:12 +01:00
|
|
|
* - ESP_ERR_INVALID_STATE when failed to register event handler
|
2017-01-04 18:54:07 +02:00
|
|
|
* - ESP_ERR_NO_MEM on memory error
|
2019-03-22 08:49:12 +01:00
|
|
|
* - ESP_FAIL when failed to start mdns task
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2019-07-16 16:33:30 +07:00
|
|
|
esp_err_t mdns_init(void);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Stop and free mDNS server
|
|
|
|
*
|
|
|
|
*/
|
2019-07-16 16:33:30 +07:00
|
|
|
void mdns_free(void);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the hostname for mDNS server
|
2017-12-07 14:21:40 +01:00
|
|
|
* required if you want to advertise services
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @param hostname Hostname to set
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_hostname_set(const char * hostname);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Adds a hostname and address to be delegated
|
|
|
|
* A/AAAA queries will be replied for the hostname and
|
|
|
|
* services can be added to this host.
|
|
|
|
*
|
|
|
|
* @param hostname Hostname to add
|
|
|
|
* @param address_list The IP address list of the host
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_delegate_hostname_add(const char * hostname, const mdns_ip_addr_t *address_list);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Remove a delegated hostname
|
|
|
|
* All the services added to this host will also be removed.
|
|
|
|
*
|
|
|
|
* @param hostname Hostname to remove
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*
|
|
|
|
*/
|
2021-04-02 18:06:10 +08:00
|
|
|
esp_err_t mdns_delegate_hostname_remove(const char * hostname);
|
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Query whether a hostname has been added
|
|
|
|
*
|
|
|
|
* @param hostname Hostname to query
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - true The hostname has been added.
|
|
|
|
* - false The hostname has not been added.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
bool mdns_hostname_exists(const char * hostname);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
|
|
|
* @brief Set the default instance name for mDNS server
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param instance_name Instance name to set
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_instance_name_set(const char * instance_name);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Add service to mDNS server
|
|
|
|
*
|
2021-06-15 20:13:00 +08:00
|
|
|
* @note The value length of txt items will be automatically decided by strlen
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param instance_name instance name to set. If NULL,
|
2021-09-13 19:33:02 +08:00
|
|
|
* global instance name or hostname will be used.
|
|
|
|
* Note that MDNS_MULTIPLE_INSTANCE config option
|
|
|
|
* needs to be enabled for adding multiple instances
|
|
|
|
* with the same instance type.
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param port service port
|
|
|
|
* @param txt string array of TXT data (eg. {{"var","val"},{"other","2"}})
|
2019-03-22 08:49:12 +01:00
|
|
|
* @param num_items number of items in TXT data
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
2019-12-19 10:31:02 +01:00
|
|
|
* - ESP_FAIL failed to add service
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_service_add(const char * instance_name, const char * service_type, const char * proto, uint16_t port, mdns_txt_item_t txt[], size_t num_items);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Add service to mDNS server with a delegated hostname
|
|
|
|
*
|
2021-06-15 20:13:00 +08:00
|
|
|
* @note The value length of txt items will be automatically decided by strlen
|
|
|
|
*
|
2021-04-07 16:21:16 +08:00
|
|
|
* @param instance_name instance name to set. If NULL,
|
|
|
|
* global instance name or hostname will be used
|
2021-09-13 19:33:02 +08:00
|
|
|
* Note that MDNS_MULTIPLE_INSTANCE config option
|
|
|
|
* needs to be enabled for adding multiple instances
|
|
|
|
* with the same instance type.
|
2021-04-07 16:21:16 +08:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param port service port
|
|
|
|
* @param txt string array of TXT data (eg. {{"var","val"},{"other","2"}})
|
|
|
|
* @param num_items number of items in TXT data
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_FAIL failed to add service
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_add_for_host(const char * instance_name, const char * service_type, const char * proto,
|
|
|
|
const char * hostname, uint16_t port, mdns_txt_item_t txt[], size_t num_items);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Check whether a service has been added.
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, checks for the local hostname.
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - true Correspondding service has been added.
|
|
|
|
* - false Service not found.
|
|
|
|
*/
|
|
|
|
bool mdns_service_exists(const char * service_type, const char * proto, const char * hostname);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2021-09-13 19:33:02 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Check whether a service has been added.
|
|
|
|
*
|
|
|
|
* @param instance instance name
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, checks for the local hostname.
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - true Correspondding service has been added.
|
|
|
|
* - false Service not found.
|
|
|
|
*/
|
|
|
|
bool mdns_service_exists_with_instance(const char *instance, const char *service_type, const char *proto,
|
|
|
|
const char *hostname);
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
|
|
|
* @brief Remove service from mDNS server
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
2017-01-04 18:54:07 +02:00
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
2019-03-22 08:49:12 +01:00
|
|
|
* - ESP_ERR_NO_MEM memory error
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_service_remove(const char * service_type, const char * proto);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Remove service from mDNS server with hostname
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
2021-03-30 13:19:01 +08:00
|
|
|
esp_err_t mdns_service_remove_for_host(const char * service_type, const char * proto, const char *hostname);
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
|
|
|
* @brief Set instance name for service
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param instance_name instance name to set
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_service_instance_name_set(const char * service_type, const char * proto, const char * instance_name);
|
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Set instance name for service with hostname
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param instance_name instance name to set
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_instance_name_set_for_host(const char * service_type, const char * proto, const char * hostname,
|
|
|
|
const char * instance_name);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2017-12-07 14:21:40 +01:00
|
|
|
/**
|
|
|
|
* @brief Set service port
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param port service port
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
2019-03-22 08:49:12 +01:00
|
|
|
* - ESP_ERR_NO_MEM memory error
|
2017-12-07 14:21:40 +01:00
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_port_set(const char * service_type, const char * proto, uint16_t port);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Set service port with hostname
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param port service port
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_port_set_for_host(const char * service_type, const char * proto, const char * hostname,
|
2021-03-30 13:19:01 +08:00
|
|
|
uint16_t port);
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Replace all TXT items for service
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2021-06-15 20:13:00 +08:00
|
|
|
* @note The value length of txt items will be automatically decided by strlen
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
2017-01-04 18:54:07 +02:00
|
|
|
* @param proto service protocol (_tcp, _udp)
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param txt array of TXT data (eg. {{"var","val"},{"other","2"}})
|
2019-03-22 08:49:12 +01:00
|
|
|
* @param num_items number of items in TXT data
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_service_txt_set(const char * service_type, const char * proto, mdns_txt_item_t txt[], uint8_t num_items);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Replace all TXT items for service with hostname
|
|
|
|
*
|
2021-06-15 20:13:00 +08:00
|
|
|
* @note The value length of txt items will be automatically decided by strlen
|
|
|
|
*
|
2021-04-07 16:21:16 +08:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param txt array of TXT data (eg. {{"var","val"},{"other","2"}})
|
|
|
|
* @param num_items number of items in TXT data
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_txt_set_for_host(const char * service_type, const char * proto, const char * hostname,
|
2021-03-30 13:19:01 +08:00
|
|
|
mdns_txt_item_t txt[], uint8_t num_items);
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Set/Add TXT item for service TXT record
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2021-06-15 20:13:00 +08:00
|
|
|
* @note The value length will be automatically decided by strlen
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
2017-01-04 18:54:07 +02:00
|
|
|
* @param proto service protocol (_tcp, _udp)
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param key the key that you want to add/update
|
|
|
|
* @param value the new value of the key
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
2017-12-07 14:21:40 +01:00
|
|
|
* - ESP_ERR_NO_MEM memory error
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_service_txt_item_set(const char * service_type, const char * proto, const char * key, const char * value);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-06-15 20:13:00 +08:00
|
|
|
/**
|
|
|
|
* @brief Set/Add TXT item for service TXT record
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param key the key that you want to add/update
|
|
|
|
* @param value the new value of the key
|
|
|
|
* @param value_len the length of the value
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_txt_item_set_with_explicit_value_len(const char *service_type, const char *proto,
|
|
|
|
const char *key, const char *value, uint8_t value_len);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Set/Add TXT item for service TXT record with hostname
|
|
|
|
*
|
2021-06-15 20:13:00 +08:00
|
|
|
* @note The value length will be automatically decided by strlen
|
|
|
|
*
|
2021-04-07 16:21:16 +08:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param key the key that you want to add/update
|
|
|
|
* @param value the new value of the key
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_txt_item_set_for_host(const char * service_type, const char * proto, const char * hostname,
|
|
|
|
const char * key, const char * value);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2021-06-15 20:13:00 +08:00
|
|
|
/**
|
|
|
|
* @brief Set/Add TXT item for service TXT record with hostname and txt value length
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param key the key that you want to add/update
|
|
|
|
* @param value the new value of the key
|
|
|
|
* @param value_len the length of the value
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_txt_item_set_for_host_with_explicit_value_len(const char *service_type, const char *proto,
|
|
|
|
const char *hostname, const char *key,
|
|
|
|
const char *value, uint8_t value_len);
|
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Remove TXT item for service TXT record
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param key the key that you want to remove
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_txt_item_remove(const char * service_type, const char * proto, const char * key);
|
|
|
|
|
2021-04-07 16:21:16 +08:00
|
|
|
/**
|
|
|
|
* @brief Remove TXT item for service TXT record with hostname
|
|
|
|
*
|
|
|
|
* @param service_type service type (_http, _ftp, etc)
|
|
|
|
* @param proto service protocol (_tcp, _udp)
|
|
|
|
* @param hostname service hostname. If NULL, local hostname will be used.
|
|
|
|
* @param key the key that you want to remove
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
* - ESP_ERR_NOT_FOUND Service not found
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_service_txt_item_remove_for_host(const char * service_type, const char * proto, const char * hostname,
|
|
|
|
const char * key);
|
2021-03-30 13:19:01 +08:00
|
|
|
|
2017-12-07 14:21:40 +01:00
|
|
|
/**
|
|
|
|
* @brief Remove and free all services from mDNS server
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_ARG Parameter error
|
|
|
|
*/
|
2019-07-16 16:33:30 +07:00
|
|
|
esp_err_t mdns_service_remove_all(void);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
2021-06-03 16:56:12 +02:00
|
|
|
/**
|
|
|
|
* @brief Deletes the finished query. Call this only after the search has ended!
|
|
|
|
*
|
|
|
|
* @param search pointer to search object
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE search has not finished
|
|
|
|
* - ESP_ERR_INVALID_ARG pointer to search object is NULL
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_query_async_delete(mdns_search_once_t* search);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get results from search pointer. Results available as a pointer to the output parameter.
|
|
|
|
* Pointer to search object has to be deleted via `mdns_query_async_delete` once the query has finished.
|
|
|
|
* The results although have to be freed manually.
|
|
|
|
*
|
|
|
|
* @param search pointer to search object
|
|
|
|
* @param timeout time in milliseconds to wait for answers
|
|
|
|
* @param results pointer to the results of the query
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* True if search has finished before or at timeout
|
|
|
|
* False if search timeout is over
|
|
|
|
*/
|
|
|
|
bool mdns_query_async_get_results(mdns_search_once_t* search, uint32_t timeout, mdns_result_t ** results);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Query mDNS for host or service asynchronousely.
|
|
|
|
* Search has to be tested for progress and deleted manually!
|
|
|
|
*
|
|
|
|
* @param name service instance or host name (NULL for PTR queries)
|
|
|
|
* @param service_type service type (_http, _arduino, _ftp etc.) (NULL for host queries)
|
|
|
|
* @param proto service protocol (_tcp, _udp, etc.) (NULL for host queries)
|
|
|
|
* @param type type of query (MDNS_TYPE_*)
|
|
|
|
* @param timeout time in milliseconds during which mDNS query is active
|
|
|
|
* @param max_results maximum results to be collected
|
2021-08-05 16:59:04 +08:00
|
|
|
* @param notifier Notification function to be called when the result is ready, can be NULL
|
2021-06-03 16:56:12 +02:00
|
|
|
*
|
|
|
|
* @return mdns_search_once_s pointer to new search object if query initiated successfully.
|
|
|
|
* NULL otherwise.
|
|
|
|
*/
|
2021-08-05 16:59:04 +08:00
|
|
|
mdns_search_once_t *mdns_query_async_new(const char *name, const char *service_type, const char *proto, uint16_t type,
|
|
|
|
uint32_t timeout, size_t max_results, mdns_query_notify_t notifier);
|
2021-06-03 16:56:12 +02:00
|
|
|
|
2017-01-04 18:54:07 +02:00
|
|
|
/**
|
|
|
|
* @brief Query mDNS for host or service
|
2017-12-07 14:21:40 +01:00
|
|
|
* All following query methods are derived from this one
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param name service instance or host name (NULL for PTR queries)
|
|
|
|
* @param service_type service type (_http, _arduino, _ftp etc.) (NULL for host queries)
|
|
|
|
* @param proto service protocol (_tcp, _udp, etc.) (NULL for host queries)
|
|
|
|
* @param type type of query (MDNS_TYPE_*)
|
|
|
|
* @param timeout time in milliseconds to wait for answers.
|
|
|
|
* @param max_results maximum results to be collected
|
|
|
|
* @param results pointer to the results of the query
|
|
|
|
* results must be freed using mdns_query_results_free below
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_ERR_INVALID_ARG timeout was not given
|
|
|
|
*/
|
|
|
|
esp_err_t mdns_query(const char * name, const char * service_type, const char * proto, uint16_t type, uint32_t timeout, size_t max_results, mdns_result_t ** results);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Free query results
|
|
|
|
*
|
|
|
|
* @param results linked list of results to be freed
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
void mdns_query_results_free(mdns_result_t * results);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Query mDNS for service
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param service_type service type (_http, _arduino, _ftp etc.)
|
|
|
|
* @param proto service protocol (_tcp, _udp, etc.)
|
|
|
|
* @param timeout time in milliseconds to wait for answer.
|
|
|
|
* @param max_results maximum results to be collected
|
|
|
|
* @param results pointer to the results of the query
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_ERR_INVALID_ARG parameter error
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_query_ptr(const char * service_type, const char * proto, uint32_t timeout, size_t max_results, mdns_result_t ** results);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Query mDNS for SRV record
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param instance_name service instance name
|
|
|
|
* @param service_type service type (_http, _arduino, _ftp etc.)
|
|
|
|
* @param proto service protocol (_tcp, _udp, etc.)
|
|
|
|
* @param timeout time in milliseconds to wait for answer.
|
|
|
|
* @param result pointer to the result of the query
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_ERR_INVALID_ARG parameter error
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_query_srv(const char * instance_name, const char * service_type, const char * proto, uint32_t timeout, mdns_result_t ** result);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Query mDNS for TXT record
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param instance_name service instance name
|
|
|
|
* @param service_type service type (_http, _arduino, _ftp etc.)
|
|
|
|
* @param proto service protocol (_tcp, _udp, etc.)
|
|
|
|
* @param timeout time in milliseconds to wait for answer.
|
|
|
|
* @param result pointer to the result of the query
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_ERR_INVALID_ARG parameter error
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2017-12-07 14:21:40 +01:00
|
|
|
esp_err_t mdns_query_txt(const char * instance_name, const char * service_type, const char * proto, uint32_t timeout, mdns_result_t ** result);
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
/**
|
2017-12-07 14:21:40 +01:00
|
|
|
* @brief Query mDNS for A record
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param host_name host name to look for
|
|
|
|
* @param timeout time in milliseconds to wait for answer.
|
|
|
|
* @param addr pointer to the resulting IP4 address
|
2017-01-04 18:54:07 +02:00
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
2017-12-07 14:21:40 +01:00
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_ERR_INVALID_ARG parameter error
|
|
|
|
*/
|
2019-08-31 19:06:54 +02:00
|
|
|
esp_err_t mdns_query_a(const char * host_name, uint32_t timeout, esp_ip4_addr_t * addr);
|
2017-12-07 14:21:40 +01:00
|
|
|
|
2021-01-18 19:14:51 +08:00
|
|
|
#if CONFIG_LWIP_IPV6
|
2017-12-07 14:21:40 +01:00
|
|
|
/**
|
|
|
|
* @brief Query mDNS for A record
|
|
|
|
*
|
2021-02-26 18:28:57 +04:00
|
|
|
* Please note that hostname must not contain domain name, as mDNS uses '.local' domain.
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param host_name host name to look for
|
|
|
|
* @param timeout time in milliseconds to wait for answer. If 0, max_results needs to be defined
|
|
|
|
* @param addr pointer to the resulting IP6 address
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* - ESP_OK success
|
|
|
|
* - ESP_ERR_INVALID_STATE mDNS is not running
|
|
|
|
* - ESP_ERR_NO_MEM memory error
|
|
|
|
* - ESP_ERR_INVALID_ARG parameter error
|
|
|
|
*/
|
2019-08-31 19:06:54 +02:00
|
|
|
esp_err_t mdns_query_aaaa(const char * host_name, uint32_t timeout, esp_ip6_addr_t * addr);
|
2021-01-18 19:14:51 +08:00
|
|
|
#endif
|
2017-12-07 14:21:40 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief System event handler
|
|
|
|
* This method controls the service state on all active interfaces and applications are required
|
|
|
|
* to call it from the system event handler for normal operation of mDNS service.
|
|
|
|
*
|
2021-02-26 18:28:57 +04:00
|
|
|
* Please note that hostname must not contain domain name, as mDNS uses '.local' domain.
|
|
|
|
*
|
2017-12-07 14:21:40 +01:00
|
|
|
* @param ctx The system event context
|
|
|
|
* @param event The system event
|
2017-01-04 18:54:07 +02:00
|
|
|
*/
|
2019-07-05 16:58:04 +08:00
|
|
|
esp_err_t mdns_handle_system_event(void *ctx, system_event_t *event) __attribute__((deprecated));
|
2017-01-04 18:54:07 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* ESP_MDNS_H_ */
|