1991-04-10 19:48:25 +00:00
|
|
|
|
1994-08-01 11:34:53 +00:00
|
|
|
/* UNIX password file access module */
|
1991-04-10 19:48:25 +00:00
|
|
|
|
1996-12-11 16:54:40 +00:00
|
|
|
#include "Python.h"
|
2002-03-01 10:38:44 +00:00
|
|
|
#include "structseq.h"
|
1991-04-10 19:48:25 +00:00
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <pwd.h>
|
|
|
|
|
2002-03-01 10:38:44 +00:00
|
|
|
static PyStructSequence_Field struct_pwd_type_fields[] = {
|
|
|
|
{"pw_name", "user name"},
|
|
|
|
{"pw_passwd", "password"},
|
|
|
|
{"pw_uid", "user id"},
|
|
|
|
{"pw_gid", "group id"},
|
|
|
|
{"pw_gecos", "real name"},
|
|
|
|
{"pw_dir", "home directory"},
|
|
|
|
{"pw_shell", "shell program"},
|
|
|
|
{0}
|
|
|
|
};
|
|
|
|
|
|
|
|
static char struct_passwd__doc__[] =
|
|
|
|
"pwd.struct_passwd: Results from getpw*() routines.\n\n\
|
|
|
|
This object may be accessed either as a tuple of\n\
|
|
|
|
(pw_name,pw_passwd,pw_uid,pw_gid,pw_gecos,pw_dir,pw_shell)\n\
|
|
|
|
or via the object attributes as named in the above tuple.\n";
|
|
|
|
|
|
|
|
static PyStructSequence_Desc struct_pwd_type_desc = {
|
|
|
|
"pwd.struct_passwd",
|
|
|
|
struct_passwd__doc__,
|
|
|
|
struct_pwd_type_fields,
|
|
|
|
7,
|
|
|
|
};
|
|
|
|
|
1998-03-03 22:03:26 +00:00
|
|
|
static char pwd__doc__ [] = "\
|
|
|
|
This module provides access to the Unix password database.\n\
|
|
|
|
It is available on all Unix versions.\n\
|
|
|
|
\n\
|
|
|
|
Password database entries are reported as 7-tuples containing the following\n\
|
|
|
|
items from the password database (see `<pwd.h>'), in order:\n\
|
|
|
|
pw_name, pw_passwd, pw_uid, pw_gid, pw_gecos, pw_dir, pw_shell.\n\
|
|
|
|
The uid and gid items are integers, all others are strings. An\n\
|
|
|
|
exception is raised if the entry asked for cannot be found.";
|
|
|
|
|
|
|
|
|
2002-03-01 10:38:44 +00:00
|
|
|
static PyTypeObject StructPwdType;
|
|
|
|
|
1996-12-11 16:54:40 +00:00
|
|
|
static PyObject *
|
2000-07-10 13:12:27 +00:00
|
|
|
mkpwent(struct passwd *p)
|
1991-04-10 19:48:25 +00:00
|
|
|
{
|
2002-03-01 10:38:44 +00:00
|
|
|
int setIndex = 0;
|
|
|
|
PyObject *v = PyStructSequence_New(&StructPwdType);
|
|
|
|
if (v == NULL)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
#define SETI(i,val) PyStructSequence_SET_ITEM(v, i, PyInt_FromLong((long) val))
|
|
|
|
#define SETS(i,val) PyStructSequence_SET_ITEM(v, i, PyString_FromString(val))
|
|
|
|
|
|
|
|
SETS(setIndex++, p->pw_name);
|
|
|
|
SETS(setIndex++, p->pw_passwd);
|
|
|
|
SETI(setIndex++, p->pw_uid);
|
|
|
|
SETI(setIndex++, p->pw_gid);
|
|
|
|
SETS(setIndex++, p->pw_gecos);
|
|
|
|
SETS(setIndex++, p->pw_dir);
|
|
|
|
SETS(setIndex++, p->pw_shell);
|
|
|
|
|
|
|
|
#undef SETS
|
|
|
|
#undef SETI
|
|
|
|
|
|
|
|
if (PyErr_Occurred()) {
|
|
|
|
Py_XDECREF(v);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return v;
|
1991-04-10 19:48:25 +00:00
|
|
|
}
|
|
|
|
|
1998-03-03 22:03:26 +00:00
|
|
|
static char pwd_getpwuid__doc__[] = "\
|
2002-03-01 10:38:44 +00:00
|
|
|
getpwuid(uid) -> (pw_name,pw_passwd,pw_uid,pw_gid,pw_gecos,pw_dir,pw_shell)\n\
|
1998-03-03 22:03:26 +00:00
|
|
|
Return the password database entry for the given numeric user ID.\n\
|
|
|
|
See pwd.__doc__ for more on password database entries.";
|
|
|
|
|
1996-12-11 16:54:40 +00:00
|
|
|
static PyObject *
|
2000-07-10 13:12:27 +00:00
|
|
|
pwd_getpwuid(PyObject *self, PyObject *args)
|
1991-04-10 19:48:25 +00:00
|
|
|
{
|
|
|
|
int uid;
|
|
|
|
struct passwd *p;
|
1996-12-11 16:54:40 +00:00
|
|
|
if (!PyArg_Parse(args, "i", &uid))
|
1991-04-10 19:48:25 +00:00
|
|
|
return NULL;
|
|
|
|
if ((p = getpwuid(uid)) == NULL) {
|
1996-12-11 16:54:40 +00:00
|
|
|
PyErr_SetString(PyExc_KeyError, "getpwuid(): uid not found");
|
1991-04-10 19:48:25 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
return mkpwent(p);
|
|
|
|
}
|
|
|
|
|
1998-03-03 22:03:26 +00:00
|
|
|
static char pwd_getpwnam__doc__[] = "\
|
2002-03-01 10:38:44 +00:00
|
|
|
getpwnam(name) -> (pw_name,pw_passwd,pw_uid,pw_gid,pw_gecos,pw_dir,pw_shell)\n\
|
1998-03-03 22:03:26 +00:00
|
|
|
Return the password database entry for the given user name.\n\
|
|
|
|
See pwd.__doc__ for more on password database entries.";
|
|
|
|
|
1996-12-11 16:54:40 +00:00
|
|
|
static PyObject *
|
2000-07-10 13:12:27 +00:00
|
|
|
pwd_getpwnam(PyObject *self, PyObject *args)
|
1991-04-10 19:48:25 +00:00
|
|
|
{
|
1992-01-27 16:51:30 +00:00
|
|
|
char *name;
|
1991-04-10 19:48:25 +00:00
|
|
|
struct passwd *p;
|
1996-12-11 16:54:40 +00:00
|
|
|
if (!PyArg_Parse(args, "s", &name))
|
1991-04-10 19:48:25 +00:00
|
|
|
return NULL;
|
1992-01-27 16:51:30 +00:00
|
|
|
if ((p = getpwnam(name)) == NULL) {
|
1996-12-11 16:54:40 +00:00
|
|
|
PyErr_SetString(PyExc_KeyError, "getpwnam(): name not found");
|
1991-04-10 19:48:25 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
return mkpwent(p);
|
|
|
|
}
|
|
|
|
|
1997-08-22 20:42:00 +00:00
|
|
|
#ifdef HAVE_GETPWENT
|
1998-03-03 22:03:26 +00:00
|
|
|
static char pwd_getpwall__doc__[] = "\
|
|
|
|
getpwall() -> list_of_entries\n\
|
|
|
|
Return a list of all available password database entries, \
|
|
|
|
in arbitrary order.\n\
|
|
|
|
See pwd.__doc__ for more on password database entries.";
|
|
|
|
|
1996-12-11 16:54:40 +00:00
|
|
|
static PyObject *
|
2002-03-25 20:46:46 +00:00
|
|
|
pwd_getpwall(PyObject *self)
|
1991-04-10 19:48:25 +00:00
|
|
|
{
|
1996-12-11 16:54:40 +00:00
|
|
|
PyObject *d;
|
1991-04-10 19:48:25 +00:00
|
|
|
struct passwd *p;
|
1996-12-11 16:54:40 +00:00
|
|
|
if ((d = PyList_New(0)) == NULL)
|
1991-04-10 19:48:25 +00:00
|
|
|
return NULL;
|
2002-03-03 02:59:16 +00:00
|
|
|
#if defined(PYOS_OS2) && defined(PYCC_GCC)
|
|
|
|
if ((p = getpwuid(0)) != NULL) {
|
|
|
|
#else
|
1991-04-10 19:48:25 +00:00
|
|
|
setpwent();
|
|
|
|
while ((p = getpwent()) != NULL) {
|
2002-03-03 02:59:16 +00:00
|
|
|
#endif
|
1996-12-11 16:54:40 +00:00
|
|
|
PyObject *v = mkpwent(p);
|
|
|
|
if (v == NULL || PyList_Append(d, v) != 0) {
|
|
|
|
Py_XDECREF(v);
|
|
|
|
Py_DECREF(d);
|
1991-04-10 19:48:25 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
1997-01-09 22:22:05 +00:00
|
|
|
Py_DECREF(v);
|
1991-04-10 19:48:25 +00:00
|
|
|
}
|
2001-03-11 03:03:07 +00:00
|
|
|
endpwent();
|
1991-04-10 19:48:25 +00:00
|
|
|
return d;
|
|
|
|
}
|
1997-08-22 20:42:00 +00:00
|
|
|
#endif
|
1991-04-10 19:48:25 +00:00
|
|
|
|
1996-12-11 16:54:40 +00:00
|
|
|
static PyMethodDef pwd_methods[] = {
|
2000-08-03 02:34:44 +00:00
|
|
|
{"getpwuid", pwd_getpwuid, METH_OLDARGS, pwd_getpwuid__doc__},
|
|
|
|
{"getpwnam", pwd_getpwnam, METH_OLDARGS, pwd_getpwnam__doc__},
|
1997-08-22 20:42:00 +00:00
|
|
|
#ifdef HAVE_GETPWENT
|
2002-03-25 20:46:46 +00:00
|
|
|
{"getpwall", pwd_getpwall, METH_NOARGS, pwd_getpwall__doc__},
|
1997-08-22 20:42:00 +00:00
|
|
|
#endif
|
1991-04-10 19:48:25 +00:00
|
|
|
{NULL, NULL} /* sentinel */
|
|
|
|
};
|
|
|
|
|
1998-12-04 18:50:17 +00:00
|
|
|
DL_EXPORT(void)
|
2000-07-21 06:00:07 +00:00
|
|
|
initpwd(void)
|
1991-04-10 19:48:25 +00:00
|
|
|
{
|
2002-03-01 10:38:44 +00:00
|
|
|
PyObject *m, *d;
|
|
|
|
m = Py_InitModule4("pwd", pwd_methods, pwd__doc__,
|
1998-03-03 22:03:26 +00:00
|
|
|
(PyObject *)NULL, PYTHON_API_VERSION);
|
2002-03-01 10:38:44 +00:00
|
|
|
d = PyModule_GetDict(m);
|
|
|
|
PyStructSequence_InitType(&StructPwdType, &struct_pwd_type_desc);
|
|
|
|
PyDict_SetItemString(d, "struct_pwent", (PyObject *) &StructPwdType);
|
1991-04-10 19:48:25 +00:00
|
|
|
}
|