[ADVAPI32]
authorEric Kohl <eric.kohl@reactos.org>
Tue, 31 Dec 2013 09:05:31 +0000 (09:05 +0000)
committerEric Kohl <eric.kohl@reactos.org>
Tue, 31 Dec 2013 09:05:31 +0000 (09:05 +0000)
LogonUserW: Convert the logon type and pass it to LsaLogonUser.

svn path=/trunk/; revision=61467

reactos/dll/win32/advapi32/misc/logon.c

index d1fa333..ff06b42 100644 (file)
@@ -316,20 +316,45 @@ LogonUserW(LPWSTR lpszUsername,
     LUID LogonId = {0, 0};
     HANDLE TokenHandle = NULL;
     QUOTA_LIMITS QuotaLimits;
+    SECURITY_LOGON_TYPE LogonType;
     NTSTATUS SubStatus = STATUS_SUCCESS;
     NTSTATUS Status;
 
     *phToken = NULL;
 
+    switch (dwLogonType)
+    {
+        case LOGON32_LOGON_INTERACTIVE:
+            LogonType = Interactive;
+            break;
+
+        case LOGON32_LOGON_NETWORK:
+            LogonType = Network;
+            break;
+
+        case LOGON32_LOGON_BATCH:
+            LogonType = Batch;
+            break;
+
+        case LOGON32_LOGON_SERVICE:
+            LogonType = Service;
+            break;
+
+       default:
+            ERR("Invalid logon type: %ul\n", dwLogonType);
+            Status = STATUS_INVALID_PARAMETER;
+            goto done;
+    }
+
     if (LsaHandle == NULL)
     {
         Status = OpenLogonLsaHandle();
         if (!NT_SUCCESS(Status))
-            return Status;
+            goto done;
     }
 
     RtlInitAnsiString((PANSI_STRING)&OriginName,
-                      "Testapp");
+                      "Advapi32 Logon");
 
     RtlInitUnicodeString(&DomainName,
                          lpszDomain);
@@ -443,7 +468,7 @@ LogonUserW(LPWSTR lpszUsername,
 
     Status = LsaLogonUser(LsaHandle,
                           &OriginName,
-                          Interactive,
+                          LogonType,
                           AuthenticationPackage,
                           (PVOID)AuthInfo,
                           AuthInfoLength,
@@ -457,7 +482,7 @@ LogonUserW(LPWSTR lpszUsername,
                           &SubStatus);
     if (!NT_SUCCESS(Status))
     {
-        TRACE("LsaLogonUser failed (Status 0x%08lx)\n", Status);
+        ERR("LsaLogonUser failed (Status 0x%08lx)\n", Status);
         goto done;
     }