some little name changes

This commit is contained in:
Stefan Bethge 2006-05-26 19:18:13 +00:00
parent a9fc3c54cb
commit 0d195c1516
1 changed files with 32 additions and 24 deletions

View File

@ -1,5 +1,6 @@
import os import os
import sys import sys
import getpass
try: try:
import avahi, gobject, dbus import avahi, gobject, dbus
@ -12,12 +13,12 @@ except ImportError, e:
pass pass
class Zeroconf: class Zeroconf:
def __init__(self, name): def __init__(self):
self.domain = None # specific domain to browse self.domain = None # specific domain to browse
self.stype = '_presence._tcp' self.stype = '_presence._tcp'
self.port = 5298 # listening port that gets announced self.port = 5298 # listening port that gets announced
self.name = name # service name / username self.name = getpass.getuser() # service name / username
self.txt = {} self.txt = {} # service data
self.service_browsers = {} self.service_browsers = {}
self.contacts = {} # all current local contacts with data self.contacts = {} # all current local contacts with data
@ -66,21 +67,21 @@ class Zeroconf:
def service_added_callback(self): def service_added_callback(self):
print "Service successfully added" print 'Service successfully added'
def service_committed_callback(self): def service_committed_callback(self):
print "Service successfully committed" print 'Service successfully committed'
def service_updated_callback(self): def service_updated_callback(self):
print "Service successfully updated" print 'Service successfully updated'
def service_add_fail_callback(self, err): def service_add_fail_callback(self, err):
print "Error while adding service:", str(err) print 'Error while adding service:', str(err)
self.name = self.server.GetAlternativeServiceName(self.name) self.name = self.server.GetAlternativeServiceName(self.name)
self.create_service() self.create_service()
def server_state_changed_callback(self, state, error): def server_state_changed_callback(self, state, error):
print "server.state %s" % state print 'server.state %s' % state
if state == avahi.SERVER_RUNNING: if state == avahi.SERVER_RUNNING:
self.create_service() self.create_service()
elif state == avahi.SERVER_COLLISION: elif state == avahi.SERVER_COLLISION:
@ -88,12 +89,10 @@ class Zeroconf:
# elif state == avahi.CLIENT_FAILURE: # TODO: add error handling (avahi daemon dies...?) # elif state == avahi.CLIENT_FAILURE: # TODO: add error handling (avahi daemon dies...?)
def entrygroup_state_changed_callback(self, state, error): def entrygroup_state_changed_callback(self, state, error):
# the name is already present, so ... # the name is already present, so recreate
if state == avahi.ENTRY_GROUP_COLLISION: if state == avahi.ENTRY_GROUP_COLLISION:
print "Collision with existing service of name %s" % self.name self.service_add_fail_callback('Local name collision, recreating.')
# ... get a new one and recreate the service
self.name = self.server.GetAlternativeServiceName(self.name)
self.create_service()
# elif state == avahi.ENTRY_GROUP_FAILURE: # elif state == avahi.ENTRY_GROUP_FAILURE:
def create_service(self): def create_service(self):
@ -110,7 +109,7 @@ class Zeroconf:
self.entrygroup.AddService(avahi.IF_UNSPEC, avahi.PROTO_UNSPEC, dbus.UInt32(0), self.name, self.stype, '', '', self.port, avahi.dict_to_txt_array(self.txt), reply_handler=self.service_added_callback, error_handler=self.service_add_fail_callback) self.entrygroup.AddService(avahi.IF_UNSPEC, avahi.PROTO_UNSPEC, dbus.UInt32(0), self.name, self.stype, '', '', self.port, avahi.dict_to_txt_array(self.txt), reply_handler=self.service_added_callback, error_handler=self.service_add_fail_callback)
self.entrygroup.Commit(reply_handler=self.service_committed_callback, error_handler=self.print_error_callback) self.entrygroup.Commit(reply_handler=self.service_committed_callback, error_handler=self.print_error_callback)
def publish(self): def announce(self):
state = self.server.GetState() state = self.server.GetState()
if state == avahi.SERVER_RUNNING: if state == avahi.SERVER_RUNNING:
@ -146,8 +145,8 @@ class Zeroconf:
# Just browse the domain the user wants us to browse # Just browse the domain the user wants us to browse
self.browse_domain(avahi.IF_UNSPEC, avahi.PROTO_UNSPEC, domain) self.browse_domain(avahi.IF_UNSPEC, avahi.PROTO_UNSPEC, domain)
# def disconnect: def disconnect(self):
# necessary ? self.remove_announce()
# refresh data manually - really ok or too much traffic? # refresh data manually - really ok or too much traffic?
def resolve_all(self): def resolve_all(self):
@ -160,8 +159,11 @@ class Zeroconf:
self.resolve_all self.resolve_all
return self.contacts return self.contacts
def set_status(self, status): def update_txt(self, txt):
self.txt[('status')] = status # update only given keys
for key in txt.keys():
self.txt[key]=txt[key]
txt = avahi.dict_to_txt_array(self.txt) txt = avahi.dict_to_txt_array(self.txt)
self.entrygroup.UpdateServiceTxt(avahi.IF_UNSPEC, avahi.PROTO_UNSPEC, dbus.UInt32(0), self.name, self.stype,'', txt, reply_handler=self.service_updated_callback, error_handler=self.print_error_callback) self.entrygroup.UpdateServiceTxt(avahi.IF_UNSPEC, avahi.PROTO_UNSPEC, dbus.UInt32(0), self.name, self.stype,'', txt, reply_handler=self.service_updated_callback, error_handler=self.print_error_callback)
@ -172,11 +174,17 @@ class Zeroconf:
''' '''
def main(): def main():
zeroconf = Zeroconf('foo') zeroconf = Zeroconf()
zeroconf.connect() zeroconf.connect()
zeroconf.txt[('last')] = 'foo' zeroconf.txt[('1st')] = 'foo'
zeroconf.publish() zeroconf.txt[('last')] = 'bar'
zeroconf.set_status('avail') zeroconf.announce()
# updating after announcing
txt = {}
txt['status'] = 'avail' # out of avail/away/dnd
txt['msg'] = 'Here I am'
zeroconf.update_txt(txt)
try: try:
gobject.MainLoop().run() gobject.MainLoop().run()