Auto-connection for gnome-3-24 content interface

The Ubuntu Desktop team has created the gnome-3-24[1] snap which provides supported backports of libraries needed for GNOME 3.24 apps on 16.04 via a content interface. As we are populating the store with desktop apps which utilize this content interface, we would like a snap declaration to auto-connect this interface.

default-provider: gnome-3-24:gnome-3-24-platform

We have some snaps already in the store using this interface, and many more on the way. Examples include: gedit, gnome-dictionary, gnome-clocks, gnome-calculator, gnome-sudoku and quadrapassel.

Thanks for your consideration

  1. https://dashboard.snapcraft.io/dev/snaps/7777/
3 Likes

Keep in mind that snaps from the same publisher already auto-connect, so, AIUI, the examples you listed of consumers for this interface should already auto-connect.

Can you confirm that you want this snap to auto-connect for snaps from any publisher? If so, can you also comment on the stability of the libraries, APIs, ABIs, etc of the gnome-3-24 snap and any other information stating the promise of updates to this snap not breaking 3rd party publishers?

1 Like

The GNOME platform snap is published by the Canonical account but Gustavo didnā€™t want us to use that one for the applications so Ken has published those under his account (and other team members are going to do the same) so the publisher is different?

We also want this to auto-connect for 3rd party app developers publishing apps that need GNOME.

1 Like

Itā€™s clear you want people to connect to this snap, but can someone comment on this?

The gnome-3-24 platform snap is built from the ubuntu-desktop backports PPA for which we are maintaining specifically to provide a supported gnome-3.24 base for GNOME apps and app developers to utilize. Itā€™s GNOME 3.24 which is ABI stable and we are committed to only push updates from the 3.24 stable series. Weā€™ll ensure a variety of the GNOME apps are well tested before pushing updates of the gnome-3-24 snap to the stable channel.

Ok, thanks.

+1 for allowing any app to auto-connect to this interface. Note, we need at least one other reviewer to vote before granting the snap declaration.

1 Like

I just noticed Iā€™m affected by this the other day. handbrake-jz stopped working and prompted me to do

snap install --edge gnome-3-24
snap connect handbrake-jz:gnome-3-24-platform gnome-3-24:gnome-3-24-platform

Iā€™m told the --edge may not be necessary, but thatā€™s what the error message in the terminal asks me to do.

At this point, more than one week has passed, so tallying votes:

1 vote for
0 votes against
0 votes abstained.

There are not enough votes at this time to grant the auto-connection. Adding the 3 day extension to the voting period (to be tallied on Aug 9 or after).

Directly pinging a few store reviewers to push this along: @niemeyer, @Wimpress, @tyhicks and/or @natalia can you vote on whether to allow or deny this auto-connection?

As a bystander, Iā€™d like to put my voice behind this anyway, so that corebird snap can be reduced in size - from 80MB to 40MB (ish) by leaning on the platform snap, so autoconnection would be awesome.

I didnā€™t say you shouldnā€™t use that one for applications.

What I said was actually this:

So itā€™s just a matter of making it clear that it is maintained by a team at Canonical (and will continue to be) and having some information available so we can tell which snaps those are and what is the maintenance plan, ideally here in the forum.

With that said, part of the point of that particular content interface on gnome-3-24 as I understand it is being a base for other snaps to rely upon, so being able to auto-connect it sounds interesting nevertheless. The point above by @lucyllewy already shows that being desired.

Iā€™d like to thread carefully while doing that though, only because this is the first time weā€™ll be opening up that specific door, which means we have very little experience with that sort of interface being public so far. To that end, can you respond to @jdstrandā€™s question above in a bit more detail:

From the name of the snap and its interface, it doesnā€™t look like that was accounted for. In particular, that snap and interface are globally visible, not only across multiple distributions but also across multiple versions of those which will span several years. What happens when there are ABI breakages that take place because not Gnome itself but the underlying infrastructure changed? How should one pick the right ā€œgnome-3-24ā€ snap and interface?

Could you give some details on what you call ā€œthe underlying
infrastructureā€, are you speaking about the core snap changing its ABI?

If thatā€™s the case itā€™s going to impact any snap and not only the
platform (there is no reason the gtk library built into the platform
would be any different from the one bundled by e.g vlc). How do we (plan
to) handle those cases for non-platform snaps?

No, the point is unrelated to the core snap or snapd. Think about any change outside of the Gnome source code that could make an application binary built 5 years from now incompatible with the libraries built today.

Sorry but I donā€™t understand how thatā€™s specific to the platform snap
and not going to impact any application snap that e.g bundles gtk the
same way. Could you maybe give an example (real or imaginary) to help me
to understand what you mean there?

The application that bundles gtk holds all of its libraries inside the same snap. When you cross the line between snaps, then thereā€™s an ABI being promised which we need to understand and plan for. Thatā€™s the most important reason why we constrain content interfaces to the same publisher, and also part of the rationale for why there is more bundling in snaps than debs. Once you introduce a more traditional dependency, then all of those issues need to be accounted for again, and now itā€™s not about a Linux distribution anymore, but many versions of many distributions.

Consider glibc for example: https://abi-laboratory.pro/tracker/timeline/glibc/

Sorry but Iā€™m still unsure to understand what you mean. You wrote ā€œwhen
there are ABI breakages that take place because not Gnome itself but the
underlying infrastructure changed?ā€ but there is no infrastructure under
the gnome platform snap putside of ubuntu core, what part could be
moving/changing ABI?

When there is a content interface, there are three snaps involved: the base snap (core for now), the snap with the interface plug, and the snap with the interface slot. There are binaries on all of those, and they must work together. How do we organize things in a way that will continue to make sense over time?

Well, the problem definition is simple there. We only add one extra part
compared to a normal snap, the platform. The way to make sure it doesnā€™t
create issues for snaps using it is to ensure that there is no
incompatible changes made ever to that platform snap.

GNOME stable versions donā€™t change much (if at all after a while) and
itā€™s our job to make sure that if we do an update it doesnā€™t include any
abi/behaviour change (basically the same job than we do today for SRUs
or security updates).

Ken stated in that topic that updates to that platform snap are going to
be stable serie changes from GNOME and careful tested by us, is there
anything more we can do to help you making more confident that itā€™s good
enough?

Again, the issue is that the bits outside the platform snap are not under control. Even if the platform snap remains unchanged, the other bits will change, and possibly make the interaction with that platform snap impossible. It sounds like we need to acknowledge these issues and plan for them.

Note that on a typical snap, there are only the application snap and the base snap. The base snap will often be based on the underlying platform being used (say, Debian 10), which means the built bits will be compatible with it. The application is obviously compatible with itself, because it was just built. The gnome platform is the odd bit out in this picture, because it was compiled in a different platform and may not be compatible anymore.

How do we organize that?

But what ā€œbitsā€?

The picture looks like

[base snap] <- [platform] <- [application snap]

instead of

[base snap] <- [application snap]

If the base and platform snaps donā€™t change what can be the issue?