DocSpace-buildtools/common/ASC.Core.Common/Data/DbAzService.cs

120 lines
3.5 KiB
C#
Raw Normal View History

using AutoMapper.QueryableExtensions;
2022-02-15 11:52:43 +00:00
namespace ASC.Core.Data;
[Scope]
class DbAzService : IAzService
2020-10-19 15:53:15 +00:00
{
2022-02-15 11:52:43 +00:00
private UserDbContext UserDbContext => _lazyUserDbContext.Value;
private Lazy<UserDbContext> _lazyUserDbContext;
private readonly IMapper _mapper;
public DbAzService(DbContextManager<UserDbContext> dbContextManager, IMapper mapper)
2019-11-29 13:47:05 +00:00
{
2022-02-15 11:52:43 +00:00
_lazyUserDbContext = new Lazy<UserDbContext>(() => dbContextManager.Value);
_mapper = mapper;
}
public IEnumerable<AzRecord> GetAces(int tenant, DateTime from)
{
// row with tenant = -1 - common for all tenants, but equal row with tenant != -1 escape common row for the portal
var commonAces =
UserDbContext.Acl
.Where(r => r.Tenant == Tenant.DefaultTenant)
.ProjectTo<AzRecord>(_mapper.ConfigurationProvider)
.ToDictionary(a => string.Concat(a.Tenant.ToString(), a.Subject.ToString(), a.Action.ToString(), a.Object));
var tenantAces =
UserDbContext.Acl
.Where(r => r.Tenant == tenant)
.ProjectTo<AzRecord>(_mapper.ConfigurationProvider)
.ToList();
// remove excaped rows
foreach (var a in tenantAces)
{
var key = string.Concat(a.Tenant.ToString(), a.Subject.ToString(), a.Action.ToString(), a.Object);
if (commonAces.TryGetValue(key, out var common))
2019-08-15 15:08:40 +00:00
{
2022-02-15 11:52:43 +00:00
commonAces.Remove(key);
if (common.AceType == a.AceType)
{
tenantAces.Remove(a);
}
2019-08-15 15:08:40 +00:00
}
2022-02-15 11:52:43 +00:00
}
2022-02-15 11:52:43 +00:00
return commonAces.Values.Concat(tenantAces);
}
public AzRecord SaveAce(int tenant, AzRecord r)
{
r.Tenant = tenant;
using var tx = UserDbContext.Database.BeginTransaction();
if (!ExistEscapeRecord(r))
2019-11-29 13:47:05 +00:00
{
2022-02-15 11:52:43 +00:00
InsertRecord(r);
}
else
2019-11-29 13:47:05 +00:00
{
2022-02-15 11:52:43 +00:00
// unescape
DeleteRecord(r);
}
tx.Commit();
return r;
}
public void RemoveAce(int tenant, AzRecord r)
{
r.Tenant = tenant;
using var tx = UserDbContext.Database.BeginTransaction();
if (ExistEscapeRecord(r))
2019-11-29 13:47:05 +00:00
{
2022-02-15 11:52:43 +00:00
// escape
InsertRecord(r);
}
else
{
DeleteRecord(r);
}
tx.Commit();
}
private bool ExistEscapeRecord(AzRecord r)
{
return UserDbContext.Acl
.Where(a => a.Tenant == Tenant.DefaultTenant)
.Where(a => a.Subject == r.Subject)
.Where(a => a.Action == r.Action)
.Where(a => a.Object == (r.Object ?? string.Empty))
.Where(a => a.AceType == r.AceType)
.Any();
}
private void DeleteRecord(AzRecord r)
{
var record = UserDbContext.Acl
.Where(a => a.Tenant == r.Tenant)
.Where(a => a.Subject == r.Subject)
.Where(a => a.Action == r.Action)
.Where(a => a.Object == (r.Object ?? string.Empty))
.Where(a => a.AceType == r.AceType)
.FirstOrDefault();
if (record != null)
{
UserDbContext.Acl.Remove(record);
UserDbContext.SaveChanges();
}
}
private void InsertRecord(AzRecord r)
{
UserDbContext.AddOrUpdate(r => r.Acl, _mapper.Map<AzRecord, Acl>(r));
UserDbContext.SaveChanges();
}
2019-05-15 14:56:09 +00:00
}