Bug 35100

Summary: New error SoftwareUpgradeRequired
Product: Telepathy Reporter: Danielle Madeley <danielle>
Component: tp-specAssignee: Telepathy bugs list <telepathy-bugs>
Status: RESOLVED FIXED QA Contact: Telepathy bugs list <telepathy-bugs>
Severity: normal    
Priority: medium Keywords: patch
Version: git master   
Hardware: Other   
OS: All   
URL: http://git.collabora.co.uk/?p=user/danni/telepathy-spec.git;a=shortlog;h=refs/heads/software-upgrade-required-35100
Whiteboard:
i915 platform: i915 features:
Attachments: Add EmergencyCallsNotSupported error
Add EmergencyCallsNotSupported error

Description Danielle Madeley 2011-03-07 16:56:27 UTC
Some connection libraries can detect when a library upgrade is required and sometimes will disconnect clients that do not claim to support the latest protocol version. This error would allow clients to detect that as a disconnection reason, and inform the user appropriately.
Comment 2 Will Thompson 2011-03-08 02:35:14 UTC
It'd be nice to accompany this with stuff in the details dictionary in <http://telepathy.freedesktop.org/spec/Connection.html#Signal:ConnectionError> — for instance, a URL, maybe the human-readable message from the server, etc.

It follows that we could also use a D-Bus error name meaning “you need to upgrade”.
Comment 3 Will Thompson 2011-03-08 02:37:29 UTC
I totally misread the commit. This already is a D-Bus error. My mistake.

So, better review comment on top of the above remark about defining some standard details for UIs: it might be nice to document which Connection_Status_Reason should be used to correspond to this.
Comment 4 Jonathon Jongsma 2011-03-08 07:13:43 UTC
Created attachment 44231 [details] [review]
Add EmergencyCallsNotSupported error
Comment 5 Jonathon Jongsma 2011-03-08 07:14:14 UTC
Comment on attachment 44231 [details] [review]
Add EmergencyCallsNotSupported error

sorry, wrong bug :/
Comment 6 Jonathon Jongsma 2011-03-08 07:14:57 UTC
Created attachment 44232 [details] [review]
Add EmergencyCallsNotSupported error
Comment 7 Jonathon Jongsma 2011-03-08 07:16:22 UTC
Comment on attachment 44232 [details] [review]
Add EmergencyCallsNotSupported error

what is wrong with me?
Comment 8 Jonathon Jongsma 2011-03-08 07:49:26 UTC
Apparently tp:error names need to be separated with spaces, rather than camel-cased, otherwise you'll end up with TP_ERROR_SOFTWAREUPGRADEREQUIRED instead of TP_ERROR_SOFTWARE_UPGRADE_REQUIRED
Comment 9 Danielle Madeley 2011-03-08 14:46:42 UTC
(In reply to comment #3)
 
> So, better review comment on top of the above remark about defining some
> standard details for UIs: it might be nice to document which
> Connection_Status_Reason should be used to correspond to this.

Added Connection_Status_Reason.

I'm not sure what standard details we might include. There is already the non-translatable debug-message. We could try and include an (as) of package names, but I don't see how we could do that in a portable way. I suppose it could be presented as a list of binaries/libraries that needed upgrading.

e.g.
upgrade-required = { "telepathy-rakia", "libsofiasip.so.0" }

And let the package manager figure out what packages provides those.

(In reply to comment #8)
> Apparently tp:error names need to be separated with spaces, rather than
> camel-cased, otherwise you'll end up with TP_ERROR_SOFTWAREUPGRADEREQUIRED
> instead of TP_ERROR_SOFTWARE_UPGRADE_REQUIRED

Fixed.
Comment 10 Danielle Madeley 2011-03-08 14:49:29 UTC
(In reply to comment #9)

> I'm not sure what standard details we might include. There is already the
> non-translatable debug-message. We could try and include an (as) of package
> names, but I don't see how we could do that in a portable way. I suppose it
> could be presented as a list of binaries/libraries that needed upgrading.
> 
> e.g.
> upgrade-required = { "telepathy-rakia", "libsofiasip.so.0" }
> 
> And let the package manager figure out what packages provides those.

Wondering how you would express python modules... papyon.py, python:papyon ?

Perhaps this isn't even worth it. The client can see what CM failed and could look to see if there's an upgrade of that CM and/or its dependencies available.
Comment 11 Sjoerd Simons 2011-03-08 18:02:54 UTC
(In reply to comment #10)
> (In reply to comment #9)
> 
> > I'm not sure what standard details we might include. There is already the
> > non-translatable debug-message. We could try and include an (as) of package
> > names, but I don't see how we could do that in a portable way. I suppose it
> > could be presented as a list of binaries/libraries that needed upgrading.

> Perhaps this isn't even worth it. The client can see what CM failed and could
> look to see if there's an upgrade of that CM and/or its dependencies available.

I don't think it's worth it. The initial implementation in empathy will probably just be to report this to the user in a nice way and optionally have a button to start the package manager and have it check for any updates. If we want to go a step further we can indeed map protocol/cm name to packages and specially ask/check for updates of those (or its dependencies)..

This is vaguely related to the idea that empathy's account UI should show all protocols we might potentially support and call a package manager if the user selects one we don't have a CM installed for (like gstreamer can do for plugin installation)
Comment 12 Sjoerd Simons 2011-03-09 05:16:21 UTC
Merged, thanks!.  A fresh spec has just released and a new telepathy-glib
release should be out soon

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.