Остановка сервиса Avahi и возврат списка элементов - PullRequest
1 голос
/ 26 февраля 2011

После этого примера Я хочу остановить службу, когда получу все элементы и верну их в списке.

Чтобы остановить бесконечный цикл, нужно вызвать gobject.MainLoop().quit(), но сделатьне знаю когда и куда звонить.Спасибо

Ответы [ 2 ]

2 голосов
/ 12 марта 2011

Вы захотите остановить просмотр службы , когда прибудет последняя служба на данный момент. Это даст вам снимок текущих доступных услуг.

В слое C есть флаг, позволяющий вам проверить, будут ли в скором времени появляться другие сервисы. Это называется AVAHI_BROWSER_ALL_FOR_NOW. Я не знаком с привязками python , но, возможно, этот флаг можно как-то проверить в аргументах stype или flags обратного вызова?

Когда вы видите этот флаг установлен - звоните gobject.MainLoop().quit()

1 голос
/ 24 января 2013

Вы также захотите прослушать сигнал AllForNow . Также рассмотрим CacheExhausted и Failure . Интерфейс для org.freedesktop.Avahi.ServiceBrowser объявлен здесь .

Выполнение следующего на моей машине возвращает примерно секунду и печатает:

browsing ...
cache exhausted
New service: name = Lexmark X264dn; address = 10.9.0.93; port = 80
that's all for now
done
0:00:01.004258

Надеюсь, это поможет!


from _dbus_glib_bindings import DBusGMainLoop
import dbus, avahi
import gobject

class ServiceBrowser():
    def __init__(self, service):
        loop = DBusGMainLoop(set_as_default=True)

        bus = dbus.SystemBus(mainloop=loop)

        self._server = dbus.Interface(bus.get_object(avahi.DBUS_NAME, avahi.DBUS_PATH_SERVER), avahi.DBUS_INTERFACE_SERVER)

        browser = self._server.ServiceBrowserNew(avahi.IF_UNSPEC, avahi.PROTO_INET, service, '', 0)
        listener = dbus.Interface(bus.get_object(avahi.DBUS_NAME, browser), avahi.DBUS_INTERFACE_SERVICE_BROWSER)

        listener.connect_to_signal("ItemNew", self.item_new_handler)
        listener.connect_to_signal("ItemRemove", self.item_remove_handler)
        listener.connect_to_signal("AllForNow", self.all_for_now_handler)
        listener.connect_to_signal("CacheExhausted", self.cache_exhausted_handler)
        listener.connect_to_signal("Failure", self.failure_handler)

        self._mainloop = gobject.MainLoop()


    def service_resolved(self, *args):
        print 'New service: name = %s; address = %s; port = %s' % (args[2], args[7], args[8])


    def print_error(self, *args):
        print 'error_handler'
        print args[0]

    def item_new_handler(self, interface, protocol, name, stype, domain, flags):
        self._server.ResolveService(interface, protocol, name, stype, domain, avahi.PROTO_UNSPEC, dbus.UInt32(0), reply_handler=self.service_resolved, error_handler=self.print_error)


    def item_remove_handler(self, interface, protocol, name, stype, domain, flags):
        print "Removed service: %s" % name


    def all_for_now_handler(self):
        print "that's all for now"
        self._mainloop.quit()


    def cache_exhausted_handler(self):
        print "cache exhausted"


    def failure_handler(self, error):
        print "failure: %s" % error


    def browse(self):
        self._mainloop.run()


def browse_avahi(service):
    browser = ServiceBrowser(service)
    browser.browse()

def main():
    t0 = datetime.utcnow()
    print "browsing ..."
    browse_avahi('_http._tcp')
    print "done"
    print datetime.utcnow()-t0

if __name__ == '__main__':
    main()
...