CQRS & MediatR in a .NET 8 Web API 🚀

แชร์
ฝัง
  • เผยแพร่เมื่อ 25 ธ.ค. 2024

ความคิดเห็น • 31

  • @ChathurangaLiyanagenk
    @ChathurangaLiyanagenk 21 วันที่ผ่านมา +1

    Short and sweet. Thanks a lot.❤

  • @TrinitaRebeccaLasrado
    @TrinitaRebeccaLasrado 15 วันที่ผ่านมา

    You made it so easy to understand, Thank you❤

  • @qubitza
    @qubitza 6 หลายเดือนก่อน +7

    Thanks for the Video and the super explanation ❤
    It might feel super clean in the first place. However, for me the mediator added another layer of abstraction which made it harder to analyze dependencies.
    Moreover, I wondered how to execute multiple commands in a transaction.

  • @-INC0GNIT0-
    @-INC0GNIT0- 6 หลายเดือนก่อน

    Great stuff, I always like your channel because you always show stuff we developers really need and the common streamers always seem to ignore to show like: authorization, mailing, refreshing tokens, ... it's always very knowledgeable engineering concepts

  • @portahack
    @portahack 4 หลายเดือนก่อน

    Amazing video, really good example and very well explained

  • @adam-xt8te
    @adam-xt8te 6 หลายเดือนก่อน +15

    God created The World in 7 days. Patrick explaned CQRS in 22 minutes.

    • @PatrickGod
      @PatrickGod  6 หลายเดือนก่อน

      😂

    • @harishchaudhari9681
      @harishchaudhari9681 4 หลายเดือนก่อน

      True fabulous tutorial on CQRS❤❤❤❤

  • @daWoody01
    @daWoody01 6 หลายเดือนก่อน +5

    Any benefits or issues using MediatR in a Blazor component? I usually inject a service into a Blazor component and use the service to make any queries or commands.

  • @eyoo369
    @eyoo369 5 หลายเดือนก่อน +7

    Everyone saying that Mediatr is useless.
    For our team the biggest advantage is having controllers with literally 1 line of code and a single dependancy injection which is MediatR itself.
    Also having your project structured by Features (commands & queries) makes it so much more easy to navigate as opposed to a God-like 1000+ line service class.
    And the best of all is that testing commands & queries is a lot easier than testing and mocking a service class.
    Everyone can work on a feature and saves us git merge headaches when 2 or more devs are working in the same Service class.

    • @shadmansudipto7287
      @shadmansudipto7287 23 วันที่ผ่านมา +1

      You could do the same without mediatr right? although I guess this enforced the pattern so your coworkers don't go back to putting everything in one file.

    • @eyoo369
      @eyoo369 22 วันที่ผ่านมา

      @@shadmansudipto7287 Absolutely, could've been done without MediatR but having mediatr helps by achieving clean pipeline middleware. It works seamlessly together with FluentValidation and other libraries .

  • @imadabab
    @imadabab 5 หลายเดือนก่อน

    Great video. Thanks a lot. Very clear.

  • @dimasvyrydiuk5955
    @dimasvyrydiuk5955 4 หลายเดือนก่อน

    Thanks, you taught me how to work with the backend. Best)

  • @sergiodaniel6656
    @sergiodaniel6656 2 หลายเดือนก่อน

    TY so much!!!

  • @dasfahrer8187
    @dasfahrer8187 6 หลายเดือนก่อน +7

    Interesting, but it's just another abstraction layer that doesn't buy you much. If you're managing multiple brownfield projects that already have a standard pattern, introducing this only adds time and confusion to technical debt as you're now having to navigate multiple ways of doing things.

    • @PatrickGod
      @PatrickGod  6 หลายเดือนก่อน +1

      Thanks for sharing your thoughts! What approach do you prefer for implementing the same feature without adding an extra abstraction layer?

    • @dasfahrer8187
      @dasfahrer8187 6 หลายเดือนก่อน

      @@PatrickGod Well, for some context, we have dozens of projects with API interfaces in them that hit various services across our own internal network as well as external endpoints. That in and of itself is a lot to manage so we try to keep things as generic as possible w/o having to rely on too many third party NuGet packages that don't bring much to the table for us.
      Because of that, we rolled our own base service implementations and interfaces to fit our security and network requirements. They don't follow a specific design or organizational patterns other than separating concerns and decoupling key areas where we know potentially breaking changes have taken place in the past or are likely to take place.
      We do regularly re-evaluate our architecture and implementations to see if there are any new ideas/tech that may help us manage things more efficiently, but so far we have yet to find anything significant enough to warrant a complete redesign and rebuild. Typically what we'll do is change something like a series of classes over to records and make the corresponding downstream changes to properly utilize them.

  • @nobuffer-indef
    @nobuffer-indef 2 หลายเดือนก่อน +1

    awesome

  • @quanghungnguyen3018
    @quanghungnguyen3018 6 หลายเดือนก่อน

    thanks a lot 😀

  • @axelbryancasauran5159
    @axelbryancasauran5159 2 หลายเดือนก่อน

    Is it possible to create and register a generic mediatr command and handler?

  • @samehgenah8067
    @samehgenah8067 6 หลายเดือนก่อน

    You always different👍

  • @codefoxtrot
    @codefoxtrot 6 หลายเดือนก่อน +6

    It was wayyyy simpler before MediatR and CRQS, but thanks for explaining in a quick demo! Though it leaves me wondering what's the benefit of doing this in a larger project? Seems like it just adds another layer of work.

    • @SireTheKing
      @SireTheKing 4 หลายเดือนก่อน +1

      CQRS is a pattern that allows developers to decouple everything, which makes it easier to update and feature add-ons via interfaces. it also allows for easier testing since you can mock the dependencies. This creates loosely coupled applications, and the trade-off is more complexity.

  • @50LEDBURY
    @50LEDBURY หลายเดือนก่อน +1

    where is the download link?

  • @n.sharma5810
    @n.sharma5810 4 หลายเดือนก่อน

    Hi Patrick, can we implement repository in this example?

    • @martinzaloga3843
      @martinzaloga3843 2 หลายเดือนก่อน

      I think that here the repo is represented by the DBContext class, which is injected to the command and query handlers, which are replacing the service. Is it more clear now? :-D

  • @wordlifejohn1122
    @wordlifejohn1122 4 หลายเดือนก่อน

    You the 🐐

  • @salman.akhtarm
    @salman.akhtarm หลายเดือนก่อน

    Can you make a video on clean architecture using .net8 web api & mediatr

  • @TheLUCKYONETutorials
    @TheLUCKYONETutorials 6 หลายเดือนก่อน +2

    I get the idea. But it seems just like another layer of work and complexity. I dont think that I want to implement this every time I start a new project..

  • @baebcbcae
    @baebcbcae 17 วันที่ผ่านมา

    try more complicated examples please, creating entity A requires automatic creation of entity B, it should be different commands but it must be atomic and it might be concurrent and result must be unique by field but you can't use unique index on DB... how you organise your handlers then ?