Hi Enrique,
> Regarding error "Your computer was not found in the database" > This is presented to anyone hitting the portal from the public Internet. For instance if you went to http://pf4.dotto-one.com/ right now, you should see it, as the listener is active, for other client activities like email link activation, pre-registration (we do not use) and the default captive portal landing page will not find you in the database, because it can only do MAC based identification on the registration and isolation networks where it can see that L2 information. Traffic from the Internet is routed, and will show as MAC:0 and the current client public IP at the bottom of the page. On the iPhone, once network detection is complete, it shouldn't be talking the user back to the captive portal, but it is. Just blocking this traffic would force the client into believing it was no longer captive, but this would prevent access to the listener for email activation. > Have you tried local DNS resolution for the captive portal domain on > the default network, applying firewall rule to secure access to the > portal listener interface > I am not sure what you are asking me here. The DNS server on the Default network is on the local subnet, and is the gateway. It resolves the same public DNS as the link above to the portal listener. The firewall in front of the portal listener has firewall rules, and only Port 80/444 are allowed and forwarded on to the packetfence server portal listener. I believe this is standard routed topology; It has been setup this way since our first routed captive portal on Packetfence 5. - And I'll throw this unrelated comment in. ** We only use the captive portal functionality for free public wifi; though I am keen to find some clients that need a full NAC. The fact that we have been able to evergreen some circa Packetfence 5/7 instances across Debian upgrades is impressive and speaks to the Inverse team's platform commitment. The new docker model reduces cross-platform complexity even further. The GUI is so functional; In my recent sessions, I stumbled across the netflow renderings; The lease timelines; It is sharp; Bien fait. I posted modified hostapd.sh <https://github.com/inverse-inc/packetfence/issues/7472> for recent OpenWRT releases which will hopefully show up in Add-ons. It makes it straightforward to turn any supported OpenWRT hardware into a captive portal for anyone wanting to get familiar with Packetfence, radius, vlan switching, isolation, authentication, etc. without any enterprise gear in their home lab. ** > > When the client lands on the default network, resolving the external > IP address for the captive portal domain, that "Nating" presents “as > computer not found on database”, I remember also adding a "network" > filter to the connection profile for routed networks that need to > access captive-portal. > I am not sure I understand what you are suggesting; The "computer not found on database" is the expected result - we just do not want iPhones getting there once they are connected to the Internet. They should just detect Internet and move on without returning to the portal. If we block it using the firewall, detection is fine. If you know how to create a filter for the /captive-portal on the public facing portal listener, that would be one way to workaround our iPhone network detection problem. All our other clients that we have tested seem to be okay with the current javascript implementation. We just need to get the iPhones fixed until RFC8908 is supported. I can see it has been discussed <https://github.com/inverse-inc/packetfence/issues/7040> but it seems what used to work in IOS 13/14 using the RFC7710bis <https://github.com/inverse-inc/packetfence/issues/5638> introduced in PF10 isn't working any longer. The clients do not use the network detection IP or image embedded in the captive portal javascript as seen in the captures we posted. They simply 'test' if they are still trapped based on reachability to the captive portal URL. I believe if we can somehow separate the ConfNet.PortalFQDN used by the captive portal redirect from the one used in email activation, we can use our Default network local DNS to make the current RFC7710bis implementation work with iPhones. If you know how this could be done, it would be a second to workaround our iPhone network detection problem. > El mar, 24 ene 2023 a las 19:59, Ian MacDonald (<i...@netstatz.com>) > escribió: > > > > Quick inline response to your questions; Thank you for having a peek. > > > > On Tue, Jan 24, 2023 at 5:45 PM Enrique Gross via PacketFence-users < > packetfence-users@lists.sourceforge.net> wrote: > >> > >> Regarding DNS, domain resolves to your public address? is that > >> correct? And that is the same domain as captive portal? > > > > Yes, as seen from the Default network, and the Internet, the packetfence > server hostname resolves using public DNS, and lands on the portal listener > attached to the management network interface on the server. > > > >> > >> On your topology, port 80/443 redirected to “PF redirection URL”? > > > > > > Yes, in hindsight, that detail should have been removed, as it is > confusing in that it is unrelated to the issue, and that redirection rule > is not active in this test environment. > > > > In production, there was a redirection URL in the Captive Portal > configuration that goes to a web site; Provided by the ISP that is > providing the free Internet. > > A similar redirection, if you happen to point your web browser at the > Default network gateway, also goes to that same location. The thinking > here was if you are surfing in the Public space, and get curious and do a > myipaddress.com look up and then go to that IP in your browser, you hit > the same landing page as the captive portal redirection. > > > > It is not active in this environment, so I should have purged it from > the topology snapshot > > > >> > >> Enrique > >> > >> El mar, 24 ene 2023 a las 8:19, James Andrewartha via > >> PacketFence-users (<packetfence-users@lists.sourceforge.net>) > >> escribió: > >> > > >> > Hi Ian, > >> > > >> > So looking through the registration PCAP, one thing I notice is that > there's three requests for http://captive.apple.com/hotspot-detect.html > before it tries to follow the redirect that page returns. Also your DNS is > returning the same IP (66.70.255.147) for captive.apple.com as for > pf4.dotto-one.com. Are you doing DNS enforcement on the portal? Then on > the default network, you return 104.244.196.73 for pf4.dotto-one.com. I > don't think that's wrong per se but just wanted to be clear. > >> > > >> > I see some accesses to https://pf4.dotto-one.com/rfc7710 after it > joins the default network, can you see what content is returned? Since it > tries that first before going to the captive portal URL on the default > network. Short of that, could you remove option 114 and 160 from both > registration and default network DHCP scopes? My feeling is that it's > holding onto the URL from the registration network and re-using that on the > default network instead of looking at the cappport:unrestricted value > returned on the default network. > >> > > >> > So was the iPhone not re-DHCPing problem solved by very short lease > times on the registration network? > >> > > >> > Thanks, > >> > > >> > -- > >> > James Andrewartha > >> > Network & Projects Engineer > >> > Christ Church Grammar School > >> > Claremont, Western Australia > >> > Ph. (08) 9442 1757 > >> > Mob. 0424 160 877 > >> > > >> > On 24/1/23 06:53, Ian MacDonald via PacketFence-users wrote: > >> > > >> > Okay, > >> > > >> > We have, again, scoped down our issue further to iPhones not properly > detecting they are no longer behind the Packetfence Captive Portal. I am > going to frame it up once again to see if anyone has any new insights. > >> > > >> > Problem: The iPhone is holding on to the captive portal page it > learns on the Registration network, and when it gets to the Default > network, it fails at detecting it is on the Internet, and it returns to the > Captive Portal page and traps the user there in the iphone's Log In > interface. > >> > > >> > If we block the iPhone from the Packetfence portal listener, after it > is on the Default network, it works and believes it is no longer Captive. > Unfortunately this also blocks registration activation links sent via > Email, so it doesn't quite qualify as a workaround unless we can separate > the hostname used for Email Activation from the hostname used for the > Captive Portal and block the latter with DNS overrides on our Default > network. > >> > > >> > It seems like the correct configuration would have Packetfence > instruct the iPhones to not use the Captive Portal URL reachability as > network detection, and possibly we have no control over this OR possibly it > can be done somehow through the Captive Portal API TBD. > >> > > >> > Help on how to do either of these things in Packetfence config > appreciated. > >> > > >> > Here is our lab v12.1 setup. > >> > > >> > > >> > As we moved through our testing we have made a few changes, none of > which seem to impact the expected outcome. We have enabled proxy > interception, changed our network detection to a local IP, modified the > detection delay (30s) so that it starts after the fencing delay (25s), and > allow 60s for the re-evaluation on the portal page progress bar. We > disabled CSP headers and secure_redirect in hopes of providing more > information during packet captures. Passthrough during fencing is now > disabled as well to keep traffic to a minimum. Our registration DHCP lease > time was shortened to 15 seconds. > >> > > >> > [fencing] > >> > wait_for_redirect=25 > >> > interception_proxy=enabled > >> > [captive_portal] > >> > network_detection_ip=104.244.196.157 > >> > network_detection_initial_delay=30s > >> > network_redirect_delay=60s > >> > request_timeout=5 > >> > secure_redirect=disabled > >> > rate_limiting=disabled > >> > [advanced] > >> > portal_csp_security_headers=disabled > >> > > >> > [10.2.2.0] > >> > dhcp_default_lease_time=15 > >> > dhcp_max_lease_time=15 > >> > > >> > The iPhone in this latest scenario is an iPhone 7 Pro running IOS 15. > >> > Registration has no issues, and VLAN switching occurs as expected at > 25s on the "Enabling network access" portal page, placing the iPhone onto > the Default network. > >> > > >> > > >> > > >> > When the iPhone is disconnected from the Registration network, the > Log In page closes, and the wifi settings appear briefly. > >> > > >> > > >> > > >> > The iPhone then connects to the Default network, however it decides > it must be still behind the packetfence captive portal, as it reloads the > Portal Login page again, and the user is trapped, and can not escape except > to hit Cancel and select "Use without Internet". > >> > > >> > > >> > > >> > The iPhone is holding on to the captive portal page it learned on the > Registration network, and when it gets to the Default network it fails at > detecting it is on the Internet, it returns to the Captive Portal page, and > is effectively trapped there. If it can see the Packetfence listener, it > believes it is still captured. > >> > > >> > With this in mind, we decided to simply block traffic from the > Default network to the Portal Page with a simple firewall rule to drop > traffic to the packetfence public IP. > >> > > >> > And the iPhone detects Internet. That was it. The detection was not > based on DHCP option 114, or reaching some other site, or the > network-access-detection.gif It is based on reaching the Captive Portal > URL, which is responding, as it is the same hostname where we expect our > users to go for Email Activation Links. > >> > > >> > The problem with blocking the Portal listener on the Default network > is that the user can not complete the email registration, as the same > portal listener that serves up the Captive Portal service up the > Registration Activation Link (/activation/email.html). > >> > > >> > It suggests we have to get the iPhone to ignore the Captive Portal > URL it learned from the Registration VLAN? Is this a bug in implementation > of the captive portal API usage in iPhones? > >> > > >> > Our Default network DHCP sees Option 114 requested, and provides the > unrestricted value (shown below). Maybe somebody can confirm the format > and content is correct so we can validate our assumption that the iPhone is > just ignoring it. We also pass the same value in Option 160 just in case > it ever is requested by an old client. > >> > > >> > > >> > > >> > I have collected pCaps from the Registration VLAN (Interface 10.2.2.2 > on our PF server) and from the Default Network (Interface 10.2.4.1) as well > as the haproxy_portal.log and packetfence.log from the same time period. > Nothing removed from those time periods, as there were no other devices on > those networks. I will leave them up whilst we are working on this issue > for anyone to inspect with Wireshark. > >> > > >> > > https://drive.google.com/drive/folders/1NFuDqJIkPrsMWs_DXqIeY0l_TTLYkPpE?usp=share_link > >> > > >> > I suppose a workaround could be to change the [% activation_uri %] to > a DNS hostname alias that is different than the captive portal hostname and > override the Default Network DNS so that the captive portal URL goes > nowhere (equivalent to our firewall block), allowing the users to still > hit the activation link and block iPhones from getting trapped on the > portal page at the same time. > >> > > >> > A follow-up question is does anyone know how to specify the > activation URL as a configuration parameter? We couldn't find it, as it > seems generated in the templates. > >> > > >> > It seems we are just down to configuration here; Getting close. > >> > > >> > > >> > _______________________________________________ > >> > PacketFence-users mailing list > >> > PacketFence-users@lists.sourceforge.net > >> > https://lists.sourceforge.net/lists/listinfo/packetfence-users > >> > > >> > > >> > _______________________________________________ > >> > PacketFence-users mailing list > >> > PacketFence-users@lists.sourceforge.net > >> > https://lists.sourceforge.net/lists/listinfo/packetfence-users > >> > >> > >> > >> -- > >> > >> > >> _______________________________________________ > >> PacketFence-users mailing list > >> PacketFence-users@lists.sourceforge.net > >> https://lists.sourceforge.net/lists/listinfo/packetfence-users > > > > -- > > > _______________________________________________ > PacketFence-users mailing list > PacketFence-users@lists.sourceforge.net > https://lists.sourceforge.net/lists/listinfo/packetfence-users >
_______________________________________________ PacketFence-users mailing list PacketFence-users@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/packetfence-users