Patch by Mark Bradshaw <bradshaw@staff.crosswalk.com>:
* mkpasswd.c: include lmerr.h (main): New -u option to allow specifying a specific user. If specified, groups aren't displayed and output is limited to only the specified user. (enum_users): If specific user is specified, via -u option, display only that user's record. With -u use NetUserGetInfo instead of NetUserEnum. (load_netapi): Added netusergetinfo.
This commit is contained in:
		| @@ -1,3 +1,14 @@ | |||||||
|  | 2001-11-20  Mark Bradshaw  <bradshaw@staff.crosswalk.com> | ||||||
|  |  | ||||||
|  | 	* mkpasswd.c: include lmerr.h | ||||||
|  | 	(main): New -u option to allow specifying a | ||||||
|  | 	specific user.  If specified, groups aren't displayed and | ||||||
|  | 	output is limited to only the specified user. | ||||||
|  | 	(enum_users): If specific user is specified, via -u option, | ||||||
|  | 	display only that user's record.  With -u use NetUserGetInfo | ||||||
|  | 	instead of NetUserEnum. | ||||||
|  | 	(load_netapi): Added netusergetinfo. | ||||||
|  |  | ||||||
| 2001-11-15  Gary R. Van Sickle  <g.r.vansickle@worldnet.att.net> | 2001-11-15  Gary R. Van Sickle  <g.r.vansickle@worldnet.att.net> | ||||||
|  |  | ||||||
| 	* strace.cc (main): Change getopt() to getopt_long(). | 	* strace.cc (main): Change getopt() to getopt_long(). | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| /* mkpasswd.c: | /* mkpasswd.c: | ||||||
|  |  | ||||||
|    Copyright 1997, 1998, 1999, 2000 Red Hat, Inc. |    Copyright 1997, 1998, 1999, 2000, 2001 Red Hat, Inc. | ||||||
|  |  | ||||||
|    This file is part of Cygwin. |    This file is part of Cygwin. | ||||||
|  |  | ||||||
| @@ -19,6 +19,7 @@ | |||||||
| #include <lmaccess.h> | #include <lmaccess.h> | ||||||
| #include <lmapibuf.h> | #include <lmapibuf.h> | ||||||
| #include <sys/fcntl.h> | #include <sys/fcntl.h> | ||||||
|  | #include <lmerr.h> | ||||||
|  |  | ||||||
| SID_IDENTIFIER_AUTHORITY sid_world_auth = {SECURITY_WORLD_SID_AUTHORITY}; | SID_IDENTIFIER_AUTHORITY sid_world_auth = {SECURITY_WORLD_SID_AUTHORITY}; | ||||||
| SID_IDENTIFIER_AUTHORITY sid_nt_auth = {SECURITY_NT_AUTHORITY}; | SID_IDENTIFIER_AUTHORITY sid_nt_auth = {SECURITY_NT_AUTHORITY}; | ||||||
| @@ -27,6 +28,7 @@ NET_API_STATUS WINAPI (*netapibufferfree)(PVOID); | |||||||
| NET_API_STATUS WINAPI (*netuserenum)(LPWSTR,DWORD,DWORD,PBYTE*,DWORD,PDWORD,PDWORD,PDWORD); | NET_API_STATUS WINAPI (*netuserenum)(LPWSTR,DWORD,DWORD,PBYTE*,DWORD,PDWORD,PDWORD,PDWORD); | ||||||
| NET_API_STATUS WINAPI (*netlocalgroupenum)(LPWSTR,DWORD,PBYTE*,DWORD,PDWORD,PDWORD,PDWORD); | NET_API_STATUS WINAPI (*netlocalgroupenum)(LPWSTR,DWORD,PBYTE*,DWORD,PDWORD,PDWORD,PDWORD); | ||||||
| NET_API_STATUS WINAPI (*netgetdcname)(LPWSTR,LPWSTR,PBYTE*); | NET_API_STATUS WINAPI (*netgetdcname)(LPWSTR,LPWSTR,PBYTE*); | ||||||
|  | NET_API_STATUS WINAPI (*netusergetinfo)(LPWSTR,LPWSTR,DWORD,PBYTE*); | ||||||
|  |  | ||||||
| #ifndef min | #ifndef min | ||||||
| #define min(a,b) (((a)<(b))?(a):(b)) | #define min(a,b) (((a)<(b))?(a):(b)) | ||||||
| @@ -48,6 +50,8 @@ load_netapi () | |||||||
|     return FALSE; |     return FALSE; | ||||||
|   if (!(netgetdcname = (void *) GetProcAddress (h, "NetGetDCName"))) |   if (!(netgetdcname = (void *) GetProcAddress (h, "NetGetDCName"))) | ||||||
|     return FALSE; |     return FALSE; | ||||||
|  |   if (!(netusergetinfo = (void *) GetProcAddress (h, "NetUserGetInfo"))) | ||||||
|  |     return FALSE; | ||||||
|  |  | ||||||
|   return TRUE; |   return TRUE; | ||||||
| } | } | ||||||
| @@ -104,7 +108,7 @@ uni2ansi (LPWSTR wcs, char *mbs, int size) | |||||||
|  |  | ||||||
| int | int | ||||||
| enum_users (LPWSTR servername, int print_sids, int print_cygpath, | enum_users (LPWSTR servername, int print_sids, int print_cygpath, | ||||||
| 	    const char * passed_home_path, int id_offset) | 	    const char * passed_home_path, int id_offset, char *disp_username) | ||||||
| { | { | ||||||
|   USER_INFO_3 *buffer; |   USER_INFO_3 *buffer; | ||||||
|   DWORD entriesread = 0; |   DWORD entriesread = 0; | ||||||
| @@ -112,6 +116,7 @@ enum_users (LPWSTR servername, int print_sids, int print_cygpath, | |||||||
|   DWORD resume_handle = 0; |   DWORD resume_handle = 0; | ||||||
|   DWORD rc; |   DWORD rc; | ||||||
|   char ansi_srvname[256]; |   char ansi_srvname[256]; | ||||||
|  |   WCHAR uni_name[512]; | ||||||
|  |  | ||||||
|   if (servername) |   if (servername) | ||||||
|     uni2ansi (servername, ansi_srvname, sizeof (ansi_srvname)); |     uni2ansi (servername, ansi_srvname, sizeof (ansi_srvname)); | ||||||
| @@ -120,6 +125,14 @@ enum_users (LPWSTR servername, int print_sids, int print_cygpath, | |||||||
|     { |     { | ||||||
|       DWORD i; |       DWORD i; | ||||||
|  |  | ||||||
|  |     if (disp_username != NULL) | ||||||
|  |       { | ||||||
|  | 	MultiByteToWideChar (CP_ACP, 0, disp_username, -1, uni_name, 512 ); | ||||||
|  | 	rc = netusergetinfo(servername, (LPWSTR) & uni_name, 3, | ||||||
|  | 			    (LPBYTE *) &buffer ); | ||||||
|  | 	entriesread=1; | ||||||
|  |       } | ||||||
|  |     else  | ||||||
|       rc = netuserenum (servername, 3, FILTER_NORMAL_ACCOUNT, |       rc = netuserenum (servername, 3, FILTER_NORMAL_ACCOUNT, | ||||||
| 			(LPBYTE *) & buffer, 1024, | 			(LPBYTE *) & buffer, 1024, | ||||||
| 			&entriesread, &totalentries, &resume_handle); | 			&entriesread, &totalentries, &resume_handle); | ||||||
| @@ -134,7 +147,9 @@ enum_users (LPWSTR servername, int print_sids, int print_cygpath, | |||||||
| 	  break; | 	  break; | ||||||
|  |  | ||||||
| 	default: | 	default: | ||||||
| 	  fprintf (stderr, "NetUserEnum() failed with %ld\n", rc); | 	  fprintf (stderr, "NetUserEnum() failed with error %ld.\n", rc); | ||||||
|  | 	  if (rc == NERR_UserNotFound)  | ||||||
|  | 	    fprintf (stderr, "That user doesn't exist.\n"); | ||||||
| 	  exit (1); | 	  exit (1); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -381,6 +396,7 @@ usage () | |||||||
|   fprintf (stderr, "                           (this affects ntsec)\n"); |   fprintf (stderr, "                           (this affects ntsec)\n"); | ||||||
|   fprintf (stderr, "   -p,--path-to-home path  if user account has no home dir, use\n"); |   fprintf (stderr, "   -p,--path-to-home path  if user account has no home dir, use\n"); | ||||||
|   fprintf (stderr, "                           path instead of /home/\n"); |   fprintf (stderr, "                           path instead of /home/\n"); | ||||||
|  |   fprintf (stderr, "   -u,--username username  only return information for the specified user\n"); | ||||||
|   fprintf (stderr, "   -?,--help               displays this message\n\n"); |   fprintf (stderr, "   -?,--help               displays this message\n\n"); | ||||||
|   fprintf (stderr, "One of `-l', `-d' or `-g' must be given on NT/W2K.\n"); |   fprintf (stderr, "One of `-l', `-d' or `-g' must be given on NT/W2K.\n"); | ||||||
|   return 1; |   return 1; | ||||||
| @@ -394,11 +410,12 @@ struct option longopts[] = { | |||||||
|   {"no-mount", no_argument, NULL, 'm'}, |   {"no-mount", no_argument, NULL, 'm'}, | ||||||
|   {"no-sids", no_argument, NULL, 's'}, |   {"no-sids", no_argument, NULL, 's'}, | ||||||
|   {"path-to-home", required_argument, NULL, 'p'}, |   {"path-to-home", required_argument, NULL, 'p'}, | ||||||
|  |   {"username", required_argument, NULL, 'u'}, | ||||||
|   {"help", no_argument, NULL, 'h'}, |   {"help", no_argument, NULL, 'h'}, | ||||||
|   {0, no_argument, NULL, 0} |   {0, no_argument, NULL, 0} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| char opts[] = "ldo:gsmhp:"; | char opts[] = "ldo:gsmhpu:"; | ||||||
|  |  | ||||||
| int | int | ||||||
| main (int argc, char **argv) | main (int argc, char **argv) | ||||||
| @@ -414,6 +431,7 @@ main (int argc, char **argv) | |||||||
|   int print_cygpath = 1; |   int print_cygpath = 1; | ||||||
|   int id_offset = 10000; |   int id_offset = 10000; | ||||||
|   int i; |   int i; | ||||||
|  |   char *disp_username = NULL; | ||||||
|  |  | ||||||
|   char name[256], passed_home_path[MAX_PATH]; |   char name[256], passed_home_path[MAX_PATH]; | ||||||
|   DWORD len; |   DWORD len; | ||||||
| @@ -459,6 +477,9 @@ main (int argc, char **argv) | |||||||
| 		if (optarg[strlen (optarg)-1] != '/') | 		if (optarg[strlen (optarg)-1] != '/') | ||||||
| 		  strcat (passed_home_path, "/"); | 		  strcat (passed_home_path, "/"); | ||||||
| 		break; | 		break; | ||||||
|  | 	      case 'u': | ||||||
|  | 		disp_username = optarg; | ||||||
|  | 		break; | ||||||
| 	      case 'h': | 	      case 'h': | ||||||
| 		return usage (); | 		return usage (); | ||||||
| 	      default: | 	      default: | ||||||
| @@ -513,19 +534,25 @@ main (int argc, char **argv) | |||||||
|   /* |   /* | ||||||
|    * Get `Everyone' group |    * Get `Everyone' group | ||||||
|   */ |   */ | ||||||
|   print_special (print_sids, &sid_world_auth, 1, SECURITY_WORLD_RID, 0, 0, 0, 0, 0, 0, 0); |   if (disp_username == NULL) | ||||||
|  |     { | ||||||
|  |       print_special (print_sids, &sid_world_auth, 1, SECURITY_WORLD_RID, | ||||||
|  | 		     0, 0, 0, 0, 0, 0, 0); | ||||||
|       /* |       /* | ||||||
|        * Get `system' group |        * Get `system' group | ||||||
|       */ |       */ | ||||||
|   print_special (print_sids, &sid_nt_auth, 1, SECURITY_LOCAL_SYSTEM_RID, 0, 0, 0, 0, 0, 0, 0); |       print_special (print_sids, &sid_nt_auth, 1, SECURITY_LOCAL_SYSTEM_RID, | ||||||
|  | 		     0, 0, 0, 0, 0, 0, 0); | ||||||
|       /* |       /* | ||||||
|        * Get `administrators' group |        * Get `administrators' group | ||||||
|       */ |       */ | ||||||
|       if (!print_local_groups) |       if (!print_local_groups) | ||||||
|     print_special (print_sids, &sid_nt_auth, 2, SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, 0, 0, 0, 0, 0, 0); | 	print_special (print_sids, &sid_nt_auth, 2, SECURITY_BUILTIN_DOMAIN_RID, | ||||||
|  | 		       DOMAIN_ALIAS_RID_ADMINS, 0, 0, 0, 0, 0, 0); | ||||||
|  |  | ||||||
|       if (print_local_groups) |       if (print_local_groups) | ||||||
| 	enum_local_groups (print_sids); | 	enum_local_groups (print_sids); | ||||||
|  |     } | ||||||
|  |  | ||||||
|   if (print_domain) |   if (print_domain) | ||||||
|     { |     { | ||||||
| @@ -541,11 +568,13 @@ main (int argc, char **argv) | |||||||
| 	  exit (1); | 	  exit (1); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|       enum_users (servername, print_sids, print_cygpath, passed_home_path, id_offset); |       enum_users (servername, print_sids, print_cygpath, passed_home_path, | ||||||
|  | 		  id_offset, disp_username); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   if (print_local) |   if (print_local) | ||||||
|     enum_users (NULL, print_sids, print_cygpath, passed_home_path, 0); |     enum_users (NULL, print_sids, print_cygpath, passed_home_path, 0, | ||||||
|  |     		disp_username); | ||||||
|  |  | ||||||
|   if (servername) |   if (servername) | ||||||
|     netapibufferfree (servername); |     netapibufferfree (servername); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user