Hook up private activities and share invite-only

implicitly.
This commit is contained in:
Marco Pesenti Gritti 2007-09-11 19:59:40 +02:00
parent 88d196d089
commit 971fd857e0

View File

@ -53,6 +53,8 @@ class ActivityToolbar(gtk.Toolbar):
gtk.Toolbar.__init__(self) gtk.Toolbar.__init__(self)
self._activity = activity self._activity = activity
self._updating_share = False
activity.connect('shared', self._activity_shared_cb) activity.connect('shared', self._activity_shared_cb)
activity.connect('joined', self._activity_shared_cb) activity.connect('joined', self._activity_shared_cb)
activity.connect('notify::max_participants', activity.connect('notify::max_participants',
@ -99,6 +101,8 @@ class ActivityToolbar(gtk.Toolbar):
self._update_title_sid = None self._update_title_sid = None
def _update_share(self): def _update_share(self):
self._updating_share = True
if self._activity.props.max_participants == 1: if self._activity.props.max_participants == 1:
self.share.hide() self.share.hide()
@ -109,18 +113,17 @@ class ActivityToolbar(gtk.Toolbar):
self.share.set_sensitive(True) self.share.set_sensitive(True)
self.share.combo.set_active(0) self.share.combo.set_active(0)
self._updating_share = False
def _share_changed_cb(self, combo): def _share_changed_cb(self, combo):
if not self.props.sensitive: if self._updating_share:
# Ignore programmatic combo changes, only respond
# to user-initiated ones
return return
model = self.share.combo.get_model() model = self.share.combo.get_model()
it = self.share.combo.get_active_iter() it = self.share.combo.get_active_iter()
(scope, ) = model.get(it, 0) (scope, ) = model.get(it, 0)
if scope == SCOPE_NEIGHBORHOOD: if scope == SCOPE_NEIGHBORHOOD:
self._activity.share() self._activity.share()
elif scope == SCOPE_INVITE_ONLY:
self._activity.share(private=True)
def _keep_clicked_cb(self, button): def _keep_clicked_cb(self, button):
self._activity.copy() self._activity.copy()
@ -270,6 +273,8 @@ class Activity(Window, gtk.Container):
self._updating_jobject = False self._updating_jobject = False
self._closing = False self._closing = False
self._max_participants = 0 self._max_participants = 0
self._share_scope = SCOPE_PRIVATE
self._invites_queue = []
self._bus = ActivityService(self) self._bus = ActivityService(self)
self._owns_file = False self._owns_file = False
@ -533,29 +538,46 @@ class Activity(Window, gtk.Container):
if not success: if not success:
logging.debug('Share of activity %s failed: %s.' % (self._activity_id, err)) logging.debug('Share of activity %s failed: %s.' % (self._activity_id, err))
return return
logging.debug('Share of activity %s successful.' % self._activity_id) logging.debug('Share of activity %s successful.' % self._activity_id)
activity.props.name = self._jobject.metadata['title'] activity.props.name = self._jobject.metadata['title']
self._shared_activity = activity self._shared_activity = activity
if activity.props.private:
self._share_scope = SCOPE_INVITE_ONLY
else:
self._share_scope = SCOPE_NEIGHBORHOOD
self.emit('shared') self.emit('shared')
if self._jobject: if self._jobject:
# FIXME: some way to distinguish between share scopes # FIXME: some way to distinguish between share scopes
self._jobject.metadata['share-scope'] = SCOPE_NEIGHBORHOOD self._jobject.metadata['share-scope'] = self._share_scope
self._send_invites()
def _invite_response_cb(self, error): def _invite_response_cb(self, error):
if error: if error:
logging.error('Invite failed: %s' % error) logging.error('Invite failed: %s' % error)
def invite(self, buddy_key): def _send_invites(self):
if self._shared_activity is None: while self._invites_queue:
return buddy_key = self._invites_queue.pop()
buddy = self._pservice.get_buddy(buddy_key)
if buddy:
self._shared_activity.invite(buddy, '', self._invite_response_cb)
else:
logging.error('Cannot invite %s, no such buddy.' % buddy_key)
buddy = self._pservice.get_buddy(buddy_key) def invite(self, buddy_key):
if buddy: self._invites_queue.append(buddy_key)
self._shared_activity.invite(buddy, '', self._invite_response_cb)
if self._share_scope == SCOPE_PRIVATE:
self.share(True)
else: else:
logging.error('Cannot invite %s, no such buddy.' % buddy_key) self._send_invites()
def share(self, private=False): def share(self, private=False):
"""Request that the activity be shared on the network. """Request that the activity be shared on the network.