| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											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 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 */ | 
					
						
							|  |  |  |     // 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; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @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, | 
					
						
							|  |  |  |  *                          global instance name or hostname will be used | 
					
						
							|  |  |  |  * @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 | 
					
						
							|  |  |  |  * @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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @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_ */
 |