Bug 71016

Summary: have ways for Polari to handle the channels it wants
Product: Telepathy Reporter: Simon McVittie <smcv>
Component: tp-specAssignee: Telepathy bugs list <telepathy-bugs>
Status: RESOLVED MOVED QA Contact: Telepathy bugs list <telepathy-bugs>
Severity: enhancement    
Priority: medium CC: fmuellner, xclaesse
Version: git master   
Hardware: Other   
OS: All   
Whiteboard:
i915 platform: i915 features:

Description Simon McVittie 2013-10-29 18:58:39 UTC
fmuellner would like Polari to be the Handler for:

* named chatrooms on IRC and XMPP

* private messages from IRC contacts

* private messages mediated via XMPP chatrooms
  (e.g. a 1-1 channel with telepathy@chatrooms.example.com/smcv)

but not:

* 1-1 messages in general

* truly nameless ad-hoc chatrooms on e.g. MSNP

* ad-hoc chatrooms with no *human-readable* name on XMPP (via XEP-0045 ยง10.1.4),
  Skype, Google Talk

This is not currently possible. We should make it possible.
Comment 1 Simon McVittie 2013-10-29 19:00:24 UTC
For named chatrooms, the closest we can currently get is:

    { ...TargetHandleType: ROOM, ...ChannelType: ...Text }

but we want to exclude chatrooms that don't have a human-readable name (Room2.RoomName = "").

Proposal: add Room2.HasRoomName and have Polari match this:

    { ...TargetHandleType: ROOM, ...ChannelType: ...Text, ...HasRoomName: True }
Comment 2 Simon McVittie 2013-10-29 19:14:28 UTC
For 1-1 messages, the filter syntax can't currently say anything about the protocol of a channel.

One solution for the protocol bit is Bug #30963 but I never really liked that proposal - I suspect it's rather more general than we actually need.

Another possible solution is: extend the MC filter syntax so some special token ("protocol"?) is special-cased to match against the Channel's Connection's protocol instead of the immutable properties. We can add further tokens, distinguished from D-Bus properties somehow (not containing a dot? starting with a character that isn't valid in an interface?), as and when we need them.

Another possibility would be to define a redundant Channel.Protocol property so that filters can use it.
Comment 3 Simon McVittie 2013-10-29 19:25:40 UTC
For 1-1 messages related to a chatroom, again, we don't have an answer.

One way would be for Polari to pop up one additional Handler head per channel it handles, with a filter like this (assume we add suitable properties to the Channel):


    {
        ...ChannelType: ...Text,
        ...TargetHandleType: CONTACT,
        Hypothetical.Channel.I.RoomRelated1.RelatedToRoom: "telepathy@rooms.example.com",
     }

but there's a race condition there between "1-1 IM comes in from a contact" and "Mission Control inspects the Handler and finds out that it wants this".

Another way would be to have a boolean RelatedToRoom = True, and have Polari be the handler for such channels. The down side there is that it can't distinguish between "a room Polari is handling" and "a room someone else is handling for some reason".

Maybe there's another way but I can't think of it right now.
Comment 4 Xavier Claessens 2013-10-29 19:44:00 UTC
(In reply to comment #0)
> fmuellner would like Polari to be the Handler for:
> 
> * named chatrooms on IRC and XMPP

+1 for the HasRoomName solution, neat!

> * private messages from IRC contacts

I guess we can add a special ChannelClass key in the asv "protocol: $foo"

> * private messages mediated via XMPP chatrooms
>   (e.g. a 1-1 channel with telepathy@chatrooms.example.com/smcv)

Can MC know from which room channel "telepathy@chatrooms.example.com/smcv" comes from? If yes it can get that room channel's handler in priority to dispatch the 1-1 channel.
Comment 5 Xavier Claessens 2013-10-29 19:49:29 UTC
(In reply to comment #4)
> (In reply to comment #0)
> > * private messages mediated via XMPP chatrooms
> >   (e.g. a 1-1 channel with telepathy@chatrooms.example.com/smcv)
> 
> Can MC know from which room channel "telepathy@chatrooms.example.com/smcv"
> comes from? If yes it can get that room channel's handler in priority to
> dispatch the 1-1 channel.

If MC can't know that, maybe the hint can come from Gabble: add an immutable property on the Channel: "RelatedToRoom: $room_object_path". Then MC can use that property to lookup who is currently handling $room_object_path and pick that handler first. I think it is a good general rule that channels related to another channel gets the same handler.
Comment 6 Xavier Claessens 2013-10-29 19:53:56 UTC
can even be totally general: the CM can decide that any channel is ReletatedTo any other channel. And MC use that hint to pick the handler in the case more than one handler can equally handle a channel.
Comment 7 Simon McVittie 2013-10-30 17:40:38 UTC
(In reply to comment #2)
> For 1-1 messages, the filter syntax can't currently say anything about the
> protocol of a channel.

The implementation in MC for this turns out to be pretty easy.

Another way this could work would be for Polari to have an Observer "head" for all incoming 1-1 Text channels (under a secondary name not listed in a .client file, so that it's only active while Polari is running), and non-interactively approve those that turn out to be IRC by using HandleWith('...Polari') or Claim(). If it does that, it should follow the usual rule of not acknowledging messages until it is "officially" the Handler.

That would mean that Text Approvers never see those channels - does that match what we want in practice?

That would also interact poorly with a hypothetical second client that was doing the same thing (does anything?) - if you're running two concurrent clients, both of which try to claim all incoming channels without user interaction, then Mission Control will say "yes" to whichever one gets its request in first, and it'll be non-deterministic which one ends up with the channel.

On the other hand, if you consider it to be OK for new messages to show up in more than one place, it could be a simultaneous Observer/Handler, display the messages, ack the messages if and only if it's currently the Handler, and otherwise not care too much about whether it wins or loses the race?
Comment 8 Simon McVittie 2013-10-30 18:12:10 UTC
(In reply to comment #5)
> (In reply to comment #4)
> > (In reply to comment #0)
> > > * private messages mediated via XMPP chatrooms
> > >   (e.g. a 1-1 channel with telepathy@chatrooms.example.com/smcv)
> > 
> > Can MC know from which room channel "telepathy@chatrooms.example.com/smcv"
> > comes from?

Not without help from the CM.

> If MC can't know that, maybe the hint can come from Gabble: add an immutable
> property on the Channel: "RelatedToRoom: $room_object_path". Then MC can use
> that property to lookup who is currently handling $room_object_path and pick
> that handler first. I think it is a good general rule that channels related
> to another channel gets the same handler.

Polari would need some way to say: I am able to deal with 1-1 text channels, but please don't actually give me those channels unless they are related to one I'm already handling.
Comment 9 Simon McVittie 2013-10-30 18:21:00 UTC
(In reply to comment #8)
> Polari would need some way to say: I am able to deal with 1-1 text channels,
> but please don't actually give me those channels unless they are related to
> one I'm already handling.

That's quite similar to Bug #31325.
Comment 10 GitLab Migration User 2019-12-03 20:26:47 UTC
-- GitLab Migration Automatic Message --

This bug has been migrated to freedesktop.org's GitLab instance and has been closed from further activity.

You can subscribe and participate further through the new bug through this link to our GitLab instance: https://gitlab.freedesktop.org/telepathy/telepathy-spec/issues/143.

Use of freedesktop.org services, including Bugzilla, is subject to our Code of Conduct. How we collect and use information is described in our Privacy Policy.