Getting API security right - Philippe De Ryck - NDC London 2023

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

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

  • @EldonElledge
    @EldonElledge ปีที่แล้ว +11

    Excellent work here. Thank you. I am glad to see the focus on "Security First" instead of "Security as Technical Debt".

  • @kbrnsr
    @kbrnsr 3 หลายเดือนก่อน +3

    00:00 Getting API security right - Philippe De Ryck - NDC London 2023
    00:33 Knight Ink study, e-health apps
    01:49 - Start taking security seriously
    02:40 Self-introduction
    04:24 - OWASP API Security Top 10
    05:19 Bumble
    06:30 Twitter
    06:51 - The client is irrelevant for security
    09:10 Grindr
    10:46 - OWASP API Security Top 10, broken object property level authorization, excessive data exposure
    16:47 - Test your APIs in their natural habitat
    18:21 - API contracts
    20:29 - Use Swagger/OpenAPI definitions for security
    23:11 T-mobile, IDOR, insecure direct object references
    25:08 REST API without authentication
    27:31 - Enforce authorization at the function level
    29:42 - Empower auditability
    30:25 Object-level access control is often challenging to implement
    34:06 - Centralize complex authorization logic
    37:25 - Traditional web sessions are still valid
    40:48 - Analyze your security requirements
    42:32 - Follow JWT best current practices
    42:51 What happens when things goes wrong?
    43:27 - Compartmentalize your APIs
    47:15 - Perimeter security requires a secure perimeter

  • @JulianneCohen
    @JulianneCohen ปีที่แล้ว +7

    Very good! As a junior developer I had not thought these things through so thankyou!

  • @capability-snob
    @capability-snob ปีที่แล้ว +1

    Solid talk, great points. I really love the focus on Broken Object Level Authorisation, which is absolutely everywhere.
    Even though I build Object Capability systems, which take care of many of these problems by construction, that point about WAFs is relevant to me, as DoS becomes a genuine risk when you have everything else covered.

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

    I'm pretty proud to have come to the conclusion that OpenAPI is a useful tool for enforcing security between starting to play this and him suggesting exactly that.

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

    Great talk!

  • @wildpett
    @wildpett 11 หลายเดือนก่อน

    Excellent talk. Auditability means you should be able to read the code easily

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

    I wonder how many are using aspect-orientation for the centralization.

  • @sidekick3rida
    @sidekick3rida 10 หลายเดือนก่อน

    I was reluctant to watch this because security is boring. So glad I did.

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

    I see many "Senior" developers who fail to understand these basic concepts even after hours of discussion.

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

    👏👏👏👏👏

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

    I spent about 4 hours a week telling people people why windows integrated security requests won’t work with my azure Apim that’s secured by azure ad app reg.

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

    Surprised there is a 403 for something you are not authorized for.
    I'd argue a 403 is only for something someone can know is there (so maybe a bad idea for other user records).
    404 (deny it exists) is my strong preference if someone does not have access to an object.

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

      There are transformations for that, but what happens if you have a valid user but they try update an object on which they only have read access? Should we 404 then?

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

      First solution that comes to mind is to have the authorization policy return the error code to use; i.e. (C#) if (!AuthorizationPolicy.canDeleteTask(task, user, out status)) {return status}; else {/*...*/}. Very simple solution, and can do more complex handling like a 404 when the endpoint is hidden and a 403 when the operation is incorrect.

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

      ​@@AlgoristHQHe did say "403 is only for something someone can know is there," so if they have read access but not write access, they know it's there, therefore 403 if they attempt to write it.

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

      Little is more annoying than getting a 404 because your session expired or is insufficient. Just send a 403 for the whole tree beyond /my-secure-path/ whether the item itself exists or not.
      Imagine an entrance where you have to present your batch card first. It's ok to know that access is restricted and way more obvious than a guard telling you that Mr Anderson doesn't work here until you present the proper token.
      Also feels like abuse of the status codes and security by obscurity.

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

      It SHOULD NOT be problem, if it is, you are doing "security through obscurity" for lack of a better term

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

    API world !

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

    34:33

  • @haroldpepete
    @haroldpepete ปีที่แล้ว +6

    it's not practical at all, too much talk and less code, 90% of this conference was talk with no sense, too much

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

      Free courses on his site, how is that not practical

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

      @@goldnutter412 too much talk, show me the code better

    • @KD2139-b
      @KD2139-b ปีที่แล้ว +9

      @@haroldpepete Guess you are working for T-Mobile?

    • @EldonElledge
      @EldonElledge ปีที่แล้ว +9

      @@haroldpepete, a general confrence with the information needed for you to learn the topics. Now you have what you need to go do the research and implement this is whatever code language you use.

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

      This is what they are, about taking the anarchist to some sort of path to best practice.

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

    Too much talk and self advertising 3/3