Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GUACAMOLE-1855: Allow MFA modules to be configured to bypass or enforce for specific hosts. #911

Merged
merged 4 commits into from
Aug 29, 2024

Conversation

necouchman
Copy link
Contributor

This pull request implements the feature proposed in Jira for GUACAMOLE-1855 - the Duo and TOTP modules can be configured to either be bypassed for users logging in from specific hosts, or can be configured to be explicitly required for users logging in from specific hosts, while other hosts are bypassed.

This allows situations where users connecting from the Internet ought to be required to complete MFA, but users logging in from behind a VPN or on a corporate network may not need to perform the extra authentication step.

@mike-jumper
Copy link
Contributor

Looks pretty neat. What's the intended behavior for the case that an address matches subnets/addresses within both the enforce list and the bypass list?

@necouchman
Copy link
Contributor Author

What's the intended behavior for the case that an address matches subnets/addresses within both the enforce list and the bypass list?

That's a good point - probably should give some more intentional thought to that. As it is currently written, as soon as an address is found in the bypass list, the user verification function will return, bypassing MFA authentication, and the enforcement list will never be processed.

I'm tempted to re-arrange things a bit where enforcement would actually "take precedence", and that a host in both lists would always be enforced. That seems like the more security-conscious way to go.

I'm open to suggestions, opinions, or discussion, though!

@necouchman
Copy link
Contributor Author

Also figured out that I missed the actual code for host checking on the TOTP side. Oops.

@necouchman
Copy link
Contributor Author

Okay, I've restructured things a bit such that having hosts listed in the enforce list should override anything listed in the bypass list. I need to do some testing before it's ready, so I'll mark this as a draft for the moment - in the meantime if you see anything else amiss, please let me know.

@necouchman necouchman marked this pull request as draft September 30, 2023 03:14
@mike-jumper
Copy link
Contributor

Sounds good! And I agree regarding giving enforcement priority over bypass. Better for a mistake in configuration to result in excessive enforcement of MFA than unexpected bypassing of MFA.

@necouchman necouchman force-pushed the working/mfa-bypass branch 2 times, most recently from 0b2260c to 5b04f6b Compare October 1, 2023 05:09
@necouchman
Copy link
Contributor Author

Okay, I think I've got the checks working. I'm currently hitting three issues:

  • Build is impacted by the odd Bouncycastle version update. Once that's fixed the build will work properly.
  • If I try to use Tomcat with its default IPv4 + IPv6 dual-stack enabled, the request.getRemoteAddr() call periodically flips between the actual IPv4 client IP and an IPv6 loopback IP (0:0:0:0:0:0:0:0:1 - or some number of 0s). I was able to pretty well remove this by adding -Djava.net.preferIPv4Stack=true to CATALINA_OPTS in the Tomcat startup, but ideally this would be able to reliably handle both IPv4 and IPv6. If anyone has any hints for that, I'm open.
  • I had to make some unusual changes to the IPAddress detection code because I couldn't loop through a List of IPAddress types - I'd get an error about how IPv4Address couldn't be cast to IPAddress. What's even more weird is that I converted everything to IPAddressString data types, and I can't even do a for (IPAddressString ipAddr : ipAddrList) - I get the same error about being unable to cast it. Again, if anyone has hints, I'm open to them.

@necouchman necouchman force-pushed the working/mfa-bypass branch 2 times, most recently from 351cd10 to 850533c Compare October 1, 2023 22:06
@necouchman necouchman marked this pull request as ready for review October 1, 2023 22:09
@necouchman
Copy link
Contributor Author

Alrighty then - this should be ready for review, now. I've tested with the TOTP module and it appears to work as expected, at least with IPv4 addresses. I still have a bit of an issue with the IPv4 + IPv6 config and the client address flipping between a real IPv4 address and IPv6 loopback, but that seems to be more of a Nginx + Tomcat issue than it is anything to do with this.

@mike-jumper
Copy link
Contributor

I still have a bit of an issue with the IPv4 + IPv6 config and the client address flipping between a real IPv4 address and IPv6 loopback, but that seems to be more of a Nginx + Tomcat issue than it is anything to do with this.

I've seen this before, as well - I think it's due to the local OS' networking stack occasionally choosing the IPv6 address for localhost instead of IPv4, but the default RemoteIpValve regex only matches IPv4 addresses.

@necouchman
Copy link
Contributor Author

I've seen this before, as well - I think it's due to the local OS' networking stack occasionally choosing the IPv6 address for localhost instead of IPv4, but the default RemoteIpValve regex only matches IPv4 addresses.

Ah, okay - and, now that you mention it, it seems like something we've discussed before. Maybe I'll put in a Jira issue and update the manual page with that information.

@necouchman necouchman force-pushed the working/mfa-bypass branch 3 times, most recently from 10d6aae to edc1f03 Compare January 18, 2024 21:32
@necouchman necouchman force-pushed the working/mfa-bypass branch 3 times, most recently from 4715508 to f286f09 Compare April 7, 2024 01:33
@necouchman necouchman force-pushed the working/mfa-bypass branch 2 times, most recently from 9baad08 to ab78fe2 Compare April 7, 2024 01:49
@necouchman necouchman requested a review from mike-jumper April 25, 2024 19:32
@necouchman necouchman force-pushed the working/mfa-bypass branch from ab78fe2 to 41094e4 Compare July 6, 2024 20:01
@WilliamHorner
Copy link

I was having a look at this pull request because this functionality will be very useful. But I am hitting two compile errors:

[ERROR] ..../guacamole-client/extensions/guacamole-auth-duo/src/main/java/org/apache/guacamole/auth/duo/UserVerificationService.java:[178,20] error: variable credentials is already defined in method verifyAuthenticatedUser(AuthenticatedUser)
[ERROR] ..../guacamole-client/extensions/guacamole-auth-duo/src/main/java/org/apache/guacamole/auth/duo/UserVerificationService.java:[179,27] error: variable request is already defined in method verifyAuthenticatedUser(AuthenticatedUser)

Im not sure if this is my mishandling of git, but if I look at the file in the pull request I can see the two definitions there too.
I think it is probably just as simple as removing the second set of definitions? ... or fixing my understanding of git.

@necouchman necouchman force-pushed the working/mfa-bypass branch from 41094e4 to 2ecad02 Compare July 29, 2024 13:25
@necouchman
Copy link
Contributor Author

I was having a look at this pull request because this functionality will be very useful. But I am hitting two compile errors:

[ERROR] ..../guacamole-client/extensions/guacamole-auth-duo/src/main/java/org/apache/guacamole/auth/duo/UserVerificationService.java:[178,20] error: variable credentials is already defined in method verifyAuthenticatedUser(AuthenticatedUser) [ERROR] ..../guacamole-client/extensions/guacamole-auth-duo/src/main/java/org/apache/guacamole/auth/duo/UserVerificationService.java:[179,27] error: variable request is already defined in method verifyAuthenticatedUser(AuthenticatedUser)

Im not sure if this is my mishandling of git, but if I look at the file in the pull request I can see the two definitions there too. I think it is probably just as simple as removing the second set of definitions? ... or fixing my understanding of git.

It should be fixed, now - apparently I didn't verify that it compiled after the last round of changes I made. Oops.

@mike-jumper mike-jumper changed the base branch from main to staging/1.6.0 July 31, 2024 21:37
@mike-jumper mike-jumper merged commit f6c2787 into apache:staging/1.6.0 Aug 29, 2024
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants