How to Roll Your Own Auth

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

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

  • @con-f-use
    @con-f-use 3 หลายเดือนก่อน +655

    I was fully prepared for sarcasm and snark. Instead I got the most useful short intro on web-authentication there is.

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

      We were taught how to roll our own auth at my boot camp just so we could have a deeper understanding on how it works and what can go wrong. Super valuable skill to have!
      to clarify, we did this from scratch, including hashing and salting passwords and using session tokens.

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

      that all of ben's videos

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

      @@snowballeffect7812 that is the basics everyone should know that

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

      @@petleveler8366 you'd be surprised, apparently. maybe they do know that, but it seemed rare for anyone to implement working auth from scratch.

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

      @@petleveler8366 not sure why my response was deleted lol. but I'll try again and say that I don't think most devs have implemented auth from scratch on their own.

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

    I PERSIST MY TOKENS ON MY ARMS USING TATTOOS.

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

    No way hes back

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

      We are so back

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

      hostinger bro :)

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

      guess what, he is

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

    This was quite possibly the best and most concise explanation of how to implement auth I have seen. Thank you!

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

    Literally popped on my suggestion seconds before i was going to search for this!

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

      damn google really has your personal data dead to rights

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

    Great high level tutorial for a very confusing topic! There are so many tutorials out there that make it seem like you have to start out at enterprise level complication, when in reality a setup like this is going to work great for most people.

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

    Very concise explanation of JWT vs Sessions. Interesting to see how your take on the two has developed over the years. I find your videos super helpful when it comes to doing auth without 3rd party
    Lastly, it’s great seeing you Ben. Much peace and success brother

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

    I can't believe you just explained so much about auth I had no idea about in this short video, so well. Thank you.

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

    Ben, you're mi inspiration for becoming a web dev, it's been like 3 years since I started this journey seriously (at 17), now I have a decent job, thanks for existing brother, love your vids, we miss you homie !

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

    Perfect timing for this. I had just decided to try rolling my own auth on my latest side project since its not critical, will be low traffic and I'm tired of auth feeling like such a black box.

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

    I've just watched several videos on this topic whilst deciding on how to proceed and this is by far the best one. I love fireship vids but this extra depth into pros and cons gives Jeff a run for his money. Keep it up! I'd love to see a collab between you two.

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

    Hi Ben this video was pretty useful, kindly keep coming back with these

  • @user-zo2ky4mz7d
    @user-zo2ky4mz7d 3 หลายเดือนก่อน +3

    I was just researching this for a side project. Thanks Ben for reading my mind.

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

    Very nice. I've used this design with two JWT, but never seen it explained anywhere. Cool!

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

    You uploaded this video right when I needed it! You answered so many questions of mine in just 15 mins than I found answers online for last 2 days. Thank you so much. And please make a next video on how you setup username and password auth.

  • @Andres-Estrella
    @Andres-Estrella 3 หลายเดือนก่อน +1

    Thanks!
    Auth is one of those things you have to implement 2 or 3 times to fully understand.

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

    From all of the authentication videos I have seen, you explained everything very well.

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

    Thanks a ton ... nobody explained it better and all in one video.. I will need to dig a bit more in CSRF and XSS bits.. but still crisp and yet adequately detailed. Kudos

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

    that's why we love you Ben, what an amazing video, mad props yo, tight, tight tight tight!

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

    i missed this type of content bro
    pls keep doin it

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

    You don’t need to buy a service for email. It’s a bit annoying but you can setup postfix on a VPS and point MX, SPF, DMARC records.

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

    He's back! Great overview. I've rolled my own auth quite a few times and this is a great guide.
    Recently I've been using a self hosted zitadel instance for the user management and I have a reusable nestjs module for handling all the zitadel oauth stuff and session management etc. Super easy to add additional auth providers or implement 2fa via settings on zitadel without changing anything at all on my backend which is just basic session cookies storing access and refresh tokens for zitadel.

  • @w.e.b_b
    @w.e.b_b 3 หลายเดือนก่อน +8

    I am stoked for this. You’re such an incredible engineer and I owe much of my success as a programmer to your teachings!
    Thank you my friend

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

      What did you learn from him? I see mostly reaction videos

    • @w.e.b_b
      @w.e.b_b 3 หลายเดือนก่อน

      @@monsieurLDN you’ll have to go back to his content from 2018-2019ish when he was making more long form content

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

    Summarized months of learning all of this in a short video, good stuff

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

    Well explained, straight to the point with pros and cons of each method.
    Thank you!

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

    This is so good. Nice one.
    With regards to Cookies vs LocalStorage, I always have my reservations and would usually choose LocalStorage as it'll only keep the user logged in on the Frontend. If it is tempered with, the user is kicked of out the system.
    I realized one thing that even with cookies, when I copied the cookies with their values on a certain browser and put it on a different browser, all I had to do was reload the page and I was logged in.
    Great insight though.

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

    I absolutely love this, was asking for it and he provided thanks Ben

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

    here I have walked literal years wondering why we have refresh tokens. Your explanation is so clear

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

    A wild Ben has appeared!

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

    Had to figure all this out myself a year ago. This video will serve well for anyone else that finds themselves in the same position. Thanks Benji!

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

    Oooohhh crap, our boy Ben Awad is finally back. Welcome back baby, we missed you.

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

    My go-to method is to use JWT with a refresh token and token version, make the access token short-lived, like 15 min, and store it in the memory on the frontend.

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

    PLEASE KEEP THIS GOING, VERY EDUCATIONAL

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

    I always really really liked how you explained everything!!!
    Really enjoyed this quick rundown

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

    Great intro to authentication, Thanks a lot Ben

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

    Hell yeah you're back homie

  • @regularyt-pz4ki
    @regularyt-pz4ki 3 หลายเดือนก่อน +1

    bro just back like he never left

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

    This is insane, best auth video / resource I've seen

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

    very good video, everything was super clear, maybe this is a bit niche or too specific to be useful but a video about how you'd go about rolling your own oauth provider would be very interesting imo

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

    step by step tutorial on doing this, like the old style videos this channel did, would be super cool

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

    Amazing video man!!! It's literally what I've been looking for lately. I would personally love a video talking about the username/password login approach. Greetings!

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

    Best web-dev video I saw this week.

  • @DanTheMan-rr3yg
    @DanTheMan-rr3yg 3 หลายเดือนก่อน +2

    great video, you should do a video on the username + password, but do the whole shebang too! Reset password, forgot username, two factor authentication, magic link too, etc.

  • @i-am-artur
    @i-am-artur 3 หลายเดือนก่อน

    Thanks for the video a lot! I am currently working on a project with JWT, and was about to read on xss

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

    Yep, oath + jwt + cookies be my fav flow right now. I have to use this at work.

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

    great vid super informative benjamin

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

    Love it. Practical and simple. I have build the db setup in php but I like your methods on the jwt way

  • @TechTube-22
    @TechTube-22 3 หลายเดือนก่อน +1

    Auth with cookies makes you're API only callable via browser, so if you want to use them in a mobile app, you have to change maaaany things

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

    Sweet, thanks! For my situation, a tutorial on expo react native app with using secure storage as you mentioned and session storage would be great!

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

    amazing video, please do more. this popped on my suggestions, clicked on it immediately. had to do jwt for a client, i didn't know how to set up the refresh token.

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

    he is back with tutorials!!!

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

    babe wake up ben's new video just dropped

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

    THE KING IS BACK

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

    This section looks great. And going deep into passwords, how to get credentials, why is not ok to send the token in cookies and get it in headers... Can be good.
    And in the future, I see you doing a video like this but " Exploring Coolify", host your own "vercel". It would be awesome to see that.
    Thank you for the information!

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

    the ThioJoe effect has hit Ben

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

    The 2 doors in the back are hitting some weird parts in my brain. Its like they are saying red pill or blue pill

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

    Bro thanks so much for this!! This was very useful and cleared a bunch of stuff for me!! Yes please do the next video if how you set up username/email and password

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

    I would have paid for this video more than I paid my auth provider 3 years ago.

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

    He back! But the room, mic and cuts make it look like he's been kidnapped.

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

    Fantastic, I'm down for a longer video 😄

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

    Ben coding tutorials back lets goo🔥

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

    The true token is the friends we made along the way

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

    welcome back king

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

    Ben Awad making a video? what a surprise

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

    The good old Ben is back

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

    Yoo thanks for the explanation of creating a fully working auth model for my website thanks

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

    Good job! I like the explanation of the log out of all devices. Next let's do authorization 😂

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

    This was a very good explanation thank you!

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

    Welcome back I guess, thanks for the video

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

    ⏱ CHAPTERS ⏱(By TimeSkip AI)
    00:00:00 - Introduction to Authentication Setup
    00:01:30 - Setting Up Your VPS with Hostinger
    00:02:51 - User Account Verification and Security
    00:04:30 - Session Storage vs JWTs Explained
    00:05:36 - Implementing JWTs for Authentication
    00:06:52 - Managing User Sessions and Tokens
    00:09:40 - Best Practices for Token Storage
    00:11:35 - Front-End User Authentication Checks
    00:12:41 - Conclusion and Resources

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

    Hey Ben, will you please make a video about career choices and their difficulties and how to make sure to learn it...

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

    Ben where you been? Good to see you back.

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

    For me refresh token is usually not a JWT since accessing the database is happening there anyway. And that gives you the best of both worlds with revoking as well. Usually stored in redis with EX.
    Also for early MVP services I like to do a Frankenstein approach of letting an access token close to expiry refresh itself (works quite well, but obviously isn't as good as refresh tokens).

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

    Please do an email password auth video, I need it. Most useful video you've dropped in a few years tysm

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

    This is so helpful. Thank you for this video!

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

    Good tech content is back ❤❤

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

    You actually have YT. I just saw you on tiktok 😂 now I'm gonna be your subscriber

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

    I always use keycloak !

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

    Fun fact: saying "JWT" takes longer than just saying "JSON Web Token"

    • @SimonPaul-u7x
      @SimonPaul-u7x 3 หลายเดือนก่อน

      Fun Fact: everyone pronounced these two words now

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

    Where was this video when i had to go and do all this research myself

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

    A simpler way to invalidate tokens would be to create a table/collection for all your tokens. Then, when a user logouts, you search the table/collection for all tokens associated with that user and delete them.

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

      Congrats you have just reinvented regular sessions

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

    I wish this video came out 24 hours earlier

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

    Is lucia analogous to passport.js or is it a higher level of abstraction

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

    Welcome Back

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

    One way to do it without relying on a sass product its to use Lucia Auth... full fine grained control of the flow without magic like others

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

    the first auth I self-rolled was an OIDC IdP server to connect a third party to our existing session-based auth (not SaaS it was just for one particular partner). It was fiddly at first but once you get it, like most things, it doesn't feel so bad and I'd be much more confident doing it again if I had to

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

    One benefit of cookie I think is SSR? JWTs stored in local storage cant be read on SSR since you won't be able to send it in the first document call, while if you use cookies you can fetch user data on the frontend server. Correct me if I am wrong

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

    Throwback to a very similar video you made 4 years ago.

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

    Amazing video bro!

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

    5:30 - in a microservice environment you are most likely going to have a token AND a session cache, especially if you are working on a complex business SaaS (software like Salesforce, AWS, SAP, etc.) with RBAC/ACL/etc. The API Gateway will validate the token and then look up the users permissions in the cache.
    You could store the permissions within the token, yes. BUT that is very complicated. Imagine you have a user and that user has a role with a bunch of permissions. What if the permissions of the role change or the role of the user changes while the user is logged in?

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

    ben is back 🎉🎉

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

    thanks for the video i was just looking up this last night lol

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

    Dev: How do I deal with auth?
    Ben: Yes

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

    Wrong answer. You would use passkeys. Those should become the standard

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

    I can recommend firebase auth its dirt cheap, very fast (although its session based auth), and simple to setup (no need to manage auth via ur database or redis urself)

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

    He's alive great

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

    you can sign the session token as well and store in a cookie

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

    Bro is back 🚀🚀🚀🚀🚀

  • @TestFirstTestLast-m7u
    @TestFirstTestLast-m7u 2 หลายเดือนก่อน

    You can literally send the tokens through server cookies and if they sign out just remove the cookies and token itself from the db

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

    Easy to understand and covers everything :)