Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    Where is pfSense support for HTTP/3 and QUIC protocol support?

    Scheduled Pinned Locked Moved General pfSense Questions
    91 Posts 12 Posters 26.6k Views 14 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • lohphatL Offline
      lohphat @johnpoz
      last edited by

      @johnpoz said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

      So now you want your "firewall" to do a PTR query on every single hit of traffic that wants to go through the firewall.. That is going to be a shit ton of dns queries, where most of them as far as PTRs go wont even resolve to anything..

      Not at all, the overhead would be incurred not for all traffic but for a specific rule requesting the reverse lookup (e.g. UDP/443 requests only), and caching the results to reduce the need for a reverse lookup for each request.

      I know PTRs are not required and may not match but it's what we have available and the larger CDNs I'm trying to target (Google, MSFT, et al) usually (not always) have more consistent DNS records.

      SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

      johnpozJ 1 Reply Last reply Reply Quote 0
      • johnpozJ Offline
        johnpoz LAYER 8 Global Moderator @lohphat
        last edited by

        @lohphat Can't wait for you to come out with this magic firewall of yours.. Since clearly pfsense is just not doing it right..

        Free as well like pfsense I assume.

        An intelligent man is sometimes forced to be drunk to spend time with his fools
        If you get confused: Listen to the Music Play
        Please don't Chat/PM me for help, unless mod related
        SG-4860 25.07.1 | Lab VMs 2.8.1, 25.07.1

        lohphatL 1 Reply Last reply Reply Quote 1
        • lohphatL Offline
          lohphat @johnpoz
          last edited by

          @johnpoz

          Aug 4 09:11:16 LAN QUIC HTTP/3 (1659322461)[2603:xxxx::1d04]:49375
          [2607:f8b0:4006:823::200a]:443
          lga34s39-in-x0a.1e100.net
          

          So in the case of YouTube, the destination address DID resolve into a sane FQDN

          SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

          johnpozJ 1 Reply Last reply Reply Quote 0
          • johnpozJ Offline
            johnpoz LAYER 8 Global Moderator @lohphat
            last edited by johnpoz

            @lohphat said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

            into a sane FQDN

            but is not the domain user was trying top go to - so where is this list pfsense is magic going to have that says oh if user looks up domainX something, and the PTR comes back otherdomainY or somethinG or xyzdomainX then sure let it through..

            How does this magic firewall even know that IP 1.2.3.4 should have a ptr done on it and only if in its list of ok domains should it be allowed.

            So any destination IP using udp 443, it should do a ptr on and only allow from your list of domains that are permitted. Who is compiling this list of PTR domains that are ok? How is it going to be updated?

            What if going to udp 8443, what about udp 10443, or 4430, etc.. Just block all those? Or should it do PTR queries on the IPs

            An intelligent man is sometimes forced to be drunk to spend time with his fools
            If you get confused: Listen to the Music Play
            Please don't Chat/PM me for help, unless mod related
            SG-4860 25.07.1 | Lab VMs 2.8.1, 25.07.1

            lohphatL 1 Reply Last reply Reply Quote 0
            • lohphatL Offline
              lohphat @johnpoz
              last edited by

              @johnpoz said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

              @lohphat Can't wait for you to come out with this magic firewall of yours.. Since clearly pfsense is just not doing it right..

              Free as well like pfsense I assume.

              I don't think the snark is necessary.

              Having a method to trigger an additional address verification for a specified rule -- and not all traffic (I don't know where you got that impression I was suggesting that) -- doesn't seem impossible or need to "create a new firewall".

              SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

              1 Reply Last reply Reply Quote 0
              • lohphatL Offline
                lohphat @johnpoz
                last edited by lohphat

                @johnpoz said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                @lohphat said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                into a sane FQDN

                but is not the domain user was trying top go to - so where is this list pfsense is magic going to have that says oh if user looks up domainX something, and the PTR comes back otherdomainY or somethinG or xyzdomainX then sure let it through..

                You're not getting the point -- AT ALL.

                1. I want to PERMIT google UDP/443 requests for YouTube.
                2. I know that Google uses *.1e100.net for most if not all their YT content.
                3. I want a rule to check if the UDP/443 destination address is within *.1e100.net
                4. For THIS RULE, take the time to reverse lookup the destination FQDN and cache it for any subsequent requests, and match the domains in the permit rule.
                5. For ALL OTHER UDP/443, drop.

                @johnpoz said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                but is not the domain user was trying top go to - so where is this list pfsense is magic going to have that says oh if user looks up domainX something, and the PTR comes back otherdomainY or somethinG or xyzdomainX then sure let it through..

                I have no idea where you got this from. I never suggested this was the use case.

                SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

                johnpozJ 1 Reply Last reply Reply Quote 0
                • johnpozJ Offline
                  johnpoz LAYER 8 Global Moderator @lohphat
                  last edited by johnpoz

                  @lohphat said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                  I know that Google uses *.1e100.net for most if not all their YT content.

                  How do you know this - where does pfsense learn this from... You going to manually put that in? What if google now starts having ptrs that resolve with new1e200.net etc..

                  Where is this info going to come from - who is going to put it in to the firewall, how is it going to be updated and maintained as it changes, etc.

                  And you want this only for quic but not tcp - because why exactly? The same stuff that can happen over quic can happen over tcp 443..

                  So pfsense should also do all this over tcp 443 as well..

                  Lets say you query when user hits udp 443 going to 1.2.3.4 - how fast does that ptr resolve? What if takes longer than normal, clients hasn't got an answer and has already sent 3 retrans - oh well guess I can't get there - sorry user.. Try again later in his browser window.

                  An intelligent man is sometimes forced to be drunk to spend time with his fools
                  If you get confused: Listen to the Music Play
                  Please don't Chat/PM me for help, unless mod related
                  SG-4860 25.07.1 | Lab VMs 2.8.1, 25.07.1

                  lohphatL 1 Reply Last reply Reply Quote 1
                  • lohphatL Offline
                    lohphat @johnpoz
                    last edited by

                    @johnpoz said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                    @lohphat said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                    I know that Google uses *.1e100.net for most if not all their YT content.

                    How do you know this - where does pfsense learn this from... You going to manually put that in? What if google now starts having ptrs that resolve with new1e200.net etc..

                    Where is this info going to come from - who is going to put it in to the firewall, how is it going to be updated and maintained as it changes, etc.

                    And you want this only for quic but not tcp - because why exactly? The same stuff that can happen over quic can happen over tcp 443..

                    So pfsense should also do all this over tcp 443 as well..

                    I wasn't suggesting pfSense do this automatically -- ME THE ADMIN determines the domains to permit. If things change over time, I WILL MAKE THE CHANGES.

                    I just want the functionality of being able to do this.

                    This is no different than blocking/permitting any other website -- or any other protocol.

                    What's missing is wildcard domain aliases and I think this is a solvable problem so that admins have the choice to use it -- or not. If they try to do this on too many requests then yes, the f/w will slow.

                    But I'm not suggesting ANYONE do that, I just want some way to OPTIONALLY add an additional reverse lookup -- and cache the result -- to then use in a rule.

                    That doesn't seem unreasonable.

                    SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

                    JonathanLeeJ 1 Reply Last reply Reply Quote 0
                    • JonathanLeeJ Offline
                      JonathanLee @lohphat
                      last edited by

                      @lohphat QUIC protocol has been in the works for some time now Google and Facebook want to use it. PaloAlto is also a firewall company has even released an update that can detect QUIC traffic. New protocols have to be approved before getting used. For now, I only allow TCP traffic to 443. It was created to help speed up streaming traffic and it was experimental for sometime. Just block it and the traffic defaults back to TCP.

                      Make sure to upvote

                      lohphatL 1 Reply Last reply Reply Quote 0
                      • lohphatL Offline
                        lohphat @JonathanLee
                        last edited by lohphat

                        @jonathanlee I understand all that. But the protocol has now been ratified by the IETF and thus having some level of control other than all or nothing is desirable. Being able to whitelist QUIC from well-known sources and not others seems a reasonable middle-ground. I want YouTube and Google data streamlined but not from any random site.

                        SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

                        JonathanLeeJ 1 Reply Last reply Reply Quote 1
                        • JonathanLeeJ Offline
                          JonathanLee @lohphat
                          last edited by JonathanLee

                          @lohphat Palo Alto recently gained capacity last year for appID to see what the traffic is. Firewalls do have the ability. Give it time PfSense will soon have that ability as well.

                          I did a discussion post about this in Firewall class while working on my AA. As Facebook turned it on when I was working with Palo Alto images for assignments the Professor said that it is normal to block the UDP 443 traffic unless it is required.

                          Screenshot_20221003-175027.png

                          URL blocking and items will be a problem if you let HTTPS3 run. Facebook started tested HTTPS3 today and now is only using this with my IP address. Hypothetically if a triad of major IT companies all start using HTTPS3 at once, example being Google, Facebook, and Cisco. Firewall companies are forced to react. The real question is what is the proper guidelines for security controls and use of HTTPS3 in firewalls. Over many years in the field I have seen this tactic done to force major sales. One can forecast a new product will come out after that protocol is staged for major use. Again, hypothetically, "Cisco's New ____" fill in the blank. ASA with QUIC controls for example. Understanding the movements and planning is important I feel in cybersecurity. Watch out for this protocol. When I worked at NCR we had products that were only allowed to be used with one vendor per contract for a specific amount of years, and no one else. So Google's HTTPS3 proprietary protocol could be licensed to only one firewall vendor for decryption for a specific timeline of for example 5 years maybe Palo Alto could have the decryption rights for it. It is the gray areas we need to watch out for. Investments and the sole investors into the new products get first dibs on such items explicitly. The real question comes back to, what is the Federal Government Guidelines for such a triad of issues Firewalls, Protocols, and Approval of Use.

                          Again to look at this within security and corporate network issues, Obscurity is of upmost importance when working with exploits. Antivirus software is finetuned daily to detect specific exploits within the signatures of files. Encoders play a key role in obfuscation for the security of the exploit and it's handlers. Use of encoders gives rise to polymorphism within code, code that is ever changing in its location and signature. To put in other words this is so new that it has not been hardened enough to be left wide open with a firewall. Follow the recommendations until they approve of it's use for secure networks. Nation state actors love the grey areas. For now only allow 443 and 80 with tcp, until explicitly advised that it's safe.

                          Ref:
                          https://knowledgebase.paloaltonetworks.com/KCSArticleDetail?id=kA10g000000ClarCAC

                          Make sure to upvote

                          lohphatL 1 Reply Last reply Reply Quote 0
                          • lohphatL Offline
                            lohphat @JonathanLee
                            last edited by

                            @jonathanlee There's a great playlist describing QUIC at the protocol level. Even with the AppID details of the protocol details, so much of the payload is encrypted that individual URLs are cloaked so that they can't be detected by filters (pfBlockerNG, snort, suricata) -- you have to block the entire QUIC request or nothing, you can't pick it apart.

                            HOW QUIC WORKS
                            https://www.youtube.com/watch?v=HnDsMehSSY4&list=PLW8bTPfXNGdDcSDSmcfYs3ynYOdc1cXSh

                            SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

                            JonathanLeeJ 2 Replies Last reply Reply Quote 0
                            • JonathanLeeJ Offline
                              JonathanLee @lohphat
                              last edited by JonathanLee

                              @lohphat

                              HTTPS 3 uses UDP and TCP over port 443

                              Current HTTPS uses TCP.

                              To disable quic you just block UDP traffic to port 443 and port 80.

                              There is a overview of it with Palo Alto and other firewalls.

                              Thanks for the reply

                              You just close off UDP over 443 to stop it. I did and you can see the QUIC error code with Facebook during testing. After it will default back to TCP use and Facebook runs again.

                              That's the current recommendation. Without 443 UDP access it won't work.

                              Chrome browser can decrypt it. But yes it is an issue that's why the major firewall companies want it blocked if it's not required.

                              Make sure to upvote

                              lohphatL 1 Reply Last reply Reply Quote 0
                              • JonathanLeeJ Offline
                                JonathanLee @lohphat
                                last edited by

                                @lohphat
                                https://youtu.be/QRRHA_5hS2c

                                This is amazing they decypt QUIC in this with pen testing software.

                                So why isn't SQUID doing this?

                                Make sure to upvote

                                lohphatL 1 Reply Last reply Reply Quote 1
                                • lohphatL Offline
                                  lohphat @JonathanLee
                                  last edited by

                                  @jonathanlee I know what QUIC is and how to block it. That's not the issue. I WANT to allow it but from a list of acceptable domains. That's the problem with pfSense, you can't whitelist QUIC by domain easily. That's my ask, It's going to be complicated to scope out what the QUIC request is asking for and then be able to whitelist "trusted" domains (Google, et al).

                                  SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

                                  1 Reply Last reply Reply Quote 0
                                  • lohphatL Offline
                                    lohphat @JonathanLee
                                    last edited by

                                    @jonathanlee This works because the TLS 1.3 keys are being captured at the host where the QUIC request is originating from.

                                    A gateway (pfSense, PANs, Cisco, etc.) don't have access to those client keys UNLESS there's a capture agent on each host -- OR all the host keys have some sort of enterprise PKI management in place to escrow client keys on the fly.

                                    This is a hard problem to tackle.

                                    SG-3100 25.07.1-RELEASE (arm) | Avahi (2.2_7) | ntopng (6.2.0) | openvpn-client-export (1.9.5) | pfBlockerNG-devel (3.2.10) | System_Patches (2.2.23)

                                    P JonathanLeeJ 2 Replies Last reply Reply Quote 0
                                    • P Offline
                                      Patch @lohphat
                                      last edited by

                                      Perhaps using pfblocker to create and alias native for the ASN then include that in the black or white list for the QUIC rule

                                      JonathanLeeJ stephenw10S lohphatL 3 Replies Last reply Reply Quote 3
                                      • JonathanLeeJ Offline
                                        JonathanLee @lohphat
                                        last edited by

                                        @lohphat PfSense open source community can do it. Just you watch. . . . Soon viruses will be stomped out. They have to have an http get request in there that is easily accessible, something. I can't wait to see the solution to it.

                                        Make sure to upvote

                                        1 Reply Last reply Reply Quote 0
                                        • JonathanLeeJ Offline
                                          JonathanLee @Patch
                                          last edited by JonathanLee

                                          @patch maybe some form of adapting attestation that is being used with the TPM chips? TPM key attestation?

                                          Make sure to upvote

                                          1 Reply Last reply Reply Quote 0
                                          • stephenw10S Offline
                                            stephenw10 Netgate Administrator @Patch
                                            last edited by

                                            @patch said in Where is pfSense support for HTTP/3 and QUIC protocol support?:

                                            Perhaps using pfblocker to create and alias native for the ASN then include that in the black or white list for the QUIC rule

                                            Exactly that ^.

                                            lohphatL 2 Replies Last reply Reply Quote 1
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.