invalid login gid in /etc/passwd does not show group name as 'mkgroup'
Thu Oct 9 11:06:00 GMT 2008
On Oct 7 11:22, Herb Maeder wrote:
> The "Special values of user and group ids" section of the Cygwin User's
> Guide (http://cygwin.com/1.7/cygwin-ug-net.html#ntsec-ids) states:
> Also, since Cygwin release 1.3.20, if the current user is present in
> /etc/passwd, but that user's login group is not present in /etc/group,
> the group name will be shown as 'mkgroup', again indicating the
> appropriate command.
> I don't see that this holds true, at least for the case of a Domain User.
> In fact, I see that an invalid login group id will be shown as a group
> name of 'Domain Users' even though there is no such gid listed in
> /etc/group. This can be confusing since things appear to work normally on
> the surface, but some commands may fail in some not-so-obvious ways as a
> result of the invalid login gid.
> I noticed this under cygwin-1.7, but I believe the same holds under
> This is my passwd entry, 'id' output, and group id from a file created by
> % grep herb /etc/passswd
> % grep :10513: /etc/group
> Domain Users:S-1-5-21-1936786716-3317986166-2952453263-513:10513:
> % id
> uid=11647(herb) gid=10513(Domain Users) groups=545(Users),10513(Domain Users)
> % touch foobar
> % ls -ln foobar
> -rw-r--r-- 1 11647 10513 0 Oct 7 10:27 foobar
> If I change the uid from 10513 to 898 (not in /etc/group), then fire up a
> new window+shell, I see this:
> % grep herb /etc/passwd
> % grep :898: /etc/group
> % id
> uid=11647(herb) gid=898(Domain Users) groups=545(Users),10513(Domain Users),898(Domain Users)
> % ls -ln foobar
> -rw-r--r-- 1 11647 898 0 Oct 7 10:27 foobar
> Note that the "id" displays the gid as 'Domain Users', and the gid of file
> foobar is listed as 898 even though it was originally created with gid
> I'm not sure if this is specific to Domain Users or not. Also I don't
> know if there is some valid reason for this behavior.
It's not specific to "Domain Users" and there's no *valid* reason for
this. The whole idea (which is a couple of years old, from 2002
actually) is that Cygwin tries to have valid passwd and group entries in
memory for *at least* the current user. So, the situation from Cygwin's
point of view develops along these lines:
First, Cygwin checks the user token and finds the user's primary
Next it checks /etc/passwd and finds that the pgid is 898.
There's no /etc/group entry for the primary gid of the current user?
Ok, let's create one so that this gid makes sense.
Grab the SID. Check if there's a group entry corresponding to that
SID. Gotcha. It's the entry with gid 10513 (which is ignored) and
the name "Domain Users".
Ok, so let's add a group entry in memory like this:
Bingo. We now have two entries for Domain Users, one with gid 898
and one with 10513.
It's well meant since you now see the real name of your primary group.
And, in theory, nothing bad should happen since the underlying SID is
correct. But the outcome is somewhat puzzeling, whatever Cygwin does.
For instance, the gid of a file depends on the numbers. If the pgid is
smaller than the real gid, files are owned by the faked pgid and vice
versa. Either way, id will show you two group entries which have the
same meaning, even if the names would differ (Domain User/mkgroup).
I'm not sure how to fix that issue right now.
Corinna Vinschen Please, send mails regarding Cygwin to
Cygwin Project Co-Leader cygwin AT cygwin DOT com
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
Problem reports: http://cygwin.com/problems.html
More information about the Cygwin