I am in self hosting for a bit now, have an unraid server and a bunch of services running. Now I want to expose some services through a reverse proxy, but with authentication, preferably google oauth2. I’ve tried a lot of things, Authentik, Authelia, NPM, and so on. I found everything way to complicated. What I liked the most until now is Caddy with the greenpau/caddy-security module. Very easy config through the caddyfile… Though the module has to be manually installed after every update of the caddy docker container, thats kind of a turn of for me, since everything else on my server is almost maintainance-free.

You have any suggestions?

… also this is my first post on lemmy, since I migrated from reddit. ;)

    • momsi@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      2 years ago

      I found that before and it’s really interesting. I didn’t really find it easy to understand, though. Maybe I’ll look into it again. As I understand it, you wouldn’t even need caddy, oauth2-proxy itself can act as reverse proxy, right?

      • smutsmutsmut@lemmy.world
        link
        fedilink
        English
        arrow-up
        1
        ·
        2 years ago

        upstream services > oauth2-proxy > caddy

        Not sure what kind of services you want to run. But I guess you want auto https etc. so probably you want to stick to caddy.

  • DudeWithaTwist@lemmy.world
    link
    fedilink
    English
    arrow-up
    6
    ·
    2 years ago

    I’ve always used Nginx for my reverse proxy and their basic_auth directive for password protection. For a homelab setup, I’m not sure why you’d need anything heavier.

    • momsi@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      arrow-down
      1
      ·
      2 years ago

      Well yeah, basic auth is surely the easiest method … though I rather like to go the oauth2/OIDC route.

      • DudeWithaTwist@lemmy.world
        link
        fedilink
        English
        arrow-up
        4
        ·
        2 years ago

        Just wondering why, because you need some justification to take the harder route. Oath2 is enterprise level, developed by Meta, Google, and others to be top-notch. basic_auth works to dissuade intruders.

        Unless you have a stalker trying to infiltrate your network, I can only imagine this will cause more headaches than it’s worth.

    • das@lemellem.dasonic.xyz
      link
      fedilink
      English
      arrow-up
      4
      ·
      2 years ago

      That seems really cool. Is it much use if you don’t want to run the programs inside cosmos?

      E.g. they’re already running through unraid

      • warmaster@lemmy.world
        link
        fedilink
        English
        arrow-up
        0
        arrow-down
        1
        ·
        2 years ago

        I don’t know honestly, but it uses standard stuff, theoretically speaking you should be able to do it.

        But if you have an already existing setup, I guess nothing will be noob-proof, because you have to manually link the two parts.

    • momsi@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      2
      ·
      2 years ago

      It really does look cool. It can be deployed using Docker. I’ll have a look at it.

  • momsi@lemmy.worldOP
    link
    fedilink
    English
    arrow-up
    2
    ·
    1 year ago

    To follow up on this: I now use a combination of caddy as reverse proxy and authelia for authentication. In my opinion caddy is the best reverse proxy, it’s super lightweight and the caddyfiles are super easy to read. Authelia is surprisingly easy to get setup. I was a bit hesitant because it looked a little overwhelming in the beginning. When you sit down for half a day and dig into it, it’s really surprisingly straightforward.

  • CodaBool@lemmy.world
    link
    fedilink
    English
    arrow-up
    2
    ·
    edit-2
    2 years ago

    You mentioned NPM. Not sure if you mean the UI version since you mention config files. Id recommend it heavy. Very noob friendly and provides certs for you.

    Image: jc21/nginx-proxy-manager

    Docs: https://nginxproxymanager.com/guide/#quick-setup

    I’m not sure how to do auth with this setup so I’m missing that info for you though.