Nest.js | Middleware, Pipes & Interceptors Explained By Example

Sdílet
Vložit
  • čas přidán 9. 07. 2024
  • Learn how to build great Nest.js applications by understanding the differences between Middleware, Pipes, Interceptors, Guards & Exception Filters.
    Github: github.com/mguay22/nestjs-req...
    Diagram by Demisx: stackoverflow.com/questions/5...
    Timestamps:
    00:00:00 Introduction
    00:00:30 Diagram
    00:04:50 Project Setup
    00:05:45 Middleware
    00:13:30 Guards
    00:16:56 Interceptors
    00:25:00 Pipes
    00:28:53 Filters
    Get my highly-rated Udemy courses at a discount here: michaelguay.dev/udemy/
  • Věda a technologie

Komentáře • 72

  • @mguay
    @mguay  Před 5 měsíci

    Get my highly-rated Udemy courses at a discount here: michaelguay.dev/udemy/

    • @ElyesBoudhina
      @ElyesBoudhina Před 3 měsíci

      Hey Michael, I followed your tutorial on nest js microservice using RabbitMQ, but I did not find if you used service registry. My idea is to have an auth microservice and an Api gateway app listing on 3200 that essentially work as a proxy forwarding request to auth. I looked online, most of them were too complexes. Can you help?

  • @SHIVAMPANDEYSJTG
    @SHIVAMPANDEYSJTG Před rokem +11

    One of the best explanations I have seen. In just 30 minutes every things is explained in such a depth.

  • @williamx0
    @williamx0 Před 2 lety +33

    Wow this was amazing! Thanks so much for teaching us all of this again! As always lots of knowledge gained from watching your videos. Many thanks! What I learned is that the path a request goes through in order is...
    1) Middleware - For things like authenticating a user
    2) Guards - To check a user is authenticated before getting to the controller (manager of the task) among other use cases
    3) Interceptor (before) - Can be used to log the method, url, userAgent, ip, controller name (ie., AppController), controller handler/method name (ie., getHello). Can also be used to transform incoming data
    4) Pipes - Can be used to freeze parameters in the request so it isn't mistakenly changed in the code. Also validate input data, transform input data, etc. Typical usage is validating request parameters with built in NestJS pipes like ParseIntPipe, ParseArrayPipe, ParseUUIDPipe
    5) Route handler - The "manager" that tells the provider (ie., service/worker/task implementer) what to do
    6) Interceptor (after) - Can get the response and status code after handled by the control handler (ie., the method/function inside the manager). Useful for logging. Can be accessed via next.handle().pipe(tap(res=>{}))
    7) Exception filters - To log errors internally or change the error response into user friendly wording for better UI
    Then it becomes a beautiful response
    Wooh! Just wrote the above to summarize what I learned - all info from going through this video. Thanks again and looking forward to your future videos! And ofc I gave your video a like as it's very helpful.

    • @mguay
      @mguay  Před 2 lety +4

      Thank you! And that is a great textual summary.

  • @phn9669
    @phn9669 Před 8 měsíci

    I've been using NestJs for 2 years and wirh this video I have witnessed the power of scoped dependency injection. Thank you!

  • @TusharParekhtpar2014
    @TusharParekhtpar2014 Před rokem

    Awesome Explanations and fluent demonstrations on Request-Response Pipeline for Nest JS . I really appreciate your efforts and thank you very much for such deep insights !!

  • @miguelacosta707
    @miguelacosta707 Před 2 lety +1

    This is a great video, I wanna say thank you for explaining these concepts in an easy way

  • @TheSiddhaartha
    @TheSiddhaartha Před 2 lety +3

    This is a useful example to quickly understand the concepts of NestJs. I had forgotten all of it as I didn't use it for few months. Now trying to quickly revise the concepts and also understand other things which I had not used before. Your videos have been very helpful!

  • @user-ym9fp2je8u
    @user-ym9fp2je8u Před 2 lety

    All of this stuf were explained simple and clear... Thank you!

  • @mauriciomatias6261
    @mauriciomatias6261 Před rokem

    Thank you!! what a nice and clean way to explain how nest works

  • @Nageswararao93
    @Nageswararao93 Před rokem

    One of the best explanations I have seen. Thank you so much for the great video Michael.

  • @johnmark-ps8jy
    @johnmark-ps8jy Před 2 lety

    Concept simply explained. You deserve more subscriptions. Thank you very much!

  • @10x-dev
    @10x-dev Před 2 lety

    Awesome please keep posting videos like these!

  • @xavierhaas2560
    @xavierhaas2560 Před rokem

    Very nice tuto. Good exemples, it helps !

  • @marudhuraj6709
    @marudhuraj6709 Před 2 lety

    Super explanation about the framework flow architecture, Really a great job.

  • @meshakbain1094
    @meshakbain1094 Před 7 měsíci

    This is amazing! Thanks Michael

  • @supermanor
    @supermanor Před 2 lety

    thanks so much for this video it helped me alot understanding the response request path and how to implement it correctly

  • @innocentmazando3808
    @innocentmazando3808 Před 11 měsíci

    I just got some lessons on good architecture here :)
    The request service and freezing requests, am definitely applying that onto my current toy project and beyond.
    Thanks a lot Michael

  • @kirakira160
    @kirakira160 Před 2 lety

    Thank you Michael !!! You are The best🤩🤩

  • @warpmonkey
    @warpmonkey Před 2 lety +3

    Great video, you deserve many more subscribers, keep up the great work.
    I love it that you take the time to keep going through the different ways that features can be hooked into the code base, it's that type of repetition that helps teach the pattern rather than summarise the options.

    • @mguay
      @mguay  Před 2 lety +1

      Thank you very much!

  • @ronaldmarrou5127
    @ronaldmarrou5127 Před rokem

    Thanks a lot for the video!

  • @saeedakhshijan8159
    @saeedakhshijan8159 Před rokem

    wow, OMG, sec by sec was useful for me. thank you.

  • @barkaouimohamed
    @barkaouimohamed Před 2 lety

    Thank you for the video !

  • @budget002
    @budget002 Před rokem

    Thanks a lot!
    Everything worked fine !

  • @alihamoud6863
    @alihamoud6863 Před rokem

    Thank you so match,All love.❤

  • @foxfrito
    @foxfrito Před rokem

    Very nice! Thx! 👍

  • @shwackthenoobsac
    @shwackthenoobsac Před 2 lety

    Wow awesome video. Thank you.

  • @atakandurkal2400
    @atakandurkal2400 Před měsícem

    Very well! explained clearly now I can move on :))

  • @mohammadalathamena
    @mohammadalathamena Před 2 lety

    this is awesome , i hope you will post video like this in future

  • @nurullah733
    @nurullah733 Před rokem

    Great work thanks

  • @cameronosborne7405
    @cameronosborne7405 Před 7 měsíci

    Nice walk through

  • @juststudying1019
    @juststudying1019 Před 3 měsíci

    You are amazing man.

  • @vladimiragaev4360
    @vladimiragaev4360 Před 2 lety

    Very good explanation. I couldn't have done better :)

  • @es7729
    @es7729 Před 20 dny

    AWESOME!!!

  • @anouarzougrar8332
    @anouarzougrar8332 Před 6 měsíci

    my brain melt down when i saw that request provider scoop exists 🤯🤯🤯

  • @samtufail3966
    @samtufail3966 Před rokem

    Thank you ❤

  • @priyankdev.
    @priyankdev. Před měsícem

    thank you this sharing amezing video and keep it to help my codding careet

  • @nikolapanic6194
    @nikolapanic6194 Před 3 měsíci

    A.M.A.Z.I.N.G (truly)!

  • @kisstamas6675
    @kisstamas6675 Před rokem

    This video is very useful. The nestjs framework is huge. It is similar the complexity like Laravel in php language.

  • @harrylinuz6731
    @harrylinuz6731 Před 2 lety

    thank you! and subbed!

  • @idcmardelplata
    @idcmardelplata Před 5 měsíci

    As we say in my country, you left 10 fields... Congratulations, your content is too good :)

  • @dakshgupta2002
    @dakshgupta2002 Před rokem

    Awesome Awesome Awesome Awesome Awesome

  • @GriffinKlett-ig6vt
    @GriffinKlett-ig6vt Před rokem

    Hi @Michael, Does this order change at all if an exception is thrown by something before the route handler?
    Ie, I was getting a 413: RequestPayloadTooLarge, which I think is an error from Express, and my global ExceptionFilter was being triggered but not my interceptor.
    If the error occurs anywhere inside the actual method, then the order happens as I'd expect from this video.
    Thanks

  • @maddyIncubus
    @maddyIncubus Před 7 měsíci

    Great video man! a quick question, slight off topic. Could you please explain the bit where @Catch() is used. Have seen a lot of examples where they always catch http expection. Are there other other types of exception ? Wat all types are allowed ?

  • @builong0905
    @builong0905 Před rokem +1

    hi, this is a beautiful tutorial. Thank you!!!
    But i have a question, why in the interceptor, the next.handle() return an observable? i am expect something like:
    const result = next.handle();
    // do something with result
    return result;
    Thank you!

  • @PheapSophearith
    @PheapSophearith Před rokem

    Greate tutoria please create more video about the full authentication process and authorization with JWT, thank

  • @GajderStudio
    @GajderStudio Před 7 měsíci

    Could you tell me where would it be best to place business logic in nest app? The example of such business logic is checking if resource that is about to be created has a unique name, however the name uniqueness is scoped to some information inside request object (i use passportjs which ends up attaching decoded jwt content in the request object), or e.g. checking if referenced resource exists when updating - then id of the resource is one of the URL params and update data is the body? I cannot find anything in the docs that will fit my needs. Please help

  • @dobryden7196
    @dobryden7196 Před 7 měsíci

    the best

  • @Brometey
    @Brometey Před rokem

    Can u explain please why we need to set scope as request? Cuz thats not so clear in this case

  • @ramakantlondhe4941
    @ramakantlondhe4941 Před rokem

    Sir how can stored the logging information with http response in file?

  • @SaidkamolO
    @SaidkamolO Před 2 lety

    Can you make videos on configuration, caching and task scheduling on nest js? Also websokets are appretiated.

  • @DimmeX1
    @DimmeX1 Před rokem

    Thanks for the great video.
    But I have one clarification: we can still use global interceptors in main.ts
    Example:
    app.useGlobalInterceptors(new LoggingInterceptor(await app.resolve(RequestService)))

  • @sylvain7010
    @sylvain7010 Před rokem

    does a middleware or an interceptor can be used to check if incoming request has some value in header, like accept-version, or token etc (without checking the content of the value) ?

    • @mguay
      @mguay  Před rokem

      Yes! This is a great place to make that check.

  • @sagar7929
    @sagar7929 Před 2 lety +1

    Can you also do tutorial on nestjs prisma using pg db to do cascading delete, soft delete, and many more logical concept or ideas?
    Can you also update or making new series on socket io backend server using nestjs prisma orm as use of pg db?
    Thank you for this tutorial🙏🏽

    • @mguay
      @mguay  Před 2 lety +1

      A Prisma video is in the works.

  • @TheWalrus_45
    @TheWalrus_45 Před 2 lety

    Hi Michael - thanks for the great video!
    Have you tried out v10 of nestjs graphql? Its plug-in based now and supports Mercurius and as of v10.0.6 is supports federated subscriptions which would be cool to see.

    • @mguay
      @mguay  Před 2 lety +1

      Thank you! I played around with it briefly, but I will have to take a closer look into federated subs.

  • @trentcox9239
    @trentcox9239 Před 11 měsíci

    just putting it out there, but was anyone else ready to smash their keyboard at the wildcard route not working for the middleware? i tried every which way bloody regex combination and in the end, an empty string worked. i hate my life. Nest v10.1.0 in an nrwl/nx monorepo for reference....

  • @thomassohet3619
    @thomassohet3619 Před rokem

    Thanks for the explanation. It's quite clear to understand the differences between Middleware, Pipes, and Interceptors 👏.
    There is a catch though. You are injecting "scope Request" like Santa is giving candies 😃.
    But this has huge side effects. For example, in the user service, it means that the app will have a new instance of the service for each request and moreover, a new instance of every class this service is injected into. This will massively slow down the app. And same for the LoggingInterceptor: each request = a new instance of the logging class → memory-intensive.
    How can we overcome that? What would you recommend as an alternative to your current solution?

    • @mguay
      @mguay  Před rokem +1

      Hi thanks - and great question as this is a valid concern.
      I recommend using Node AsyncLocalStorage. You can find other packages wrapping it like this one: www.npmjs.com/package/nestjs-request-context

  • @jafar1607
    @jafar1607 Před 2 lety

    Brother. A quick help pls
    Nestjs and mongoose. Nx monorepo
    I have organisation module, product module and category module.
    - product schema defined in product module.
    - category schema is defined in category module.
    - organisation schema defined in organisation module. But schema has a array of products and category as subcollection to org collection.
    - when I create a product or category, I need to use organisation model in product and category module. So i would need to import organisation module in product and category module
    - since I have product and category as subcollection to organisation schema. I need both product and category imported in organisation too.
    This makes it circular dependent. How to approach this use case. Plz help.

    • @TheWalrus_45
      @TheWalrus_45 Před 2 lety

      Prisma is gonna be the end of Mongoose.

  • @TheDoktorot
    @TheDoktorot Před rokem

    How do you inject the request service in other modules? Does not work for me.

  • @learn_code_101
    @learn_code_101 Před rokem

    Nice explanation but `Guards` are supposed to be used for Authentication and Authorization as long as I know in Nestjs app

  • @youcefmantas4944
    @youcefmantas4944 Před rokem

    my question is simple : WHERE DO U GET ALL THIS KNOWLEDGE LOLLL (btw thank you soo much for the video !!)

  • @mrs013
    @mrs013 Před 2 lety

    I dont get it :'(
    How long you learn nestjs until you can understand that diagram?

    • @mguay
      @mguay  Před rokem

      Try looking up some example use cases online and then try to implement for yourself in a side project.

  • @blainefire4588
    @blainefire4588 Před 3 měsíci

    this guy is so pretty