• @Valmond
    link
    English
    120 hours ago

    So why can’t I make my own cert? Give the caller my public key and on we go.

    • @[email protected]
      link
      fedilink
      English
      517 hours ago

      You can distribute your public key, and have people manually add it to their trust stores.
      But OSs and browsers ship with preloaded trusted certificates. This way, the owner of a preloaded trusted certificate can issue new certificates that are automatically trusted by people’s OSs and browsers.
      To become a preloaded trusted certificate owner, I imagine that there are stringent audits and security requirements. Part of that will be verifying the identity of the requester before issuing them a certificate.

      With LetsEncrypt, they either need to talk to a server hosted at the domain to retrieve a token (generated when the request is initiated).
      This proves the requester owns/controls the domain and the server (the requester has correctly set up DNS records, and placed the required token on the server). This is HTTP challenge mode.
      The other method is by a DNS challenge. The requester adds a TXT record to their nameservers with the token value, letsencrypt then inspects the DNS records for the domain and will issue a cert when it sees the token. This proves the requester owns/controls the domain.

      So, proving identity is required (otherwise anyone could generate a trusted cert for any domain). And trusted certificate issuers are required, so people don’t have to constantly import (possibly dodgy) public keys

    • Give the caller my public key and on we go.

      And how does the client validate that your public key is actually your public key and not some attacker’s?

      The idea of having a trusted 3rd party is to ensure that some impartial and trustworthy arbiter can confirm to the client that yes, this certificate is trustworthy, because they issued it to the correct party.

      But you can absolutely self-sign a certificate. Works just fine, though not all clients accept self-signed certificates as trustworthy as anyone could have issued it.

      • @Valmond
        link
        English
        113 hours ago

        Because they’ll use it and it’s I that verify by decrypting it with my private key? If someone makes him use a bad key then it just won’t work.

        • How do they know you verified by decrypting?

          The client has to be able to verify. They can’t trust your result. Imagine a man-in-the-middle attack; if someone intercepted all traffic between you and the client, including the cert exchange, how would either party figure out that traffic was being intercepted?

          Client connects to website, but gets intercepted. Attacker provides own self-signed certificate to client. Client asks you to verify the certificate, but attacker can intercept that too and just reply the certificate is “totes cool bro just trust me”. You are none the wiser either, because the attacker can just decrypt client traffic and pretend they are the client by re-encrypting the data themselves.

          With a Certificate Authority, the client can take the received cert and ask the CA “did you sign this?”. The CA will then tell you they didn’t, exposing the attacker’s fake cert. This works, because the CA is already a trusted entity. That trust is being extended to your website’s certificate validity and thus the website identity.

          • @Valmond
            link
            English
            13 hours ago

            I see where you’re getting at, or so I think:

            A malevolent user takes over my website and installs his non-authorised certificate => danger!

            But I mean he can use my certificate, it’s already there, installed and set up to work?

            • If he fully takes over your website there’s nothing you can do as a client to detect it. But that’s not the point of the certificate. The certificate is there to ensure you are communicating with the website/server you think you’re communicating with.

              It ensures your communication is safe. In my example, the attacker doesn’t take over your website, he takes over some part of the network infrastructure between your website and the client, thus intercepting all the traffic. There’s a “man in the middle”, e.g. the website is safe, the client is safe, but the communication between them is not. The certificate ensures nobody is impersonating the website by intercepting all the traffic, ensuring the communication.

              If the website does get compromised, the CA has the option to invalidate the certificate at your request, via some verification procedure. Thus it also defends against compromised servers, though it’s not the primary purpose for which they exist.

        • @[email protected]
          link
          fedilink
          English
          113 hours ago

          Sure, but the first time the other person would have to accept your self signed cert. There is no knowing that the cert presented the first time was actually from you and not someone else.

          • @Valmond
            link
            English
            13 hours ago

            How would that matter?

            Say my website sends you my homemade cert, if you don’t use it you cant communicate with me (or go unsecure).

            Why myst some “trusted entity” emit tjose certificates? They are just a bunch of RSA keys!

            • @[email protected]
              link
              fedilink
              English
              11 hour ago

              Yes, there is no difference from your homemade cert compared to anyone else’s homemade cert.

              So if someone else claims to be your website and uses a similar homemade cert there is no way to know that the site isn’t yours.

    • @Gremour
      link
      English
      420 hours ago

      You can make your own cert. To make sure your cert belongs to you (your site) it is signed by authority and the client then may verify that authority (which cetificate is preinstalled in their system) in fact had verified ownership of your site and then signed your cert claims with their private key.