Xferase is an always-on background service that automatically imports pictures & videos into your personal photo library as they come in.
When combined with other software, it can be used as a kind of self-hosted / DIY alternative to cloud photo services like Google Photos or iCloud.
My photo library has always been a hot mess. I have photos from my cell phone, photos from my digital camera, and photos Iβve gotten from other people. Some live in the cloud, some live on my cell phone, some live on my laptop, some live on a backup drive in my shoe closet, and others will sit on my digital cameraβs SD card for a couple weeks before I remember that I wanted to share them with someone.
I got tired of taking lots of photos and then having to look in three places to find the ones I wanted. I just wanted my old photos to live in the same place as my new photos, plus a few other modest requirements:
-
automatic photo import from any source*
βAutomaticβ means no mouse/keyboard interaction:
- π± cell phone pictures get imported as soon as theyβre taken;
- π¬ chat app downloads, as soon as theyβre saved;
- π· digital camera pictures, as soon as itβs plugged into USB.
-
master copy of library stored locally, on disk
My digital photo/video library belongs to me. But if I donβt own the pipeline for storing and managing it, then does it really? π€
Cloud services can raise their prices, go offline, or fall victim to ransomware attacks. My own Internet can fail, too. Iβm happy to use the cloud for Netflix & Spotify, but for something as personal and unreplaceable as my photos, I want the master copy in my own hands.
-
automatic syncing of library back to phone*
Obviously, I donβt just want to collect my personal photos; I want to use them, and to have them with me wherever I go. But your complete photo collection is probably too large to fit on your cell phone, which is why Google and Apple host it in the cloud.
Xferase gets around this by maintaining two parallel copies of your library: one master, and one optimized for web. Keep both on your computer and sync the latter to your phone; Xferase will make sure that when a photo is deleted from one, itβs automatically removed from the other, too.
-
clean, consistent, user-visible directory & filename scheme
Call me obsessive-compulsive, but which would you rather haveβ
# this? # ...or this? ~/Pictures ~/Pictures βββ 1619593208911.jpeg βββ 2020 βββ DCIM β βββ 2020-08-01_113129.heic β βββ 2021_03_26 β βββ 2020-05-20_160209.png β βββ R0014285.MOV βββ 2021 β βββ R0014286.DNG βββ 2021-02-12_081933a.jpg β βββ R0014286.JPG βββ 2021-02-12_081933b.jpg β βββ R0014287.DNG βββ 2021-02-12_081939.mp4 β βββ R0014287.JPG βββ 2021-03-26_161245.mp4 βββ IMG_20210212_081933_001.jpg βββ 2021-03-26_161518.dng βββ IMG_20210212_081933_002.jpg βββ 2021-03-26_161518.jpg βββ IMG_8953.HEIC βββ 2021-03-26_170304.dng βββ Screenshot_20200520_160209.png βββ 2021-03-26_170304.jpg βββ VID_20210212_081939.mp4 βββ 2021-04-28_000008.jpg
I also want to know where my files are so I can find them in a βBrowse...β dialog or mirror them to other devices with Dropbox, Syncthing, or even rsync.
-
available on Linux
Xferase has not been tested on macOS, but it should work when run in a Docker container.
For points 1 and 3, Xferase needs the help of additional software (Syncthing & systemd). If you have no experience (or interest in) tinkering with Linux, Xferase is not for you.
See the next section for more details.
Xferase watches a directory of your choosing (its βinboxβ), and whenever any files are placed there, it automatically optimizes and imports them into your photo library, like so:
# Before # After
~/Pictures ~/Pictures
βββ .inbox βββ .inbox
β βββ 1619593208911.jpeg βββ library
β βββ DCIM βββ 2020
β β βββ 2021_03_26 β βββ 2020-08-01_113129.heic
β β βββ R0014285.MOV β βββ 2020-05-20_160209.png
β β βββ R0014286.DNG βββ 2021
β β βββ R0014286.JPG βββ 2021-02-12_081933a.jpg
β β βββ R0014287.DNG βββ 2021-02-12_081933b.jpg
β β βββ R0014287.JPG βββ 2021-02-12_081939.mp4
β βββ IMG_20210212_081933_001.jpg βββ 2021-03-26_161245.mp4
β βββ IMG_20210212_081933_002.jpg βββ 2021-03-26_161518.dng
β βββ IMG_8953.HEIC βββ 2021-03-26_161518.jpg
β βββ Screenshot_20200520_160209.png βββ 2021-03-26_170304.dng
β βββ VID_20210212_081939.mp4 βββ 2021-03-26_170304.jpg
βββ library βββ 2021-04-28_000008.jpg
(You may have noticed that this is identical to the snippet from above,
except for the .inbox
and library
parent directories.)
How you get those files from your phone or camera into the inbox is up to you.
Yes, but only with the help of other software. Automatically getting files from other devices onto your computer is not a trivial problem, and there are existing utilities that already do it better than Xferase could.
Consider that different users may have a different technical requirements:
- Should digital camera photos be transferred over USB, or using a Wi-Fi SD card?
- Should cell phone photos be transferred over cellular data, or only over Wi-Fi?
- How many other devices should the library be mirrored/synced to?
Limiting the scope of what Xferase does gives you the flexibility to use the best available tools for your needs, every step of the way.
Here is a diagram outlining the recommended approach:
For more on each step, see the guides below.
π‘ The examples below assume you have Docker installed.
Why use Docker? Xferase can be installed natively as a Ruby gem, but there are lots of external dependencies.
$ docker run -d \
--name xferase \
--user $(id -u):$(id -g) \
--env TZ=$(timedatectl show --property=Timezone --value) \
--volume $HOME/Pictures:/data \
--env INBOX=/data/_inbox \
--env LIBRARY=/data/master \
--env HOME=/tmp \ # hotfix for https://github.com/janfri/mini_exiftool/issues/51
rlue/xferase
Any photos or videos placed in the inbox will be automatically moved to the library, with videos being compressed to save space on disk.
$ docker run -d \
--name xferase \
--user $(id -u):$(id -g) \
--env TZ=$(timedatectl show --property=Timezone --value) \
--volume $HOME/Pictures:/data \
--env INBOX=/data/.inbox \
--env LIBRARY=/data/master \
--env LIBRARY_WEB=/data/web \
--env HOME=/tmp \ # hotfix for https://github.com/janfri/mini_exiftool/issues/51
rlue/xferase
Xferase will create a separate, lo-res copy of each imported file and save it to the web-optimized library.
Xferase keeps both libraries in sync, meaning that when a photo is deleted from one, it will be automatically deleted from the other.
β οΈ Warning
This also applies to copies of the same image in different formats: if you shoot RAW+JPEG, deleting a .jpg will cause Xferase to delete the corresponding raw image file (and vice versa).
With Docker Compose, you can store your deployment parameters in a static configuration file:
# docker-compose.yml
version: '3.4'
services:
xferase:
image: rlue/xferase:latest
container_name: xferase
user: 1000:1000
environment:
TZ: America/Los_Angeles
INBOX: /data/.inbox
LIBRARY: /data/master
LIBRARY_WEB: /data/web
HOME: /tmp # hotfix for https://github.com/janfri/mini_exiftool/issues/51
volumes:
- $HOME/Pictures:/data
restart: unless-stopped
- π·β‘οΈπ₯οΈ Get photos from your camera into Xferaseβs inbox
- π±β‘οΈπ₯οΈ Get photos from your phone into Xferaseβs inbox
Whenever youβre shooting on devices that need their clocks set manually, the timestamps on all your stuff can end up out of whack. For instance:
-
I often forget to adjust the clock on my camera when DST changes, or when I fly across time zones. In these cases, you will want to shift timestamps by some fixed number of hours.
To apply this change automatically during import, simply place your files in a directory named
shift-timestamp:<n>h
(where<n>
is an integer number of hours to shift by; e.g.,4
or-8
). -
Video timestamps should always be in UTC, while photo timestamps should always be in local time. (Donβt ask me for a source on this one; supposedly itβs in the EXIF and MP4/MOV specs, which I donβt have access to, but this fact is repeated all over the place on the Exiftool forums.)
If your camera doesnβt have GPS capabilities or any other way of knowing what time zone itβs in, your video timestamps will not be in UTC. In these cases, you will want to backfill the missing time zone data.
To apply this change automatically during import, simply place your files in a directory named
local-tz:<timezone>
(where<timezone>
is a valid IANA time zone, with colons in place of slashes; e.g.,America:Argentina:Buenos_Aires
orAsia:Calcutta
).Xferase is smart enough to make the right adjustments when you do this: metadata timestamps will be set to UTC, and filename timestamps will be set to local time.
To apply both changes, simply nest the folders within each other. If multiple conflicting directories are found, Xferase will use the one nearest to the file being imported.
Β© 2021 Ryan Lue. This project is licensed under the terms of the MIT License.