mini.dns.zeroconf module¶
Multicast DNS Service Discovery for Python, v0.14-wmcbrine Copyright 2003 Paul Scott-Murphy, 2014 William McBrine
This module provides a framework for the use of DNS Service Discovery using IP multicast.
This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- class mini.dns.zeroconf.Zeroconf(interfaces: Union[List[Union[str, int]], mini.dns.zeroconf.InterfaceChoice] = InterfaceChoice.All, unicast: bool = False, ip_version: Optional[mini.dns.zeroconf.IPVersion] = None, apple_p2p: bool = False)[source]¶
Bases:
mini.dns.zeroconf.QuietLogger
Implementation of Zeroconf Multicast DNS Service Discovery
Supports registration, unregistration, queries and browsing.
- property done: bool¶
- wait(timeout: float) None [source]¶
Calling thread waits for a given number of milliseconds or until notified.
- get_service_info(type_: str, name: str, timeout: int = 3000) Optional[mini.dns.zeroconf.ServiceInfo] [source]¶
Returns network’s service information for a particular name and type, or None if no service matches by the timeout, which defaults to 3 seconds.
- add_service_listener(type_: str, listener: mini.dns.zeroconf.ServiceListener) None [source]¶
Adds a listener for a particular service type. This object will then have its add_service and remove_service methods called when services of that type become available and unavailable.
- remove_service_listener(listener: mini.dns.zeroconf.ServiceListener) None [source]¶
Removes a listener from the set that is currently listening.
- remove_all_service_listeners() None [source]¶
Removes a listener from the set that is currently listening.
- register_service(info: mini.dns.zeroconf.ServiceInfo, ttl: Optional[int] = None, allow_name_change: bool = False, cooperating_responders: bool = False) None [source]¶
Registers service information to the network with a default TTL. Zeroconf will then respond to requests for information for that service. The name of the service may be changed if needed to make it unique on the network. Additionally multiple cooperating responders can register the same service on the network for resilience (if you want this behavior set cooperating_responders to True).
- update_service(info: mini.dns.zeroconf.ServiceInfo) None [source]¶
Registers service information to the network with a default TTL. Zeroconf will then respond to requests for information for that service.
- unregister_service(info: mini.dns.zeroconf.ServiceInfo) None [source]¶
Unregister a service.
- check_service(info: mini.dns.zeroconf.ServiceInfo, allow_name_change: bool, cooperating_responders: bool = False) None [source]¶
Checks the network for a unique service name, modifying the ServiceInfo passed in if it is not unique.
- add_listener(listener: mini.dns.zeroconf.RecordUpdateListener, question: Optional[mini.dns.zeroconf.DNSQuestion]) None [source]¶
Adds a listener for a given question. The listener will have its update_record method called when information is available to answer the question.
- remove_listener(listener: mini.dns.zeroconf.RecordUpdateListener) None [source]¶
Removes a listener.
- update_record(now: float, rec: mini.dns.zeroconf.DNSRecord) None [source]¶
Used to notify listeners of new information that has updated a record.
- handle_response(msg: mini.dns.zeroconf.DNSIncoming) None [source]¶
Deal with incoming response packets. All answers are held in the cache, and listeners are notified.
- handle_query(msg: mini.dns.zeroconf.DNSIncoming, addr: Optional[str], port: int) None [source]¶
Deal with incoming query packets. Provides a response if possible.
- class mini.dns.zeroconf.ServiceInfo(type_: str, name: str, address: Optional[Union[bytes, List[bytes]]] = None, port: Optional[int] = None, weight: int = 0, priority: int = 0, properties: Union[bytes, Dict] = b'', server: Optional[str] = None, host_ttl: int = 120, other_ttl: int = 4500, *, addresses: Optional[List[bytes]] = None)[source]¶
Bases:
mini.dns.zeroconf.RecordUpdateListener
Service information.
Constructor parameters are as follows:
type_: fully qualified service type name
name: fully qualified service name
address: IP address as unsigned short, network byte order (deprecated, use addresses)
port: port that the service runs on
weight: weight of the service
priority: priority of the service
properties: dictionary of properties (or a bytes object holding the contents of the text field). converted to str and then encoded to bytes using UTF-8. Keys with None values are converted to value-less attributes.
server: fully qualified name for service host (defaults to name)
host_ttl: ttl used for A/SRV records
other_ttl: ttl used for PTR/TXT records
addresses: List of IP addresses as unsigned short (IPv4) or unsigned 128 bit number (IPv6), network byte order
- text = b''¶
- property address: Optional[bytes]¶
- property addresses: List[bytes]¶
IPv4 addresses of this service.
Only IPv4 addresses are returned for backward compatibility. Use
addresses_by_version()
orparsed_addresses()
to include IPv6 addresses as well.
- property properties: Dict¶
If properties were set in the constructor this property returns the original dictionary of type Dict[Union[bytes, str], Any].
If properties are coming from the network, after decoding a TXT record, the keys are always bytes and the values are either bytes, if there was a value, even empty, or None, if there was none. No further decoding is attempted. The type returned is Dict[bytes, Optional[bytes]].
- addresses_by_version(version: mini.dns.zeroconf.IPVersion) List[bytes] [source]¶
List addresses matching IP version.
- parsed_addresses(version: mini.dns.zeroconf.IPVersion = IPVersion.All) List[str] [source]¶
List addresses in their parsed string form.
- update_record(zc: mini.dns.zeroconf.Zeroconf, now: float, record: Optional[mini.dns.zeroconf.DNSRecord]) None [source]¶
Updates service information from a DNS record
- request(zc: mini.dns.zeroconf.Zeroconf, timeout: float) bool [source]¶
Returns true if the service could be discovered on the network, and updates this object with details discovered.
- class mini.dns.zeroconf.ServiceBrowser(zc: mini.dns.zeroconf.Zeroconf, type_: str, handlers: Optional[Union[mini.dns.zeroconf.ServiceListener, List[Callable[[...], None]]]] = None, listener: Optional[mini.dns.zeroconf.ServiceListener] = None, addr: Optional[str] = None, port: int = 5353, delay: int = 1000)[source]¶
Bases:
mini.dns.zeroconf.RecordUpdateListener
,threading.Thread
Used to browse for a service of a specific type.
The listener object will have its add_service() and remove_service() methods called when this browser discovers changes in the services availability.
- property service_state_changed: mini.dns.zeroconf.SignalRegistrationInterface¶
- update_record(zc: mini.dns.zeroconf.Zeroconf, now: float, record: mini.dns.zeroconf.DNSRecord) None [source]¶
Callback invoked by Zeroconf when new information arrives.
Updates information required by browser in the Zeroconf cache.
Ensures that there is are no unecessary duplicates in the list
- run() None [source]¶
Method representing the thread’s activity.
You may override this method in a subclass. The standard run() method invokes the callable object passed to the object’s constructor as the target argument, if any, with sequential and keyword arguments taken from the args and kwargs arguments, respectively.
- class mini.dns.zeroconf.InterfaceChoice(value)[source]¶
Bases:
enum.Enum
An enumeration.
- Default = 1¶
- All = 2¶