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

CA-356901: Perform ldap query if winbind failed to resovle subject #4478

Merged
merged 2 commits into from
Jul 28, 2021

Conversation

liulinC
Copy link
Collaborator

@liulinC liulinC commented Jul 26, 2021

name to subject identifier

winbind has cache timeout set to 60s, so winbind sync its cached data
with domain controller every 60 seconds.
If a user is newly created in DC within 60s, winbind failed to resovle it.
This commit fix this issue by perform ldap query on winbin fail

Signed-off-by: Lin Liu [email protected]

Copy link
Contributor

@lippirk lippirk left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM - even though this is making an extra request sometimes, it'll only happen when users enter an incorrect user name (which should be rare)

ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
ocaml/xapi/extauth_plugin_ADwinbind.ml Show resolved Hide resolved
@edwintorok
Copy link
Contributor

There is a typo in the title here and several places in the commit message: resovle -> resolve.

Copy link
Contributor

@edwintorok edwintorok left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We probably need a generic function to escape arguments that we pass to ldapquery that can be user controlled.

ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
ocaml/xapi/extauth_plugin_ADwinbind.ml Show resolved Hide resolved
name to subject identifier

winbind has cache timeout set to 60s, so winbind sync its cached data
with domain controller every 60 seconds.
If a user is newly created in DC within 60s, winbind failed to resolve it.
This commit fix this issue by perform ldap query on winbind fail

Signed-off-by: Lin Liu <[email protected]>
@liulinC liulinC force-pushed the private/linl/winbind branch from 0d006c2 to 6ff5967 Compare July 26, 2021 10:33
@liulinC liulinC requested review from edwintorok and lindig July 26, 2021 10:34
@liulinC liulinC force-pushed the private/linl/winbind branch from 6ff5967 to 15c0337 Compare July 26, 2021 13:45
@liulinC liulinC requested a review from edwintorok July 26, 2021 13:47
ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
ocaml/xapi/extauth_plugin_ADwinbind.ml Outdated Show resolved Hide resolved
@liulinC liulinC force-pushed the private/linl/winbind branch from 15c0337 to 2a5a95e Compare July 26, 2021 16:19
@liulinC liulinC requested a review from edwintorok July 26, 2021 16:20
@liulinC liulinC force-pushed the private/linl/winbind branch from 2a5a95e to 87adc86 Compare July 27, 2021 02:03
@liulinC liulinC requested a review from edwintorok July 27, 2021 02:06
@liulinC
Copy link
Collaborator Author

liulinC commented Jul 27, 2021

updated, @lindig @edwintorok please help to review at your convenient, thanks

Copy link
Contributor

@edwintorok edwintorok left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not an expert on winbind, so this will have to rely on testing to prove that this works correctly and securely. I can't spot any immediate issues in terms of OCaml language.

let escape str =
List.fold_left
(fun acc element ->
let reg = fst element in
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This can also be written as let reg, value = element, or fun acc (reg, value), but is fine like this too.

@@ -200,12 +263,15 @@ module Ldap = struct
; password_expired= logand user_account_control passw_expire_bit <> 0l
}

let query_user sid domain_netbios kdc =
let env_of_krb5 domain_netbios =
let domain_krb5_cfg =
Filename.concat domain_krb5_dir
(Printf.sprintf "krb5.conf.%s" domain_netbios)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this created by winbind itself? I can't find any code in xapi that would create this file

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes, winbind create it, we just re-use it (for the KDCs configured)

@edwintorok
Copy link
Contributor

edwintorok commented Jul 27, 2021

Might be useful to add a comment to get_subject_identifier' that it is called in the login path with a yet unauthenticated user, and to treat parameters as untrusted (so things like the LDAP escaping are especially important here, otherwise an unauthenticated user could trick XAPI into authenticating them as another user via LDAP query injection).

@edwintorok
Copy link
Contributor

edwintorok commented Jul 27, 2021

There are some concerns on whether the login process here is secure (but that is unrelated to this PR). Could a user set up their own domain server then attempt to login with [email protected], which would successfully authenticate them and when asked to map the domain to a KDC it would map it to an attacker controlled one, and map the username to a SID or the SID to a name it would map it to a SID that exists in our AD hierarchy, and map the name to [email protected] (assuming that the pool is joined to trusteddomain.example.com).

@liulinC
Copy link
Collaborator Author

liulinC commented Jul 27, 2021

There are some concerns on whether the login process here is secure (but that is unrelated to this PR). Could a user set up their own domain server then attempt to login with [email protected], which would successfully authenticate them and when asked to map the domain to a KDC it would map it to an attacker controlled one, and map the username to a SID or the SID to a name it would map it to a SID that exists in our AD hierarchy, and map the name to [email protected] (assuming that the pool is joined to trusteddomain.example.com).

The faked DC will not serve as normal DC, as during ldap query, net command will authenticate with domain controller by kerberos protocol, I do not think the fake server can hold the machine password for the machine account created during domain join. There is an xenrt automation test for this by @xihuany

@liulinC
Copy link
Collaborator Author

liulinC commented Jul 28, 2021

Might be useful to add a comment to get_subject_identifier' that it is called in the login path with a yet unauthenticated user, and to treat parameters as untrusted (so things like the LDAP escaping are especially important here, otherwise an unauthenticated user could trick XAPI into authenticating them as another user via LDAP query injection).

If you use ldap query injection and successfully become another user, you still needs to provide the password for that user.

@liulinC liulinC force-pushed the private/linl/winbind branch from 87adc86 to f1a520d Compare July 28, 2021 03:44
@liulinC
Copy link
Collaborator Author

liulinC commented Jul 28, 2021

The security concen is addressed in PSEC-8206, if still any further concern, let's talk there as it should not block this PR.

@liulinC liulinC merged commit f8507dc into feature/winbind/master Jul 28, 2021
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