полно. Пусть там хранятся карточки и пользователи, типа трелло, пусть карточки принадлежат пользователям, чтобы было проще и понятнее.
Есть слой доступа к данным - express. Там всякая авторизация, роли, ограничения доступа, в общем радости.
Теперь я начал строить систему уведомлений. Например, пользователь что-то там поменял в карточке - надо всем причастным разослать по уведомлению (почта, apns, gcm, внутренний лог).
В уведомлении, грубо говоря, содержится:
* кто поменял
* когда
* что
* как (ну типа дифф-а)
Собственно идея такая, что кто-то там - модель или доступ к данным, генерирует событие, это событие через eventemitter уносится уже в соответствующий контроллер, где из него с помощью небольшого количества магии генерируются нотифай в почту, apns, fcm.
Вопрос. К какому слою - модель или доступ к данным, положить генерацию этих самых сырых ивентов о том, что что-то поменялось?
В чем проблема:
для тестирования сильно удобнее, чтобы модель mongoose эти ивенты генерировала.
но модель не до конца знает кто её вызывает
Я бы делал это на уровне контроллера (ввиду его отсутствия - в слое доступа к данным). Исхожу из логики, что модель - сырые данные. Больше она ничего не должна делать. Т.е. условно говоря, что-то типа (нет контроллера): app.patch((req, res, next) => { // Do something with model model.save().then(() => generateEvent('update', model.id)); // Reply to client or die with an error });
Обсуждают сегодня