The BEST OAuth Golang Tutorial for Authentication | Sign In With Google

Поделиться
HTML-код
  • Опубликовано: 3 янв 2025

Комментарии •

  • @MelkeyDev
    @MelkeyDev  Год назад +33

    I hope you enjoy this longer tutorial style video!
    Let me know if you enjoy this style of content - been experimenting a lot with different types of videos!
    Please make sure to comment + like - the algo loves it

    • @heliorosa8148
      @heliorosa8148 Год назад +1

      blurs email, leaks email in the console output. lol

    • @jaymartinez311
      @jaymartinez311 Год назад

      I prefer the longer videos. They provide more context and show me how you think as a developer with golang.

    • @amardeepsingh1168
      @amardeepsingh1168 Год назад +1

      Can you please extend this video how auth can utilised for auhtnicating other api ?

    • @jaymartinez311
      @jaymartinez311 Год назад

      @@amardeepsingh1168 I asked for a full series on this actually 😃 @MelkeyDev hey man i see opportunity. 🤷🏾‍♂️ Maybe even a paid course some day. A lot of us are a bit off in putting all these pieces together and sometimes the examples are to complicated, require to clone and work on a project we didn’t create ourselves or minimal with the, oh you can figure it out 😂🫡. Just saying.

    • @BryceChudomelka
      @BryceChudomelka Год назад

      The state parameter passed from login to callback differs, thus is not secure from CRFS.

  • @shintaii84
    @shintaii84 Год назад +53

    “I do not want you to show my email” a few second later the email is printed out in the console.

  • @jaymartinez311
    @jaymartinez311 Год назад +23

    Maybe a whole backend tutorial series to combine it all and we all become golang ninjas 😅

  • @AzzynTeam
    @AzzynTeam 11 месяцев назад +7

    A complete implementation of authentication with cookies, permissions, middleware using this library would be great help. Thanks for share your knolage ^^

    • @MelkeyDev
      @MelkeyDev  11 месяцев назад +1

      I really appreciate this comment

    • @banafish
      @banafish 11 месяцев назад

      i agree, even just authorization on routes would be really great

  • @brotherthegrest
    @brotherthegrest Год назад +7

    The one video i needed for my project

  • @nnamdi6739
    @nnamdi6739 10 месяцев назад +1

    How about performance consederations? if I did not need more than 3 oauth services, using the built in go oauth package may be a better choice, what's your take, but at the end it all make sense what to choose

  • @nanakwesiaikins9026
    @nanakwesiaikins9026 Год назад +2

    I have a golang api only project. How can I use it with a mobile app? Since there is no redirect to the mobile application

  • @OsvaldoPereiraBarzaga
    @OsvaldoPereiraBarzaga 8 дней назад

    I have a question and I would appreciate if you can answer it: After successful authentication how could I validate the tokens of different providers in the authorization middleware. For example I have a protected route and I want to validate the authorization token before giving access to the route

  • @hrqmonteiro
    @hrqmonteiro Год назад +7

    Would be nice to see beyond from that, like storing the User in your "user" table in a database. This way you can handle a signup and signin for the user.
    Couldn't find any example of that online. In other languages is plenty of it, like Node with Prisma and Nextauth for Oauth.

  • @banafish
    @banafish 11 месяцев назад +4

    I think there are too many jumpy cuts. I followed this very closely while looking at the repo and the video leaves out the "beginAuthProviderCallback" function, without which this won't work. But most importantly I don't understand the use of context here and would have liked more details about that. On the upside it made me curious so I looked it up.

    • @MelkeyDev
      @MelkeyDev  10 месяцев назад +1

      Appreciate the feedback banafish

  • @esra_erimez
    @esra_erimez 4 месяца назад +1

    A small creature is sitting under your nose. I know you can't see it so I thought I'd point it out for you. Great video by the way, I've been binge watching your channel.

    • @MelkeyDev
      @MelkeyDev  4 месяца назад +1

      Hahah thank you
      The creature is gone in the newer videos :)

  • @emil_l889
    @emil_l889 Год назад +1

    Let’s goooo Go auth video dropped, putting a suit on one sec!!!

  • @martingallauner
    @martingallauner 8 месяцев назад +1

    Awesome video! Exactly what I was looking for.
    Fun fact: I watch your video on 0.8x speed

  • @meirionlayton6077
    @meirionlayton6077 Год назад +1

    Great video, has helped my out with implementing this exact thing in my project! I think having a way to view the final code for at least the implementation of the goth authorization functions in the backend could be helpful. You mentioned copy and pasting 2 of the 3 functions from goth accross to save video time, but being able to see the end result of that and how it all should fit together could help make it clearer for people. Very helpful video regardless, thanks.

  • @SuperTieX
    @SuperTieX 10 месяцев назад

    Any idea how to manage this from a mobile app using dart or react native instead of the web interface?

  • @joseph0x45
    @joseph0x45 Год назад +2

    noice, I struggled a little bit to implement github oauth in my Golang x Sveltekit app recently. Will probably rewrite it using goth cos it looks so much cleaner than my implementation. That editing tho! 🙌

    • @CuongNguyen-gu9fl
      @CuongNguyen-gu9fl 9 месяцев назад +1

      Yo can I have your repo link?

    • @joseph0x45
      @joseph0x45 9 месяцев назад

      @@CuongNguyen-gu9flhey, sorry but I ultimately ditched the github oauth all together xD not sure if you still want the repo link after hearing that

  • @lcarv20
    @lcarv20 8 месяцев назад

    As you said at the beginning, I have been looking for a video like this, great video!! Ps: How does teej feels about you using vsode?

  • @the_doctor_cat
    @the_doctor_cat Год назад

    I am new to golang and I was searching for some times now, thank you boss

  • @sevafadeev2257
    @sevafadeev2257 2 месяца назад

    Can you please share source code of that example with us?
    I have been trying to implement google oauth for days, but I’m facing cors error from google any ways.
    I appreciate any kind of help

  • @SuperOmercohen
    @SuperOmercohen Год назад +2

    I think you need to first implement the integration with google oauth yourself to understand how things work and only then go to libraries

  • @jorgesa4244
    @jorgesa4244 10 месяцев назад +1

    What console do you use? seems prett6 different from wsl

    • @MelkeyDev
      @MelkeyDev  10 месяцев назад

      Just the standard console from Ubuntu lol

  • @rudy-anconi
    @rudy-anconi 7 месяцев назад +2

    You can call it a complete tutorial when you store the user on the database, setup the cookies and create a profile page.

    • @MelkeyDev
      @MelkeyDev  7 месяцев назад

      I can add it to a future tutorial if you want, I didnt want to overload with so much information into one video.

  • @CuongNguyen-gu9fl
    @CuongNguyen-gu9fl 9 месяцев назад +1

    I can't get redirected URI right for some reason.

    • @MelkeyDev
      @MelkeyDev  9 месяцев назад

      What is the issue?

    • @CuongNguyen-gu9fl
      @CuongNguyen-gu9fl 9 месяцев назад

      @@MelkeyDevI was silly, didn't put the correct redirect URL.
      Thanks for your video, but another video using it with an endpoint would be nice.

  • @anthonygravier2055
    @anthonygravier2055 5 месяцев назад

    Hey Melkey, I am having trouble, where I am encountering a "could not find a matching session for this request". Do you know what my issue could be?

    • @anthonygravier2055
      @anthonygravier2055 5 месяцев назад

      I do want to mention that I am using gorilla mux as my router as well

    • @NNeshz
      @NNeshz 3 месяца назад

      Do you fix it? Can you help me please?

  • @ChristopherRyan-i9p
    @ChristopherRyan-i9p Год назад +3

    Nice one definitely would like to see more of this type of stuff from you, great tutorial

  • @Antonio-yy2ec
    @Antonio-yy2ec 10 месяцев назад

    Pure gold! Thanks for sharing. It was just I needed

  • @artemcodes
    @artemcodes 2 месяца назад

    As usual, amazing work!

    • @MelkeyDev
      @MelkeyDev  2 месяца назад

      Thank you! Cheers!

  • @ashraffayad
    @ashraffayad Год назад

    Thank you very much for this clear and detailed tutorial. It was a big help.

  • @MarkMcKavanagh
    @MarkMcKavanagh 11 месяцев назад +1

    Helpful vid! However wondering what the purpose is of the cookie store? Does this send a cookie back to client?

    • @Rahman-xm7zm
      @Rahman-xm7zm 10 месяцев назад +1

      The cookie is for storing acsess token on the client. To make your app more secure, the access token should not be passed directly to the user. Instead, create a session token that is sent to the user as a cookie. The app will maintain a mapping of the session tokens to access tokens on the server side (most likely a database).

  • @moonlags1605
    @moonlags1605 Год назад +2

    how can frontend know if user is authenticated??

    • @MelkeyDev
      @MelkeyDev  Год назад

      You would need to do something with a session token

    • @BryceChudomelka
      @BryceChudomelka Год назад

      You could also create your own JWT from the user email and user ID for the session. I just used the OAuth for fast sign-up/sign-in.

  • @RubberGopher
    @RubberGopher 5 месяцев назад +1

    You should've used `r.Context()` when you use `r.WithContext` instead of `context.Background()`. If the client closes the connection, you do not want to waste time on the auth flow. Take advantage of the context that comes with the request.

  • @ezrahel
    @ezrahel 4 месяца назад

    Melkey, it's not clear... You keep skipping some process and I end up getting "you must select a provider" on my screen

    • @abhishekshukla7803
      @abhishekshukla7803 3 месяца назад

      I think you need to pass the provider in the route where you call gothic.BeginAuthHandler()
      provider := chi.URLParam(r, "provider")
      r = r.WithContext(context.WithValue(context.Background(), "provider", provider))

  • @BryceChudomelka
    @BryceChudomelka Год назад +1

    Your code does not work. :)
    After the callback, check state from the url query and then check your state, they are different. In other words, not secure to CRFS and thus invalid.

  • @oscarmendez9079
    @oscarmendez9079 Год назад

    Liked and subscribed - thanks for the great content my dude

  • @manee427
    @manee427 7 месяцев назад +1

    Awsome can you provide the repo for your code also ?

    • @MelkeyDev
      @MelkeyDev  7 месяцев назад +1

      I can make a new one!

    • @manee427
      @manee427 7 месяцев назад

      @@MelkeyDev would be a good idea to ake a new more in depth video about it

  • @jaymartinez311
    @jaymartinez311 7 месяцев назад +1

    the maintainer has a medium blog stating he’s not maintaining the package anymore and is looking for someone to take it over. Just so everybody knows

    • @MelkeyDev
      @MelkeyDev  7 месяцев назад

      oh what? do you have a link?

    • @jaymartinez311
      @jaymartinez311 7 месяцев назад

      @@MelkeyDev hold on i’ll get it but you might have to have a medium premium account though.

  • @camilo5821
    @camilo5821 Год назад +1

    hi mate, i really enjoy your content can you do more like this?? , cheers from Chile 🇨🇱

  • @khoirularifin3648
    @khoirularifin3648 7 месяцев назад +1

    How to logout and login with another account?

    • @MelkeyDev
      @MelkeyDev  7 месяцев назад

      You might need to clear cache and try again to get to the Google OAuth home screen

  • @theangelofspace155
    @theangelofspace155 Год назад +10

    Maybe not editing that much. Show the whole setup. Maybe redo this making a vite react app (todo) with go as the backend, chi as api server, postgres for the database (show how to connect to the databased) and auth (can use goauth but instead just printing the user, actually use it and show the worflow with the database). So a full stack tutorial. We will watch even if it is a couple hours. If it goes above an hours break it doen on parts like, "setting the backend" , "setting the frontend", "adding posgres driver", etc.

  • @charleschen4093
    @charleschen4093 Год назад

    Thanks man! love this content

  • @JensUwe-24
    @JensUwe-24 Год назад

    nice stuff really like your channel :)

  • @vaayuo
    @vaayuo Год назад

    Yess omg
    I got fed up with searching for an 3rd party auth example for go lang and started learning jwts and shizz

  • @valentineejk
    @valentineejk Год назад

    can you please do one for apple

  • @Cruzylife
    @Cruzylife 8 месяцев назад

    where the github repo

  • @fatalsg92
    @fatalsg92 10 месяцев назад +1

    More Tutorials please!!!

    • @MelkeyDev
      @MelkeyDev  10 месяцев назад

      Okay - what do you want to see?

    • @fatalsg92
      @fatalsg92 10 месяцев назад

      @@MelkeyDev videos like this one. Go tutorials of things you think are interesting. Cheers!

  • @dikan34
    @dikan34 Год назад

    This is fire! We need more content like this

  • @jfkongphop
    @jfkongphop Год назад +1

    Can you give this github repo

    • @MelkeyDev
      @MelkeyDev  Год назад

      For this project? or go auth?

    • @mirandagonebald
      @mirandagonebald Год назад

      This repository, it would be greatly appretiated@@MelkeyDev

    • @andriiboiadzhi
      @andriiboiadzhi 5 месяцев назад

      @@MelkeyDev For this project. Some parts are missing

  • @iCrimzon
    @iCrimzon Год назад

    Youre like, 1 of 4 Go users in the whole world, should def make a whole Go backend series , oauth, api security, etc, backend stuff we should know

  • @woodmanmade
    @woodmanmade Год назад +2

    no htmx frontend!!?? Melkey, big disappoint

  • @andybright3809
    @andybright3809 Год назад

    Timely for me, and appreciated. Thanks.

  • @jesulobajohn8468
    @jesulobajohn8468 7 месяцев назад

    Goth has no documentation bro

    • @MelkeyDev
      @MelkeyDev  7 месяцев назад

      I looked at it?

  • @kenzo3477
    @kenzo3477 Год назад

    😂 I still prefer to go with rust

  • @iliassglitch
    @iliassglitch 5 месяцев назад +2

    Incomplete useless video.
    1. You define getAuthCallbakcFunction to handle the route "/auth/{provider/callback" which you never use
    2. You never show the actual auth route /auth/{provider} which you route to in your react app's handleLogin function
    3. You just print the user in your getAuthCallbackFunction which you never use

    • @MelkeyDev
      @MelkeyDev  5 месяцев назад

      make a better one then

    • @Lohan_Guedes
      @Lohan_Guedes 4 месяца назад

      @@MelkeyDev bro you're menace lol Love you

  • @celestinediask
    @celestinediask 8 месяцев назад +31

    very bad tutorial you are skipping important parts of the video like setting up client id and secret key in google console and also you are skipping without even explaining things well. Now I have to watch another video to finish this. So here is my dislike. Sorry for being rude.

    • @sirichan3131
      @sirichan3131 8 месяцев назад +7

      i think same

    • @SirJagerYT
      @SirJagerYT 5 месяцев назад +3

      yup

    • @anthonygravier2055
      @anthonygravier2055 5 месяцев назад

      Love you melkey and your vid’s but I have to agree for once

    • @dotarjun
      @dotarjun 4 месяца назад

      get gud kid

    • @umardev500
      @umardev500 2 месяца назад

      This garbage channel

  • @FrankiDaTank
    @FrankiDaTank Год назад

    common W!

  • @stratavr
    @stratavr 10 месяцев назад

    you don't need to blast your face on my screen every 10 seconds. jesus christ

    • @MelkeyDev
      @MelkeyDev  10 месяцев назад +1

      what the fuck are you talking about

  • @ysomad
    @ysomad Год назад

    Great vid! Just found out for my projects ory kratos - perfect solution, oss, selfhosted identity service with social logins etc. Very easy to setup almost all oauth2/oidc providers to sign in with. Highly recommend!