diff --git a/.markdownlint.yaml b/.markdownlint.yaml index b10aa8c..98d423d 100644 --- a/.markdownlint.yaml +++ b/.markdownlint.yaml @@ -8,6 +8,10 @@ "MD024": "siblings_only": true +# We use different page yaml titles to markdown TOC level #1 heading, on purpose, for SEO +"MD025": + "front_matter_title": "" + # Allow trailing punctuation in headings "MD026": false @@ -16,3 +20,5 @@ "MD038": false "MD046": false +# We need inline HTML to embed YouTube videos +"MD033": false \ No newline at end of file diff --git a/_snippets/common-links.md b/_snippets/common-links.md index 7232642..8fac0f5 100644 --- a/_snippets/common-links.md +++ b/_snippets/common-links.md @@ -16,6 +16,7 @@ [github_sponsor]: https://github.com/sponsors/funkypenguin [headphones]: /recipes/autopirate/headphones/ [homeassistant]: /recipes/homeassistant/ +[immich]: /recipes/immich/ [jackett]: /recipes/autopirate/jackett/ [jellyfin]: /recipes/jellyfin/ [kavita]: /recipes/kavita/ @@ -42,6 +43,7 @@ [prowlarr]: /recipes/autopirate/prowlarr/ [radarr]: /recipes/autopirate/radarr/ [readarr]: /recipes/autopirate/readarr/ +[review/immich]: /review/immich/ [rss-bridge]: /recipes/rss-bridge/ [rtorrent]: /recipes/autopirate/rtorrent/ [sabnzbd]: /recipes/autopirate/sabnzbd/ diff --git a/_snippets/review-footer.md b/_snippets/review-footer.md new file mode 100644 index 0000000..5b2e2f8 --- /dev/null +++ b/_snippets/review-footer.md @@ -0,0 +1,36 @@ +## Chef's notes 📓 + +///Footnotes Go Here/// + +### Tip your waiter (sponsor) 👏 + +Did you receive excellent service? Want to compliment the chef? (_..and support development of current and future recipes!_) Sponsor me on [Github][github_sponsor] / [Patreon][patreon], or see the [contribute](/community/contribute/) page for more (_free or paid)_ ways to say thank you! 👏 + +### Employ your chef (engage) 🤝 + +Is this too much of a geeky PITA? Do you just want results, stat? [I do this for a living](https://www.funkypenguin.co.nz/about/) - I'm a full-time Kubernetes contractor, providing consulting and engineering expertise to businesses needing short-term, short-notice support in the cloud-native space, including AWS/Azure/GKE, Kubernetes, CI/CD and automation. + +Learn more about working with me [here](https://www.funkypenguin.co.nz/work-with-me/). + +### Flirt with waiter (subscribe) 💌 + +Want to know now when this recipe gets updated, or when future recipes are added? Subscribe to the [RSS feed](https://mastodon.social/@geekcookbook_changes.rss), or leave your email address below, and we'll keep you updated. + +
+ +## Your comments? 💬 + +
+ + + +--8<-- "common-links.md" \ No newline at end of file diff --git a/manuscript/docker-swarm/traefik-forward-auth/index.md b/manuscript/docker-swarm/traefik-forward-auth/index.md index b37c120..e26c6b8 100644 --- a/manuscript/docker-swarm/traefik-forward-auth/index.md +++ b/manuscript/docker-swarm/traefik-forward-auth/index.md @@ -23,7 +23,7 @@ This is the role of Traefik Forward Auth. When employing Traefik Forward Auth as "[middleware](https://doc.traefik.io/traefik/middlewares/forwardauth/)", the forward-auth process sits in the middle of this transaction - traefik receives the incoming request, "checks in" with the auth server to determine whether or not further authentication is required. If the user is authenticated, the auth server returns a 200 response code, and Traefik is authorized to forward the request to the backend. If not, traefik passes the auth server response back to the user - this process will usually direct the user to an authentication provider (*[Google][tfa-google], [Keycloak][tfa-keycloak], and [Dex][tfa-dex-static] are common examples*), so that they can perform a login. Illustrated below: -![Traefik Forward Auth](../../images/traefik-forward-auth.png){ loading=lazy } +![Traefik Forward Auth](/images/traefik-forward-auth.png){ loading=lazy } The advantage under this design is additional security. If I'm deploying a web app which I expect only an authenticated user to require access to (*unlike something intended to be accessed publically, like [Linx][linx]*), I'll pass the request through Traefik Forward Auth. The overhead is negligible, and the additional layer of security is well-worth it. diff --git a/manuscript/images/reviews/immich-mobile-browse-photos.jpeg b/manuscript/images/reviews/immich-mobile-browse-photos.jpeg new file mode 100644 index 0000000..7871ed6 Binary files /dev/null and b/manuscript/images/reviews/immich-mobile-browse-photos.jpeg differ diff --git a/manuscript/images/reviews/immich-mobile-save-photos.png b/manuscript/images/reviews/immich-mobile-save-photos.png new file mode 100644 index 0000000..7b3d1ed Binary files /dev/null and b/manuscript/images/reviews/immich-mobile-save-photos.png differ diff --git a/manuscript/images/reviews/immich-mobile-search-photos.jpeg b/manuscript/images/reviews/immich-mobile-search-photos.jpeg new file mode 100644 index 0000000..e43fb89 Binary files /dev/null and b/manuscript/images/reviews/immich-mobile-search-photos.jpeg differ diff --git a/manuscript/images/reviews/immich-mobile.gif b/manuscript/images/reviews/immich-mobile.gif new file mode 100644 index 0000000..51b7ab2 Binary files /dev/null and b/manuscript/images/reviews/immich-mobile.gif differ diff --git a/manuscript/images/reviews/immich-web.jpg b/manuscript/images/reviews/immich-web.jpg new file mode 100644 index 0000000..f9d16c1 Binary files /dev/null and b/manuscript/images/reviews/immich-web.jpg differ diff --git a/manuscript/index.md b/manuscript/index.md index 01dbcf4..9da267b 100644 --- a/manuscript/index.md +++ b/manuscript/index.md @@ -129,7 +129,7 @@ I regularly donate to / sponsor the following projects. **Join me** in supportin | Project | Donate via.. | ------------- |-------------| -| [Komga](/recipes/komga/) | [GitHub Sponsors](https://github.com/sponsors/gotson) +| [Immich](/review/immich/) | [GitHub Sponsors](https://github.com/sponsors/alextran1502) | [Material for MKDocs](https://squidfunk.github.io/mkdocs-material/) | [GitHub Sponsors](https://github.com/sponsors/squidfunk) | [Calibre](https://calibre-ebook.com/) | [Credit Card](https://calibre-ebook.com/donate) / [Patreon](https://www.patreon.com/kovidgoyal) / [LibrePay](https://liberapay.com/kovidgoyal/donate) | [LinuxServer.io](https://www.linuxserver.io) | [PayPal](https://www.linuxserver.io/donate) diff --git a/manuscript/kubernetes/ingress/traefik/dashboard.md b/manuscript/kubernetes/ingress/traefik/dashboard.md index f317fe5..629c8b5 100644 --- a/manuscript/kubernetes/ingress/traefik/dashboard.md +++ b/manuscript/kubernetes/ingress/traefik/dashboard.md @@ -6,7 +6,7 @@ description: Unlike competing ingresses (*cough* nginx *cough*), the beautiful T One of the advantages [Traefik](/kubernetes/ingress/traefik/) offers over [Nginx](/kubernetes/ingress/nginx/), is a native dashboard available in the open-source version (*Nginx+, the commercially-supported version, also includes a dashboard*). -![Traefik Dashboard Screenshot](../../../images/traefik-dashboard.png){ loading=lazy } +![Traefik Dashboard Screenshot](..//images/traefik-dashboard.png){ loading=lazy } !!! summary "Ingredients" diff --git a/manuscript/kubernetes/ingress/traefik/index.md b/manuscript/kubernetes/ingress/traefik/index.md index 528b957..87abf5f 100644 --- a/manuscript/kubernetes/ingress/traefik/index.md +++ b/manuscript/kubernetes/ingress/traefik/index.md @@ -12,7 +12,7 @@ Traefik natively includes some features which Nginx lacks: * [x] An elegant "middleware" implementation allowing certain requests to pass through additional layers of authentication * [x] A beautiful dashboard -![Traefik Screenshot](../../../images/traefik.png){ loading=lazy } +![Traefik Screenshot](..//images/traefik.png){ loading=lazy } !!! summary "Ingredients" diff --git a/manuscript/recipes/autopirate/headphones.md b/manuscript/recipes/autopirate/headphones.md index a03daa4..459941a 100644 --- a/manuscript/recipes/autopirate/headphones.md +++ b/manuscript/recipes/autopirate/headphones.md @@ -5,7 +5,7 @@ [Headphones](https://github.com/rembo10/headphones) is an automated music downloader for NZB and Torrent, written in Python. It supports [SABnzbd][sabnzbd], [NZBget][nzbget], Transmission, µTorrent, Deluge and Blackhole. -![Headphones Screenshot](../../images/headphones.png){ loading=lazy } +![Headphones Screenshot](/images/headphones.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/index.md b/manuscript/recipes/autopirate/index.md index d4e62eb..52a04bd 100644 --- a/manuscript/recipes/autopirate/index.md +++ b/manuscript/recipes/autopirate/index.md @@ -8,7 +8,7 @@ Once the cutting edge of the "internet" (_pre-world-wide-web and mosiac days_), A good starter for the usenet scene is . Because it's so damn complicated, a host of automated tools exist to automate the process of finding, downloading, and managing content. The tools included in this recipe are as per the following example: -![Autopirate Screenshot](../../images/autopirate.png){ loading=lazy } +![Autopirate Screenshot](/images/autopirate.png){ loading=lazy } This recipe presents a method to combine these tools into a single swarm deployment, and make them available securely. diff --git a/manuscript/recipes/autopirate/jackett.md b/manuscript/recipes/autopirate/jackett.md index ec5baaf..085d053 100644 --- a/manuscript/recipes/autopirate/jackett.md +++ b/manuscript/recipes/autopirate/jackett.md @@ -11,7 +11,7 @@ description: Jackett works as a proxy server, standardizing your apps' (Radarr / This allows for getting recent uploads (like RSS) and performing searches. Jackett is a single repository of maintained indexer scraping & translation logic - removing the burden from other apps. -![Jackett Screenshot](../../images/jackett.png){ loading=lazy } +![Jackett Screenshot](/images/jackett.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/lazylibrarian.md b/manuscript/recipes/autopirate/lazylibrarian.md index 3110731..0e42971 100644 --- a/manuscript/recipes/autopirate/lazylibrarian.md +++ b/manuscript/recipes/autopirate/lazylibrarian.md @@ -16,7 +16,7 @@ description: LazyLibrarian is a tool to follow authors and manage your ebook / a * AutoAdd feature for book management tools like Calibre which must have books in flattened directory structure, or use calibre to import your books into an existing calibre library * LazyLibrarian can also be used to search for and download magazines, and monitor for new issues -![Lazy Librarian Screenshot](../../images/lazylibrarian.png){ loading=lazy } +![Lazy Librarian Screenshot](/images/lazylibrarian.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/lidarr.md b/manuscript/recipes/autopirate/lidarr.md index 86e7105..45f72e5 100644 --- a/manuscript/recipes/autopirate/lidarr.md +++ b/manuscript/recipes/autopirate/lidarr.md @@ -9,7 +9,7 @@ description: Lidarr is an automated music downloader for NZB and Torrent [Lidarr](https://lidarr.audio/) is an automated music downloader for NZB and Torrent. It performs the same function as [Headphones][headphones], but is written using the same(ish) codebase as [Radarr][radarr] and [Sonarr][sonarr]. It's blazingly fast, and includes beautiful album/artist art. Lidarr supports [SABnzbd][sabnzbd], [NZBGet][nzbget], Transmission, µTorrent, Deluge and Blackhole (_just like Sonarr / Radarr_) -![Lidarr Screenshot](../../images/lidarr.png){ loading=lazy } +![Lidarr Screenshot](/images/lidarr.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/mylar.md b/manuscript/recipes/autopirate/mylar.md index 49f2788..33bb7dc 100644 --- a/manuscript/recipes/autopirate/mylar.md +++ b/manuscript/recipes/autopirate/mylar.md @@ -10,7 +10,7 @@ description: Mylar is a tool for downloading and managing digital comic books, a [Mylar](https://github.com/mylar3/mylar3) is a tool for downloading and managing digital comic books. -![Mylar Screenshot](../../images/mylar.jpg) +![Mylar Screenshot](/images/mylar.jpg) ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/nzbget.md b/manuscript/recipes/autopirate/nzbget.md index 90ea91f..a40f881 100644 --- a/manuscript/recipes/autopirate/nzbget.md +++ b/manuscript/recipes/autopirate/nzbget.md @@ -12,7 +12,7 @@ description: NZBGet is a tool for downloading "content" from Usenet providers, a NZBGet performs the same function as [SABnzbd][sabnzbd] (_downloading content from Usenet servers_), but it's lightweight and fast(er), written in C++ (_as opposed to Python_). -![NZBGet Screenshot](../../images/nzbget.jpg) +![NZBGet Screenshot](/images/nzbget.jpg) ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/nzbhydra.md b/manuscript/recipes/autopirate/nzbhydra.md index f2f6383..b4162ce 100644 --- a/manuscript/recipes/autopirate/nzbhydra.md +++ b/manuscript/recipes/autopirate/nzbhydra.md @@ -10,7 +10,7 @@ description: NZBHydra is a meta search engine for NZB indexers, and can be used [NZBHydra2](https://github.com/theotherp/nzbhydra2) is a meta search for NZB indexers. It provides easy access to a number of raw and newznab based indexers. You can search all your indexers from one place and use it as an indexer source for tools like Sonarr, Radarr or CouchPotato. -![NZBHydra Screenshot](../../images/nzbhydra2.png){ loading=lazy } +![NZBHydra Screenshot](/images/nzbhydra2.png){ loading=lazy } Features include: diff --git a/manuscript/recipes/autopirate/ombi.md b/manuscript/recipes/autopirate/ombi.md index 742ffab..3b6a27a 100644 --- a/manuscript/recipes/autopirate/ombi.md +++ b/manuscript/recipes/autopirate/ombi.md @@ -18,7 +18,7 @@ User management system (_supports plex.tv, Emby and local accounts_) * Will show if the request is already on plex or even if it's already monitored. * Automatically updates the status of requests when they are available on Plex/Emby/Jellyfin -![Ombi Screenshot](../../images/ombi.png){ loading=lazy } +![Ombi Screenshot](/images/ombi.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/prowlarr.md b/manuscript/recipes/autopirate/prowlarr.md index 38c4fd3..aa0fa70 100644 --- a/manuscript/recipes/autopirate/prowlarr.md +++ b/manuscript/recipes/autopirate/prowlarr.md @@ -12,7 +12,7 @@ description: Prowlarr aggregates nzb/torrent searches. Imagine NZBHydra and Jack Prowlarr supports management of both Torrent Trackers and Usenet Indexers. It integrates seamlessly with [Lidarr][lidarr], [Mylar3][mylar], [Radarr][radarr], [Readarr][readarr], and [Sonarr][sonarr] offering complete management of your indexers with no per app Indexer setup required! -![Prowlarr Screenshot](../../images/prowlarr.png){ loading=lazy } +![Prowlarr Screenshot](/images/prowlarr.png){ loading=lazy } Fancy features include: diff --git a/manuscript/recipes/autopirate/radarr.md b/manuscript/recipes/autopirate/radarr.md index 83fd8d0..240690b 100644 --- a/manuscript/recipes/autopirate/radarr.md +++ b/manuscript/recipes/autopirate/radarr.md @@ -24,7 +24,7 @@ description: Radarr is a tool for finding, downloading and managing movies, and * And a beautiful UI * Importing Metadata such as trailers or subtitles -![Radarr Screenshot](../../images/radarr.png){ loading=lazy } +![Radarr Screenshot](/images/radarr.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/readarr.md b/manuscript/recipes/autopirate/readarr.md index ef8a8a6..ef52d4e 100644 --- a/manuscript/recipes/autopirate/readarr.md +++ b/manuscript/recipes/autopirate/readarr.md @@ -10,7 +10,7 @@ description: Readarr is "Sonarr/Radarr for eBooks and audiobooks, and plays perf [Readarr](https://github.com/Readarr/Readarr), in the fine tradition of [Radarr][radarr] and [Sonarr][sonarr], is a tool for "sourcing" eBooks, using usenet or bittorrent indexers. -![Readarr Screenshot](../../images/readarr.png){ loading=lazy } +![Readarr Screenshot](/images/readarr.png){ loading=lazy } Features include: diff --git a/manuscript/recipes/autopirate/rtorrent.md b/manuscript/recipes/autopirate/rtorrent.md index e93257d..53181f4 100644 --- a/manuscript/recipes/autopirate/rtorrent.md +++ b/manuscript/recipes/autopirate/rtorrent.md @@ -10,7 +10,7 @@ description: ruTorrent (looks like uTorrent) is a popular web UI frontend to rto [RTorrent](http://rakshasa.github.io/rtorrent) is a popular CLI-based bittorrent client, and [ruTorrent](https://github.com/Novik/ruTorrent) is a powerful web interface for rtorrent. -![Rtorrent Screenshot](../../images/rtorrent.png){ loading=lazy } +![Rtorrent Screenshot](/images/rtorrent.png){ loading=lazy } ## Choose incoming port diff --git a/manuscript/recipes/autopirate/sabnzbd.md b/manuscript/recipes/autopirate/sabnzbd.md index 813bf49..2795fd3 100644 --- a/manuscript/recipes/autopirate/sabnzbd.md +++ b/manuscript/recipes/autopirate/sabnzbd.md @@ -12,7 +12,7 @@ description: SABnzbd is a tool for downloading "content" from Usenet providers, SABnzbd is a workhorse of the stack. It takes .nzb files as input (_manually or from other [autopirate](/recipes/autopirate/) stack tools_), then connects to your chosen Usenet provider, downloads all the individual binaries referenced by the .nzb, and then tests/repairs/combines/uncompresses them all into the final result - media files. -![SABNZBD Screenshot](../../images/sabnzbd.png){ loading=lazy } +![SABNZBD Screenshot](/images/sabnzbd.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/autopirate/sonarr.md b/manuscript/recipes/autopirate/sonarr.md index 943ba42..633d950 100644 --- a/manuscript/recipes/autopirate/sonarr.md +++ b/manuscript/recipes/autopirate/sonarr.md @@ -10,7 +10,7 @@ description: Sonarr is a tool for finding, downloading and managing TV series*, [Sonarr](https://sonarr.tv/) is a tool for finding, downloading and managing your TV series. -![Sonarr Screenshot](../../images/sonarr.png){ loading=lazy } +![Sonarr Screenshot](/images/sonarr.png){ loading=lazy } ## Inclusion into AutoPirate diff --git a/manuscript/recipes/keycloak/index.md b/manuscript/recipes/keycloak/index.md index f548ca8..33745b7 100644 --- a/manuscript/recipes/keycloak/index.md +++ b/manuscript/recipes/keycloak/index.md @@ -8,7 +8,7 @@ title: Run Keycloak behind traefik in Docker Keycloak's OpenID provider can also be used in combination with [Traefik Forward Auth](/docker-swarm/traefik-forward-auth/), to protect [vulnerable services](/recipes/autopirate/nzbget/) with an extra layer of authentication. -![Keycloak Screenshot](../../images/keycloak.png){ loading=lazy } +![Keycloak Screenshot](/images/keycloak.png){ loading=lazy } --8<-- "recipe-standard-ingredients.md" diff --git a/manuscript/reference/networks.md b/manuscript/reference/networks.md index 0947359..5cdc639 100644 --- a/manuscript/reference/networks.md +++ b/manuscript/reference/networks.md @@ -16,6 +16,8 @@ In order to avoid IP addressing conflicts as we bring swarm networks up/down, we | [Tiny Tiny RSS](/recipes/tiny-tiny-rss/) | 172.16.5.0/24 | | [Huginn](/recipes/huginn/) | 172.16.6.0/24 | | [Gollum](/recipes/gollum/) | 172.16.7.0/24 | +| Immich (coming soon!) | 172.16.8.0/24 | +| Mastodon (coming soon!) | 172.16.9.0/24 | | [Duplicity](/recipes/duplicity/) | 172.16.10.0/24 | | [Autopirate](/recipes/autopirate/) | 172.16.11.0/24 | | [Nextcloud](/recipes/nextcloud/) | 172.16.12.0/24 | diff --git a/manuscript/review/immich.md b/manuscript/review/immich.md new file mode 100644 index 0000000..c2525fe --- /dev/null +++ b/manuscript/review/immich.md @@ -0,0 +1,166 @@ +--- +title: Review / Immich - a self-hosted Google Photos alternative +description: Immich is a polished and functional replacement for Google Photos +upstream_version: v1.19.1 +upstream_repo: https://github.com/immich-app/immich +review_latest_change: Initial review! +--- + +# I'm defz going to replace Google Photos with Immich! + +| Review details | | +| ----------- | ------------------------------------ | +| :material-calendar-check: Last updated | *{{ git_revision_date_localized }}* | +| :octicons-number-24: Reviewed version | *[{{ page.meta.upstream_version }}]({{ page.meta.upstream_repo }})* | + +Immich is a promising self-hosted alternative to Google Photos. Its UI and features are clearly heavily inspired by Google Photos, and like [Photoprism][photoprism], Immich uses tensorflow-based machine learning to auto-tag your photos! + +!!! warning "Pre-production warning" + The developer makes it abundantly clear that Immich is under heavy development, and features and APIs may change, and all your photos may be lost, or (worse) auto-shared with to your :dragon_face: mother-in-law! Take due care :wink: + +I'm personally excited about Immich because I've recently been debating how to migrate from Google Photos, in which I'm hitting my 15GB storage limit. + +![Immich Screenshot](/images/reviews/immich-web.jpg){ loading=lazy } + +Immich is a bit of an outlier in the self-hosted application space in terms of its maturity.. the [repository](https://github.com/immich-app/immich) currently states that it's **not** production-ready, but it's already got both an Android and iOS app available in the respective app stores. + +![Immich Screenshot](/images/reviews/immich-mobile.gif){ align=right loading=lazy } + +Two things stand out to me here - first off, the developer actively tries to discourage users from relying on the app for anything other than testing, and secondly, by investing in the mobile apps / app stores (*which come with a cost*), they're clearly thinking long-term and are committed to the project. + +## Immich Features + +Here are the current Immich features, which I scraped directly from the repo. As you'll note, the mobile apps mostly have parity with the web app, other than administrative functions, and even have some extra features, like search.. + +| | Mobile | Web | +| - | - | - | +| Upload and view videos and photos | Yes | Yes +| Auto backup when app is opened | Yes | N/A +| Selective album(s) for backup | Yes | N/A +| Download photos and videos to local device | Yes | Yes +| Multi-user support | Yes | Yes +| Album | No | Yes +| Shared Albums | Yes | Yes +| Quick navigation with draggable scrollbar | Yes | Yes +| Support RAW (HEIC, HEIF, DNG, Apple ProRaw) | Yes | Yes +| Metadata view (EXIF, map) | Yes | Yes +| Search by metadata, objects and image tags | Yes | No +| Administrative functions (user management) | N/A | Yes + +## Background + +Primarily what I want Immich to do is to backup all my photos from both my mobile phone, and my wife's phone, so that we can have a consolidated photo backup for our family. (*We currently use a dedicated gmail account with Google Photos for this purpose, but it's run out of space and is a little convoluted*) + +We're iOS users, and we have a 2TB family iCloud account to which all of our photos are synced. Since the advent of iCloud Photo Library, it's not possible to "combine" photo libraries, so the only way we can share photos of our family is to manually add them to an album which one of us shares with the other. This is waaay too much work, and what inevitably happens is that we each end up with separate photo albums, and regularly have to send each other photos of events and kids. + +So what I'm looking for is a solution to replace Google Photos - a way for each user to upload *all* photos taken on their device, and have these photos combined into a "master album" which both parties can access, manage, and create albums from. + +## Details + +### Install + +Installation was... tricky, but that's because I wanted to install Immich using Docker Swarm, rather than the example docker-compose included with the repo. I'm working on a recipe, and will update this review when done. + +### Web UI + +The setup process was straightforward. After deploying Immich, I was prompted to setup a username and password, which subsequently became my admin credentials. Using these credentials, I setup a second user, and shared an album with him. Here's a video I made to illustrate the process: + + + +### Mobile app + +The Mobile app seems very polished, and based on my testing, works better than the Synology "Moments" app I was previously trialling (*especially given the volume of photos I have!*) + +
+ ![Immich Screenshot](/images/reviews/immich-mobile.gif){ loading=lazy } +
Apparently this was 4000+ photos!
+
+ + +### Other + +Here's what the filesystem where photos are stored looks like: + +```bash +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/34ce58c4-8100-49d4-a5a3-f13a74b478f9.webp +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/34ce58c4-8100-49d4-a5a3-f13a74b478f9.jpeg +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/7d8abe14-77c3-4214-804a-d35d68084a2c.webp +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/309228ef-0b21-4986-acc4-d0c0d10e43ac.webp +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/309228ef-0b21-4986-acc4-d0c0d10e43ac.jpeg +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/7d8abe14-77c3-4214-804a-d35d68084a2c.jpeg +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/8adff3fe-d0ac-4855-b0ca-12a1f6ef2caf.webp +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/8adff3fe-d0ac-4855-b0ca-12a1f6ef2caf.jpeg +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/30505706-520b-4eac-89ed-9f1227802306.jpeg +/var/data/immich/upload/49a82212-e1bb-48d9-8b8f-7076e54bd6aa/thumb/WEB/30505706-520b-4eac-89ed-9f1227802306.webp +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8 +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/original +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/original/WEB +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/original/WEB/2245d33b-fbc5-40ee-a50b-2a234f73e3d9.jpg +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/thumb +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/thumb/WEB +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/thumb/WEB/2245d33b-fbc5-40ee-a50b-2a234f73e3d9.webp +/var/data/immich/upload/cae22784-474c-4527-825c-46d7f324e8e8/thumb/WEB/2245d33b-fbc5-40ee-a50b-2a234f73e3d9.jpeg +``` + +As you'll note, while it's true that files are stored locally, there's no filesystem-level metadata easily parsable, like yearly or album-based folders. While the files are stored locally, and *technically* you could move them elsewhere, it certainly wouldn't be easy. + +It's also not easy to access the files via any sort of sharing (*NFS, SMB, etc*), other than using the Immich UI. Par for the course though, I expect, if we want to be able to rely on the database for metadata without requiring intensive filesystem interaction. + +## Alternatives + +### Photoprism + +Until Immich, the only viable self-hosted Google Photos replacement I was aware of was [Photoprism][photoprism], which has a far wider featureset and several years of stable releases. + +Given my goal of having a non-Apple secondary backup of my family photos, let's selfishly compare the features which matter (*to me*): + +
+| Feature | Immich | Photoprism | +| ----- | ----------- | ------------------------------------ | +| :material-nas: Photos stored locally | Y | Y | +| :octicons-device-mobile-24: Automatic mobile uploads (automatic) | Y | [paid 3rd-party app](https://www.photosync-app.com/home.html) | +| :material-share-variant: Share albums with trusted users | Y | Y | +| :material-bomb-off: Stable release | haha | [2021](https://docs.photoprism.app/developer-guide/) +| :material-face-recognition: AI facial recognition | N | Y | +| :octicons-tag-24: AI tagging ("photo of dog") | Y | Y | + +
Immich vs Photoprism
+
+ +Conclusion: For my secondary-backup use-case, Immich (*even in its current pre-production buggy state*) is perfectly fine. The mobile app is beautiful (*if a little buggy*), and I do appreciate the cheeky "google photos" theming / styling. I think it'll appeal to a lot of Google Photos refugees for this reason alone. + +### Google Photos + +OK, obviously one is self-hosted, and the other is not. This massive differenec aside, again for my use-case, the other feature differences are: + +
+| Feature | Immich | Google Photos | +| ----- | ----------- | ------------------------------------ | +| :material-nas: Storage limit | :octicons-infinity-24: | 15GB :fontawesome-solid-hand-middle-finger: | +| :octicons-device-mobile-24: Automatic mobile uploads (automatic) | Y | Y (*but deletions sync with my phone, which is less-than-idea, for my secondary-backup plan*) | +| :material-share-variant: Share all photos with user | Y | Only with 1 partner :couple: | +| :material-bomb-off: Stable release | haha | Y +| :material-face-recognition: AI facial recognition | N | Y | +| :octicons-tag-24: AI tagging ("photo of dog") | Y | Y | + +
Immich vs Google Photos
+
+ +**Conclusion**: I setup my secondary-backup plan when Google first announced unlimited storage for Google Photos. Now that this is no longer possible, I'm out. + +## Summary + +### TL;DR + +I'm in (*for a secondary backup to my iCloud Photo Library*) + +Based on how the pre-production development has progressed, and the massive hunger in the self-hosted community for an alternative to Google Photos, I suspect that Immich will quickly gain traction and continue its rapid pace of development. + +Please [join me](/#sponsored-projects) in sponsoring [@alextran1502](https://github.com/sponsors/alextran1502), to support this exceptional product! + +### Setup Immiche via premix + +I'll have a recipe up for Immich in due course, but if you're wanting to use the pre-prod, development, dont-blame-me version, there's an ansible role in the [Premix](/premix/) playbook which will set it up in under 60s (*see below*): + + +--8<-- "review-footer.md" diff --git a/manuscript/review/index.md b/manuscript/review/index.md new file mode 100644 index 0000000..6c15f44 --- /dev/null +++ b/manuscript/review/index.md @@ -0,0 +1,17 @@ +--- +title: Awesome self-hosted app reviews +description: This list focuses on reviews of self-hosted apps themselves, rather than deployment strategies +--- +# Reviews of self-hosted apps + +Unlike the [Docker Swarm](/docker-swarm/) or [Kubernetes](/kubernetes/) sections, which focus on deployment of various applications, this section reviews the applications themselves, irrespective of the deployment methodology. + +What you'll find here are opinions and notes about various self-hosted applications, which will be updated from time-to-time to keep them "fresh" :leafy_green: + + +App | Description | Date +---------|----------| --------- + [Immich][review/immich] | Google Photos replacement | 3 Aug 2022 + + + --8<-- "common-links.md" \ No newline at end of file diff --git a/mkdocs.yml b/mkdocs.yml index bf5339b..434946d 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -42,7 +42,7 @@ plugins: #theme_dir: mkdocs-material nav: - Home: index.md - - Docker Swarm: + - 🐳 Docker Swarm: - docker-swarm/index.md - Preparation: - Design: docker-swarm/design.md @@ -240,7 +240,10 @@ nav: - Operation: premix/ansible/operation.md - Design: premix/ansible/design.md # - Swarm: premix/swarm.md - # - Kubernetes: premix/kubernetes.md + # - Kubernetes: premix/kubernetes.md + - ✅ Reviews: + - review/index.md + - Immich: review/immich.md - CHANGELOG: recent-changes.md - Support: support.md - Contribute: community/contribute.md