726d90d871
git-svn-id: http://google-refine.googlecode.com/svn/branches/split-refactor@908 7d457c2a-affb-35e4-300a-418c747d4874
84 lines
2.2 KiB
Python
84 lines
2.2 KiB
Python
"""
|
|
Access to the Unix group database.
|
|
|
|
Group entries are reported as 4-tuples containing the following fields
|
|
from the group database, in order:
|
|
|
|
name - name of the group
|
|
passwd - group password (encrypted); often empty
|
|
gid - numeric ID of the group
|
|
mem - list of members
|
|
|
|
The gid is an integer, name and password are strings. (Note that most
|
|
users are not explicitly listed as members of the groups they are in
|
|
according to the password database. Check both databases to get
|
|
complete membership information.)
|
|
"""
|
|
|
|
__all__ = ['getgrgid', 'getgrnam', 'getgrall']
|
|
|
|
from os import _name, _posix
|
|
|
|
if _name == 'nt':
|
|
raise ImportError, 'grp module not supported on Windows'
|
|
|
|
class struct_group(tuple):
|
|
"""
|
|
grp.struct_group: Results from getgr*() routines.
|
|
|
|
This object may be accessed either as a tuple of
|
|
(gr_name,gr_passwd,gr_gid,gr_mem)
|
|
or via the object attributes as named in the above tuple.
|
|
"""
|
|
|
|
attrs = ['gr_name', 'gr_passwd', 'gr_gid', 'gr_mem']
|
|
|
|
def __new__(cls, grp):
|
|
return tuple.__new__(cls, (grp.gr_name, grp.gr_passwd, grp.gr_gid,
|
|
list(grp.getMembers())))
|
|
|
|
def __getattr__(self, attr):
|
|
try:
|
|
return self[self.attrs.index(attr)]
|
|
except ValueError:
|
|
raise AttributeError
|
|
|
|
|
|
def getgrgid(uid):
|
|
"""
|
|
getgrgid(id) -> tuple
|
|
Return the group database entry for the given numeric group ID. If
|
|
id is not valid, raise KeyError.
|
|
"""
|
|
entry = _posix.getgrgid(uid)
|
|
if not entry:
|
|
raise KeyError(uid)
|
|
return struct_group(entry)
|
|
|
|
|
|
def getgrnam(name):
|
|
"""
|
|
getgrnam(name) -> tuple
|
|
Return the group database entry for the given group name. If
|
|
name is not valid, raise KeyError.
|
|
"""
|
|
entry = _posix.getgrnam(name)
|
|
if not entry:
|
|
raise KeyError(name)
|
|
return struct_group(entry)
|
|
|
|
|
|
def getgrall():
|
|
"""
|
|
getgrall() -> list of tuples
|
|
Return a list of all available group database entries,
|
|
in arbitrary order.
|
|
"""
|
|
groups = []
|
|
while True:
|
|
group = _posix.getgrent()
|
|
if not group:
|
|
break
|
|
groups.append(struct_group(group))
|
|
return groups
|