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

160 lines
5.3 KiB
C#
Raw Normal View History

2022-03-15 18:00:53 +00:00
// (c) Copyright Ascensio System SIA 2010-2022
//
// This program is a free software product.
// You can redistribute it and/or modify it under the terms
// of the GNU Affero General Public License (AGPL) version 3 as published by the Free Software
// Foundation. In accordance with Section 7(a) of the GNU AGPL its Section 15 shall be amended
// to the effect that Ascensio System SIA expressly excludes the warranty of non-infringement of
// any third-party rights.
//
// This program is distributed WITHOUT ANY WARRANTY, without even the implied warranty
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For details, see
// the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
//
// You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia, EU, LV-1021.
//
// The interactive user interfaces in modified source and object code versions of the Program must
// display Appropriate Legal Notices, as required under Section 5 of the GNU AGPL version 3.
//
// Pursuant to Section 7(b) of the License you must retain the original Product logo when
// distributing the program. Pursuant to Section 7(e) we decline to grant you any rights under
// trademark law for use of our trademarks.
//
// All the Product's GUI elements, including illustrations and icon sets, as well as technical writing
// content are licensed under the terms of the Creative Commons Attribution-ShareAlike 4.0
// International. See the License terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
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;
2022-03-17 15:07:17 +00:00
private readonly Lazy<UserDbContext> _lazyUserDbContext;
2022-02-15 11:52:43 +00:00
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;
var strategy = UserDbContext.Database.CreateExecutionStrategy();
strategy.Execute(() =>
2019-11-29 13:47:05 +00:00
{
using var tx = UserDbContext.Database.BeginTransaction();
if (!ExistEscapeRecord(r))
{
InsertRecord(r);
}
else
{
// unescape
DeleteRecord(r);
}
tx.Commit();
});
2022-02-15 11:52:43 +00:00
return r;
}
public void RemoveAce(int tenant, AzRecord r)
{
r.Tenant = tenant;
var strategy = UserDbContext.Database.CreateExecutionStrategy();
strategy.Execute(() =>
2022-02-15 11:52:43 +00:00
{
using var tx = UserDbContext.Database.BeginTransaction();
if (ExistEscapeRecord(r))
{
// escape
InsertRecord(r);
}
else
{
DeleteRecord(r);
}
tx.Commit();
});
2022-02-15 11:52:43 +00:00
}
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
}