In the last couple of weeks, I’ve started getting this error ~1/5 times when I try to open one of my own locally hosted services.

I’ve never used ECH, and have always explicitly restricted nginx to TLS1.2 which doesn’t support it. Why am I suddenly getting this, why is it randomly erroring, then working just fine again 2min later, and how can I prevent it altogether? Is anyone else experiencing this?

I’m primarily noticing it with Ombi. I’m also mainly using Chrome Android for this. But, checking just now; DuckDuckGo loads the page just fine everytime, and Firefox is flat out refusing to load it at all.

Firefox refuses to show the cert it claims is invalid, and ‘accept and continue’ just re-loads this error page. Chrome will show the cert; and it’s the correct, valid cert from LE.

There’s 20+ services going through the same nginx proxy, all using the same wildcard cert and identical ssl configurations; but Ombi is the only one suddenly giving me this issue regularly.

The vast majority of my services are accessed via lan/vpn; I don’t need or want ECH, though I’d like to keep a basic https setup at least.

  • Moonrise2473@feddit.it
    link
    fedilink
    English
    arrow-up
    2
    ·
    2 hours ago

    I had a similar problem when using nginx proxy manager. In the end I just gave up and directly used cloudflare tunnels+cloudflare ssl

    • Darkassassin07@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      2 hours ago

      I think I’ve found the problem:

      It seems my issue is pihole being unable to block/modify dns requests for HTTPS records, which don’t match the LAN IPs pihole handed out in A/AAAA records.

      I’ve disabled cloudflare proxying so they don’t have HTTPS records to serve, but I’ll have to replace pihole with a better lan DNS solution if I want to turn that back on.

    • Darkassassin07@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      2 hours ago

      Thanks. That seems to be a similar, but slightly different error. I think the below may apply though.

      I believe I’ve tracked down more of my issue, but fixing it is going to be a hassle:

      When cloudflare proxying is enabled, there are 3 DNS records involved; A record with cloudflares ipv4, AAAA record with cloudflares IPV6, and the key to this puzzle: an HTTPS record with cloudflares ech/https config.

      With pihole I can set DNS records for A/AAAA, but I have no way of blocking/setting the HTTPS record so it gets through from cloudflare.

      The LAN A/AAAA records don’t match the HTTPS record from cloudflare, so browsers freak out.

      Once I disabled cloudflares proxying, I no longer get HTTPS records returned and all works as intended.

      I’ll either have to keep cloudflare proxying disabled, or switch pihole out for a more comprehensive DNS solution so I can set/block HTTPS records :(

      Thank you @bobslaede@feddit.dk for pointing me in the right direction.

  • bobslaede@feddit.dk
    link
    fedilink
    English
    arrow-up
    5
    ·
    3 hours ago

    Any chance you are both accessing your services locally with a local DNS, and publicly with something like Cloudflare?

    • Darkassassin07@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      3 hours ago

      I do have external acces to Ombi via cloudflare; but the device I’m seeing this problem on is permanently connected to a VPN hosted from the same server machine as ombi/nginx with ‘block all connections without VPN’ enabled. And this testing has been done from within the same LAN.

      It should never see/reach cloudflare for this service.

      /edit; I’ve also disabled ‘use secure DNS’ in chrome. I host a local DNS within that lan/vpn network.

      • solrize@lemmy.world
        link
        fedilink
        English
        arrow-up
        2
        ·
        3 hours ago

        Can you verify with wireshark that the traffic is only going through your lan? I’m not hip enough for nginx but I used to have to run apache under gdb all the time to trace random errors from the server. That would be next, if the traffic is really local.

      • bobslaede@feddit.dk
        link
        fedilink
        English
        arrow-up
        2
        ·
        edit-2
        3 hours ago

        Try with nslookup and see if you’re resolving the domain to both your local ipv4 address, and the Cloudflare ipv6 at the same time. I am using pihole for my local DNS, and it would give me both my local address, and also the Cloudflare ipv6 address.

        Edit
        My pihole will ask upstream even if the domain was listed locally. It doesn’t ask Upstream for cname.

        • Darkassassin07@lemmy.caOP
          link
          fedilink
          English
          arrow-up
          1
          ·
          3 hours ago

          Added an AAAA record to pihole:

          ombi.mydomain.example 0000:0000::0000:0000

          Now nslookup returns the correct ipv4 address, and ‘::’ as the ipv6.

          We’ll see if that works.

          • Darkassassin07@lemmy.caOP
            link
            fedilink
            English
            arrow-up
            1
            ·
            edit-2
            3 hours ago

            That unfortunately did not work. I am only getting the ipv4 address now, but I still get the same ECH error in chrome 1/5 tries.

            Firefox now changed errors from ‘invalid certificate’ to ‘connection is insecure but this site has HSTS’ (true). Still wont show the cert or provide any further info. (forgot to grab a screenshot before the below ‘solution’)

            I’m really annoyed at this point and have just disabled cloudflare proxying for this service. That seems to have sorted it for all browsers. I may look further later, I may just say fuck it and leave it like this. Gotta walk away for a bit.