/*
* TODO:
- * Implement NetUserChangePassword
* Implement NetUserGetGroups
* Implement NetUserSetGroups
* NetUserGetLocalGroups does not support LG_INCLUDE_INDIRECT yet.
}
+static
+ULONG
+GetAccountControl(ULONG Flags)
+{
+ ULONG AccountControl = 0;
+
+ if (Flags & UF_ACCOUNTDISABLE)
+ AccountControl |= USER_ACCOUNT_DISABLED;
+
+ if (Flags & UF_HOMEDIR_REQUIRED)
+ AccountControl |= USER_HOME_DIRECTORY_REQUIRED;
+
+ if (Flags & UF_PASSWD_NOTREQD)
+ AccountControl |= USER_PASSWORD_NOT_REQUIRED;
+
+ if (Flags & UF_LOCKOUT)
+ AccountControl |= USER_ACCOUNT_AUTO_LOCKED;
+
+ if (Flags & UF_DONT_EXPIRE_PASSWD)
+ AccountControl |= USER_DONT_EXPIRE_PASSWORD;
+
+ /* Set account type flags */
+ if (Flags & UF_TEMP_DUPLICATE_ACCOUNT)
+ AccountControl |= USER_TEMP_DUPLICATE_ACCOUNT;
+ else if (Flags & UF_NORMAL_ACCOUNT)
+ AccountControl |= USER_NORMAL_ACCOUNT;
+ else if (Flags & UF_INTERDOMAIN_TRUST_ACCOUNT)
+ AccountControl |= USER_INTERDOMAIN_TRUST_ACCOUNT;
+ else if (Flags & UF_WORKSTATION_TRUST_ACCOUNT)
+ AccountControl |= USER_WORKSTATION_TRUST_ACCOUNT;
+ else if (Flags & UF_SERVER_TRUST_ACCOUNT)
+ AccountControl |= USER_SERVER_TRUST_ACCOUNT;
+
+ return AccountControl;
+}
+
+
+static
+DWORD
+GetPasswordAge(IN PLARGE_INTEGER PasswordLastSet)
+{
+ LARGE_INTEGER SystemTime;
+ ULONG SystemSecondsSince1970;
+ ULONG PasswordSecondsSince1970;
+ NTSTATUS Status;
+
+ Status = NtQuerySystemTime(&SystemTime);
+ if (!NT_SUCCESS(Status))
+ return 0;
+
+ RtlTimeToSecondsSince1970(&SystemTime, &SystemSecondsSince1970);
+ RtlTimeToSecondsSince1970(PasswordLastSet, &PasswordSecondsSince1970);
+
+ return SystemSecondsSince1970 - PasswordSecondsSince1970;
+}
+
+
static
NET_API_STATUS
-BuildUserInfoBuffer(PUSER_ACCOUNT_INFORMATION UserInfo,
+BuildUserInfoBuffer(PUSER_ALL_INFORMATION UserInfo,
DWORD level,
ULONG RelativeId,
LPVOID *Buffer)
{
+ UNICODE_STRING LogonServer = RTL_CONSTANT_STRING(L"\\\\*");
LPVOID LocalBuffer = NULL;
PUSER_INFO_0 UserInfo0;
PUSER_INFO_1 UserInfo1;
PUSER_INFO_2 UserInfo2;
PUSER_INFO_3 UserInfo3;
+ PUSER_INFO_4 UserInfo4;
PUSER_INFO_10 UserInfo10;
+ PUSER_INFO_11 UserInfo11;
PUSER_INFO_20 UserInfo20;
PUSER_INFO_23 UserInfo23;
LPWSTR Ptr;
if (UserInfo->FullName.Length > 0)
Size += UserInfo->FullName.Length + sizeof(WCHAR);
- /* FIXME: usri2_usr_comment */
- /* FIXME: usri2_parms */
+ if (UserInfo->UserComment.Length > 0)
+ Size += UserInfo->UserComment.Length + sizeof(WCHAR);
+
+ if (UserInfo->Parameters.Length > 0)
+ Size += UserInfo->Parameters.Length + sizeof(WCHAR);
if (UserInfo->WorkStations.Length > 0)
Size += UserInfo->WorkStations.Length + sizeof(WCHAR);
- /* FIXME: usri2_logon_hours */
- /* FIXME: usri2_logon_server */
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ Size += (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8;
+
+ if (LogonServer.Length > 0)
+ Size += LogonServer.Length + sizeof(WCHAR);
break;
case 3:
if (UserInfo->FullName.Length > 0)
Size += UserInfo->FullName.Length + sizeof(WCHAR);
- /* FIXME: usri3_usr_comment */
- /* FIXME: usri3_parms */
+ if (UserInfo->UserComment.Length > 0)
+ Size += UserInfo->UserComment.Length + sizeof(WCHAR);
+
+ if (UserInfo->Parameters.Length > 0)
+ Size += UserInfo->Parameters.Length + sizeof(WCHAR);
if (UserInfo->WorkStations.Length > 0)
Size += UserInfo->WorkStations.Length + sizeof(WCHAR);
- /* FIXME: usri3_logon_hours */
- /* FIXME: usri3_logon_server */
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ Size += (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8;
+
+ if (LogonServer.Length > 0)
+ Size += LogonServer.Length + sizeof(WCHAR);
if (UserInfo->ProfilePath.Length > 0)
Size += UserInfo->ProfilePath.Length + sizeof(WCHAR);
Size += UserInfo->HomeDirectoryDrive.Length + sizeof(WCHAR);
break;
-// case 4:
+ case 4:
+ Size = sizeof(USER_INFO_4) +
+ UserInfo->UserName.Length + sizeof(WCHAR);
+
+ if (UserInfo->HomeDirectory.Length > 0)
+ Size += UserInfo->HomeDirectory.Length + sizeof(WCHAR);
+
+ if (UserInfo->AdminComment.Length > 0)
+ Size += UserInfo->AdminComment.Length + sizeof(WCHAR);
+
+ if (UserInfo->ScriptPath.Length > 0)
+ Size += UserInfo->ScriptPath.Length + sizeof(WCHAR);
+
+ if (UserInfo->FullName.Length > 0)
+ Size += UserInfo->FullName.Length + sizeof(WCHAR);
+
+ if (UserInfo->UserComment.Length > 0)
+ Size += UserInfo->UserComment.Length + sizeof(WCHAR);
+
+ if (UserInfo->Parameters.Length > 0)
+ Size += UserInfo->Parameters.Length + sizeof(WCHAR);
+
+ if (UserInfo->WorkStations.Length > 0)
+ Size += UserInfo->WorkStations.Length + sizeof(WCHAR);
+
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ Size += (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8;
+
+ if (LogonServer.Length > 0)
+ Size += LogonServer.Length + sizeof(WCHAR);
+
+ /* FIXME: usri4_user_sid */
+
+ if (UserInfo->ProfilePath.Length > 0)
+ Size += UserInfo->ProfilePath.Length + sizeof(WCHAR);
+
+ if (UserInfo->HomeDirectoryDrive.Length > 0)
+ Size += UserInfo->HomeDirectoryDrive.Length + sizeof(WCHAR);
+ break;
case 10:
Size = sizeof(USER_INFO_10) +
if (UserInfo->AdminComment.Length > 0)
Size += UserInfo->AdminComment.Length + sizeof(WCHAR);
- /* FIXME: usri10_usr_comment */
+ if (UserInfo->UserComment.Length > 0)
+ Size += UserInfo->UserComment.Length + sizeof(WCHAR);
if (UserInfo->FullName.Length > 0)
Size += UserInfo->FullName.Length + sizeof(WCHAR);
break;
-// case 11:
+ case 11:
+ Size = sizeof(USER_INFO_11) +
+ UserInfo->UserName.Length + sizeof(WCHAR);
+
+ if (UserInfo->AdminComment.Length > 0)
+ Size += UserInfo->AdminComment.Length + sizeof(WCHAR);
+
+ if (UserInfo->UserComment.Length > 0)
+ Size += UserInfo->UserComment.Length + sizeof(WCHAR);
+
+ if (UserInfo->FullName.Length > 0)
+ Size += UserInfo->FullName.Length + sizeof(WCHAR);
+
+ if (UserInfo->HomeDirectory.Length > 0)
+ Size += UserInfo->HomeDirectory.Length + sizeof(WCHAR);
+
+ if (UserInfo->Parameters.Length > 0)
+ Size += UserInfo->Parameters.Length + sizeof(WCHAR);
+
+ if (LogonServer.Length > 0)
+ Size += LogonServer.Length + sizeof(WCHAR);
+
+ if (UserInfo->WorkStations.Length > 0)
+ Size += UserInfo->WorkStations.Length + sizeof(WCHAR);
+
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ Size += (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8;
+ break;
case 20:
Size = sizeof(USER_INFO_20) +
UserInfo1->usri1_password = NULL;
- /* FIXME: UserInfo1->usri1_password_age */
+ UserInfo1->usri1_password_age = GetPasswordAge(&UserInfo->PasswordLastSet);
+
/* FIXME: UserInfo1->usri1_priv */
if (UserInfo->HomeDirectory.Length > 0)
Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
- /* FIXME: usri2_password_age */
+ UserInfo2->usri2_password_age = GetPasswordAge(&UserInfo->PasswordLastSet);
+
/* FIXME: usri2_priv */
if (UserInfo->HomeDirectory.Length > 0)
Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
}
- /* FIXME: usri2_usr_comment */
- /* FIXME: usri2_parms */
+ if (UserInfo->UserComment.Length > 0)
+ {
+ UserInfo2->usri2_usr_comment = Ptr;
+
+ memcpy(UserInfo2->usri2_usr_comment,
+ UserInfo->UserComment.Buffer,
+ UserInfo->UserComment.Length);
+ UserInfo2->usri2_usr_comment[UserInfo->UserComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->Parameters.Length > 0)
+ {
+ UserInfo2->usri2_parms = Ptr;
+
+ memcpy(UserInfo2->usri2_parms,
+ UserInfo->Parameters.Buffer,
+ UserInfo->Parameters.Length);
+ UserInfo2->usri2_parms[UserInfo->Parameters.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->Parameters.Length + sizeof(WCHAR));
+ }
if (UserInfo->WorkStations.Length > 0)
{
&UserInfo2->usri2_acct_expires);
UserInfo2->usri2_max_storage = USER_MAXSTORAGE_UNLIMITED;
+ UserInfo2->usri2_units_per_week = UserInfo->LogonHours.UnitsPerWeek;
+
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ {
+ UserInfo2->usri2_logon_hours = (PVOID)Ptr;
+
+ memcpy(UserInfo2->usri2_logon_hours,
+ UserInfo->LogonHours.LogonHours,
+ (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
- /* FIXME: usri2_units_per_week */
- /* FIXME: usri2_logon_hours */
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
+ }
UserInfo2->usri2_bad_pw_count = UserInfo->BadPasswordCount;
UserInfo2->usri2_num_logons = UserInfo->LogonCount;
- /* FIXME: usri2_logon_server */
- /* FIXME: usri2_country_code */
- /* FIXME: usri2_code_page */
+ if (LogonServer.Length > 0)
+ {
+ UserInfo2->usri2_logon_server = Ptr;
+
+ memcpy(UserInfo2->usri2_logon_server,
+ LogonServer.Buffer,
+ LogonServer.Length);
+ UserInfo2->usri2_logon_server[LogonServer.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + LogonServer.Length + sizeof(WCHAR));
+ }
+ UserInfo2->usri2_country_code = UserInfo->CountryCode;
+ UserInfo2->usri2_code_page = UserInfo->CodePage;
break;
case 3:
Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
- /* FIXME: usri3_password_age */
+ UserInfo3->usri3_password_age = GetPasswordAge(&UserInfo->PasswordLastSet);
+
/* FIXME: usri3_priv */
if (UserInfo->HomeDirectory.Length > 0)
Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
}
- /* FIXME: usri3_usr_comment */
- /* FIXME: usri3_parms */
+ if (UserInfo->UserComment.Length > 0)
+ {
+ UserInfo3->usri3_usr_comment = Ptr;
+
+ memcpy(UserInfo3->usri3_usr_comment,
+ UserInfo->UserComment.Buffer,
+ UserInfo->UserComment.Length);
+ UserInfo3->usri3_usr_comment[UserInfo->UserComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->Parameters.Length > 0)
+ {
+ UserInfo3->usri3_parms = Ptr;
+
+ memcpy(UserInfo3->usri3_parms,
+ UserInfo->Parameters.Buffer,
+ UserInfo->Parameters.Length);
+ UserInfo3->usri3_parms[UserInfo->Parameters.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->Parameters.Length + sizeof(WCHAR));
+ }
if (UserInfo->WorkStations.Length > 0)
{
&UserInfo3->usri3_acct_expires);
UserInfo3->usri3_max_storage = USER_MAXSTORAGE_UNLIMITED;
+ UserInfo3->usri3_units_per_week = UserInfo->LogonHours.UnitsPerWeek;
+
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ {
+ UserInfo3->usri3_logon_hours = (PVOID)Ptr;
+
+ memcpy(UserInfo3->usri3_logon_hours,
+ UserInfo->LogonHours.LogonHours,
+ (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
- /* FIXME: usri3_units_per_week */
- /* FIXME: usri3_logon_hours */
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
+ }
UserInfo3->usri3_bad_pw_count = UserInfo->BadPasswordCount;
UserInfo3->usri3_num_logons = UserInfo->LogonCount;
- /* FIXME: usri3_logon_server */
- /* FIXME: usri3_country_code */
- /* FIXME: usri3_code_page */
+ if (LogonServer.Length > 0)
+ {
+ UserInfo3->usri3_logon_server = Ptr;
+
+ memcpy(UserInfo3->usri3_logon_server,
+ LogonServer.Buffer,
+ LogonServer.Length);
+ UserInfo3->usri3_logon_server[LogonServer.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + LogonServer.Length + sizeof(WCHAR));
+ }
+ UserInfo3->usri3_country_code = UserInfo->CountryCode;
+ UserInfo3->usri3_code_page = UserInfo->CodePage;
UserInfo3->usri3_user_id = RelativeId;
UserInfo3->usri3_primary_group_id = UserInfo->PrimaryGroupId;
UserInfo3->usri3_password_expired = (UserInfo->UserAccountControl & USER_PASSWORD_EXPIRED);
break;
-// case 4:
+ case 4:
+ UserInfo4 = (PUSER_INFO_4)LocalBuffer;
+
+ Ptr = (LPWSTR)((ULONG_PTR)UserInfo4 + sizeof(USER_INFO_4));
+
+ UserInfo4->usri4_name = Ptr;
+
+ memcpy(UserInfo4->usri4_name,
+ UserInfo->UserName.Buffer,
+ UserInfo->UserName.Length);
+ UserInfo4->usri4_name[UserInfo->UserName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
+
+ UserInfo4->usri4_password = NULL;
+ UserInfo4->usri4_password_age = GetPasswordAge(&UserInfo->PasswordLastSet);
+
+ /* FIXME: usri4_priv */
+
+ if (UserInfo->HomeDirectory.Length > 0)
+ {
+ UserInfo4->usri4_home_dir = Ptr;
+
+ memcpy(UserInfo4->usri4_home_dir,
+ UserInfo->HomeDirectory.Buffer,
+ UserInfo->HomeDirectory.Length);
+ UserInfo4->usri4_home_dir[UserInfo->HomeDirectory.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->HomeDirectory.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->AdminComment.Length > 0)
+ {
+ UserInfo4->usri4_comment = Ptr;
+
+ memcpy(UserInfo4->usri4_comment,
+ UserInfo->AdminComment.Buffer,
+ UserInfo->AdminComment.Length);
+ UserInfo4->usri4_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
+ }
+
+ UserInfo4->usri4_flags = GetAccountFlags(UserInfo->UserAccountControl);
+
+ if (UserInfo->ScriptPath.Length > 0)
+ {
+ UserInfo4->usri4_script_path = Ptr;
+
+ memcpy(UserInfo4->usri4_script_path,
+ UserInfo->ScriptPath.Buffer,
+ UserInfo->ScriptPath.Length);
+ UserInfo4->usri4_script_path[UserInfo->ScriptPath.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->ScriptPath.Length + sizeof(WCHAR));
+ }
+
+ /* FIXME: usri4_auth_flags */
+
+ if (UserInfo->FullName.Length > 0)
+ {
+ UserInfo4->usri4_full_name = Ptr;
+
+ memcpy(UserInfo4->usri4_full_name,
+ UserInfo->FullName.Buffer,
+ UserInfo->FullName.Length);
+ UserInfo4->usri4_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->UserComment.Length > 0)
+ {
+ UserInfo4->usri4_usr_comment = Ptr;
+
+ memcpy(UserInfo4->usri4_usr_comment,
+ UserInfo->UserComment.Buffer,
+ UserInfo->UserComment.Length);
+ UserInfo4->usri4_usr_comment[UserInfo->UserComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->Parameters.Length > 0)
+ {
+ UserInfo4->usri4_parms = Ptr;
+
+ memcpy(UserInfo4->usri4_parms,
+ UserInfo->Parameters.Buffer,
+ UserInfo->Parameters.Length);
+ UserInfo4->usri4_parms[UserInfo->Parameters.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->Parameters.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->WorkStations.Length > 0)
+ {
+ UserInfo4->usri4_workstations = Ptr;
+
+ memcpy(UserInfo4->usri4_workstations,
+ UserInfo->WorkStations.Buffer,
+ UserInfo->WorkStations.Length);
+ UserInfo4->usri4_workstations[UserInfo->WorkStations.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->WorkStations.Length + sizeof(WCHAR));
+ }
+
+ RtlTimeToSecondsSince1970(&UserInfo->LastLogon,
+ &UserInfo4->usri4_last_logon);
+
+ RtlTimeToSecondsSince1970(&UserInfo->LastLogoff,
+ &UserInfo4->usri4_last_logoff);
+
+ RtlTimeToSecondsSince1970(&UserInfo->AccountExpires,
+ &UserInfo4->usri4_acct_expires);
+
+ UserInfo4->usri4_max_storage = USER_MAXSTORAGE_UNLIMITED;
+ UserInfo4->usri4_units_per_week = UserInfo->LogonHours.UnitsPerWeek;
+
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ {
+ UserInfo4->usri4_logon_hours = (PVOID)Ptr;
+
+ memcpy(UserInfo4->usri4_logon_hours,
+ UserInfo->LogonHours.LogonHours,
+ (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
+ }
+
+ UserInfo4->usri4_bad_pw_count = UserInfo->BadPasswordCount;
+ UserInfo4->usri4_num_logons = UserInfo->LogonCount;
+
+ if (LogonServer.Length > 0)
+ {
+ UserInfo4->usri4_logon_server = Ptr;
+
+ memcpy(UserInfo4->usri4_logon_server,
+ LogonServer.Buffer,
+ LogonServer.Length);
+ UserInfo4->usri4_logon_server[LogonServer.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + LogonServer.Length + sizeof(WCHAR));
+ }
+
+ UserInfo4->usri4_country_code = UserInfo->CountryCode;
+ UserInfo4->usri4_code_page = UserInfo->CodePage;
+
+ /* FIXME: usri4_user_sid */
+
+ UserInfo4->usri4_primary_group_id = UserInfo->PrimaryGroupId;
+
+ if (UserInfo->ProfilePath.Length > 0)
+ {
+ UserInfo4->usri4_profile = Ptr;
+
+ memcpy(UserInfo4->usri4_profile,
+ UserInfo->ProfilePath.Buffer,
+ UserInfo->ProfilePath.Length);
+ UserInfo4->usri4_profile[UserInfo->ProfilePath.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->ProfilePath.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->HomeDirectoryDrive.Length > 0)
+ {
+ UserInfo4->usri4_home_dir_drive = Ptr;
+
+ memcpy(UserInfo4->usri4_home_dir_drive,
+ UserInfo->HomeDirectoryDrive.Buffer,
+ UserInfo->HomeDirectoryDrive.Length);
+ UserInfo4->usri4_home_dir_drive[UserInfo->HomeDirectoryDrive.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->HomeDirectoryDrive.Length + sizeof(WCHAR));
+ }
+
+ UserInfo4->usri4_password_expired = (UserInfo->UserAccountControl & USER_PASSWORD_EXPIRED);
+ break;
case 10:
UserInfo10 = (PUSER_INFO_10)LocalBuffer;
Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
- if (UserInfo->AdminComment.Length > 0)
- {
- UserInfo10->usri10_comment = Ptr;
+ if (UserInfo->AdminComment.Length > 0)
+ {
+ UserInfo10->usri10_comment = Ptr;
+
+ memcpy(UserInfo10->usri10_comment,
+ UserInfo->AdminComment.Buffer,
+ UserInfo->AdminComment.Length);
+ UserInfo10->usri10_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->UserComment.Length > 0)
+ {
+ UserInfo10->usri10_usr_comment = Ptr;
+
+ memcpy(UserInfo10->usri10_usr_comment,
+ UserInfo->UserComment.Buffer,
+ UserInfo->UserComment.Length);
+ UserInfo10->usri10_usr_comment[UserInfo->UserComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->FullName.Length > 0)
+ {
+ UserInfo10->usri10_full_name = Ptr;
+
+ memcpy(UserInfo10->usri10_full_name,
+ UserInfo->FullName.Buffer,
+ UserInfo->FullName.Length);
+ UserInfo10->usri10_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ }
+ break;
+
+ case 11:
+ UserInfo11 = (PUSER_INFO_11)LocalBuffer;
+
+ Ptr = (LPWSTR)((ULONG_PTR)UserInfo11 + sizeof(USER_INFO_11));
+
+ UserInfo11->usri11_name = Ptr;
+
+ memcpy(UserInfo11->usri11_name,
+ UserInfo->UserName.Buffer,
+ UserInfo->UserName.Length);
+ UserInfo11->usri11_name[UserInfo->UserName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
+
+ if (UserInfo->AdminComment.Length > 0)
+ {
+ UserInfo11->usri11_comment = Ptr;
+
+ memcpy(UserInfo11->usri11_comment,
+ UserInfo->AdminComment.Buffer,
+ UserInfo->AdminComment.Length);
+ UserInfo11->usri11_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->UserComment.Length > 0)
+ {
+ UserInfo11->usri11_usr_comment = Ptr;
+
+ memcpy(UserInfo11->usri11_usr_comment,
+ UserInfo->UserComment.Buffer,
+ UserInfo->UserComment.Length);
+ UserInfo11->usri11_usr_comment[UserInfo->UserComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserComment.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->FullName.Length > 0)
+ {
+ UserInfo11->usri11_full_name = Ptr;
+
+ memcpy(UserInfo11->usri11_full_name,
+ UserInfo->FullName.Buffer,
+ UserInfo->FullName.Length);
+ UserInfo11->usri11_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ }
+
+ /* FIXME: usri11_priv */
+ /* FIXME: usri11_auth_flags */
+
+ UserInfo11->usri11_password_age = GetPasswordAge(&UserInfo->PasswordLastSet);
+
+ if (UserInfo->HomeDirectory.Length > 0)
+ {
+ UserInfo11->usri11_home_dir = Ptr;
+
+ memcpy(UserInfo11->usri11_home_dir,
+ UserInfo->HomeDirectory.Buffer,
+ UserInfo->HomeDirectory.Length);
+ UserInfo11->usri11_home_dir[UserInfo->HomeDirectory.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->HomeDirectory.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->Parameters.Length > 0)
+ {
+ UserInfo11->usri11_parms = Ptr;
+
+ memcpy(UserInfo11->usri11_parms,
+ UserInfo->Parameters.Buffer,
+ UserInfo->Parameters.Length);
+ UserInfo11->usri11_parms[UserInfo->Parameters.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->Parameters.Length + sizeof(WCHAR));
+ }
+
+ RtlTimeToSecondsSince1970(&UserInfo->LastLogon,
+ &UserInfo11->usri11_last_logon);
+
+ RtlTimeToSecondsSince1970(&UserInfo->LastLogoff,
+ &UserInfo11->usri11_last_logoff);
+
+ UserInfo11->usri11_bad_pw_count = UserInfo->BadPasswordCount;
+ UserInfo11->usri11_num_logons = UserInfo->LogonCount;
+
+ if (LogonServer.Length > 0)
+ {
+ UserInfo11->usri11_logon_server = Ptr;
+
+ memcpy(UserInfo11->usri11_logon_server,
+ LogonServer.Buffer,
+ LogonServer.Length);
+ UserInfo11->usri11_logon_server[LogonServer.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + LogonServer.Length + sizeof(WCHAR));
+ }
+
+ UserInfo11->usri11_country_code = UserInfo->CountryCode;
+
+ if (UserInfo->WorkStations.Length > 0)
+ {
+ UserInfo11->usri11_workstations = Ptr;
+
+ memcpy(UserInfo11->usri11_workstations,
+ UserInfo->WorkStations.Buffer,
+ UserInfo->WorkStations.Length);
+ UserInfo11->usri11_workstations[UserInfo->WorkStations.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->WorkStations.Length + sizeof(WCHAR));
+ }
+
+ UserInfo11->usri11_max_storage = USER_MAXSTORAGE_UNLIMITED;
+ UserInfo11->usri11_units_per_week = UserInfo->LogonHours.UnitsPerWeek;
+
+ if (UserInfo->LogonHours.UnitsPerWeek > 0)
+ {
+ UserInfo11->usri11_logon_hours = (PVOID)Ptr;
+
+ memcpy(UserInfo11->usri11_logon_hours,
+ UserInfo->LogonHours.LogonHours,
+ (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + (((ULONG)UserInfo->LogonHours.UnitsPerWeek) + 7) / 8);
+ }
+
+ UserInfo11->usri11_code_page = UserInfo->CodePage;
+ break;
+
+ case 20:
+ UserInfo20 = (PUSER_INFO_20)LocalBuffer;
+
+ Ptr = (LPWSTR)((ULONG_PTR)UserInfo20 + sizeof(USER_INFO_20));
+
+ UserInfo20->usri20_name = Ptr;
+
+ memcpy(UserInfo20->usri20_name,
+ UserInfo->UserName.Buffer,
+ UserInfo->UserName.Length);
+ UserInfo20->usri20_name[UserInfo->UserName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
+
+ if (UserInfo->FullName.Length > 0)
+ {
+ UserInfo20->usri20_full_name = Ptr;
+
+ memcpy(UserInfo20->usri20_full_name,
+ UserInfo->FullName.Buffer,
+ UserInfo->FullName.Length);
+ UserInfo20->usri20_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->AdminComment.Length > 0)
+ {
+ UserInfo20->usri20_comment = Ptr;
+
+ memcpy(UserInfo20->usri20_comment,
+ UserInfo->AdminComment.Buffer,
+ UserInfo->AdminComment.Length);
+ UserInfo20->usri20_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
+ }
+
+ UserInfo20->usri20_flags = GetAccountFlags(UserInfo->UserAccountControl);
+
+ UserInfo20->usri20_user_id = RelativeId;
+ break;
+
+ case 23:
+ UserInfo23 = (PUSER_INFO_23)LocalBuffer;
+
+ Ptr = (LPWSTR)((ULONG_PTR)UserInfo23 + sizeof(USER_INFO_23));
+
+ UserInfo23->usri23_name = Ptr;
+
+ memcpy(UserInfo23->usri23_name,
+ UserInfo->UserName.Buffer,
+ UserInfo->UserName.Length);
+ UserInfo23->usri23_name[UserInfo->UserName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
+
+ if (UserInfo->FullName.Length > 0)
+ {
+ UserInfo23->usri23_full_name = Ptr;
+
+ memcpy(UserInfo23->usri23_full_name,
+ UserInfo->FullName.Buffer,
+ UserInfo->FullName.Length);
+ UserInfo23->usri23_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ }
+
+ if (UserInfo->AdminComment.Length > 0)
+ {
+ UserInfo23->usri23_comment = Ptr;
+
+ memcpy(UserInfo23->usri23_comment,
+ UserInfo->AdminComment.Buffer,
+ UserInfo->AdminComment.Length);
+ UserInfo23->usri23_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
+ }
+
+ UserInfo23->usri23_flags = GetAccountFlags(UserInfo->UserAccountControl);
+
+ /* FIXME: usri23_user_sid */
+ break;
+ }
+
+done:
+ if (ApiStatus == NERR_Success)
+ {
+ *Buffer = LocalBuffer;
+ }
+ else
+ {
+ if (LocalBuffer != NULL)
+ NetApiBufferFree(LocalBuffer);
+ }
+
+ return ApiStatus;
+}
+
+
+static
+VOID
+FreeUserInfo(PUSER_ALL_INFORMATION UserInfo)
+{
+ if (UserInfo->UserName.Buffer != NULL)
+ SamFreeMemory(UserInfo->UserName.Buffer);
+
+ if (UserInfo->FullName.Buffer != NULL)
+ SamFreeMemory(UserInfo->FullName.Buffer);
+
+ if (UserInfo->HomeDirectory.Buffer != NULL)
+ SamFreeMemory(UserInfo->HomeDirectory.Buffer);
+
+ if (UserInfo->HomeDirectoryDrive.Buffer != NULL)
+ SamFreeMemory(UserInfo->HomeDirectoryDrive.Buffer);
+
+ if (UserInfo->ScriptPath.Buffer != NULL)
+ SamFreeMemory(UserInfo->ScriptPath.Buffer);
+
+ if (UserInfo->ProfilePath.Buffer != NULL)
+ SamFreeMemory(UserInfo->ProfilePath.Buffer);
+
+ if (UserInfo->AdminComment.Buffer != NULL)
+ SamFreeMemory(UserInfo->AdminComment.Buffer);
+
+ if (UserInfo->WorkStations.Buffer != NULL)
+ SamFreeMemory(UserInfo->WorkStations.Buffer);
+
+ if (UserInfo->UserComment.Buffer != NULL)
+ SamFreeMemory(UserInfo->UserComment.Buffer);
+
+ if (UserInfo->Parameters.Buffer != NULL)
+ SamFreeMemory(UserInfo->Parameters.Buffer);
+
+ if (UserInfo->PrivateData.Buffer != NULL)
+ SamFreeMemory(UserInfo->PrivateData.Buffer);
+
+ if (UserInfo->LogonHours.LogonHours != NULL)
+ SamFreeMemory(UserInfo->LogonHours.LogonHours);
+
+ SamFreeMemory(UserInfo);
+}
+
+
+static
+NET_API_STATUS
+SetUserInfo(SAM_HANDLE UserHandle,
+ LPBYTE UserInfo,
+ DWORD Level)
+{
+ USER_ALL_INFORMATION UserAllInfo;
+ PUSER_INFO_0 UserInfo0;
+ PUSER_INFO_1 UserInfo1;
+ PUSER_INFO_2 UserInfo2;
+ PUSER_INFO_3 UserInfo3;
+ PUSER_INFO_4 UserInfo4;
+ PUSER_INFO_1003 UserInfo1003;
+ PUSER_INFO_1006 UserInfo1006;
+ PUSER_INFO_1007 UserInfo1007;
+ PUSER_INFO_1008 UserInfo1008;
+ PUSER_INFO_1009 UserInfo1009;
+ PUSER_INFO_1011 UserInfo1011;
+ PUSER_INFO_1012 UserInfo1012;
+ PUSER_INFO_1013 UserInfo1013;
+ PUSER_INFO_1014 UserInfo1014;
+ PUSER_INFO_1017 UserInfo1017;
+ PUSER_INFO_1018 UserInfo1018;
+ PUSER_INFO_1024 UserInfo1024;
+ PUSER_INFO_1025 UserInfo1025;
+ PUSER_INFO_1051 UserInfo1051;
+ PUSER_INFO_1052 UserInfo1052;
+ PUSER_INFO_1053 UserInfo1053;
+ NET_API_STATUS ApiStatus = NERR_Success;
+ NTSTATUS Status = STATUS_SUCCESS;
+
+ ZeroMemory(&UserAllInfo, sizeof(USER_ALL_INFORMATION));
+
+ switch (Level)
+ {
+ case 0:
+ UserInfo0 = (PUSER_INFO_0)UserInfo;
+
+ RtlInitUnicodeString(&UserAllInfo.UserName,
+ UserInfo0->usri0_name);
+
+ UserAllInfo.WhichFields |= USER_ALL_USERNAME;
+ break;
+
+ case 1:
+ UserInfo1 = (PUSER_INFO_1)UserInfo;
+
+ // usri1_name ignored
+
+ if (UserInfo1->usri1_password != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.NtPassword,
+ UserInfo1->usri1_password);
+ UserAllInfo.NtPasswordPresent = TRUE;
+ UserAllInfo.WhichFields |= USER_ALL_NTPASSWORDPRESENT;
+ }
+
+ // usri1_password_age ignored
+
+// UserInfo1->usri1_priv
+
+ if (UserInfo1->usri1_home_dir != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
+ UserInfo1->usri1_home_dir);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORY;
+ }
+
+ if (UserInfo1->usri1_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.AdminComment,
+ UserInfo1->usri1_comment);
+ UserAllInfo.WhichFields |= USER_ALL_ADMINCOMMENT;
+ }
+
+ UserAllInfo.UserAccountControl = GetAccountControl(UserInfo1->usri1_flags);
+ UserAllInfo.WhichFields |= USER_ALL_USERACCOUNTCONTROL;
+
+ if (UserInfo1->usri1_script_path != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ScriptPath,
+ UserInfo1->usri1_script_path);
+ UserAllInfo.WhichFields |= USER_ALL_SCRIPTPATH;
+ }
+ break;
+
+ case 2:
+ UserInfo2 = (PUSER_INFO_2)UserInfo;
+
+ // usri2_name ignored
+
+ if (UserInfo2->usri2_password != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.NtPassword,
+ UserInfo2->usri2_password);
+ UserAllInfo.NtPasswordPresent = TRUE;
+ UserAllInfo.WhichFields |= USER_ALL_NTPASSWORDPRESENT;
+ }
+
+ // usri2_password_age ignored
+
+// UserInfo2->usri2_priv;
+
+ if (UserInfo2->usri2_home_dir != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
+ UserInfo2->usri2_home_dir);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORY;
+ }
+
+ if (UserInfo2->usri2_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.AdminComment,
+ UserInfo2->usri2_comment);
+ UserAllInfo.WhichFields |= USER_ALL_ADMINCOMMENT;
+ }
+
+ UserAllInfo.UserAccountControl = GetAccountControl(UserInfo2->usri2_flags);
+ UserAllInfo.WhichFields |= USER_ALL_USERACCOUNTCONTROL;
+
+ if (UserInfo2->usri2_script_path != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ScriptPath,
+ UserInfo2->usri2_script_path);
+ UserAllInfo.WhichFields |= USER_ALL_SCRIPTPATH;
+ }
+
+// UserInfo2->usri2_auth_flags;
+
+ if (UserInfo2->usri2_full_name != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.FullName,
+ UserInfo2->usri2_full_name);
+ UserAllInfo.WhichFields |= USER_ALL_FULLNAME;
+ }
+
+ if (UserInfo2->usri2_usr_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.UserComment,
+ UserInfo2->usri2_usr_comment);
+ UserAllInfo.WhichFields |= USER_ALL_USERCOMMENT;
+ }
+
+ if (UserInfo2->usri2_parms != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.Parameters,
+ UserInfo2->usri2_parms);
+ UserAllInfo.WhichFields |= USER_ALL_PARAMETERS;
+ }
+
+ if (UserInfo2->usri2_workstations != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.WorkStations,
+ UserInfo2->usri2_workstations);
+ UserAllInfo.WhichFields |= USER_ALL_WORKSTATIONS;
+ }
+
+ // usri2_last_logon ignored
+ // usri2_last_logoff ignored
+
+ if (UserInfo2->usri2_acct_expires == TIMEQ_FOREVER)
+ {
+ UserAllInfo.AccountExpires.LowPart = 0;
+ UserAllInfo.AccountExpires.HighPart = 0;
+ }
+ else
+ {
+ RtlSecondsSince1970ToTime(UserInfo2->usri2_acct_expires,
+ &UserAllInfo.AccountExpires);
+ }
+ UserAllInfo.WhichFields |= USER_ALL_ACCOUNTEXPIRES;
+
+ // usri2_max_storage ignored
+
+// UserInfo2->usri2_units_per_week;
+// UserInfo2->usri2_logon_hours;
+
+ // usri2_bad_pw_count ignored
+ // usri2_num_logons ignored
+ // usri2_logon_server ignored
+
+ UserAllInfo.CountryCode = UserInfo2->usri2_country_code;
+ UserAllInfo.WhichFields |= USER_ALL_COUNTRYCODE;
+
+ UserAllInfo.CodePage = UserInfo2->usri2_code_page;
+ UserAllInfo.WhichFields |= USER_ALL_CODEPAGE;
+ break;
+
+ case 3:
+ UserInfo3 = (PUSER_INFO_3)UserInfo;
+
+ // usri3_name ignored
+
+ if (UserInfo3->usri3_password != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.NtPassword,
+ UserInfo3->usri3_password);
+ UserAllInfo.NtPasswordPresent = TRUE;
+ UserAllInfo.WhichFields |= USER_ALL_NTPASSWORDPRESENT;
+ }
+
+ // usri3_password_age ignored
+
+// UserInfo3->usri3_priv;
+
+ if (UserInfo3->usri3_home_dir != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
+ UserInfo3->usri3_home_dir);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORY;
+ }
+
+ if (UserInfo3->usri3_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.AdminComment,
+ UserInfo3->usri3_comment);
+ UserAllInfo.WhichFields |= USER_ALL_ADMINCOMMENT;
+ }
+
+ UserAllInfo.UserAccountControl = GetAccountControl(UserInfo3->usri3_flags);
+ UserAllInfo.WhichFields |= USER_ALL_USERACCOUNTCONTROL;
+
+ if (UserInfo3->usri3_script_path != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ScriptPath,
+ UserInfo3->usri3_script_path);
+ UserAllInfo.WhichFields |= USER_ALL_SCRIPTPATH;
+ }
+
+// UserInfo3->usri3_auth_flags;
+
+ if (UserInfo3->usri3_full_name != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.FullName,
+ UserInfo3->usri3_full_name);
+ UserAllInfo.WhichFields |= USER_ALL_FULLNAME;
+ }
+
+ if (UserInfo3->usri3_usr_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.UserComment,
+ UserInfo3->usri3_usr_comment);
+ UserAllInfo.WhichFields |= USER_ALL_USERCOMMENT;
+ }
+
+ if (UserInfo3->usri3_parms != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.Parameters,
+ UserInfo3->usri3_parms);
+ UserAllInfo.WhichFields |= USER_ALL_PARAMETERS;
+ }
+
+ if (UserInfo3->usri3_workstations != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.WorkStations,
+ UserInfo3->usri3_workstations);
+ UserAllInfo.WhichFields |= USER_ALL_WORKSTATIONS;
+ }
+
+ // usri3_last_logon ignored
+ // usri3_last_logoff ignored
+
+ if (UserInfo3->usri3_acct_expires == TIMEQ_FOREVER)
+ {
+ UserAllInfo.AccountExpires.LowPart = 0;
+ UserAllInfo.AccountExpires.HighPart = 0;
+ }
+ else
+ {
+ RtlSecondsSince1970ToTime(UserInfo3->usri3_acct_expires,
+ &UserAllInfo.AccountExpires);
+ }
+ UserAllInfo.WhichFields |= USER_ALL_ACCOUNTEXPIRES;
+
+ // usri3_max_storage ignored
+
+// UserInfo3->usri3_units_per_week;
+// UserInfo3->usri3_logon_hours;
+
+ // usri3_bad_pw_count ignored
+ // usri3_num_logons ignored
+ // usri3_logon_server ignored
+
+ UserAllInfo.CountryCode = UserInfo3->usri3_country_code;
+ UserAllInfo.WhichFields |= USER_ALL_COUNTRYCODE;
- memcpy(UserInfo10->usri10_comment,
- UserInfo->AdminComment.Buffer,
- UserInfo->AdminComment.Length);
- UserInfo10->usri10_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ UserAllInfo.CodePage = UserInfo3->usri3_code_page;
+ UserAllInfo.WhichFields |= USER_ALL_CODEPAGE;
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
- }
+ // usri3_user_id ignored
- /* FIXME: usri10_usr_comment */
+ UserAllInfo.PrimaryGroupId = UserInfo3->usri3_primary_group_id;
+ UserAllInfo.WhichFields |= USER_ALL_PRIMARYGROUPID;
- if (UserInfo->FullName.Length > 0)
+ if (UserInfo3->usri3_profile != NULL)
{
- UserInfo10->usri10_full_name = Ptr;
-
- memcpy(UserInfo10->usri10_full_name,
- UserInfo->FullName.Buffer,
- UserInfo->FullName.Length);
- UserInfo10->usri10_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ RtlInitUnicodeString(&UserAllInfo.ProfilePath,
+ UserInfo3->usri3_profile);
+ UserAllInfo.WhichFields |= USER_ALL_PROFILEPATH;
+ }
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ if (UserInfo3->usri3_home_dir_drive != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectoryDrive,
+ UserInfo3->usri3_home_dir_drive);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORYDRIVE;
}
+
+ UserAllInfo.PasswordExpired = (UserInfo3->usri3_password_expired != 0);
+ UserAllInfo.WhichFields |= USER_ALL_PASSWORDEXPIRED;
break;
-// case 11:
+ case 4:
+ UserInfo4 = (PUSER_INFO_4)UserInfo;
- case 20:
- UserInfo20 = (PUSER_INFO_20)LocalBuffer;
+ // usri4_name ignored
- Ptr = (LPWSTR)((ULONG_PTR)UserInfo20 + sizeof(USER_INFO_20));
+ if (UserInfo4->usri4_password != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.NtPassword,
+ UserInfo4->usri4_password);
+ UserAllInfo.NtPasswordPresent = TRUE;
+ UserAllInfo.WhichFields |= USER_ALL_NTPASSWORDPRESENT;
+ }
- UserInfo20->usri20_name = Ptr;
+ // usri4_password_age ignored
- memcpy(UserInfo20->usri20_name,
- UserInfo->UserName.Buffer,
- UserInfo->UserName.Length);
- UserInfo20->usri20_name[UserInfo->UserName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+// UserInfo3->usri4_priv;
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
+ if (UserInfo4->usri4_home_dir != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
+ UserInfo4->usri4_home_dir);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORY;
+ }
- if (UserInfo->FullName.Length > 0)
+ if (UserInfo4->usri4_comment != NULL)
{
- UserInfo20->usri20_full_name = Ptr;
+ RtlInitUnicodeString(&UserAllInfo.AdminComment,
+ UserInfo4->usri4_comment);
+ UserAllInfo.WhichFields |= USER_ALL_ADMINCOMMENT;
+ }
- memcpy(UserInfo20->usri20_full_name,
- UserInfo->FullName.Buffer,
- UserInfo->FullName.Length);
- UserInfo20->usri20_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ UserAllInfo.UserAccountControl = GetAccountControl(UserInfo4->usri4_flags);
+ UserAllInfo.WhichFields |= USER_ALL_USERACCOUNTCONTROL;
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ if (UserInfo4->usri4_script_path != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ScriptPath,
+ UserInfo4->usri4_script_path);
+ UserAllInfo.WhichFields |= USER_ALL_SCRIPTPATH;
}
- if (UserInfo->AdminComment.Length > 0)
+// UserInfo4->usri4_auth_flags;
+
+ if (UserInfo4->usri4_full_name != NULL)
{
- UserInfo20->usri20_comment = Ptr;
+ RtlInitUnicodeString(&UserAllInfo.FullName,
+ UserInfo4->usri4_full_name);
+ UserAllInfo.WhichFields |= USER_ALL_FULLNAME;
+ }
- memcpy(UserInfo20->usri20_comment,
- UserInfo->AdminComment.Buffer,
- UserInfo->AdminComment.Length);
- UserInfo20->usri20_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ if (UserInfo4->usri4_usr_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.UserComment,
+ UserInfo4->usri4_usr_comment);
+ UserAllInfo.WhichFields |= USER_ALL_USERCOMMENT;
+ }
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
+ if (UserInfo4->usri4_parms != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.Parameters,
+ UserInfo4->usri4_parms);
+ UserAllInfo.WhichFields |= USER_ALL_PARAMETERS;
}
- UserInfo20->usri20_flags = GetAccountFlags(UserInfo->UserAccountControl);
+ if (UserInfo4->usri4_workstations != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.WorkStations,
+ UserInfo4->usri4_workstations);
+ UserAllInfo.WhichFields |= USER_ALL_WORKSTATIONS;
+ }
- UserInfo20->usri20_user_id = RelativeId;
- break;
+ // usri4_last_logon ignored
+ // usri4_last_logoff ignored
- case 23:
- UserInfo23 = (PUSER_INFO_23)LocalBuffer;
+ if (UserInfo4->usri4_acct_expires == TIMEQ_FOREVER)
+ {
+ UserAllInfo.AccountExpires.LowPart = 0;
+ UserAllInfo.AccountExpires.HighPart = 0;
+ }
+ else
+ {
+ RtlSecondsSince1970ToTime(UserInfo4->usri4_acct_expires,
+ &UserAllInfo.AccountExpires);
+ }
+ UserAllInfo.WhichFields |= USER_ALL_ACCOUNTEXPIRES;
- Ptr = (LPWSTR)((ULONG_PTR)UserInfo23 + sizeof(USER_INFO_23));
+ // usri4_max_storage ignored
- UserInfo23->usri23_name = Ptr;
+// UserInfo3->usri4_units_per_week;
+// UserInfo3->usri4_logon_hours;
- memcpy(UserInfo23->usri23_name,
- UserInfo->UserName.Buffer,
- UserInfo->UserName.Length);
- UserInfo23->usri23_name[UserInfo->UserName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ // usri4_bad_pw_count ignored
+ // usri4_num_logons ignored
+ // usri4_logon_server ignored
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->UserName.Length + sizeof(WCHAR));
+ UserAllInfo.CountryCode = UserInfo4->usri4_country_code;
+ UserAllInfo.WhichFields |= USER_ALL_COUNTRYCODE;
- if (UserInfo->FullName.Length > 0)
- {
- UserInfo23->usri23_full_name = Ptr;
+ UserAllInfo.CodePage = UserInfo4->usri4_code_page;
+ UserAllInfo.WhichFields |= USER_ALL_CODEPAGE;
- memcpy(UserInfo23->usri23_full_name,
- UserInfo->FullName.Buffer,
- UserInfo->FullName.Length);
- UserInfo23->usri23_full_name[UserInfo->FullName.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ // usri4_user_sid ignored
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->FullName.Length + sizeof(WCHAR));
+ UserAllInfo.PrimaryGroupId = UserInfo4->usri4_primary_group_id;
+ UserAllInfo.WhichFields |= USER_ALL_PRIMARYGROUPID;
+
+ if (UserInfo4->usri4_profile != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ProfilePath,
+ UserInfo4->usri4_profile);
+ UserAllInfo.WhichFields |= USER_ALL_PROFILEPATH;
}
- if (UserInfo->AdminComment.Length > 0)
+ if (UserInfo4->usri4_home_dir_drive != NULL)
{
- UserInfo23->usri23_comment = Ptr;
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectoryDrive,
+ UserInfo4->usri4_home_dir_drive);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORYDRIVE;
+ }
- memcpy(UserInfo23->usri23_comment,
- UserInfo->AdminComment.Buffer,
- UserInfo->AdminComment.Length);
- UserInfo23->usri23_comment[UserInfo->AdminComment.Length / sizeof(WCHAR)] = UNICODE_NULL;
+ UserAllInfo.PasswordExpired = (UserInfo4->usri4_password_expired != 0);
+ UserAllInfo.WhichFields |= USER_ALL_PASSWORDEXPIRED;
+ break;
- Ptr = (LPWSTR)((ULONG_PTR)Ptr + UserInfo->AdminComment.Length + sizeof(WCHAR));
- }
+// case 21:
+// case 22:
- UserInfo23->usri23_flags = GetAccountFlags(UserInfo->UserAccountControl);
+ case 1003:
+ UserInfo1003 = (PUSER_INFO_1003)UserInfo;
- /* FIXME: usri23_user_sid */
- break;
- }
+ if (UserInfo1003->usri1003_password != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.NtPassword,
+ UserInfo1003->usri1003_password);
+ UserAllInfo.NtPasswordPresent = TRUE;
+ UserAllInfo.WhichFields |= USER_ALL_NTPASSWORDPRESENT;
+ }
+ break;
-done:
- if (ApiStatus == NERR_Success)
- {
- *Buffer = LocalBuffer;
- }
- else
- {
- if (LocalBuffer != NULL)
- NetApiBufferFree(LocalBuffer);
- }
+// case 1005:
- return ApiStatus;
-}
+ case 1006:
+ UserInfo1006 = (PUSER_INFO_1006)UserInfo;
+ if (UserInfo1006->usri1006_home_dir != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
+ UserInfo1006->usri1006_home_dir);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORY;
+ }
+ break;
-static
-VOID
-FreeUserInfo(PUSER_ACCOUNT_INFORMATION UserInfo)
-{
- if (UserInfo->UserName.Buffer != NULL)
- SamFreeMemory(UserInfo->UserName.Buffer);
+ case 1007:
+ UserInfo1007 = (PUSER_INFO_1007)UserInfo;
- if (UserInfo->FullName.Buffer != NULL)
- SamFreeMemory(UserInfo->FullName.Buffer);
+ if (UserInfo1007->usri1007_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.AdminComment,
+ UserInfo1007->usri1007_comment);
+ UserAllInfo.WhichFields |= USER_ALL_ADMINCOMMENT;
+ }
+ break;
- if (UserInfo->HomeDirectory.Buffer != NULL)
- SamFreeMemory(UserInfo->HomeDirectory.Buffer);
+ case 1008:
+ UserInfo1008 = (PUSER_INFO_1008)UserInfo;
+ UserAllInfo.UserAccountControl = GetAccountControl(UserInfo1008->usri1008_flags);
+ UserAllInfo.WhichFields |= USER_ALL_USERACCOUNTCONTROL;
+ break;
- if (UserInfo->HomeDirectoryDrive.Buffer != NULL)
- SamFreeMemory(UserInfo->HomeDirectoryDrive.Buffer);
+ case 1009:
+ UserInfo1009 = (PUSER_INFO_1009)UserInfo;
- if (UserInfo->ScriptPath.Buffer != NULL)
- SamFreeMemory(UserInfo->ScriptPath.Buffer);
+ if (UserInfo1009->usri1009_script_path != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ScriptPath,
+ UserInfo1009->usri1009_script_path);
+ UserAllInfo.WhichFields |= USER_ALL_SCRIPTPATH;
+ }
+ break;
- if (UserInfo->ProfilePath.Buffer != NULL)
- SamFreeMemory(UserInfo->ProfilePath.Buffer);
+// case 1010:
- if (UserInfo->AdminComment.Buffer != NULL)
- SamFreeMemory(UserInfo->AdminComment.Buffer);
+ case 1011:
+ UserInfo1011 = (PUSER_INFO_1011)UserInfo;
- if (UserInfo->WorkStations.Buffer != NULL)
- SamFreeMemory(UserInfo->WorkStations.Buffer);
+ if (UserInfo1011->usri1011_full_name != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.FullName,
+ UserInfo1011->usri1011_full_name);
+ UserAllInfo.WhichFields |= USER_ALL_FULLNAME;
+ }
+ break;
- if (UserInfo->LogonHours.LogonHours != NULL)
- SamFreeMemory(UserInfo->LogonHours.LogonHours);
+ case 1012:
+ UserInfo1012 = (PUSER_INFO_1012)UserInfo;
- SamFreeMemory(UserInfo);
-}
+ if (UserInfo1012->usri1012_usr_comment != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.UserComment,
+ UserInfo1012->usri1012_usr_comment);
+ UserAllInfo.WhichFields |= USER_ALL_USERCOMMENT;
+ }
+ break;
+ case 1013:
+ UserInfo1013 = (PUSER_INFO_1013)UserInfo;
-static
-NET_API_STATUS
-SetUserInfo(SAM_HANDLE UserHandle,
- LPBYTE UserInfo,
- DWORD Level)
-{
- USER_ALL_INFORMATION UserAllInfo;
- PUSER_INFO_0 UserInfo0;
- PUSER_INFO_1 UserInfo1;
- PUSER_INFO_3 UserInfo3;
- NET_API_STATUS ApiStatus = NERR_Success;
- NTSTATUS Status = STATUS_SUCCESS;
+ if (UserInfo1013->usri1013_parms != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.Parameters,
+ UserInfo1013->usri1013_parms);
+ UserAllInfo.WhichFields |= USER_ALL_PARAMETERS;
+ }
+ break;
- ZeroMemory(&UserAllInfo, sizeof(USER_ALL_INFORMATION));
+ case 1014:
+ UserInfo1014 = (PUSER_INFO_1014)UserInfo;
- switch (Level)
- {
- case 0:
- UserInfo0 = (PUSER_INFO_0)UserInfo;
+ if (UserInfo1014->usri1014_workstations != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.WorkStations,
+ UserInfo1014->usri1014_workstations);
+ UserAllInfo.WhichFields |= USER_ALL_WORKSTATIONS;
+ }
+ break;
- RtlInitUnicodeString(&UserAllInfo.UserName,
- UserInfo0->usri0_name);
+ case 1017:
+ UserInfo1017 = (PUSER_INFO_1017)UserInfo;
- UserAllInfo.WhichFields = USER_ALL_USERNAME;
+ if (UserInfo1017->usri1017_acct_expires == TIMEQ_FOREVER)
+ {
+ UserAllInfo.AccountExpires.LowPart = 0;
+ UserAllInfo.AccountExpires.HighPart = 0;
+ }
+ else
+ {
+ RtlSecondsSince1970ToTime(UserInfo1017->usri1017_acct_expires,
+ &UserAllInfo.AccountExpires);
+ }
+ UserAllInfo.WhichFields |= USER_ALL_ACCOUNTEXPIRES;
break;
- case 1:
- UserInfo1 = (PUSER_INFO_1)UserInfo;
+ case 1018:
+ UserInfo1018 = (PUSER_INFO_1018)UserInfo;
+
+ if (UserInfo1018->usri1018_max_storage != USER_MAXSTORAGE_UNLIMITED)
+ {
+ // FIXME: Report error
+ return ERROR_INVALID_PARAMETER;
+ }
+ break;
-// RtlInitUnicodeString(&UserAllInfo.UserName,
-// UserInfo1->usri1_name);
+// case 1020:
- RtlInitUnicodeString(&UserAllInfo.AdminComment,
- UserInfo1->usri1_comment);
+ case 1024:
+ UserInfo1024 = (PUSER_INFO_1024)UserInfo;
- RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
- UserInfo1->usri1_home_dir);
+ UserAllInfo.CountryCode = UserInfo1024->usri1024_country_code;
+ UserAllInfo.WhichFields |= USER_ALL_COUNTRYCODE;
+ break;
- RtlInitUnicodeString(&UserAllInfo.ScriptPath,
- UserInfo1->usri1_script_path);
+ case 1025:
+ UserInfo1025 = (PUSER_INFO_1025)UserInfo;
- RtlInitUnicodeString(&UserAllInfo.NtPassword,
- UserInfo1->usri1_password);
- UserAllInfo.NtPasswordPresent = TRUE;
+ UserAllInfo.CodePage = UserInfo1025->usri1025_code_page;
+ UserAllInfo.WhichFields |= USER_ALL_CODEPAGE;
+ break;
-// UserInfo1->usri1_flags
-// UserInfo1->usri1_priv
+ case 1051:
+ UserInfo1051 = (PUSER_INFO_1051)UserInfo;
- UserAllInfo.WhichFields =
- USER_ALL_ADMINCOMMENT |
- USER_ALL_HOMEDIRECTORY |
- USER_ALL_SCRIPTPATH |
- USER_ALL_NTPASSWORDPRESENT
-// USER_ALL_USERACCOUNTCONTROL
- ;
+ UserAllInfo.PrimaryGroupId = UserInfo1051->usri1051_primary_group_id;
+ UserAllInfo.WhichFields |= USER_ALL_PRIMARYGROUPID;
break;
+ case 1052:
+ UserInfo1052 = (PUSER_INFO_1052)UserInfo;
- case 3:
- UserInfo3 = (PUSER_INFO_3)UserInfo;
+ if (UserInfo1052->usri1052_profile != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.ProfilePath,
+ UserInfo1052->usri1052_profile);
+ UserAllInfo.WhichFields |= USER_ALL_PROFILEPATH;
+ }
+ break;
+
+ case 1053:
+ UserInfo1053 = (PUSER_INFO_1053)UserInfo;
-// LPWSTR usri3_name;
-
- RtlInitUnicodeString(&UserAllInfo.NtPassword,
- UserInfo3->usri3_password);
- UserAllInfo.NtPasswordPresent = TRUE;
-
-// DWORD usri3_password_age; // ignored
-// DWORD usri3_priv;
-
- RtlInitUnicodeString(&UserAllInfo.HomeDirectory,
- UserInfo3->usri3_home_dir);
-
- RtlInitUnicodeString(&UserAllInfo.AdminComment,
- UserInfo3->usri3_comment);
-
-// DWORD usri3_flags;
-
- RtlInitUnicodeString(&UserAllInfo.ScriptPath,
- UserInfo3->usri3_script_path);
-
-// DWORD usri3_auth_flags;
-
- RtlInitUnicodeString(&UserAllInfo.FullName,
- UserInfo3->usri3_full_name);
-
-// LPWSTR usri3_usr_comment;
-// LPWSTR usri3_parms;
-// LPWSTR usri3_workstations;
-// DWORD usri3_last_logon;
-// DWORD usri3_last_logoff;
-// DWORD usri3_acct_expires;
-// DWORD usri3_max_storage;
-// DWORD usri3_units_per_week;
-// PBYTE usri3_logon_hours;
-// DWORD usri3_bad_pw_count;
-// DWORD usri3_num_logons;
-// LPWSTR usri3_logon_server;
-// DWORD usri3_country_code;
-// DWORD usri3_code_page;
-// DWORD usri3_user_id; // ignored
-// DWORD usri3_primary_group_id;
-// LPWSTR usri3_profile;
-// LPWSTR usri3_home_dir_drive;
-// DWORD usri3_password_expired;
-
- UserAllInfo.WhichFields =
- USER_ALL_NTPASSWORDPRESENT |
- USER_ALL_HOMEDIRECTORY |
- USER_ALL_ADMINCOMMENT |
- USER_ALL_SCRIPTPATH |
- USER_ALL_FULLNAME
-// USER_ALL_USERACCOUNTCONTROL
- ;
+ if (UserInfo1053->usri1053_home_dir_drive != NULL)
+ {
+ RtlInitUnicodeString(&UserAllInfo.HomeDirectoryDrive,
+ UserInfo1053->usri1053_home_dir_drive);
+ UserAllInfo.WhichFields |= USER_ALL_HOMEDIRECTORYDRIVE;
+ }
break;
default:
LPCWSTR oldpassword,
LPCWSTR newpassword)
{
+ PMSV1_0_CHANGEPASSWORD_REQUEST RequestBuffer = NULL;
+ PMSV1_0_CHANGEPASSWORD_RESPONSE ResponseBuffer = NULL;
+ ULONG RequestBufferSize;
+ ULONG ResponseBufferSize = 0;
+ LPWSTR Ptr;
+ ANSI_STRING PackageName;
+ ULONG AuthenticationPackage = 0;
+ HANDLE LsaHandle = NULL;
+ NET_API_STATUS ApiStatus = NERR_Success;
+ NTSTATUS Status = STATUS_SUCCESS;
+ NTSTATUS ProtocolStatus;
+
TRACE("(%s, %s, ..., ...)\n", debugstr_w(domainname), debugstr_w(username));
- return NERR_Success;
+
+ /* FIXME: handle null domain or user name */
+
+ /* Check the parameters */
+ if ((oldpassword == NULL) ||
+ (newpassword == NULL))
+ return ERROR_INVALID_PARAMETER;
+
+ /* Connect to the LSA server */
+ Status = LsaConnectUntrusted(&LsaHandle);
+ if (!NT_SUCCESS(Status))
+ return NetpNtStatusToApiStatus(Status);
+
+ /* Get the authentication package ID */
+ RtlInitAnsiString(&PackageName,
+ MSV1_0_PACKAGE_NAME);
+
+ Status = LsaLookupAuthenticationPackage(LsaHandle,
+ &PackageName,
+ &AuthenticationPackage);
+ if (!NT_SUCCESS(Status))
+ {
+ ApiStatus = NetpNtStatusToApiStatus(Status);
+ goto done;
+ }
+
+ /* Calculate the request buffer size */
+ RequestBufferSize = sizeof(MSV1_0_CHANGEPASSWORD_REQUEST) +
+ ((wcslen(domainname) + 1) * sizeof(WCHAR)) +
+ ((wcslen(username) + 1) * sizeof(WCHAR)) +
+ ((wcslen(oldpassword) + 1) * sizeof(WCHAR)) +
+ ((wcslen(newpassword) + 1) * sizeof(WCHAR));
+
+ /* Allocate the request buffer */
+ ApiStatus = NetApiBufferAllocate(RequestBufferSize,
+ (PVOID*)&RequestBuffer);
+ if (ApiStatus != NERR_Success)
+ goto done;
+
+ /* Initialize the request buffer */
+ RequestBuffer->MessageType = MsV1_0ChangePassword;
+ RequestBuffer->Impersonating = TRUE;
+
+ Ptr = (LPWSTR)((ULONG_PTR)RequestBuffer + sizeof(MSV1_0_CHANGEPASSWORD_REQUEST));
+
+ /* Pack the domain name */
+ RequestBuffer->DomainName.Length = wcslen(domainname) * sizeof(WCHAR);
+ RequestBuffer->DomainName.MaximumLength = RequestBuffer->DomainName.Length + sizeof(WCHAR);
+ RequestBuffer->DomainName.Buffer = Ptr;
+
+ RtlCopyMemory(RequestBuffer->DomainName.Buffer,
+ domainname,
+ RequestBuffer->DomainName.MaximumLength);
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + RequestBuffer->DomainName.MaximumLength);
+
+ /* Pack the user name */
+ RequestBuffer->AccountName.Length = wcslen(username) * sizeof(WCHAR);
+ RequestBuffer->AccountName.MaximumLength = RequestBuffer->AccountName.Length + sizeof(WCHAR);
+ RequestBuffer->AccountName.Buffer = Ptr;
+
+ RtlCopyMemory(RequestBuffer->AccountName.Buffer,
+ username,
+ RequestBuffer->AccountName.MaximumLength);
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + RequestBuffer->AccountName.MaximumLength);
+
+ /* Pack the old password */
+ RequestBuffer->OldPassword.Length = wcslen(oldpassword) * sizeof(WCHAR);
+ RequestBuffer->OldPassword.MaximumLength = RequestBuffer->OldPassword.Length + sizeof(WCHAR);
+ RequestBuffer->OldPassword.Buffer = Ptr;
+
+ RtlCopyMemory(RequestBuffer->OldPassword.Buffer,
+ oldpassword,
+ RequestBuffer->OldPassword.MaximumLength);
+
+ Ptr = (LPWSTR)((ULONG_PTR)Ptr + RequestBuffer->OldPassword.MaximumLength);
+
+ /* Pack the new password */
+ RequestBuffer->NewPassword.Length = wcslen(newpassword) * sizeof(WCHAR);
+ RequestBuffer->NewPassword.MaximumLength = RequestBuffer->NewPassword.Length + sizeof(WCHAR);
+ RequestBuffer->NewPassword.Buffer = Ptr;
+
+ RtlCopyMemory(RequestBuffer->NewPassword.Buffer,
+ newpassword,
+ RequestBuffer->NewPassword.MaximumLength);
+
+ /* Call the authentication package */
+ Status = LsaCallAuthenticationPackage(LsaHandle,
+ AuthenticationPackage,
+ RequestBuffer,
+ RequestBufferSize,
+ (PVOID*)&ResponseBuffer,
+ &ResponseBufferSize,
+ &ProtocolStatus);
+ if (!NT_SUCCESS(Status))
+ {
+ ApiStatus = NetpNtStatusToApiStatus(Status);
+ goto done;
+ }
+
+ if (!NT_SUCCESS(ProtocolStatus))
+ {
+ ApiStatus = NetpNtStatusToApiStatus(ProtocolStatus);
+ goto done;
+ }
+
+done:
+ if (RequestBuffer != NULL)
+ NetApiBufferFree(RequestBuffer);
+
+ if (ResponseBuffer != NULL)
+ LsaFreeReturnBuffer(ResponseBuffer);
+
+ if (LsaHandle != NULL)
+ NtClose(LsaHandle);
+
+ return ApiStatus;
}
LPVOID Buffer = NULL;
ULONG i;
SAM_HANDLE UserHandle = NULL;
- PUSER_ACCOUNT_INFORMATION UserInfo = NULL;
+ PUSER_ALL_INFORMATION UserInfo = NULL;
NET_API_STATUS ApiStatus = NERR_Success;
NTSTATUS Status = STATUS_SUCCESS;
}
Status = SamQueryInformationUser(UserHandle,
- UserAccountInformation,
+ UserAllInformation,
(PVOID *)&UserInfo);
if (!NT_SUCCESS(Status))
{
SAM_HANDLE UserHandle = NULL;
PULONG RelativeIds = NULL;
PSID_NAME_USE Use = NULL;
- PUSER_ACCOUNT_INFORMATION UserInfo = NULL;
+ PUSER_ALL_INFORMATION UserInfo = NULL;
LPVOID Buffer = NULL;
NET_API_STATUS ApiStatus = NERR_Success;
NTSTATUS Status = STATUS_SUCCESS;
}
Status = SamQueryInformationUser(UserHandle,
- UserAccountInformation,
+ UserAllInformation,
(PVOID *)&UserInfo);
if (!NT_SUCCESS(Status))
{
TRACE("(%s %s %lu %p %p)\n",
debugstr_w(servername), debugstr_w(username), level, buf, parm_err);
+ if (parm_err != NULL)
+ *parm_err = PARM_ERROR_NONE;
+
/* Check the info level */
switch (level)
{
case 0:
case 1:
-// case 2:
+ case 2:
case 3:
// case 4:
// case 21:
// case 22:
-// case 1003:
+ case 1003:
// case 1005:
-// case 1006:
-// case 1007:
-// case 1008:
-// case 1009:
+ case 1006:
+ case 1007:
+ case 1008:
+ case 1009:
// case 1010:
-// case 1011:
-// case 1012:
-// case 1014:
+ case 1011:
+ case 1012:
+ case 1013:
+ case 1014:
// case 1017:
+// case 1018:
// case 1020:
-// case 1024:
-// case 1051:
-// case 1052:
-// case 1053:
+ case 1024:
+ case 1025:
+ case 1051:
+ case 1052:
+ case 1053:
break;
default: