diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2014-03-12 17:36:56 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2014-03-12 17:36:56 +0000 |
commit | 29b7313d2225eb4468170b94f80acc473b06b7ea (patch) | |
tree | b6f73d561c3948b777beca544691e167e68aa310 /winsup/cygwin/uinfo.cc | |
parent | 681bb2f78aec647c42f20d7e8157c1f258957646 (diff) | |
download | cygnal-29b7313d2225eb4468170b94f80acc473b06b7ea.tar.gz cygnal-29b7313d2225eb4468170b94f80acc473b06b7ea.tar.bz2 cygnal-29b7313d2225eb4468170b94f80acc473b06b7ea.zip |
* cygheap.h (enum cygheap_pwdgrp::cache_t): Remove.
(cygheap_pwdgrp::caching): Convert to bool.
(cygheap_pwdgrp::pwd_cache): Add cygserver member.
(cygheap_pwdgrp::grp_cache): Ditto.
(cygheap_pwdgrp::nss_db_caching): Drop.
(cygheap_pwdgrp::nss_db_full_caching): Drop.
(cygheap_pwdgrp::nss_cygserver_caching): New method.
(cygheap_pwdgrp::nss_disable_cygserver_caching): New method.
* cygserver.h (client_request::request_code_t): Add
CYGSERVER_REQUEST_PWDGRP.
* cygserver_pwdgrp.h: New file.
* cygtls.h (struct _local_storage): Remove pwbuf and grbuf members.
* grp.cc (pwdgrp::prep_tls_grbuf): Drop.
(internal_getgrsid): Handle cygserver caching and rearrange to check
the caches first.
(internal_getgrnam): Ditto.
(internal_getgrgid): Ditto.
(gr_ent::enumerate_caches): Handle cygserver cache.
* passwd.cc (pwdgrp::prep_tls_pwbuf): Drop.
(internal_getpwsid): Handle cygserver caching and rearrange to check
the caches first.
(internal_getpwnam): Ditto.
(internal_getpwuid): Ditto.
(pw_ent::enumerate_caches): Handle cygserver cache.
* pwdgrp.h (pwdgrp::add_account_from_cygserver): New method declaration.
(pwdgrp::fetch_account_from_cygserver): New method declaration.
(pwdgrp::prep_tls_pwbuf): Drop declaration.
(pwdgrp::prep_tls_grbuf): Drop declaration.
(pwdgrp::add_user_from_cygserver): New inline methods.
(pwdgrp::add_group_from_cygserver): New inline methods.
* tlsoffsets.h: Regenerate.
* tlsoffsets64.h: Regenerate.
* uinfo.cc (internal_getlogin): Call internal_getgroups if cygserver
caching is not available.
(cygheap_pwdgrp::init): Initialize pwd_cache.cygserver and
grp_cache.cygserver. Set caching to true.
(cygheap_pwdgrp::nss_init_line): Drop db_cache handling entirely.
(pwdgrp::add_account_from_windows): Drop no caching handling.
(client_request_pwdgrp::client_request_pwdgrp): New method.
(pwdgrp::fetch_account_from_cygserver): New method.
(pwdgrp::add_account_from_cygserver): New method.
* fhandler_disk_file.cc (fhandler_base::fstat_helper): Fix formatting.
* include/sys/cygwin.h: Ditto.
Diffstat (limited to 'winsup/cygwin/uinfo.cc')
-rw-r--r-- | winsup/cygwin/uinfo.cc | 115 |
1 files changed, 84 insertions, 31 deletions
diff --git a/winsup/cygwin/uinfo.cc b/winsup/cygwin/uinfo.cc index 10d335644..3b42754ed 100644 --- a/winsup/cygwin/uinfo.cc +++ b/winsup/cygwin/uinfo.cc @@ -32,8 +32,8 @@ details. */ #include "tls_pbuf.h" #include "miscfuncs.h" #include "ntdll.h" - #include "ldap.h" +#include "cygserver_pwdgrp.h" /* Initialize the part of cygheap_user that does not depend on files. The information is used in shared.cc for the user shared. @@ -124,7 +124,7 @@ internal_getlogin (cygheap_user &user) and the primary group in the token. */ pwd = internal_getpwsid (user.sid (), &cldap); pgrp = internal_getgrsid (user.groups.pgsid, &cldap); - if (cygheap->pg.nss_db_full_caching ()) + if (!cygheap->pg.nss_cygserver_caching ()) internal_getgroups (0, NULL, &cldap); if (!pwd) debug_printf ("user not found in passwd DB"); @@ -567,8 +567,10 @@ pwdgrp::add_line (char *eptr) void cygheap_pwdgrp::init () { + pwd_cache.cygserver.init_pwd (); pwd_cache.file.init_pwd (); pwd_cache.win.init_pwd (); + grp_cache.cygserver.init_grp (); grp_cache.file.init_grp (); grp_cache.win.init_grp (); /* Default settings: @@ -584,7 +586,7 @@ cygheap_pwdgrp::init () grp_src = (NSS_FILES | NSS_DB); prefix = NSS_AUTO; separator[0] = L'+'; - caching = NSS_FULL_CACHING; + caching = true; enums = (ENUM_CACHE | ENUM_BUILTIN); enum_tdoms = NULL; } @@ -670,19 +672,6 @@ cygheap_pwdgrp::nss_init_line (const char *line) else debug_printf ("Invalid nsswitch.conf content: %s", line); } - else if (!strncmp (c, "cache:", 6)) - { - c += 6; - c += strspn (c, " \t"); - if (!strncmp (c, "full", 3) && strchr (" \t", c[3])) - caching = NSS_FULL_CACHING; - else if (!strncmp (c, "yes", 3) && strchr (" \t", c[3])) - caching = NSS_CACHING; - else if (!strncmp (c, "no", 2) && strchr (" \t", c[2])) - caching = NSS_NO_CACHING; - else - debug_printf ("Invalid nsswitch.conf content: %s", line); - } else if (!strncmp (c, "enum:", 5)) { tmp_pathbuf tp; @@ -1001,11 +990,7 @@ pwdgrp::add_account_from_windows (cygpsid &sid, cyg_ldap *pldap) char *line = fetch_account_from_windows (arg, pldap); if (!line) return NULL; - if (cygheap->pg.nss_db_caching ()) - return add_account_post_fetch (line, true); - if (is_group ()) - return (prep_tls_grbuf ())->add_account_post_fetch (line, false); - return (prep_tls_pwbuf ())->add_account_post_fetch (line, false); + return add_account_post_fetch (line, true); } void * @@ -1017,11 +1002,7 @@ pwdgrp::add_account_from_windows (const char *name, cyg_ldap *pldap) char *line = fetch_account_from_windows (arg, pldap); if (!line) return NULL; - if (cygheap->pg.nss_db_caching ()) - return add_account_post_fetch (line, true); - if (is_group ()) - return (prep_tls_grbuf ())->add_account_post_fetch (line, false); - return (prep_tls_pwbuf ())->add_account_post_fetch (line, false); + return add_account_post_fetch (line, true); } void * @@ -1033,11 +1014,7 @@ pwdgrp::add_account_from_windows (uint32_t id, cyg_ldap *pldap) char *line = fetch_account_from_windows (arg, pldap); if (!line) return NULL; - if (cygheap->pg.nss_db_caching ()) - return add_account_post_fetch (line, true); - if (is_group ()) - return (prep_tls_grbuf ())->add_account_post_fetch (line, false); - return (prep_tls_pwbuf ())->add_account_post_fetch (line, false); + return add_account_post_fetch (line, true); } /* Check if file exists and if it has been written to since last checked. @@ -1828,3 +1805,79 @@ pwdgrp::fetch_account_from_windows (fetch_user_arg_t &arg, cyg_ldap *pldap) debug_printf ("line: <%s>", line); return line; } + +client_request_pwdgrp::client_request_pwdgrp (fetch_user_arg_t &arg, bool group) + : client_request (CYGSERVER_REQUEST_PWDGRP, &_parameters, sizeof (_parameters)) +{ + size_t len = 0; + char *p; + + _parameters.in.group = group; + _parameters.in.type = arg.type; + switch (arg.type) + { + case SID_arg: + RtlCopySid (sizeof (DBGSID), (PSID) &_parameters.in.arg.sid, *arg.sid); + len = RtlLengthSid (*arg.sid); + break; + case NAME_arg: + p = stpcpy (_parameters.in.arg.name, arg.name); + len = p - _parameters.in.arg.name; + break; + case ID_arg: + _parameters.in.arg.id = arg.id; + len = sizeof (uint32_t); + } + msglen (__builtin_offsetof (struct _pwdgrp_param_t::_pwdgrp_in_t, arg) + len); +} + +char * +pwdgrp::fetch_account_from_cygserver (fetch_user_arg_t &arg) +{ + client_request_pwdgrp request (arg, is_group ()); + if (request.make_request () == -1 || request.error_code ()) + { + /* Cygserver not running? Don't try again. This will automatically + avoid an endless loop in cygserver itself. */ + if (request.error_code () == ENOSYS) + cygheap->pg.nss_disable_cygserver_caching (); + return NULL; + } + if (!request.line ()) + return NULL; + return cstrdup (request.line ()); +} + +void * +pwdgrp::add_account_from_cygserver (cygpsid &sid) +{ + /* No, Everyone is no group in terms of POSIX. */ + if (sid_id_auth (sid) == 1 /* SECURITY_WORLD_SID_AUTHORITY */ + && sid_sub_auth (sid, 0) == SECURITY_WORLD_RID) + return NULL; + fetch_user_arg_t arg; + arg.type = SID_arg; + arg.sid = &sid; + char *line = fetch_account_from_cygserver (arg); + return (struct passwd *) add_account_post_fetch (line, true); +} + +void * +pwdgrp::add_account_from_cygserver (const char *name) +{ + fetch_user_arg_t arg; + arg.type = NAME_arg; + arg.name = name; + char *line = fetch_account_from_cygserver (arg); + return (struct passwd *) add_account_post_fetch (line, true); +} + +void * +pwdgrp::add_account_from_cygserver (uint32_t id) +{ + fetch_user_arg_t arg; + arg.type = ID_arg; + arg.id = id; + char *line = fetch_account_from_cygserver (arg); + return (struct passwd *) add_account_post_fetch (line, true); +} |