2020-12-22 10:30:16 +11:00
|
|
|
using System;
|
2018-03-22 11:24:12 +01:00
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
2020-09-17 09:42:55 +02:00
|
|
|
using Microsoft.Extensions.Logging;
|
2018-03-22 11:24:12 +01:00
|
|
|
using NPoco;
|
2021-10-29 10:14:52 +02:00
|
|
|
using Umbraco.Cms.Core;
|
2021-02-09 10:22:42 +01:00
|
|
|
using Umbraco.Cms.Core.Cache;
|
|
|
|
|
using Umbraco.Cms.Core.Models;
|
|
|
|
|
using Umbraco.Cms.Core.Persistence.Querying;
|
|
|
|
|
using Umbraco.Cms.Core.Persistence.Repositories;
|
2021-02-15 11:41:12 +01:00
|
|
|
using Umbraco.Cms.Core.Scoping;
|
2021-02-12 13:36:50 +01:00
|
|
|
using Umbraco.Cms.Infrastructure.Persistence.Dtos;
|
|
|
|
|
using Umbraco.Cms.Infrastructure.Persistence.Factories;
|
|
|
|
|
using Umbraco.Cms.Infrastructure.Persistence.Querying;
|
2021-02-09 11:26:22 +01:00
|
|
|
using Umbraco.Extensions;
|
2018-03-22 11:24:12 +01:00
|
|
|
|
2021-02-12 13:36:50 +01:00
|
|
|
namespace Umbraco.Cms.Infrastructure.Persistence.Repositories.Implement
|
2018-03-22 11:24:12 +01:00
|
|
|
{
|
|
|
|
|
/// <summary>
|
2021-10-29 10:14:52 +02:00
|
|
|
/// Represents the NPoco implementation of <see cref="IAuditEntryRepository" />.
|
2018-03-22 11:24:12 +01:00
|
|
|
/// </summary>
|
2020-12-22 10:30:16 +11:00
|
|
|
internal class AuditEntryRepository : EntityRepositoryBase<int, IAuditEntry>, IAuditEntryRepository
|
2018-03-22 11:24:12 +01:00
|
|
|
{
|
|
|
|
|
/// <summary>
|
2021-10-29 10:14:52 +02:00
|
|
|
/// Initializes a new instance of the <see cref="AuditEntryRepository" /> class.
|
2018-03-22 11:24:12 +01:00
|
|
|
/// </summary>
|
2020-09-17 09:42:55 +02:00
|
|
|
public AuditEntryRepository(IScopeAccessor scopeAccessor, AppCaches cache, ILogger<AuditEntryRepository> logger)
|
2018-03-22 11:24:12 +01:00
|
|
|
: base(scopeAccessor, cache, logger)
|
2021-10-29 10:14:52 +02:00
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
public IEnumerable<IAuditEntry> GetPage(long pageIndex, int pageCount, out long records)
|
|
|
|
|
{
|
|
|
|
|
Sql<ISqlContext> sql = Sql()
|
|
|
|
|
.Select<AuditEntryDto>()
|
|
|
|
|
.From<AuditEntryDto>()
|
|
|
|
|
.OrderByDescending<AuditEntryDto>(x => x.EventDateUtc);
|
|
|
|
|
|
|
|
|
|
Page<AuditEntryDto> page = Database.Page<AuditEntryDto>(pageIndex + 1, pageCount, sql);
|
|
|
|
|
records = page.TotalItems;
|
|
|
|
|
return page.Items.Select(AuditEntryFactory.BuildEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
public bool IsAvailable()
|
|
|
|
|
{
|
|
|
|
|
var tables = SqlSyntax.GetTablesInSchema(Database).ToArray();
|
|
|
|
|
return tables.InvariantContains(Constants.DatabaseSchema.Tables.AuditEntry);
|
|
|
|
|
}
|
2018-03-22 11:24:12 +01:00
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
protected override IAuditEntry PerformGet(int id)
|
|
|
|
|
{
|
2021-10-29 10:14:52 +02:00
|
|
|
Sql<ISqlContext> sql = Sql()
|
2018-03-22 11:24:12 +01:00
|
|
|
.Select<AuditEntryDto>()
|
|
|
|
|
.From<AuditEntryDto>()
|
|
|
|
|
.Where<AuditEntryDto>(x => x.Id == id);
|
|
|
|
|
|
2021-10-29 10:14:52 +02:00
|
|
|
AuditEntryDto dto = Database.FirstOrDefault<AuditEntryDto>(sql);
|
2018-03-22 11:24:12 +01:00
|
|
|
return dto == null ? null : AuditEntryFactory.BuildEntity(dto);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
protected override IEnumerable<IAuditEntry> PerformGetAll(params int[] ids)
|
|
|
|
|
{
|
|
|
|
|
if (ids.Length == 0)
|
|
|
|
|
{
|
2021-10-29 10:14:52 +02:00
|
|
|
Sql<ISqlContext> sql = Sql()
|
2018-03-22 11:24:12 +01:00
|
|
|
.Select<AuditEntryDto>()
|
|
|
|
|
.From<AuditEntryDto>();
|
|
|
|
|
|
|
|
|
|
return Database.Fetch<AuditEntryDto>(sql).Select(AuditEntryFactory.BuildEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var entries = new List<IAuditEntry>();
|
|
|
|
|
|
2021-10-29 10:14:52 +02:00
|
|
|
foreach (IEnumerable<int> group in ids.InGroupsOf(Constants.Sql.MaxParameterCount))
|
2018-03-22 11:24:12 +01:00
|
|
|
{
|
2021-10-29 10:14:52 +02:00
|
|
|
Sql<ISqlContext> sql = Sql()
|
2018-03-22 11:24:12 +01:00
|
|
|
.Select<AuditEntryDto>()
|
|
|
|
|
.From<AuditEntryDto>()
|
|
|
|
|
.WhereIn<AuditEntryDto>(x => x.Id, group);
|
|
|
|
|
|
|
|
|
|
entries.AddRange(Database.Fetch<AuditEntryDto>(sql).Select(AuditEntryFactory.BuildEntity));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return entries;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
protected override IEnumerable<IAuditEntry> PerformGetByQuery(IQuery<IAuditEntry> query)
|
|
|
|
|
{
|
2021-10-29 10:14:52 +02:00
|
|
|
Sql<ISqlContext> sqlClause = GetBaseQuery(false);
|
2018-03-22 11:24:12 +01:00
|
|
|
var translator = new SqlTranslator<IAuditEntry>(sqlClause, query);
|
2021-10-29 10:14:52 +02:00
|
|
|
Sql<ISqlContext> sql = translator.Translate();
|
2018-03-22 11:24:12 +01:00
|
|
|
return Database.Fetch<AuditEntryDto>(sql).Select(AuditEntryFactory.BuildEntity);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
protected override Sql<ISqlContext> GetBaseQuery(bool isCount)
|
|
|
|
|
{
|
2021-10-29 10:14:52 +02:00
|
|
|
Sql<ISqlContext> sql = Sql();
|
2018-03-22 11:24:12 +01:00
|
|
|
sql = isCount ? sql.SelectCount() : sql.Select<AuditEntryDto>();
|
|
|
|
|
sql = sql.From<AuditEntryDto>();
|
|
|
|
|
return sql;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
2021-10-29 10:14:52 +02:00
|
|
|
protected override string GetBaseWhereClause() => $"{Constants.DatabaseSchema.Tables.AuditEntry}.id = @id";
|
2018-03-22 11:24:12 +01:00
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
2021-10-29 10:14:52 +02:00
|
|
|
protected override IEnumerable<string> GetDeleteClauses() =>
|
2018-03-22 11:24:12 +01:00
|
|
|
throw new NotSupportedException("Audit entries cannot be deleted.");
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
|
|
|
|
protected override void PersistNewItem(IAuditEntry entity)
|
|
|
|
|
{
|
2019-06-28 09:19:11 +02:00
|
|
|
entity.AddingEntity();
|
2018-03-22 11:24:12 +01:00
|
|
|
|
2021-10-29 10:14:52 +02:00
|
|
|
AuditEntryDto dto = AuditEntryFactory.BuildDto(entity);
|
2018-03-22 11:24:12 +01:00
|
|
|
Database.Insert(dto);
|
|
|
|
|
entity.Id = dto.Id;
|
|
|
|
|
entity.ResetDirtyProperties();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <inheritdoc />
|
2021-10-29 10:14:52 +02:00
|
|
|
protected override void PersistUpdatedItem(IAuditEntry entity) =>
|
2018-03-22 11:24:12 +01:00
|
|
|
throw new NotSupportedException("Audit entries cannot be updated.");
|
|
|
|
|
}
|
|
|
|
|
}
|