featute/ChangeLog #6
@ -9,52 +9,63 @@ namespace Persistence.API.Controllers;
|
||||
[ApiController]
|
||||
[Authorize]
|
||||
[Route("api/[controller]")]
|
||||
public class ChangeLogRotorController : ControllerBase, IChangeLogApi<ProcessMapRotorDto, ChangeLogDto<ProcessMapRotorDto>>
|
||||
public class ChangeLogController<TDto> : ControllerBase, IChangeLogApi<TDto, ChangeLogDto<TDto>>
|
||||
where TDto : class, IChangeLogDto, new()
|
||||
{
|
||||
private IChangeLogRepository<ProcessMapRotorDto, ChangeLogDto<ProcessMapRotorDto>> repository;
|
||||
private IChangeLogRepository<TDto, ChangeLogDto<TDto>> repository;
|
||||
|
||||
public ChangeLogRotorController(IChangeLogRepository<ProcessMapRotorDto, ChangeLogDto<ProcessMapRotorDto>> repository)
|
||||
public ChangeLogController(IChangeLogRepository<TDto, ChangeLogDto<TDto>> repository)
|
||||
{
|
||||
this.repository = repository;
|
||||
}
|
||||
public async Task<ActionResult<int>> Add(ProcessMapRotorDto dto, CancellationToken token)
|
||||
{
|
||||
await repository.InsertRange(0, [dto], token);
|
||||
|
||||
return null;
|
||||
[HttpPost]
|
||||
public async Task<ActionResult<int>> Add(TDto dto, CancellationToken token)
|
||||
|
||||
{
|
||||
var userId = User.GetUserId<Guid>();
|
||||
ng.frolov
commented
idDiscriminator лучше сделать частью route idDiscriminator лучше сделать частью route
|
||||
var result = await repository.InsertRange(userId, [dto], token);
|
||||
|
||||
return Ok(result);
|
||||
}
|
||||
ng.frolov
commented
Тут Да же проблема что и с сообщениями. Id системы, которая нам эти данные отправила, сюда не очень подходит Тут Да же проблема что и с сообщениями. Id системы, которая нам эти данные отправила, сюда не очень подходит
on.nemtina
commented
Решили пока оставить, как есть Решили пока оставить, как есть
|
||||
|
||||
public Task<ActionResult<int>> AddRange(IEnumerable<ProcessMapRotorDto> dtos, CancellationToken token)
|
||||
[HttpPost("range")]
|
||||
public Task<ActionResult<int>> AddRange(IEnumerable<TDto> dtos, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
[HttpDelete]
|
||||
public Task<ActionResult<int>> Delete(int id, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
[HttpDelete("range")]
|
||||
public Task<ActionResult<int>> DeleteRange(IEnumerable<int> ids, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public Task<ActionResult<IEnumerable<ProcessMapRotorDto>>> GetChangeLogCurrent(CancellationToken token)
|
||||
[HttpGet]
|
||||
public Task<ActionResult<IEnumerable<TDto>>> GetChangeLogCurrent(CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
ng.frolov
commented
Если метод repository.MarkAsDeleted вернет 0 (удаляемая запись отсутствует), то методы delete должны возвращать NoContent Если метод repository.MarkAsDeleted вернет 0 (удаляемая запись отсутствует), то методы delete должны возвращать NoContent
|
||||
}
|
||||
|
||||
public Task<ActionResult<IEnumerable<ChangeLogDto<ProcessMapRotorDto>>>> GetChangeLogForDate(DateTimeOffset historyMoment, CancellationToken token)
|
||||
[HttpGet("history")]
|
||||
public Task<ActionResult<IEnumerable<ChangeLogDto<TDto>>>> GetChangeLogForDate(DateTimeOffset historyMoment, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public Task<ActionResult<int>> Update(ProcessMapRotorDto dto, CancellationToken token)
|
||||
[HttpPut]
|
||||
public Task<ActionResult<int>> Update(TDto dto, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public Task<ActionResult<int>> UpdateRange(IEnumerable<ProcessMapRotorDto> dtos, CancellationToken token)
|
||||
[HttpPut("range")]
|
||||
public Task<ActionResult<int>> UpdateRange(IEnumerable<TDto> dtos, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
@ -1,5 +1,6 @@
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
using Persistence.Database.Model;
|
||||
using Persistence.Models;
|
||||
using Persistence.Repositories;
|
||||
using Persistence.Repository.Data;
|
||||
using Persistence.Repository.Repositories;
|
||||
@ -16,6 +17,7 @@ public static class DependencyInjection
|
||||
MapsterSetup();
|
||||
|
||||
services.AddTransient<ITimeSeriesDataRepository<DataSaubDto>, TimeSeriesDataCachedRepository<DataSaub, DataSaubDto>>();
|
||||
services.AddTransient(typeof(IChangeLogRepository<,>), typeof(ChangeLogRepository<,>));
|
||||
|
||||
return services;
|
||||
}
|
||||
|
@ -46,9 +46,21 @@ public class ChangeLogRepository<TDto, TChangeLogDto> : IChangeLogRepository<TDt
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public Task<int> InsertRange(int idUser, IEnumerable<TDto> dtos, CancellationToken token)
|
||||
public Task<int> InsertRange(Guid idUser, IEnumerable<TDto> dtos, CancellationToken token)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
var entity = new ChangeLog() {
|
||||
Value = dtos,
|
||||
Creation = DateTimeOffset.UtcNow,
|
||||
ng.frolov
commented
немного смущает название немного смущает название
|
||||
Id = idUser,
|
||||
IdAuthor = idUser,
|
||||
IdDiscriminator = new Guid(),
|
||||
IdEditor = idUser
|
||||
ng.frolov
commented
Думаю тут будет разумно проверить, что помечаемые записи еще не устарели. И если мы собираемся отредактировать устаревшее, то падаем в исключение. Думаю тут будет разумно проверить, что помечаемые записи еще не устарели. И если мы собираемся отредактировать устаревшее, то падаем в исключение.
|
||||
};
|
||||
entity.Id = idUser;
|
||||
|
||||
db.Set<ChangeLog>().Add(entity);
|
||||
var result = db.SaveChangesAsync(token);
|
||||
return result;
|
||||
}
|
||||
|
||||
public Task<int> MarkAsDeleted(int idUser, IEnumerable<int> ids, CancellationToken token)
|
||||
|
@ -7,7 +7,7 @@ namespace Persistence.API;
|
||||
/// Интерфейс для работы с API журнала изменений
|
||||
/// </summary>
|
||||
public interface IChangeLogApi<TDto, TChangeLogDto>
|
||||
where TDto : class, new()
|
||||
where TDto : class, IChangeLogDto, new()
|
||||
where TChangeLogDto : ChangeLogDto<TDto>
|
||||
{
|
||||
/// <summary>
|
||||
|
@ -5,7 +5,7 @@ namespace Persistence.Models;
|
||||
/// Часть записи описывающая изменение
|
||||
/// </summary>
|
||||
public class ChangeLogDto<T> : IChangeLogDto
|
||||
where T: class
|
||||
where T: class, IChangeLogDto, new()
|
||||
{
|
||||
/// <summary>
|
||||
/// Запись
|
||||
|
@ -17,7 +17,7 @@ public interface IChangeLogRepository<TDto, TChangeLogDto> : ISyncRepository<TDt
|
||||
/// <param name="dtos"></param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task<int> InsertRange(int idUser, IEnumerable<TDto> dtos, CancellationToken token);
|
||||
Task<int> InsertRange(Guid idUser, IEnumerable<TDto> dtos, CancellationToken token);
|
||||
ng.frolov
commented
idUser -> idAuthor, Такое имя позволит не читать комментарий. И совпадает с названием свойства Dto idUser -> idAuthor, Такое имя позволит не читать комментарий. И совпадает с названием свойства Dto
|
||||
|
||||
/// <summary>
|
||||
/// Редактирование записей
|
||||
|
Loading…
Reference in New Issue
Block a user
Не тот хттп код
И дальше тоже есть.