Policy-based Authorization in ASP.Net Core (with Custom Authorization Handler)

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

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

  • @justonegoodtrade
    @justonegoodtrade 4 ปีที่แล้ว +1

    my friend, you saved my life with a current project. You're amazing

  • @sawairasana
    @sawairasana ปีที่แล้ว

    can you kindly tell me how to write authorization handler to keep user with same role i.e. user from editing or deleting each others records

  • @yanchenru
    @yanchenru 3 ปีที่แล้ว

    First of all, great video.
    Got a quick question, at 16:58, you replaced the previous policy "AdminAndPowerUser" with the new one "EmployeeWithMoreThan20Years".
    What if I want to keep the previous one as well, so a user who is an Admin but has worked less than 20 years can still have the access?
    Could you please help to explain how to implement that? Thanks very much.

    • @DotNetCoreCentral
      @DotNetCoreCentral  3 ปีที่แล้ว

      @Chenru Yan, I am not 100% sure, I will have to try it out, but the easiest solution I can think of is creating a new policy to cover all the scenarios.

    • @yanchenru
      @yanchenru 3 ปีที่แล้ว

      @@DotNetCoreCentral Thanks for your reply. For the new policy, does that mean a new handler will be created to check if the user belongs to Admin or PowerUser or has worked more than 20 years? That feels like repeating what already have been done in the other two policies. Just curious is possible in the Startup.cs file, do something such as
      options.AddPolicy("Combined", policy => policy.Add("AdminAndPowerUser", "EmployeeWithMoreThan20Years"));
      I am quite new to ASP.NET, please bear with all my naive questions.

    • @DotNetCoreCentral
      @DotNetCoreCentral  3 ปีที่แล้ว

      @@yanchenru This post in stack overflow should help you with your requirement: stackoverflow.com/questions/35609632/asp-net-5-authorize-against-two-or-more-policies-or-combined-policy

    • @yanchenru
      @yanchenru 3 ปีที่แล้ว

      @@DotNetCoreCentral Thank you for the information, it is very helpful.

    • @DotNetCoreCentral
      @DotNetCoreCentral  3 ปีที่แล้ว

      @@yanchenru you are welcome!

  • @OsamaALSHABANi
    @OsamaALSHABANi 4 ปีที่แล้ว

    good vide , but i have question , what if my Roles are created on the running of the Application , it should not be hard coded here specially when you are using RequireRole function

    • @DotNetCoreCentral
      @DotNetCoreCentral  4 ปีที่แล้ว

      @Osama ALSHABANi, thanks for watching!
      For your question, roles are usually decided as part of the requirement gathering process, not so much as a part of runtime code.
      But if you have a scenario where roles are created dynamically, in that case, you cannot use it this way for sure.

  • @xposedcadabiola.o111
    @xposedcadabiola.o111 4 ปีที่แล้ว

    Excellent explanation. Thank you very much.

  • @Yusuf07HD
    @Yusuf07HD 4 ปีที่แล้ว +2

    great works! Keep it up.

  • @nickeax
    @nickeax 3 ปีที่แล้ว

    Excellent lesson, thank you very much.

  • @syneticsolutions344
    @syneticsolutions344 2 ปีที่แล้ว

    Great video, thanks!

  • @sav4384
    @sav4384 3 ปีที่แล้ว

    how can we fetch roles from db and use in handler

    • @DotNetCoreCentral
      @DotNetCoreCentral  3 ปีที่แล้ว

      @saveen gs, it should be just like any other place where you access the database. You do it from the middleware for authentication.

    • @sav4384
      @sav4384 3 ปีที่แล้ว

      @@DotNetCoreCentral thankq

  • @nuwan099
    @nuwan099 9 หลายเดือนก่อน

    Great content! thank you!

  • @ataaact9375
    @ataaact9375 4 ปีที่แล้ว

    great vid. but unrelated question, what 's the name of the extension that you're using to get when the code was committed last and by whom?

    • @KunalMukherjee3701
      @KunalMukherjee3701 3 ปีที่แล้ว

      It comes by default in visual studio pro and enterprise, it's called git blame

    • @ataaact9375
      @ataaact9375 3 ปีที่แล้ว

      @@KunalMukherjee3701 aha that's why I don't have it, I use community. Thanks for the reply!

  • @elioscipioni8908
    @elioscipioni8908 3 ปีที่แล้ว

    thanks for sharing, great video!!

  • @yogeswarank
    @yogeswarank 4 ปีที่แล้ว

    Thank you very much. Can you also make a video on how to change the user claim after the user is logged in. Need a flexibility to refresh the claims of the user without asking him to log out and login again.

    • @DotNetCoreCentral
      @DotNetCoreCentral  4 ปีที่แล้ว

      @yoges waran, thanks for watching the video!
      If I understand your requirement correctly, what you are looking for is the refresh token implementation. I have done a video on the same here: th-cam.com/video/7JP7V59X1sk/w-d-xo.html
      Please take a look and let me know if this serves your purpose.

  • @saurabhchauhan232
    @saurabhchauhan232 4 ปีที่แล้ว

    Suggestion: Video for when to use Transient, Scoped and Singleton would be really helpful. (on you realworld project experience :) )

    • @DotNetCoreCentral
      @DotNetCoreCentral  4 ปีที่แล้ว +1

      @Saurabh Chauhan, thanks for watching, and thanks for the suggestion!

  • @trinhnv1205
    @trinhnv1205 3 ปีที่แล้ว

    very helpful

    • @DotNetCoreCentral
      @DotNetCoreCentral  3 ปีที่แล้ว +1

      @Nguyễn Văn Trình, thanks for watching!

  • @giampaolotucci5897
    @giampaolotucci5897 3 ปีที่แล้ว

    Really tnx

  • @karenj5880
    @karenj5880 4 ปีที่แล้ว

    Thank you!

    • @DotNetCoreCentral
      @DotNetCoreCentral  4 ปีที่แล้ว

      @Karen D, thanks for watching!

    • @karenj5880
      @karenj5880 4 ปีที่แล้ว +1

      @@DotNetCoreCentral It was very straight forward and to the point, answered exactly what I was looking for!

    • @DotNetCoreCentral
      @DotNetCoreCentral  4 ปีที่แล้ว

      @@karenj5880 glad this video could help!

  • @genotypek6133
    @genotypek6133 3 ปีที่แล้ว

    My friend it's authorization not authentication.
    You can authenticate yourself with bearer token, cookie etc. - just to tell who you are.
    You can authorize yourself with policies or roles - check if you're allowed to do something.