Bug 15260 - int overflow in winbind_nss_aix
Summary: int overflow in winbind_nss_aix
Status: RESOLVED FIXED
Alias: None
Product: Samba 4.1 and newer
Classification: Unclassified
Component: Winbind (show other bugs)
Version: 4.17.3
Hardware: All All
: P5 normal (vote)
Target Milestone: ---
Assignee: Björn Jacke
QA Contact: Samba QA Contact
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2022-12-06 12:12 UTC by Jule Anger
Modified: 2023-01-06 21:49 UTC (History)
1 user (show)

See Also:


Attachments
Patch (1.11 KB, patch)
2022-12-06 14:09 UTC, Volker Lendecke
no flags Details
Patch (1.11 KB, patch)
2022-12-06 14:46 UTC, Volker Lendecke
no flags Details

Note You need to log in before you can comment on or make changes to this bug.
Description Jule Anger 2022-12-06 12:12:41 UTC
Created attachment 17674 [details]
vulnerability report

See report for details.
Comment 1 Volker Lendecke 2022-12-06 14:04:16 UTC
Just to make sure: Yes, this is a problem, but exploiting it requires a bug in winbind or a malicious process acting as winbind. If you can do that, you've pretty much taken over the machine anyway.
Comment 2 Volker Lendecke 2022-12-06 14:09:11 UTC
Created attachment 17677 [details]
Patch

Björn, can you see if this builds on AIX? It *should* have SIZE_MAX.
Comment 3 David Disseldorp 2022-12-06 14:38:02 UTC
(In reply to Volker Lendecke from comment #2)
> Created attachment 17677 [details]
> Patch

Looks like the check should be ">=" to allow for the terminator.

https://www.ibm.com/docs/en/aix/7.2?topic=s-sysconf-subroutine indicates that sysconf(_SC_NGROUPS_MAX) is possible on AIX, so we could also compare the server's response.data.num_entries against that. My preference is to just use a hardcoded limit for now though.
Comment 4 Volker Lendecke 2022-12-06 14:46:36 UTC
Created attachment 17678 [details]
Patch
Comment 5 David Disseldorp 2022-12-06 15:06:26 UTC
(In reply to Volker Lendecke from comment #4)
> Created attachment 17678 [details]
> Patch

Looks okay, although the subsequent gid_list[] traversal should probably also be audited for safety... is the gid_list length checked against num_gids on the client side, or are both provided separately by the server? Same thing for the sid list before the ids2xids...
Comment 6 Volker Lendecke 2022-12-06 16:17:03 UTC
(In reply to David Disseldorp from comment #5)
> Looks okay, although the subsequent gid_list[] traversal should probably
> also be audited for safety... is the gid_list length checked against
> num_gids on the client side, or are both provided separately by the server?
> Same thing for the sid list before the ids2xids...

Yep, true. We don't do that in winbind_nss_linux.c either. Now that we have to protect against a malicious winbind, this opens a big can of worms.
Comment 7 Jeremy Allison 2022-12-06 17:20:13 UTC
Hardening code is one thing (and generically good to prevent mistakes). Assuming a malicious winbindd is another thing altogether.

If I may quote a famous movie, "Game over Man...!" :-).

I don't think it's rational to treat winbindd as a malicious component and try and protect against it from the client side.
Comment 8 Björn Jacke 2022-12-06 19:07:58 UTC
(In reply to Volker Lendecke from comment #2)
looks good!
Comment 9 Volker Lendecke 2022-12-07 10:54:02 UTC
(In reply to Jeremy Allison from comment #7)
> I don't think it's rational to treat winbindd as a malicious component and
> try and protect against it from the client side.

How do we deal with this bug report then? With a friendly winbind the int overflow initially reported will not happen. But for the reporter it is worth a security alert, so according to the security community we have to protect against a malicious winbind.
Comment 10 Jeremy Allison 2022-12-07 17:20:57 UTC
(In reply to Volker Lendecke from comment #9)

I think we should treat it like a crash bug. We can harden the client code against errors in the data returned (just do regular sanity checks against array overflow etc). There's no reason we can't do defensive coding - but for a component that returns authorization data it's silly to "protect" against it.

As for "the security community" - there is no security community. Just a bunch of individuals trying to make a name for themselves by considering every bug a vuln (IMHO of course).

Let's do a bugfix and move on.
Comment 11 Samba QA Contact 2022-12-13 14:07:54 UTC
This bug was referenced in samba master:

b3ed90a0541a271a7c6d4bee1201fa47adc3c0c1
f964c0c357214637f80d0089723b9b11d1b38f7e
Comment 12 Stefan Metzmacher 2022-12-13 14:48:29 UTC
(In reply to Samba QA Contact from comment #11)

Sorry it seems

b3ed90a0541a271a7c6d4bee1201fa47adc3c0c1
f964c0c357214637f80d0089723b9b11d1b38f7e

got the bug url wrong 15260 instead of 15240.
Comment 13 Andrew Bartlett 2022-12-14 09:13:13 UTC
I've marked some team-internal comments private and opened this bug as we will deal with this as with all other bugs, there isn't a security escalation here.