mirror of
https://github.com/bitwarden/server.git
synced 2025-07-04 01:22:50 -05:00
Only return policy in TakeoverResponse if Owner
This commit is contained in:
@ -94,7 +94,7 @@ namespace Bit.Core.Models.Api.Response
|
|||||||
KeyEncrypted = emergencyAccess.KeyEncrypted;
|
KeyEncrypted = emergencyAccess.KeyEncrypted;
|
||||||
Kdf = grantor.Kdf;
|
Kdf = grantor.Kdf;
|
||||||
KdfIterations = grantor.KdfIterations;
|
KdfIterations = grantor.KdfIterations;
|
||||||
Policy = policy.Select<Policy, PolicyResponseModel>(policy => new PolicyResponseModel(policy));
|
Policy = policy?.Select<Policy, PolicyResponseModel>(policy => new PolicyResponseModel(policy));
|
||||||
}
|
}
|
||||||
|
|
||||||
public int KdfIterations { get; private set; }
|
public int KdfIterations { get; private set; }
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Bit.Core.Enums;
|
using Bit.Core.Enums;
|
||||||
using Bit.Core.Exceptions;
|
using Bit.Core.Exceptions;
|
||||||
@ -249,7 +250,10 @@ namespace Bit.Core.Services
|
|||||||
}
|
}
|
||||||
|
|
||||||
var grantor = await _userRepository.GetByIdAsync(emergencyAccess.GrantorId);
|
var grantor = await _userRepository.GetByIdAsync(emergencyAccess.GrantorId);
|
||||||
var policy = await _policyRepository.GetManyByUserIdAsync(grantor.Id);
|
|
||||||
|
var grantorOrganizations = await _organizationUserRepository.GetManyByUserAsync(grantor.Id);
|
||||||
|
var isOrganizationOwner = grantorOrganizations.Any<OrganizationUser>(organization => organization.Type == OrganizationUserType.Owner);
|
||||||
|
var policy = isOrganizationOwner ? await _policyRepository.GetManyByUserIdAsync(grantor.Id) : null;
|
||||||
|
|
||||||
return (emergencyAccess, grantor, policy);
|
return (emergencyAccess, grantor, policy);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user