Hello,

I’m currently using Minio as an easy database for serving my images. To make things simpler everything is set to public, so that just with the URL, you can access it directly. While it’s working great for my website, by setting everything public you can easily see ALL the images. So my question is : What is the best way to setup my node JS app as a proxy ? Is it going through the full S3 protocol hell mess, or is there any solution ?

PS : I have a lot of images, so setting everything in the node app is not possible

    • Scrubbles@poptalk.scrubbles.tech
      link
      fedilink
      English
      arrow-up
      3
      ·
      4 months ago

      Very cool! Thanks for posting this. Minio was great, but they started tailoring to enterprise clients, and it’s become more and more annoying to keep it running in a homelab. (Security is 100% a great thing, but forcing high levels of security on me when I’m running 2 containers in a compose stack, where the minio container will never have exterior access… eh, I just gave up). So, I’m happy there’s one tailored a bit more towards self hosters

  • rglullis@communick.news
    link
    fedilink
    English
    arrow-up
    8
    ·
    4 months ago

    You know that you can configure minio to only serve images for authenticated requests, right?

    Don’t reinvent the wheel unless you have a very good reason to do so.

  • partizan@lemm.ee
    link
    fedilink
    English
    arrow-up
    3
    ·
    4 months ago

    Why do you use minio for image serving ? There are much better ways to do so. Nextcloud, Immich, Photoprism and others…

  • asperan@programming.dev
    link
    fedilink
    English
    arrow-up
    1
    ·
    4 months ago

    Hi, just a disclaimer as I’ve never used Minio in a serious/professional project, only in home fiddling and school projects, so I may not suggest the optimal way to do things.

    You can create Access Keys (Service Accounts) in Minio for your application, and make the bucket(s) accessible only by this account (private with an access policy, I guess). In your JS app, if I remember correctly, you should be able to specify an access key to use for the connection.

    Access keys are credentials, so be sure to store them (and pass them around) safely.

    I hope this gives you at least a general direction to investigate, happy tinkering!

  • computergeek125@lemmy.world
    link
    fedilink
    English
    arrow-up
    1
    ·
    4 months ago

    I’m not entirely sure what you’re seeking to accomplish here - are you looking to just impose authorization on a subset of the images? Probably those should be in a non-public bucket for starters.

    Looking to only give certain people access to files and also have a nicer UI (a la Google Drive / Photos)? Maybe plain S3 isn’t the play here and a dedicated application is needed for that subset.

    Pre signed URLs may also be a thing useful to what you’re trying to to solve. https://docs.min.io/docs/javascript-client-api-reference.html#presignedGetObject