2007-09-19 05:56:55 +04:00
/*
* mdns . c : advertise libvirt hypervisor connections
*
* Copyright ( C ) 2007 Daniel P . Berrange
*
* Derived from Avahi example service provider code .
*
* 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 . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*
* Author : Daniel P . Berrange < berrange @ redhat . com >
*/
# include "internal.h"
# ifndef __VIRTD_MDNS_H__
2010-03-09 21:22:22 +03:00
# define __VIRTD_MDNS_H__
2007-09-19 05:56:55 +04:00
struct libvirtd_mdns ;
struct libvirtd_mdns_group ;
struct libvirtd_mdns_entry ;
/**
* Prepares a new mdns manager object for use
*/
struct libvirtd_mdns * libvirtd_mdns_new ( void ) ;
/**
2008-03-17 13:27:31 +03:00
* Starts the mdns client , advertising any groups / entries currently registered
2008-02-05 22:27:37 +03:00
*
2008-03-17 13:27:31 +03:00
* @ mdns : manager to start advertising
2007-09-19 05:56:55 +04:00
*
* Starts the mdns client . Services may not be immediately visible , since
* it may asynchronously wait for the mdns service to startup
*
* returns - 1 upon failure , 0 upon success .
*/
int libvirtd_mdns_start ( struct libvirtd_mdns * mdns ) ;
/**
2008-03-17 13:27:31 +03:00
* Stops the mdns client , removing any advertisements
2007-09-19 05:56:55 +04:00
*
2008-03-17 13:27:31 +03:00
* @ mdns : manager to start advertising
2007-09-19 05:56:55 +04:00
*
*/
void libvirtd_mdns_stop ( struct libvirtd_mdns * mdns ) ;
/**
2008-03-17 13:27:31 +03:00
* Adds a group container for advertisement
2007-09-19 05:56:55 +04:00
*
* @ mdns manager to attach the group to
* @ name unique human readable service name
*
* returns the group record , or NULL upon failure
*/
struct libvirtd_mdns_group * libvirtd_mdns_add_group ( struct libvirtd_mdns * mdns , const char * name ) ;
/**
2008-03-17 13:27:31 +03:00
* Removes a group container from advertisement
2007-09-19 05:56:55 +04:00
*
2008-02-29 15:53:10 +03:00
* @ mdns amanger to detach group from
2007-09-19 05:56:55 +04:00
* @ group group to remove
*/
void libvirtd_mdns_remove_group ( struct libvirtd_mdns * mdns , struct libvirtd_mdns_group * group ) ;
/**
* Adds a service entry in a group
*
* @ group group to attach the entry to
* @ type service type string
* @ port tcp port number
*
* returns the service record , or NULL upon failure
*/
struct libvirtd_mdns_entry * libvirtd_mdns_add_entry ( struct libvirtd_mdns_group * group , const char * type , int port ) ;
/**
* Removes a service entry from a group
*
2008-02-29 15:53:10 +03:00
* @ group group to detach service entry from
2007-09-19 05:56:55 +04:00
* @ entry service entry to remove
*/
void libvirtd_mdns_remove_entry ( struct libvirtd_mdns_group * group , struct libvirtd_mdns_entry * entry ) ;
# endif /* __VIRTD_MDNS_H__ */