• lemmyvore@feddit.nl
    link
    fedilink
    English
    arrow-up
    47
    arrow-down
    6
    ·
    4 months ago

    You. Don’t. Store. Secrets. In. Plaintext.

    SSH stores the secret keys in plaintext too. In a home dir accessible only by the owning user.

    I won’t speak about Windows but on Linux and other Unix systems the presumption is that if your home dir is compromised you’re fucked anyway. Effort should be spent on actually protecting access to the home personal files not on security theater.

      • dave@programming.dev
        link
        fedilink
        arrow-up
        10
        ·
        4 months ago

        Well yes, but also how would users react if they had to type in their passphrase every time they open the app? This is also exactly what we’re giving up everywhere else by clicking ‘remember this device’.

      • lemmyvore@feddit.nl
        link
        fedilink
        English
        arrow-up
        2
        ·
        4 months ago

        If someone gets access they can delete your keys, or set up something that can intercept your keys in other ways.

        The security of data at rest is just one piece of the puzzle. In many systems the access to the data is considered much more important than whether the data itself is encrypted in one particular scenario.

    • x1gma@lemmy.world
      link
      fedilink
      arrow-up
      13
      arrow-down
      4
      ·
      4 months ago

      Kinda expected the SSH key argument. The difference is the average user group.

      The average dude with a SSH key that’s used for more than their RPi knows a bit about security, encryption and opsec. They would have a passphrase and/or hardening mechanisms for their system and network in place. They know their risks and potential attack vectors.

      The average dude who downloads a desktop app for a messenger that advertises to be secure and E2EE encrypted probably won’t assume that any process might just wire tap their whole “encrypted” communications.

      Let’s not forget that the threat model has changed by a lot in the last years, and a lot of effort went into providing additional security measures and best practices. Using a secure credential store, additional encryption and not storing plaintext secrets are a few simple ones of those. And sure, on Linux the SSH key is still a plaintext file. But it’s a deliberate decision of you to keep it as plaintext. You can at least encrypt with a passphrase. You can use the actual working file permission model of Linux and SSH will refuse to use your key with loose permissions. You would do the same on Windows and Mac and use a credential store and an agent to securely store and use your keys.

      Just because your SSH key is a plaintext file and the presumption of a secure home dir, you still wouldn’t do a ~/passwords.txt.