• Spectacle8011@lemmy.comfysnug.space
    link
    fedilink
    arrow-up
    62
    arrow-down
    1
    ·
    1 year ago

    What really needs to happen:

    Flatpak packages should ask for every permission they need, and the user needs to approve every one of them.

    Right now, we have this weird in-between state where some flatpak packages ship with limited permissions (like Bottles). That’s because every permission the package asks for is immediately granted. The user doesn’t get a chance to refuse these requests. This current model serves to make life more difficult for non-malicious flatpak packagers while failing to protect users from malicious packages.

    Also, GNOME needs a Flatpak permissions center like KDE. You shouldn’t need to install a third party program to manage permissions.

    • JoYo 🇺🇸@lemmy.ml
      link
      fedilink
      English
      arrow-up
      24
      arrow-down
      4
      ·
      1 year ago

      it’s weird that android and ios already provide this but THE container standard doesn’t

      • aardA
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        Android also shows that it doesn’t work because developers are idiot, and are requesting too much and/or don’t handle denial of permissions gracefully.

        On Android that’s currently not fixable as they decided not to sandbox the applications. With something like Flatpack that’d be easily fixable by giving the user the choice of allowing a permission - or allowing the permission to a dummy resource. You could then even offer to have a dummy resource shared between a bunch of applications.

    • miss_brainfart@lemmy.ml
      link
      fedilink
      arrow-up
      15
      ·
      1 year ago

      Absolutely, permissions should be disabled by default, and only when the app needs to do something that requires a certain permission should it ask for it.

      Maybe even do something like Android, where permissions automatically get revoked if you don’t use an app for a certain time. I love that feature.

      • oldfart@lemm.ee
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        1 year ago

        It’s the first time I hear someone praise Android messing with user’s settings. Care to elaborate why you like it?

        • miss_brainfart@lemmy.ml
          link
          fedilink
          arrow-up
          4
          ·
          1 year ago

          There is very little reason any app should keep its permissions if you never actually use it, is there?

          Especially when most people use apps that phone home every last piece of data they give them access to.

          • oldfart@lemm.ee
            link
            fedilink
            arrow-up
            3
            ·
            1 year ago

            I don’t agree but I see your point, that would certainly be useful to some people. Thank you for explaining.

            • miss_brainfart@lemmy.ml
              link
              fedilink
              arrow-up
              1
              ·
              1 year ago

              I think it’s enabled by default, but you can also just disable it for specific apps.

              But if you leave it enabled and permissions get revoked after a while, you’ll get a notification telling you about it. I think that’s fair.

              There’s always going to be a debate on whether something like this should be opt-in or opt-out, but for the purpose of privacy and data security, it makes sense to be on by default, I reckon.

    • FOSS Is Fun@lemmy.ml
      link
      fedilink
      English
      arrow-up
      8
      ·
      1 year ago

      I’ve tried to combat this a bit with a global Flatpak override that takes unnecessarily broad permissions away by default, like filesystem=home, but apps could easily circumvent it by requesting permissions for specific subdirectories. This cat-and-mouse game could be fixed by allowing a recursive override, such as nofilesystem=home/*.

      But even then, there is still the issue with D-Bus access, which is even more difficult to control …

      I think it is sad that Flatpak finally provides the tool to restrict desktop apps in the same way that mobile apps have been restricted for a decade, but the implementation chooses to be insecure by default and only provides limited options to make it secure by default.

      • TeryVeneno@lemmy.ml
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        I think the main reason why the implementation is insecure by default is simply because when it started most applications did not use portals and many portals we have today did not exist. You had to poke holes in the sandbox to make anything work cause all applications expected to run unconstrained. In the future as more apps become flatpak aware this should stop being an issue.

      • Spectacle8011@lemmy.comfysnug.space
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        1 year ago

        I don’t doubt it, but this is a good place to start.

        This claim has interesting phrasing:

        Adding X11 sandboxing via a nested X11 server, such as Xpra, would not be difficult, but Flatpak developers refuse to acknowledge this and continue to claim, “X11 is impossible to secure”.

        If you look at the GNOME post, you’ll see they haven’t argued against including a nested X server at all:

        Now that the basics are working it’s time to start looking at how to create a real sandbox. This is going to require a lot of changes to the Linux stack. For instance, we have to use Wayland instead of X11, because X11 is impossible to secure.

        I’m not saying they haven’t refused to acknowledge this elsewhere, but it’s strange to point to this blog post which acknowledges that the sandbox is very much a work-in-progress and agrees with Madaidan that X11 is hard to secure.

        Does Xpra provide better sandboxing than XWayland? If not, I think the Flatpak developer’s solution to this is: just use Wayland. And obviously, there’s plenty of room to improve with the permissions Flatpak does offer.

        I did some searching on the Flatpak Github for issues and found that you can actually use Xpra with Flatpak, and the answer is “just use Wayland”:


        This is also concerning:

        As odd as this may sound, you should not enable (blind) unattended updates of Flatpak packages. If you or a Flatpak frontend (app store) simply executes flatpak update -y, Flatpaks will be automatically granted any new permissions declared upstream without notifying you. Using automatic update with GNOME Software is fine, as it does not automatically update Flatpaks with permission changes and notifies the user instead.

        Source: https://privsec.dev/posts/linux/desktop-linux-hardening/#flatpak

        It’s great that GNOME Software notifies you when permissions change! I don’t use Flatpak enough to know, but I hope flatpak update notifies you too if you don’t use the -y option.