Open ngtrio opened 4 months ago
Can you be more specific with the filesize? How are you determining this size and what changes are you seeing?
I believe the backup symbol is supposed to indicate images that were backed up from that device, which the downloaded one was not, since it was uploaded on Web.
This happens (https://github.com/immich-app/immich/issues/6209) when you upload file with the same filename but different content than you have downloaded to device. Seems the file is moddified during transfer to device. Please compare it binary.
@mmomjian I exported two images, and renamed them to "upload" and "download" for convenience. The uploaded one is 100842 bytes, and the downloaded one is 101518 bytes. Moreover, this change occurs only between the steps of uploading from the web and downloading from the app.
I think the change in file size causes the hash of the two images to differ, so duplicate images exist on the server.
BTW, I am unable to reproduce this issue with PNG images. When I download the image from the app, the backup button is correctly checked and there is only one image, even if the image was uploaded from the web.
So, is anyone else able to reproduce this issue with JPG images, or is it a configuration issue on my end?
This happens (#6209) when you upload file with the same filename but different content than you have downloaded to device. Seems the file is moddified during transfer to device. Please compare it binary.
It doesn't appear to be the same issue, as I haven't performed any editing operations on the images.
I think the change in file size causes the hash of the two images to differ, so duplicate images exist on the server.
Binary comparison of those two would help to track the cause of file size change. It could be many reasons, reverse proxy missconfiguration, unintentional modification some app on your phone, etc.
I have tried the following steps again with the help of a few friends:
Now I have the following three images, corresponding to the three steps above by name:
.
As you can see, the sizes of the last two images are the same(16983 bytes), both larger than the original image(693 bytes).
Then I used exiftool to compare the three images, the latter two are consistent and both contain more information than the original image, especially this one: Thumbnail Image : (Binary data 16004 bytes, use -b option to extract)
:
Therefore, I speculate that the way immich's iOS app saves images may be similar to the way images are saved in the iOS Share, which adds some additional data to the original image, rather than using the system API to save original images (if there is one). Could iOS developers please help confirm this?
ExifTool Version Number : 12.76
File Name : origin-image.jpg
Directory : .
File Size : 693 bytes
File Modification Date/Time : 2024:04:17 11:19:08+08:00
File Access Date/Time : 2024:04:17 11:24:55+08:00
File Inode Change Date/Time : 2024:04:17 11:24:54+08:00
File Permissions : -rw-r--r--
File Type : JPEG
File Type Extension : jpg
MIME Type : image/jpeg
JFIF Version : 1.01
Resolution Unit : None
X Resolution : 1
Y Resolution : 1
Image Width : 256
Image Height : 213
Encoding Process : Progressive DCT, Huffman coding
Bits Per Sample : 8
Color Components : 3
Y Cb Cr Sub Sampling : YCbCr4:2:0 (2 2)
Image Size : 256x213
Megapixels : 0.055
ExifTool Version Number : 12.76
File Name : save-from-immich-app.JPG
Directory : .
File Size : 17 kB
File Modification Date/Time : 2024:04:17 11:22:50+08:00
File Access Date/Time : 2024:04:17 11:24:51+08:00
File Inode Change Date/Time : 2024:04:17 11:24:49+08:00
File Permissions : -rw-r--r--
File Type : JPEG
File Type Extension : jpg
MIME Type : image/jpeg
JFIF Version : 1.01
Exif Byte Order : Big-endian (Motorola, MM)
X Resolution : 72
Y Resolution : 72
Resolution Unit : inches
Y Cb Cr Positioning : Centered
Exif Version : 0221
Components Configuration : Y, Cb, Cr, -
Flashpix Version : 0100
Color Space : sRGB
Exif Image Width : 256
Exif Image Height : 213
Scene Capture Type : Standard
Compression : JPEG (old-style)
Thumbnail Offset : 304
Thumbnail Length : 16004
Image Width : 256
Image Height : 213
Encoding Process : Progressive DCT, Huffman coding
Bits Per Sample : 8
Color Components : 3
Y Cb Cr Sub Sampling : YCbCr4:2:0 (2 2)
Image Size : 256x213
Megapixels : 0.055
Thumbnail Image : (Binary data 16004 bytes, use -b option to extract)
ExifTool Version Number : 12.76
File Name : save-from-ios-share.JPG
Directory : .
File Size : 17 kB
File Modification Date/Time : 2024:04:17 11:01:43+08:00
File Access Date/Time : 2024:04:17 11:24:51+08:00
File Inode Change Date/Time : 2024:04:17 11:24:49+08:00
File Permissions : -rw-r--r--
File Type : JPEG
File Type Extension : jpg
MIME Type : image/jpeg
JFIF Version : 1.01
Exif Byte Order : Big-endian (Motorola, MM)
X Resolution : 72
Y Resolution : 72
Resolution Unit : inches
Y Cb Cr Positioning : Centered
Exif Version : 0221
Components Configuration : Y, Cb, Cr, -
Flashpix Version : 0100
Color Space : sRGB
Exif Image Width : 256
Exif Image Height : 213
Scene Capture Type : Standard
Compression : JPEG (old-style)
Thumbnail Offset : 304
Thumbnail Length : 16004
Image Width : 256
Image Height : 213
Encoding Process : Progressive DCT, Huffman coding
Bits Per Sample : 8
Color Components : 3
Y Cb Cr Sub Sampling : YCbCr4:2:0 (2 2)
Image Size : 256x213
Megapixels : 0.055
Thumbnail Image : (Binary data 16004 bytes, use -b option to extract)
Same here. I reported this way back when and this issue is one of the main things i run into as it prevents to download images that are only on the server as it creates duplicates that are re uploaded.
Same issue here. Discovered it while playing around with what I thought was another issue.
So a note, whatever is causing the alternate-filesize duplicate, is also affecting the share button.
Seems to me this should be pretty high priority given it breaks the ability to download images in iOS, in a silent manner of inflated duplicates.
So just to be sure, I tried it again:
Like others have tried, I then tried with a PNG and there was no issue.
I tried it with an internet meme file that was a jpg and the creation date was changed to today. I guess expected since it is a new different sized file.
I'm on the latest release as of this comment.
Thanks for the report and I agree, I think this impacts usability a bit. As soon as most of your pics and not on device, you can't share / download those pics anymore because it implicitly creates duplicates.
I have the same issue with jpeg files. You mentioned that PNG files are not affected. I can also add that HEIC (the format in which iPhone camera photos are stored) are not affected either. Unfortunately, for me, jpeg files are the most often redownloaded ones (wallpapers, memes), so it is a bit of a hassle to deal with the duplicates.
Another suggestion would be to allow immich to save downloaded photos into a dedicated album (on iOS), then we can exclude that album from uploading. It still requires changes in the code, but I imagine that it should be easier than fixing de-duplicated problem (please correct me if I'm wrong).
Edit: Maybe also have a look on photo_manager.editor.saveImage() function
Just chiming in to report I've experienced this as well, although it doesn't seem to impact every single jpg file for me. I have an external library with 863 images in it, all of which I tried to download to my phone, and the automatic sync re-uploaded roughly a third of them. I can also echo that the sizes of the files downloaded to the phone through the app are ever so slightly larger, as seen in the snippet below
PS C:\Users\wwilliams\Downloads\immich-20240530_114856> ls
Directory: C:\Users\wwilliams\Downloads\immich-20240530_114856
Mode LastWriteTime Length Name
---- ------------- ------ ----
-a---- 5/30/2024 11:49 AM 1298546 000001510024.jpg
-a---- 5/30/2024 11:49 AM 1299941 IMG_5877.JPG
The bug
I have noticed that the JPG images downloaded from the server in the iOS app slightly vary in size (they look the same visually), which results in duplicate images on the server The PNG images are not affected.
The OS that Immich Server is running on
unraid 6.12.6
Version of Immich Server
1.101.0
Version of Immich Mobile App
1.101.0
IOS 17.4.1
Platform with the issue
Your docker-compose.yml content
Your .env content
Reproduction steps
Relevant log output
No response
Additional information
No response