Остановка сервиса Avahi и возврат списка элементов

1

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

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

Теги:
dbus
avahi

2 ответа

2

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

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

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

1

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

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

browsing ...
cache exhausted
New service: name = Lexmark X264dn; address = 10.9.0.93; port = 80
that 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 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()

Ещё вопросы

Сообщество Overcoder
Наверх
Меню