defs.h 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. #ifndef foodefshfoo
  2. #define foodefshfoo
  3. /***
  4. This file is part of avahi.
  5. avahi is free software; you can redistribute it and/or modify it
  6. under the terms of the GNU Lesser General Public License as
  7. published by the Free Software Foundation; either version 2.1 of the
  8. License, or (at your option) any later version.
  9. avahi is distributed in the hope that it will be useful, but WITHOUT
  10. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  11. or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
  12. Public License for more details.
  13. You should have received a copy of the GNU Lesser General Public
  14. License along with avahi; if not, write to the Free Software
  15. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
  16. USA.
  17. ***/
  18. /** \file defs.h Some common definitions */
  19. #include <avahi-common/cdecl.h>
  20. /** \mainpage
  21. *
  22. * \section choose_api Choosing an API
  23. *
  24. * Avahi provides three programming APIs for integration of
  25. * mDNS/DNS-SD features into your C progams:
  26. *
  27. * \li <b>avahi-core</b>: an API for embedding a complete mDNS/DNS-SD stack
  28. * into your software. This is intended for developers of embedded
  29. * appliances only. We dissuade from using this API in normal desktop
  30. * applications since it is not a good idea to run multiple mDNS
  31. * stacks simultaneously on the same host.
  32. * \li <b>the D-Bus API</b>: an extensive D-Bus interface for browsing and
  33. * registering mDNS/DNS-SD services using avahi-daemon. We recommend
  34. * using this API for software written in any language other than
  35. * C (e.g. Python).
  36. * \li <b>avahi-client</b>: a simplifying C wrapper around the D-Bus API. We
  37. * recommend using this API in C or C++ progams. The D-Bus internals
  38. * are hidden completely.
  39. * \li <b>avahi-gobject</b>: an object-oriented C wrapper based on
  40. * GLib's GObject. We recommd using this API for GNOME/Gtk programs.
  41. *
  42. * All three APIs are very similar, however avahi-core is the most powerful.
  43. *
  44. * In addition to the three APIs described above Avahi supports two
  45. * compatibility libraries:
  46. *
  47. * \li <b>avahi-compat-libdns_sd</b>: the original Bonjour API as documented
  48. * in the header file "dns_sd.h" by Apple Computer, Inc.
  49. *
  50. * \li <b>avahi-compat-howl</b>: the HOWL API as released with HOWL 0.9.8 by
  51. * Porchdog Software.
  52. *
  53. * Please note that these compatibility layers are incomplete and
  54. * generally a waste of resources. We strongly encourage everyone to
  55. * use our native APIs for newly written programs and to port older
  56. * programs to avahi-client!
  57. *
  58. * The native APIs (avahi-client and avahi-core) can be integrated
  59. * into external event loops. We provide adapters for the following
  60. * event loop implementations:
  61. *
  62. * \li <b>avahi-glib</b>: The GLIB main loop as used by GTk+/GNOME
  63. *
  64. * \li <b>avahi-qt</b>: The Qt main loop as used by Qt/KDE
  65. *
  66. * Finally, we provide a high-level Gtk+ GUI dialog called
  67. * <b>avahi-ui</b> for user-friendly browsing for services.
  68. *
  69. * The doxygen-generated API documentation covers avahi-client
  70. * (including its auxiliary APIs), the event loop adapters and
  71. * avahi-ui. For the other APIs please consult the original
  72. * documentation (for the compatibility APIs) or the header files.
  73. *
  74. * Please note that the doxygen-generated API documentation of the
  75. * native Avahi API is not complete. A few definitions that are part
  76. * of the Avahi API have been removed from this documentation, either
  77. * because they are only relevant in a very few low-level applications
  78. * or because they are considered obsolete. Please consult the C header
  79. * files for all definitions that are part of the Avahi API. Please
  80. * note that these hidden definitions are considered part of the Avahi
  81. * API and will stay available in the API in the future.
  82. *
  83. * \section error_reporting Error Reporting
  84. *
  85. * Some notes on the Avahi error handling:
  86. *
  87. * - Error codes are negative integers and defined as AVAHI_ERR_xx
  88. * - If a function returns some kind of non-negative integer value on
  89. * success, a failure is indicated by returning the error code
  90. * directly.
  91. * - If a function returns a pointer of some kind on success, a
  92. * failure is indicated by returning NULL
  93. * - The last error number may be retrieved by calling
  94. * avahi_client_errno()
  95. * - Just like the libc errno variable the Avahi errno is NOT reset to
  96. * AVAHI_OK if a function call succeeds.
  97. * - You may convert a numeric error code into a human readable string
  98. * using avahi_strerror()
  99. * - The constructor function avahi_client_new() returns the error
  100. * code in a call-by-reference argument
  101. *
  102. * \section event_loop Event Loop Abstraction
  103. *
  104. * Avahi uses a simple event loop abstraction layer. A table AvahiPoll
  105. * which contains function pointers for user defined timeout and I/O
  106. * condition event source implementations needs to be passed to
  107. * avahi_client_new(). An adapter for this abstraction layer is
  108. * available for the GLib main loop in the object AvahiGLibPoll. A
  109. * simple stand-alone implementation is available under the name
  110. * AvahiSimplePoll. An adpater for the Qt main loop is available from
  111. * avahi_qt_poll_get().
  112. *
  113. * \section good_publish How to Register Services
  114. *
  115. * - Subscribe to server state changes. Pass a callback function
  116. * pointer to avahi_client_new(). It will be called
  117. * whenever the server state changes.
  118. * - Only register your services when the server is in state
  119. * AVAHI_SERVER_RUNNING. If you register your services in other server
  120. * states they might not be accessible since the local host name might not necessarily
  121. * be established.
  122. * - Remove your services when the server enters
  123. * AVAHI_SERVER_COLLISION or AVAHI_SERVER_REGISTERING state. Your
  124. * services may not be reachable anymore since the local host name is
  125. * no longer established or is currently in the process of being
  126. * established.
  127. * - When registering services, use the following algorithm:
  128. * - Create a new entry group (i.e. avahi_entry_group_new())
  129. * - Add your service(s)/additional RRs/subtypes (e.g. avahi_entry_group_add_service())
  130. * - Commit the entry group (i.e. avahi_entry_group_commit())
  131. * - Subscribe to entry group state changes.
  132. * - If the entry group enters AVAHI_ENTRY_GROUP_COLLISION state the
  133. * services of the entry group are automatically removed from the
  134. * server. You may immediately add your services back to the entry
  135. * group (but with new names, perhaps using
  136. * avahi_alternative_service_name()) and commit again. Please do not
  137. * free the entry group and create a new one. This would inhibit some
  138. * traffic limiting algorithms in mDNS.
  139. * - When you need to modify your services (i.e. change the TXT data
  140. * or the port number), use the AVAHI_PUBLISH_UPDATE flag. Please do
  141. * not free the entry group and create a new one. This would inhibit
  142. * some traffic limiting algorithms in mDNS. When changing just the
  143. * TXT data avahi_entry_group_update_txt() is a shortcut for
  144. * AVAHI_PUBLISH_UPDATE. Please note that you cannot use
  145. * AVAHI_PUBLISH_UPDATE when changing the service name! Renaming a
  146. * DNS-SD service is identical to deleting and creating a new one, and
  147. * that's exactly what you should do in that case. First call
  148. * avahi_entry_group_reset() to remove it and then read it normally.
  149. *
  150. * \section good_browse How to Browse for Services
  151. *
  152. * - For normal applications you need to call avahi_service_browser_new()
  153. * for the service type you want to browse for. Use
  154. * avahi_service_resolver_new() to acquire service data for a service
  155. * name.
  156. * - You can use avahi_domain_browser_new() to get a list of announced
  157. * browsing domains. Please note that not all domains whith services
  158. * on the LAN are mandatorily announced.
  159. * - There is no need to subscribe to server state changes.
  160. *
  161. * \section daemon_dies How to Write a Client That Can Deal with Daemon Restarts
  162. *
  163. * With Avahi it is possible to write client applications that can
  164. * deal with Avahi daemon restarts. To accomplish that make sure to
  165. * pass AVAHI_CLIENT_NO_FAIL to avahi_client_new()'s flags
  166. * parameter. That way avahi_client_new() will succeed even when the
  167. * daemon is not running. In that case the object will enter
  168. * AVAHI_CLIENT_CONNECTING state. As soon as the daemon becomes
  169. * available the object will enter one of the AVAHI_CLIENT_S_xxx
  170. * states. Make sure to not create browsers or entry groups before the
  171. * client object has entered one of those states. As usual you will be
  172. * informed about state changes with the callback function supplied to
  173. * avahi_client_new(). If the client is forced to disconnect from the
  174. * server it will enter AVAHI_CLIENT_FAILURE state with
  175. * avahi_client_errno() == AVAHI_ERR_DISCONNECTED. Free the
  176. * AvahiClient object in that case (and all its associated objects
  177. * such as entry groups and browser objects prior to that) and
  178. * reconnect to the server anew - again with passing
  179. * AVAHI_CLIENT_NO_FAIL to avahi_client_new().
  180. *
  181. * We encourage implementing this in all software where service
  182. * discovery is not an integral part of application. e.g. use it in
  183. * all kinds of background daemons, but not necessarily in software
  184. * like iChat compatible IM software.
  185. *
  186. * For now AVAHI_CLIENT_NO_FAIL cannot deal with D-Bus daemon restarts.
  187. *
  188. * \section domains How to Deal Properly with Browsing Domains
  189. *
  190. * Due to the introduction of wide-area DNS-SD the correct handling of
  191. * domains becomes more important for Avahi enabled applications. All
  192. * applications that offer the user a list of services discovered with
  193. * Avahi should offer some kind of editable drop down box where the
  194. * user can either enter his own domain or select one of those offered
  195. * by AvahiDomainBrowser. The default domain to browse should be the
  196. * one returned by avahi_client_get_domain_name(). The list of domains
  197. * returned by AvahiDomainBrowser is assembled by the browsing domains
  198. * configured in the daemon's configuration file, the domains
  199. * announced inside the default domain, the domains set with the
  200. * environment variable $AVAHI_BROWSE_DOMAINS (colon-seperated) on the
  201. * client side and the domains set in the XDG configuration file
  202. * ~/.config/avahi/browse-domains on the client side (seperated by
  203. * newlines). File managers offering some kind of "Network
  204. * Neighborhood" folder should show the entries of the default domain
  205. * right inside that and offer subfolders for the browsing domains
  206. * returned by AvahiDomainBrowser.
  207. */
  208. AVAHI_C_DECL_BEGIN
  209. /** @{ \name States */
  210. /** States of a server object */
  211. typedef enum {
  212. AVAHI_SERVER_INVALID, /**< Invalid state (initial) */
  213. AVAHI_SERVER_REGISTERING, /**< Host RRs are being registered */
  214. AVAHI_SERVER_RUNNING, /**< All host RRs have been established */
  215. AVAHI_SERVER_COLLISION, /**< There is a collision with a host RR. All host RRs have been withdrawn, the user should set a new host name via avahi_server_set_host_name() */
  216. AVAHI_SERVER_FAILURE /**< Some fatal failure happened, the server is unable to proceed */
  217. } AvahiServerState;
  218. /** States of an entry group object */
  219. typedef enum {
  220. AVAHI_ENTRY_GROUP_UNCOMMITED, /**< The group has not yet been commited, the user must still call avahi_entry_group_commit() */
  221. AVAHI_ENTRY_GROUP_REGISTERING, /**< The entries of the group are currently being registered */
  222. AVAHI_ENTRY_GROUP_ESTABLISHED, /**< The entries have successfully been established */
  223. AVAHI_ENTRY_GROUP_COLLISION, /**< A name collision for one of the entries in the group has been detected, the entries have been withdrawn */
  224. AVAHI_ENTRY_GROUP_FAILURE /**< Some kind of failure happened, the entries have been withdrawn */
  225. } AvahiEntryGroupState;
  226. /** @} */
  227. /** @{ \name Flags */
  228. /** Some flags for publishing functions */
  229. typedef enum {
  230. AVAHI_PUBLISH_UNIQUE = 1, /**< For raw records: The RRset is intended to be unique */
  231. AVAHI_PUBLISH_NO_PROBE = 2, /**< For raw records: Though the RRset is intended to be unique no probes shall be sent */
  232. AVAHI_PUBLISH_NO_ANNOUNCE = 4, /**< For raw records: Do not announce this RR to other hosts */
  233. AVAHI_PUBLISH_ALLOW_MULTIPLE = 8, /**< For raw records: Allow multiple local records of this type, even if they are intended to be unique */
  234. /** \cond fulldocs */
  235. AVAHI_PUBLISH_NO_REVERSE = 16, /**< For address records: don't create a reverse (PTR) entry */
  236. AVAHI_PUBLISH_NO_COOKIE = 32, /**< For service records: do not implicitly add the local service cookie to TXT data */
  237. /** \endcond */
  238. AVAHI_PUBLISH_UPDATE = 64, /**< Update existing records instead of adding new ones */
  239. /** \cond fulldocs */
  240. AVAHI_PUBLISH_USE_WIDE_AREA = 128, /**< Register the record using wide area DNS (i.e. unicast DNS update) */
  241. AVAHI_PUBLISH_USE_MULTICAST = 256 /**< Register the record using multicast DNS */
  242. /** \endcond */
  243. } AvahiPublishFlags;
  244. /** Some flags for lookup functions */
  245. typedef enum {
  246. /** \cond fulldocs */
  247. AVAHI_LOOKUP_USE_WIDE_AREA = 1, /**< Force lookup via wide area DNS */
  248. AVAHI_LOOKUP_USE_MULTICAST = 2, /**< Force lookup via multicast DNS */
  249. /** \endcond */
  250. AVAHI_LOOKUP_NO_TXT = 4, /**< When doing service resolving, don't lookup TXT record */
  251. AVAHI_LOOKUP_NO_ADDRESS = 8 /**< When doing service resolving, don't lookup A/AAAA record */
  252. } AvahiLookupFlags;
  253. /** Some flags for lookup callback functions */
  254. typedef enum {
  255. AVAHI_LOOKUP_RESULT_CACHED = 1, /**< This response originates from the cache */
  256. AVAHI_LOOKUP_RESULT_WIDE_AREA = 2, /**< This response originates from wide area DNS */
  257. AVAHI_LOOKUP_RESULT_MULTICAST = 4, /**< This response originates from multicast DNS */
  258. AVAHI_LOOKUP_RESULT_LOCAL = 8, /**< This record/service resides on and was announced by the local host. Only available in service and record browsers and only on AVAHI_BROWSER_NEW. */
  259. AVAHI_LOOKUP_RESULT_OUR_OWN = 16, /**< This service belongs to the same local client as the browser object. Only available in avahi-client, and only for service browsers and only on AVAHI_BROWSER_NEW. */
  260. AVAHI_LOOKUP_RESULT_STATIC = 32 /**< The returned data has been defined statically by some configuration option */
  261. } AvahiLookupResultFlags;
  262. /** @} */
  263. /** @{ \name Events */
  264. /** Type of callback event when browsing */
  265. typedef enum {
  266. AVAHI_BROWSER_NEW, /**< The object is new on the network */
  267. AVAHI_BROWSER_REMOVE, /**< The object has been removed from the network */
  268. AVAHI_BROWSER_CACHE_EXHAUSTED, /**< One-time event, to notify the user that all entries from the caches have been sent */
  269. AVAHI_BROWSER_ALL_FOR_NOW, /**< One-time event, to notify the user that more records will probably not show up in the near future, i.e. all cache entries have been read and all static servers been queried */
  270. AVAHI_BROWSER_FAILURE /**< Browsing failed due to some reason which can be retrieved using avahi_server_errno()/avahi_client_errno() */
  271. } AvahiBrowserEvent;
  272. /** Type of callback event when resolving */
  273. typedef enum {
  274. AVAHI_RESOLVER_FOUND, /**< RR found, resolving successful */
  275. AVAHI_RESOLVER_FAILURE /**< Resolving failed due to some reason which can be retrieved using avahi_server_errno()/avahi_client_errno() */
  276. } AvahiResolverEvent;
  277. /** @} */
  278. /** @{ \name Other definitions */
  279. /** The type of domain to browse for */
  280. typedef enum {
  281. AVAHI_DOMAIN_BROWSER_BROWSE, /**< Browse for a list of available browsing domains */
  282. AVAHI_DOMAIN_BROWSER_BROWSE_DEFAULT, /**< Browse for the default browsing domain */
  283. AVAHI_DOMAIN_BROWSER_REGISTER, /**< Browse for a list of available registering domains */
  284. AVAHI_DOMAIN_BROWSER_REGISTER_DEFAULT, /**< Browse for the default registering domain */
  285. AVAHI_DOMAIN_BROWSER_BROWSE_LEGACY, /**< Legacy browse domain - see DNS-SD spec for more information */
  286. AVAHI_DOMAIN_BROWSER_MAX
  287. } AvahiDomainBrowserType;
  288. /** @} */
  289. /** \cond fulldocs */
  290. /** For every service a special TXT item is implicitly added, which
  291. * contains a random cookie which is private to the local daemon. This
  292. * can be used by clients to determine if two services on two
  293. * different subnets are effectively the same. */
  294. #define AVAHI_SERVICE_COOKIE "org.freedesktop.Avahi.cookie"
  295. /** In invalid cookie as special value */
  296. #define AVAHI_SERVICE_COOKIE_INVALID (0)
  297. /** \endcond fulldocs */
  298. /** @{ \name DNS RR definitions */
  299. /** DNS record types, see RFC 1035 */
  300. enum {
  301. AVAHI_DNS_TYPE_A = 0x01,
  302. AVAHI_DNS_TYPE_NS = 0x02,
  303. AVAHI_DNS_TYPE_CNAME = 0x05,
  304. AVAHI_DNS_TYPE_SOA = 0x06,
  305. AVAHI_DNS_TYPE_PTR = 0x0C,
  306. AVAHI_DNS_TYPE_HINFO = 0x0D,
  307. AVAHI_DNS_TYPE_MX = 0x0F,
  308. AVAHI_DNS_TYPE_TXT = 0x10,
  309. AVAHI_DNS_TYPE_AAAA = 0x1C,
  310. AVAHI_DNS_TYPE_SRV = 0x21
  311. };
  312. /** DNS record classes, see RFC 1035 */
  313. enum {
  314. AVAHI_DNS_CLASS_IN = 0x01 /**< Probably the only class we will ever use */
  315. };
  316. /** @} */
  317. /** The default TTL for RRs which contain a host name of some kind. */
  318. #define AVAHI_DEFAULT_TTL_HOST_NAME (120)
  319. /** The default TTL for all other records. */
  320. #define AVAHI_DEFAULT_TTL (75*60)
  321. AVAHI_C_DECL_END
  322. #endif