Я не скажу за весь ЛОР, но имхо, это может быть как фичей, так и багом.
Ситуация, когда при редактировании добавили или исправили каст — это один случай. Тогда текущее поведение — баг.
Ситуация, когда комментарий редактировали три раза, а каст не трогали — другой. Скастованному при этом придёт три уведомления, это хорошо или плохо? Вот тут может быть как баг, так и фича. Я бы предпочёл получить три каста, но кого-то это может и раздражать…
Я бы завёл отдельную таблицу с кастами, со связью один ко многим, где на каждый пост был бы список кастов. Когда юзер создаёт или редактирует пост, проверяются все касты, связанные с этим постом - и если какого-то каста ещё небыло, то он добавляется в таблицу и пользователю отсылается уведомление, а если уже такой был - то ничего не происходит.
Как не идёт, если идёт? Пользователь при редактировании может добавить новый каст или уже существующий каст, или удалить каст, или добавить вновь каст, который был удалён ранее. Всё это легко разруливается при помощи связанной таблицы кастов.
@metalbeaver ты можешь оригинальные исходники глянуть и сделать патч, либо, я думаю, соиска тебя к исходникам пустит, если ты захочешь в этом копаться.
Я сейчас глянул исходники. А подскажите, разве это не буквально то самое, о чём я говорил?
/* кастовать только тех, кто добавился. Существующие ранее не кастуются */
Включите, блядь, лоркод.
/**
Редактирование комментария.
@param oldComment данные старого комментария
@param newComment данные нового комментария
@param commentBody текст нового комментария
@param remoteAddress IP-адрес, с которого был добавлен комментарий
@param xForwardedFor IP-адрес через шлюз, с которого был добавлен комментарий
*/ @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED)
public void edit(Comment oldComment, Comment newComment, String commentBody, String remoteAddress,
String xForwardedFor, User editor, MessageText originalMessageText) {
commentDao.changeTitle(oldComment, newComment.getTitle());
msgbaseDao.updateMessage(oldComment.getId(), commentBody);
/* кастование пользователей */
Set<User> newUserRefs = textService.mentions(MessageText.apply(commentBody, originalMessageText.markup()));
MessageText messageText = msgbaseDao.getMessageText(oldComment.getId());
Set<User> oldUserRefs = textService.mentions(messageText);
Set<User> userRefs = new HashSet<>();
/* кастовать только тех, кто добавился. Существующие ранее не кастуются */
for (User user :newUserRefs) {
if (!oldUserRefs.contains(user)) {
userRefs.add(user);
}
}
if (permissionService.isUserCastAllowed(editor)) {
userEventService.addUserRefEvent(userRefs, oldComment.getTopicId(), oldComment.getId());
}
/* Обновление времени последнего изменения топика для того, чтобы данные в кеше автоматически обновились */
topicDao.updateLastmod(oldComment.getTopicId(), false);
addEditHistoryItem(editor, oldComment, originalMessageText.text(), newComment, commentBody);
updateLatestEditorInfo(editor, oldComment, newComment);
String logMessage = makeLogString("Изменён комментарий " + oldComment.getId(), remoteAddress, xForwardedFor);
logger.info(logMessage);
}
metalbeaver     ★★★★★★ Последнее исправление: metalbeaver (всего исправлений: 1) Windows / Chrome