I want to have a mirror of my local music collection on my server, and a script that periodically updates the server to, well, mirror my local collection.

But crucially, I want to convert all lossless files to lossy, preferably before uploading them.

That’s the one reason why I can’t just use git - or so I believe.

I also want locally deleted files to be deleted on the server.

Sometimes I even move files around (I believe in directory structure) and again, git deals with this perfectly. If it weren’t for the lossless-to-lossy caveat.

It would be perfect if my script could recognize that just like git does, instead of deleting and reuploading the same file to a different location.

My head is spinning round and round and before I continue messing around with find and scp it’s time to ask the community.

I am writing in bash but if some python module could help with it I’m sure I could find my way around it.

TIA


additional info:

  • Not all files in the local collection are lossless. A variety of formats.
  • The purpose of the remote is for listening/streaming with various applications
  • The lossy version is for both reducing upload and download (streaming) bandwidth. On mobile broadband FLAC tends to buffer a lot.
  • The home of the collection (and its origin) is my local machine.
  • The local machine cannot act as a server
  • Eager Eagle@lemmy.world
    link
    fedilink
    English
    arrow-up
    7
    ·
    edit-2
    5 months ago

    I want to convert all lossless files to lossy, preferably before uploading them

    so it’s not exactly a mirror, right?

    here’s an idea:

    • A - the source containing lossless files
    • B - the local storage of lossy files
    • C - a remote mirror of B

    With that, you can do:

    • A -> B: a systemd service that makes this conversion.
    • B -> C: git or syncthing to mirror and/or version control.

    This uses more storage than you probably intended to (lossy files are also stored locally), but it’s a mirror.

    • A_norny_mousse@feddit.orgOP
      link
      fedilink
      arrow-up
      2
      ·
      5 months ago

      so it’s not exactly a mirror, right?

      Correct!

      Your workflow is actually something I thought of but the duplication of all lossy files would be a bit too much and replacing them with symlinks would not work with git afaik.

    • wintermute@discuss.tchncs.de
      link
      fedilink
      arrow-up
      1
      ·
      5 months ago

      I don’t think git is the right tool for this. It’s designed for text files, not binary. Also, there’s no need for version control here. Git won’t store diffs of binary files, so if a file changes (even the slightest change like an mp3 tag) it will keep a full copy of the old file.
      OP wants to sync, so I would use rsync here. It will be way faster and efficient. If you want to know what rsync did, you can keep a log file of it’s output.