From 0208a4d196805fd610a511b4ff71af405ca38297 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Herm=C3=A8s=20B=C3=A9lusca-Ma=C3=AFto?= Date: Tue, 26 Jun 2018 22:14:03 +0200 Subject: [PATCH] [LSASRV] Add the SE_GROUP_OWNER attributes to the token owner. --- dll/win32/lsasrv/authpackage.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/dll/win32/lsasrv/authpackage.c b/dll/win32/lsasrv/authpackage.c index 0e9ab0b701d..22e668c6005 100644 --- a/dll/win32/lsasrv/authpackage.c +++ b/dll/win32/lsasrv/authpackage.c @@ -1137,7 +1137,7 @@ LsapSetTokenOwner( IN LSA_TOKEN_INFORMATION_TYPE TokenInformationType) { PLSA_TOKEN_INFORMATION_V1 TokenInfo1; - PSID OwnerSid = NULL; + PSID_AND_ATTRIBUTES OwnerSid = NULL; ULONG i, Length; if (TokenInformationType == LsaTokenInformationV1) @@ -1147,24 +1147,25 @@ LsapSetTokenOwner( if (TokenInfo1->Owner.Owner != NULL) return STATUS_SUCCESS; - OwnerSid = TokenInfo1->User.User.Sid; + OwnerSid = &TokenInfo1->User.User; for (i = 0; i < TokenInfo1->Groups->GroupCount; i++) { if (EqualSid(TokenInfo1->Groups->Groups[i].Sid, LsapAdministratorsSid)) { - OwnerSid = LsapAdministratorsSid; + OwnerSid = &TokenInfo1->Groups->Groups[i]; break; } } - Length = RtlLengthSid(OwnerSid); + Length = RtlLengthSid(OwnerSid->Sid); TokenInfo1->Owner.Owner = DispatchTable.AllocateLsaHeap(Length); if (TokenInfo1->Owner.Owner == NULL) return STATUS_INSUFFICIENT_RESOURCES; RtlCopyMemory(TokenInfo1->Owner.Owner, - OwnerSid, + OwnerSid->Sid, Length); + OwnerSid->Attributes |= SE_GROUP_OWNER; } return STATUS_SUCCESS; -- 2.17.1