Releases: immich-app/immich
v1.122.0
v1.122.0
Highlights
Welcome to release v1.122.0
of Immich. After a long release break, Immich is back and brings many new features with loads of bug fixes to enhance the user experience further and make Immich more delightful to use. Some of the highlights below:
- HDR video support in the mobile app
- Multiple URLs for machine learning service
- Automatic switching between server URLs in the mobile app
- Ability to hide users when searching in an Immich instance
- Access the most recent albums through the web navigation bar
- Custom email templates
- Automatically clean up files left behind by interrupted uploads
- More responsive hosted maps for users in Oceania
- Notable fix: swiping between videos failing on older Android devices
HDR video support
Thanks to the tireless work of @mertalev and @shenlong-tanwen, HDR videos are displayed correctly in their full dynamic range using the native video player on each respective platform directly in Immich. We hope this feature brings you a more lively experience when viewing past videos.
Note
Some videos may appear warped when viewing. If this occurs, please sign out and sign back in. This only needs to be done once and does not apply to new app installations on 1.122.0 or later.
Multiple URLs for machine learning service
Remote machine learning enables folks to run machine learning on a more powerful computer, like their gaming PC. However, the expectation of constant uptime of the remote PC was a pain point for users. Immich now allows specifying multiple URLs so it can fall back to other PCs, including the local machine learning service on the same server.
You can add additional URL endpoints in the Machine Learning Settings.
Auto-switching server URLs in the mobile app
We are happy to bring you one of the long-requested features: the ability for the app to use the local IP address of your server while you are on your home Wi-Fi and automatically switch to alternative URLs while you are out and about, ranging from VPN URLs to public DNS addresses.
This option is located in the newly redesigned settings page in the mobile app under the Networking section. We hope this setting will simplify the networking setup you must do at home, which was previously only achievable with a split DNS setup and a local DNS server.
Note
This feature requires always granting precise location permission for the Immich app so it can read the Wi-Fi name in both foreground and background.
Android Permission | iOS Permission |
---|---|
New Settings Page | Local Connection Info | External Connection Info |
---|---|---|
Ability to hide users when searching in your instance
For admins hosting a public instance who don’t want users to see each other, you can now disable that mechanism in the Server Settings.
Access the most recent albums through the web navigation bar
We added a dropdown to quickly access the most recent albums directly through the navigation bar.
Custom email templates
You can now modify the email template for user registration, album creation, and album updates. This can be configured with the Email Templates setting.
Automatically clean up files left behind by interrupted uploads
Previously, when an upload process was canceled, the partial files on the server stayed in the upload
folder as corrupted files, which wasted storage space. This release implements a mechanism that intercepts the interrupted request and cleanses the partial files.
More responsive hosted maps for users in Oceania
We have made some changes to improve the responsiveness of the hosted maps for users located in Oceania. Users located in those areas should now see their map load 2-3x faster generally as well as seeing more consistent response times.
Support Immich
If you find the project helpful, you can support Immich by purchasing a product key at https://buy.immich.app/.
Cheers! 🍻
What's Changed
🚨 Breaking Changes
🚀 Features
- feat(server): Add publicUsers toggle for user search by @samholton in #14330
- feat(ml): support multiple urls by @mertalev in #14347
- feat(web): Album preview overview in menu by @TimVanOnckelen in #13981
- feat(mobile): native_video_player by @mertalev & @shenlong-tanwen in #12104
- feat(mobile): Auto switching server URLs by @alextran1502 in #14437
🌟 Enhancements
-
feat(tiles): improve map tile responsiveness in Oceania by @zackpollard in immich-app/geoshenanigans#62
-
feat(server): clean up interrupted upload files by @alextran1502 in #14265
-
feat: show delete album option in empty album by @alextran1502 in #14271
-
refactor(mobile): refactor to use context helpers for consistency by @dvbthien in #14235
-
feat(web): persist scroll position on navigation back to album by @caburum in #11388
-
feat(web): dedicated view for user's usage stats by @alextran1502 in #14348
-
feat(server): specify names for thumbnail files by @eligao in #14425
-
feat: Notification Email Templates by @TimVanOnckelen in #13940
🐛 Bug fixes
- fix(server): use hw decoding for rkmpp w/o OpenCL if possible by @zhujunsan in #13848
- fix(web): cannot upload folder with more than 100 files by @alextran1502 in #14284
- fix(web): make custom css textarea optional by @michelheusschen in #14303
- fix(web): clear combobox value when selectedOption is undefined by @michelheusschen in #14334
- fix(web): stack preview remains visible in asset viewer by @michelheusschen in #14341
- fix(web): timeline issues on person page by @michelheusschen in #14366
- fix(web): resolve issues with user usage statistics and refactor by @michelheusschen in #14374
- fix: ConnectivityResult.wifi regression by @systemtester in #14401
- fix(server): always set transcoding device, prefer renderD* by @mertalev in #14455
- fix(server): show people without thumbnails by @mertalev in #14460
- fix(mobile): album most recent sorting on mobile by @alessandrv in #13766
📚 Documentation
- docs: add developer notes about rootless docker setup by @R-Rudolf in #13250
- docs: clarify/strengthen wording of PG deployment requirements by @mmomjian in #14294
New Contributors
- @R-Rudolf made their first contribution in #13250
- @zhujunsan made their first contribution in #13848
- @caburum made their first contribution in #11388
- @systemtester made their first contribution in #14401
- @eligao made their first contribution in #14425
- @alessandrv made their first contribution in #13766
- @TimVanOnckelen made their first contribution in #13940
Full Changelog: v1.121.0...v1.122.0
v1.121.0
v1.121.0
Highlights
Welcome to release v1.121.0
of Immich. This release focuses on bug fixes and performance optimization across the app. Some of the highlights below:
@immich/ui
component library- Fallback to system fonts for Cyrillic letters on the mobile app
- Multiselect using the shift key in the search result view
- Notable fixes: album sync on the mobile app always ran when reopening the app, leading to degradation in performance and browsing
@immich/ui
component library
Some of you may have seen that we added a new repository on GitHub. We have started building out a shared UI components library for Immich that will hopefully lead to a more manageable and consistent design. It’s still very much in the works, but here is a sneak peek at the button component.
Notable fix: album sync degrades performance on the mobile app
We fixed a bug on the server that caused visible performance degradation of the mobile app. The album syncing process is always triggered when the app is reopened instead of only syncing when there are changes on the server. This is a server fix, so we encourage you to update your server to this new release to fix this performance issue.
Support Immich
If you find the project helpful, you can support Immich by purchasing a product key at https://buy.immich.app/.
Cheers! 🍻
What's Changed
🚀 Features
- feat: add minimal devcontainer setup by @mcarbonne in #14038
🌟 Enhancements
- refactor(mobile): video controls by @mertalev in #14086
- feat: use dateTimeOriginal to calculate album date by @p2kmgcl in #14119
- feat(mobile): new video slider ui by @mertalev in #14126
- chore(web): migration svelte 5 syntax by @alextran1502 in #13883
- feat(web): Added tag button to the context menu in the favorites page by @IMBeniamin in #14156
- feat: adding photo & video storage space to server stats by @weathondev in #14125
- feat(mobile): exclude locales from overpass font by @johnstef99 in #14158
- feat(web): Implement keep this delete others for asset stacks by @bdavis2-PCTY in #14217
- feat: Added shortcuts, shift-multi select, and missing menu options to Search (Galleryviewer) by @weathondev in #14213
- feat(server): faster geodata import by @mertalev in #14241
🐛 Bug fixes
- fix(mobile): fix logout timeout by @johnstef99 in #14104
- fix(server): Some MTS videos fail to generate thumbnail by @Lukasdotcom in #14134
- fix(web): textarea autogrow height by @duckimann in #13983
- fix: Routing back button in sharedLinks page by @Pranay-Pandey in #13703
- fix(web): ensure current asset index stays within bounds by @michelheusschen in #14013
- fix(web): saving pasted coordinates by @michelheusschen in #14143
- fix(web): update description height when navigating between assets by @michelheusschen in #14145
- fix(web): allow selecting people after clearing search options by @michelheusschen in #14146
- fix(mobile): Android local notification failed to invoke by @alextran1502 in #14155
- fix(web): prevent infinite loop when modifying stacked asset by @michelheusschen in #14162
- fix(cli): Concurrency not fully using queue potential by @Tiefseetauchner in #11828
- fix(web): don't refresh the panorama viewer when modifying asset by @michelheusschen in #14163
- fix(mobile): unnecessary rebuilds from partner share notifier by @mertalev in #14170
- fix: show tags when viewing stacked assets by @michelheusschen in #14199
- fix(mobile): use sets in album refresh, concurrent futures by @mertalev in #14193
- fix(mobile): Dismissible menus by @johnstef99 in #14192
- fix(web): layout shifting when scrolling up by @alextran1502 in #14226
- fix(mobile): make search page scrollable by @johnstef99 in #14228
- fix(mobile): fixes on language change by @johnstef99 in #14089
- fix: mobile album sync is always triggered when opening the app by @alextran1502 in #14233
- fix(server): remove unnecessary guc settings for vector search by @mertalev in #14237
- fix: parse quota claim as a number by @danieldietzler in #14178
📚 Documentation
- chore(docs): Encode db dump in UTF-8 without BOM for Windows by @amorphobia in #13775
- docs: Update TrueNAS docs for TrueNAS SCALE 24.10 by @NicholasFlamy in #14067
- docs: get asset owner by ID from the database by @mmomjian in #14174
- docs: backup only selected photos by @shivanshs9 in #14225
New Contributors
- @amorphobia made their first contribution in #13775
- @p2kmgcl made their first contribution in #14119
- @johnstef99 made their first contribution in #14104
- @duckimann made their first contribution in #13983
- @IMBeniamin made their first contribution in #14156
- @weathondev made their first contribution in #14125
- @bdavis2-PCTY made their first contribution in #14217
Full Changelog: v1.120.2...v1.121.0
v1.120.2
v1.120.2
This patch release brings the following bug fixes:
- Postgres now uses the correct database dump command for version 14/15/16/17.
- Config updates were not correctly applied to some components.
- The mobile app doesn’t initialize the date locale for some languages.
Support Immich
If you find the project helpful, you can support Immich by purchasing a product key at https://buy.immich.app.
Cheers! 🍻
What's Changed
🌟 Enhancements
- feat(web): stable json settings export by @mcarbonne in #14036
- feat(server): use pg_dumpall version that matches the database version by @zackpollard in #14083
🐛 Bug fixes
- fix(server): support non-default Postgres port when taking a backup by @jrasm91 in #13992
- fix(server): thumbnail rotation when using embedded previews by @zhaoterryy in #13948
- fix(web): use locale for scrubber label when scrolling by @michelheusschen in #14012
- fix(mobile): make sure date locale is initialized for some languages by @alextran1502 in #14035
- fix(server): attempt to delete failed backups immediately after failure by @zackpollard in #13995
- fix: config updates not applying for job and storage template service by @zackpollard in #14074
📚 Documentation
- chore: backups custom location and config file docs by @zackpollard in #13996
- docs: make IGNORE_MOUNT_CHECK warning stronger by @bo0tzz in #14011
- chore(docs): roadmap SEO by @ben-basten in #14024
- docs: Fix DCM docs link by @Mraedis in #14059
- docs: clarify file size impact in hardware-transcoding.md by @gamescom15 in #14049
- docs: backup folder name is backups by @zackpollard in #14073
New Contributors
- @zhaoterryy made their first contribution in #13948
- @mcarbonne made their first contribution in #14036
- @gamescom15 made their first contribution in #14049
Full Changelog: v1.120.1...v1.120.2
v1.120.1
v1.120.1
This release addresses the issues below
What's Changed
🐛 Bug fixes
- fix(server): cannot render email template by @alextran1502 in #13957
- fix(server): allow starting backup through API and fix pg_dumpall args when using database URLs by @dotlambda in #13970
- fix(server): database backups compatible with deduplication by @Scrumplex in #13965
- fix(mobile): video player not playing in full size on Android by @alextran1502 in #13986
📚 Documentation
- fix: docker link by @danieldietzler in #13956
- docs: improve custom-locations wording to be easier to read by @slamp in #13849
- docs: Added a note about avoiding redundant database backups by @thariq-shanavas in #13958
- chore: tidy up backup-and-restore.md by @bo0tzz in #13961
- docs: 50k stars by @danieldietzler in #13964
- docs: add backups to startup folders list by @yodatak in #13967
- docs: update roadmap by @jrasm91 in #13984
New Contributors
- @slamp made their first contribution in #13849
- @yodatak made their first contribution in #13967
- @Scrumplex made their first contribution in #13965
Full Changelog: v1.120.0...v1.120.1
v1.120.0 - 50.000 Stars Release
v1.120.0 - 50.000 Stars Release
Welcome to release v1.120.0
of Immich. We've reached 50.000 stars on GitHub. Thank you for your love, support, and contributions to the project.
This release introduces a new built-in automatic database dump feature as well as bug fixes and enhancements. Some of the highlights include:
- Built-in automatic database backups
- Timeline location indicator on scrolling
- The web is now on Svelte 5
- Faster CPU transcoding for HDR videos
- Notable fix: Slow server start-up time on some systems
Built-in automatic database backups
This release introduces a mechanism that automatically creates a database dump and is enabled by default. It will run at 2 AM server time and keep the last 14 backups, all of which are configurable. You can find the settings in Administration > Settings > Backup Settings
The database zip files are placed at <UPLOAD_LOCATION>/backups
.
Below is an example of a database backup size for a library with 80_000 assets.
Currently, restores must be done manually, and instructions can be found in the documentation
Timeline location indicator on scrolling
The timeline on the web will now show the Month/Year information while scrolling to better indicate the viewport context.
Screen.Recording.2024-11-06.at.08.46.53.mov
Faster CPU transcoding for HDR videos
Immich now uses a faster tone-mapping implementation developed by the Jellyfin team to map colors from HDR to SDR. During testing, overall transcoding speed improved by as much as 69% for a 4K target resolution. The exact improvement will depend on hardware, source video, and transcoding settings.
Note
Note for third-party Immich distributions: as this filter only exists in jellyfin-ffmpeg, please ensure you use this build instead of a standard FFmpeg build.
Support Immich
If you find the project helpful, you can support Immich by purchasing a product key at https://buy.immich.app.
Cheers! 🍻
What's Changed
🚀 Features
- feat(web): scrubber label and animation by @alextran1502 in #13815
- feat: built-in automatic database backups by @zackpollard in #13773
🌟 Enhancements
- feat: mount checks on a folder level by @zackpollard in #13801
- feat(web): library settings crontab link includes existing expression by @zackpollard in #13807
- feat(web): disable opening image and library sub-items by default by @ITestInProd in #13729
- fix(mobile): Reapply thumbnail image improvements and fix issue #13804 by @dvbthien in #13835
- feat(server): use tonemapx for software tone-mapping by @mertalev in #13785
- feat: render asset path by @cfitzw in #13873
- chore(mobile): upgrade gradle by @alextran1502 in #13901
🐛 Bug fixes
- fix(server): handle N/A duration response from ffprobe by @jrasm91 in #13803
- fix: shutdown api process when another worker exits unexpectedly by @zackpollard in #13802
- fix(mobile): Revert thumbnail image ui improvements (#13655) by @alextran1502 in #13806
- fix(server): keep system config transformations by @jrasm91 in #13796
- fix(mobile): thumbnail not filled area on tablet by @alextran1502 in #13808
- fix(mobile): search page by @alextran1502 in #13833
- fix(mobile): not throwing error when cannot parse orientation value by @alextran1502 in #13853
- fix(mobile): do not removed not backup asset when selecting the correspond options by @yashrajjain726 in #13256
- fix(server): wrong image dimensions for RAW files (RAF, CR2) (also fixes face preview) by @C-Otto in #13377
- fix: healthcheck if custom host is set by @danieldietzler in #13887
- fix: remove duplicateIds on unique assets by @Pranay-Pandey in #13752
📚 Documentation
- chore(docs): update german readme to latest version by @MickLesk in #13824
- chore(docs): Add Immich Public Proxy to the Community Projects list by @alangrainger in #13836
- docs: fail2ban community project by @mmomjian in #13943
🌐 Translations
- chore(web): update translations by @weblate in #13688
- chore(web): update translations by @weblate in #13810
New Contributors
- @ITestInProd made their first contribution in #13729
- @alangrainger made their first contribution in #13836
Full Changelog: v1.119.1...v1.120.0
v1.119.1
v1.119.1
This patch release adds job options to the search view context menu when bulk-selecting assets.
What's Changed
🌟 Enhancements
- feat(web): add job action to search page result by @alextran1502 in #13784
📚 Documentation
- docs: note about Nginx reverse proxy compatibility with Let's Encrypt by @yozik04 in #13764
- docs: Add info about album sync&folder view by @aviv926 in #12371
New Contributors
Full Changelog: v1.119.0...v1.119.1
v1.119.0
v1.119.0
Caution
The env variable for the host binding was erroneously named HOST
instead of IMMICH_HOST
(which is how it was listed in the docs). This has been corrected in this release.
If you were using the HOST
env var in your setup before, please update it to IMMICH_HOST
.
If you are using the built-in Prometheus endpoint for monitoring, please read on. If not, you can ignore this section.
The following env variables have been removed:
IMMICH_METRICS
IMMICH_API_METRICS
IMMICH_HOST_METRICS
IMMICH_IO_METRICS
IMMICH_JOB_METRICS
Use IMMICH_TELEMETRY_INCLUDE
/ IMMICH_TELEMETRY_EXCLUDE
instead.
Examples:
-- IMMICH_METRICS=true
++ IMMICH_TELEMETRY_INCLUDE=all
-- IMMICH_METRICS=true
-- IMMICH_HOST_METRICS=false
++ IMMICH_TELEMETRY_INCLUDE=all
++ IMMICH_TELEMETRY_EXCLUDE=host
-- IMMICH_API_METRICS=true
-- IMMICH_HOST_METRICS=true
++ IMMICH_TELEMETRY_INCLUDE=api,host
Welcome to release v1.119.0
of Immich. This release focuses on fixing issues surrounding video encoding and thumbnail generation for a variety of old and new formats, along with minor improvements across the app. Some of the highlights below:
- Create new OAuth users without passwords
- Debounce email notifications for album changes
- Improve mobile app layout on tablets
- VAAPI hardware decoding
- Notable fix: Face Detection using excessive RAM with OpenVINO
- Notable fix: transcodes not playing in the mobile app in certain situations
VAAPI hardware decoding
Prior to this release, Immich only used VAAPI for video encoding; it still used the CPU for decoding and tone-mapping. This release adds end-to-end acceleration for VAAPI, making transcoding much faster with lower CPU utilization. With this addition, every supported acceleration API now has end-to-end acceleration in Immich.
If you use VAAPI hardware acceleration, you can enable hardware decoding in the transcoding settings to take advantage of this change.
Transcoding fix for mobile
When the source video is Dolby Vision, transcodes sometimes either didn't play in the mobile app, or only the audio was played. In particular, this meant that many videos captured on iOS could not be viewed on Android.
This issue has been fixed. However, existing transcodes of Dolby Vision videos created using Immich 1.114.0 - 1.118.2 will still have the issue and will need to be re-transcoded for correct playback in these cases.
To re-transcode affected videos, you can either select them in the web app and choose the Refresh encoded videos option or go to the Job Status page and click All next to Transcode Videos.
Note: you only need to do this if you encounter playback issues for these videos.
Support Immich
If you find the project helpful, you can support Immich by purchasing a product key at https://buy.immich.app.
Cheers! 🍻
What's Changed
🚨 Breaking Changes
- refactor(server): move host env to config repo by @jrasm91 in #13507
- refactor(server): telemetry env variables by @danieldietzler in #13705
🚀 Features
🌟 Enhancements
- feat: show warning when running main branch build by @bo0tzz in #13462
- fix(server): Allow passwordless users when oauth enabled by @jedi04 in #13517
- feat(web): Change relink person icon from minus to pencil by @CrushedAsian255 in #13536
- fix(web): improve photosphere viewer settings by @grgergo1 in #13468
- feat(server): add pcm_s16le accepted audio codec by @pyorot in #13418
- feat(server): wait five minutes before sending email on new album item by @HeyBanditoz in #12223
- chore(mobile): proper new UI layout for tablet by @alextran1502 in #13650
- chore(mobile): thumbnail image ui improvements by @dvbthien in #13655
- feat: Use video thumbnail for GIF types by @Pranay-Pandey in #13677
- feat(ml): configurable batch size for facial recognition by @mertalev in #13689
🐛 Bug fixes
- fix(server): never try to parse Duration from exif data by @jrasm91 in #13497
- fix: person update state inconsistencies by @danieldietzler in #13556
- fix: web search add to album reactivity by @danieldietzler in #13539
- fix(web): intersection observer not triggered to load more people by @alextran1502 in #13589
- fix(server): encodes iPhone 16 Pro video with unknown audio codec by @alextran1502 in #13593
- fix(server): Revert "fix(server): copy video projection metadata for 360 videos (#12376)" by @mertalev in #13611
- fix(mobile): Fix minor issues with downloading assets by @dvbthien in #13609
- fix(web): reset select all button state on escape press by @darrelhong in #13600
- fix(server): only allow absolute import paths by @etnoy in #13642
- feat(web): allow changing shared user role in album options modal by @AnimeshKotka in #13654
- fix(server): add ld_library_path in start.sh by @mertalev in #13686
- fix(server): nan transcoding estimate by @mertalev in #13693
- fix: Add debouncing to the search popup form by @Pranay-Pandey in #13684
- fix(web): add crossorigin to link manifest for PWA by @automaton82 in #13708
- fix: duplicated library scan jobs and api server library watch by @zackpollard in #13734
- fix: X years ago ordering by @darrelhong in #13742
📚 Documentation
- chore(docs): add Thai README by @richeyphu in #13591
- chore(docs): update _storage-template.md by @chriskoch in #13578
- docs: add qsv note for jasper lake cpus by @evie-lau in #13622
- docs: add warning to repair page by @polgarc in #13640
- feat(docs): add mention to purchase to support immich page by @CrushedAsian255 in #13612
- fix: Add DB_DATA_LOCATION config. by @Sweebah in #13754
🌐 Translations
- chore(web): update translations by @weblate in #13443
- chore: move weblate translations to root directory by @ben-basten in #13604
New Contributors
- @jedi04 made their first contribution in #13517
- @CrushedAsian255 made their first contribution in #13536
- @grgergo1 made their first contribution in #13468
- @richeyphu made their first contribution in #13591
- @chriskoch made their first contribution in #13578
- @HeyBanditoz made their first contribution in #12223
- @dvbthien made their first contribution in #13609
- @darrelhong made their first contribution in #13600
- @jrstrunk made their first contribution in #13644
- @evie-lau made their first contribution in #13622
- @polgarc made their first contribution in #13640
- @AnimeshKotka made their first contribution in #13654
- @Pranay-Pandey made their first contribution in #13677
- @automaton82 made their first contribution in #13708
- @Sweebah made their first contribution in #13754
Full Changelog: v1.118.2...v1.119.0
v1.118.2
Warning
Version v1.118.0 contains breaking changes. Read about them here.
Hotfixes
This release fixes images from Whatsapp failing to be processed, as well as an issue with video thumbnail generation failing in some cases. It also includes the FFmpeg 6.0 -> 7.0 upgrade that was scheduled for the next release, but oh well 🙃
What's Changed
🐛 Bug fixes
- fix: styling for last image in person grid by @MananJain-IITJ in #13444
- fix(server): ffmpeg matrices by @lyynd in #13461
New Contributors
- @MananJain-IITJ made their first contribution in #13444
Full Changelog: v1.118.1...v1.118.2
v1.118.1
Warning
Version v1.118.0 contains breaking changes. Read about them here.
Hotfixes
This release fixes some bugs introduced in version v1.118.0, specifically an issue with Google OAuth and mobile.
What's Changed
🐛 Bug fixes
📚 Documentation
New Contributors
Full Changelog: v1.118.0...v1.118.1
v1.118.0
v1.118.0
Welcome to release v1.118.0
of Immich. This version comes with several breaking changes, and also improvements to the mobile app UI and UX, a new documentation home page, as well as bug fixes and enhancements across the app. We hope you enjoy this release!
Warning
Breaking changes
This release includes the following breaking changes:
- Port alignment
- Remove deprecated API endpoints
- Remove deprecated
start.sh
arguments
1. Port alignment
We aligned the internal port of the immich-server
to be similar to the binding port. Please make the following change to your docker-compose.yml
file under the immich-server
section. Reverse proxies using port 3001 also need to be updated to use port 2283.
services:
immich-server:
container_name: immich_server
...
ports:
- - 2283:3001
+ - 2283:2283
...
2. Remove deprecated API endpoints
The following endpoints were previously deprecated and have been removed, if you are a community project maintainer and using one of the endpoints below, please make sure to make changes to your project:
/api/server-info/*
has been removed. Use/api/server/*
instead./api/people/:id/assets
has been removed. Use/api/search/metadata
instead.
Note
This includes /api/server-info/ping
, /api/server-info/version
, /api/server-features
, /api/server-info/config
, /api/server-info/statistics
, and others.
3. Remove deprecated start.sh
arguments
The following docker commands have been removed:
start.sh immich
start.sh microservices
Follow the steps below to align docker-compose.yml
with the default setup.
Note
These steps are only required if you still have the immich-microservices
section in your docker-compose.yml
or didn't follow the previous instructions to remove the command section. If you don't have the mentioned content below, you can ignore this
1. Update docker-compose.yml
Remove the command
line from immich-server
and the entire immich-microservices
service section as shown below.
services:
immich-server:
container_name: immich_server
...
:
- command: [ "start.sh", "immich" ]
...
- immich-microservices:
- container_name: immich_microservices
- ...
- :
- command: [ "start.sh", "microservices" ]
- ...
2. Remove the running immich-microservices
container
Run docker compose down --remove-orphans
after updating docker-compose.yml
to remove the old immich-microservices
container.
Highlights
Some of the highlights for this release include the following:
- Mobile UI/UX improvement
- Option to refresh face detection
- Color filters for editing photos
- Timezone improvements
- Deprecated release notes section
- Better JPEG compression
- Multi-GPU support for ML
Mobile UI/UX improvement
Thank you all for the great feedback from the dicussion we made a month ago about the proposed changes to the mobile app layout. We hope the following changes will provide more fluid experience when browing and managing your photos and videos.
Navigation bar
Photos and albums are the two most used pages. To make them more accessible, we replaced the Sharing
page with a new Albums
page where you can find all of the album related features and functions.
Albums page
This new page allows users to quickly view, sort, search, filter, create, and manage albums.
Library page
The library page now includes quick access buttons to various views, including
- Favorites
- Archived
- Shared links
- Trash
- People
- Places
- Device albums
- Partner sharing
Search page
Many of the items that were previously on this page have been moved to the Library
page, mentioned above. As a result, the search page is less cluttered and includes quick access search chips and queries. Also, clicking on the search navbar item a second time will focus on the search bar and open the keyboard for easy access.
Color filters for editing photos
This release introduces colors filter option in the edit menu on the mobile app. You can apply a set of presets colors to your photo. Thanks @Yuvi-raj-P for your contribution.
Timezone improvements
Images without timezones could previously show up incorrectly in the timeline if the server had a timezone (TZ=...
) set. This has been fixed and can be corrected by running metadata extraction on all assets.
Deprecated release notes section
Future releases will now include a "Deprecated" section in the release notes, including details of API endpoints and other changes that will become breaking changes in a future release. Moving forward, we plan to use this section of the release notes as our primary communication method for these types of changes.
Refresh face detection
Assets now have a Refresh faces
option to update the set of detected faces based on the current face detection threshold. Likewise, there is a new Refresh
button for Face Detection in the Jobs page that does the same for all assets.
Importantly, this does not clear all recognized people like the All
button (renamed to Reset
). If you find that a different detection threshold works better for your library and want to apply that new value to existing assets, Refresh
will simply add or remove faces to apply this change.
It will only ever delete faces detected through machine learning, not EXIF. Speaking of EXIF-sourced faces, they can now be used to recognize detected faces as a result of this feature. This means the facial recognition process can share the same people listed in face metadata instead of duplicating them.
Better JPEG compression
Immich now uses Jpegli, a new library leveraging the advancements of JPEG XL to shrink JPEG file size at the same (or higher) quality. This change narrows the gap between JPEG and WebP compression considerably, especially at high quality.
Multi-GPU support for ML
It is now possible for a single instance of the machine learning service to use more than one GPU. Previously, this required several services and a load balancer in front. See the documentation for instructions.
Support Immich
If you find the project helpful, you can support Immich by purchasing a product key at https://buy.immich.app.
Cheers! 🍻
What's Changed
🚨 Breaking Changes
- refactor(server): worker env by @jrasm91 in #13160
- chore: remove deprecated controller by @jrasm91 in #13189
- chore: remove deprecated endpoint by @jrasm91 in #13190
- feat: align compose ports by @jrasm91 in #13185
🚀 Features
- feat(server): refresh face detection by @mertalev in #12335
- feat(mobile): Adding filters feature to mobile image editor by @Yuvi-raj-P in #13174
- feat(ml): round-robin device assignment by @mertalev in #13237
- feat(mobile): new mobile UI by @alextran1502 in #12582
🌟 Enhancements
- feat(doc): new homepage design and font by @alextran1502 in #13084
- chore(mobile): search page minor enhancements by @alextran1502 in #13403
- fix(mobile): more efficient loading local image on ios by @alextran1502 in #13426
🐛 Bug fixes
- fix(mobile): respect orientation on displaying asset dimensions by @Yagnap in #13129
- fix(server): UTC+13 timezones treated as invalid during exif parsing by @C-Otto in #13176
- fix(server): external libraries queueing two transcode jobs by @zackpollard in #13251
- fix(server): Allow commas and braces in import paths by @etnoy in #13259
- fix(server): searching with both
personIds
andwithPeople
by @mertalev in #13254 - fix(web): video player on Safari by @alextran1502 in #13242
- fix(server): timezones by @jrasm91 in https://gi...