Как войти в систему «Кто сделал что», не добавляя пользователя в каждом методе?C#

Место общения программистов C#
Ответить
Anonymous
 Как войти в систему «Кто сделал что», не добавляя пользователя в каждом методе?

Сообщение Anonymous »

Я внедряю приложение DDD, где мои организации выделяют домены в целях аудита. Каждое действие, которое происходит в моей плате, должно что -то войти в БД. В примере Bellow я регистрирую, что кто -то обновил имя платы. Это поднимает вопрос: у моего класса доски есть около 10-15 методов, и мне придется передать ID userId в каждом из них только для целей ведения журнала. На мой взгляд, это не кажется очень чистым-есть ли у вас какие-либо альтернативные подходы?public class Board : Entity // Entity has domainEvents stuff
{
public Guid Id { get; private set; }
public string Name { get; private set; }

public Board(string name)
{
Id = Guid.NewGuid();
Name = name;
}

// PROBLEM: I want to emit event but don't have userId
public void UpdateName(string newName)
{
Name = newName;

// Missing: "by user {userId}". How to include userId without adding a parameter?
_domainEvents.Add(new BoardUpdatedEvent(Id, $"Name updated to {newName}"));

}
}

public class BoardUpdatedEvent
{
public Guid BoardId { get; }
public string Action { get; } // user X did something

public BoardUpdatedEvent(Guid boardId, string action)
{
BoardId = boardId;
Action = action;
}
}

public class UpdateBoardCommand
{
public Guid BoardId { get; }
public string NewName { get; }
public Guid UserId { get; }

public UpdateBoardCommand(Guid boardId, string newName, Guid userId)
{
BoardId = boardId;
NewName = newName;
UserId = userId;
}
}

// Mediatr simplified stuff
public class UpdateBoardHandler
{
public void Handle(UpdateBoardCommand command)
{
var board = GetBoard(command.BoardId);

board.UpdateName(command.NewName);

foreach (var evt in board.DomainEvents)
{
if (evt is BoardUpdatedEvent boardEvent)
{
Console.WriteLine($"Event: {boardEvent.Action}");
// Currently logs: "Name updated to NewName"
// Want to log: "User X updated name to NewName"
}
}

board.ClearEvents();
}
}


Подробнее здесь: https://stackoverflow.com/questions/797 ... ery-method
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»