SqlTransaciton (имплементит IDbTransaction) после коммита в свойстве Connection возвращает null, с таким условием (скриншоты 2 и 3).
И поскольку оба, и коннекшн и транзакш, берутся из DI и оба scoped, то на втором коммите кидает исключение. То есть получается 1 коммит на весь скоуп (реквест) (скриншот 4)
Попробовал такой же подход с Постгресом (NpgsqlTransaction) - все работает как и надо
Вопрос: как быть в такой неблагоприятной ситуации😢?
Мне в этом только одно любопытно, а зачем инвалидировать токены при смене пароля? )
что б вынудить остальные устройства залогиниться заново
Потому что это то действие, которое советуют сделать пользователю, если его взломали?
Это я понял, я не понял зачем? )
А если он штатно меняет пароль тоже везде повыбивает? )
Если у тебя украли доступ, ты сменил пароль а злоумышленник будеть дальше иметь доступ к твоему аакаунту
Это и есть штатно. Так вроде везде так работает
Неа, так слава богу мало где работает, но ответ я получил спасибо.
А по поводу вашей ситуации, мне тут вообще не понятно почему у вас два сейва, паттерн единица работы, вроде как подразумевает именно атомарность транзакции... тоесть она одна должна быть на все, в этом и смысл паттерна. Ну как по мне ) ЗЫ: а вовсе не в том что вы сделали просто обертку над двумя репами )
2 сейва для простоты примера. Объект юнит оф ворк может быть повторно вызван в одном скоупе каким нибудь другим методом сервиса из контроллера
Может ты исключение покажешь, раз беда в нем? Мы конечно может отгадать что дело в том что транзакция одноразовая, но все же
Не не, вы не поняли, единица работы инкапсулирует конкретную одну единицу работы, там в принципе не предпологается такого что ее можно там повызывать как то иначе с другими методами. А так толку с нее ноль, можно просто заинжектить нужные репы и вызывать их обертка то зачем да еще в таком виде?
а эта единица работы она на весь контекст запроса? у меня такого кейса еще не было, но предположил что такое может случиться
Написано же, что транзакцию нельзя "переиспользовать", после коммита/роллбека, нужно делать нувую, если тебе опять транзакциия нужна
Если вам не нужно чтобы несколько запросов выполнялись в ОДНОЙ транзакции то единица работы вам не нужна. От слова совсем.
Транзакция - это единица работы в БД
О, еще новых интерпретаций подвезли )
Мне интересно узнать предысторию для класса SqlConnection И флаг IsZomboied чем обусловлен этот нейминг и что показывает
наверное подразумевается уже использованную транзакцию. Там вроде коммент где то был, кажется в методе Zombify()
Обсуждают сегодня