mirror of
https://github.com/immich-app/immich.git
synced 2026-02-05 00:30:57 +03:00
[TECH-DEBT] Mobile upload refactor #886
Closed
opened 2026-02-04 23:19:35 +03:00 by OVERLORD
·
29 comments
No Branch/Tag Specified
main
feat/asset-file-apis
chore/translations
fix/web-switch-label-clickable
fix/web-people-hidden-state
renovate/typescript-projects
release/next
fix/timezones
fix/time-zone-upserts
midzelis/wip
push-zpwsovysllvn
push-nwxlpmyzkyrl
push-nvnkszuqwppm
renovate/github-actions
push-smstsuupsowp
refactor/adaptive_image
push-olwpzvrxnomt
push-lmxsupnmxspl
renovate/machine-learning
feat/web-chromecast-video-looping
feat/use-native-clients
renovate/flutter
fix/create-face-edited
fix/mobile-ios-mtls
docs/contributing
docs/mise-mobile
renovate/grafana-monorepo
feature/bottom-buttons-order
feat/immich-mobile-ui-showcase
refactor/consolidate-image-requests
renovate/connectivity_plus-7.x
renovate/major-vitest-monorepo
renovate/pypi-python-multipart-vulnerability
fix/mobile-people-query
sqlite_thumbs
feat/html-text
chore/no-macro-validation
refactor/purchase-store
uhthomas/mobile-fix-app-bar-fade
uhthomas/mobile-fix-asset-jump
feat/pano-ocr
feat/shared-link-login
fix/database-backup-db-names
fix-keep-correct-ios-shared-album-asset
fix-memory-generation-and-display
feat/verify-permissions
refactor/album-service-small-tests
fix/ml-rocm-build
fix/flipped-dimensions-mobile
push-vpxwmwwxwnvw
fix-migration-width-height
refactor/more-queries
revert/prettier-translations
refactor/asset-service-queries
fix/locale-settings-desc
chore/add-debug-log
feat/edit-filters
shared-deep-link-handler
feat/mobile-editing
feat/thumbnail-native-clients
feat/platform-clients
feat/integrity-checks-izzy
fix/foreground-cloud-sync
feat/dynamic-layout
filter-by-person
feat/csp
refactor/sidebar
fix/disable-editing
fix/view-timeline-deeplink
image-zoom-on-slow-connection
fix-consider-dar-for-video-dimension
fix/merged-edited-assets
perf/optimize-album-sort
open-api-fix
feat/create-job-with-dto
use-toast-primary
feat/vitest-4
feat/ios-fastlane-match
match-signing
fix-update-time-update-timeline
chore/translation-keys
feat/modal-routes
feat/panorama-tiles
feature/mobile-view-asset-owner
feat/system-settings
feature/show-activity-count
better-info-in-asset-viewer
fix/all-people-count
feat/location-favorites
feature/rearrange-buttons-2
fix/download-storage-template
feat/kb-shortcuts-mobile
fix/people-count
push-qolzzzzxrvvn
chore/originals-in-asset-files
feat/asset-size-columns
ben/tree-a11y
new-search-filter-ui
refactor/expectSelectedReadonly
refactor/mobile-grdb
push-qvuktpxmkknu
feat/mobile-native-local-sync
refactor/timeline_ops
fix/scrubber_end
feat/version.txt
feat/context-menus
feat/server-chunked-uploads
refactor/virtualsegment
refactor/rename_daymonth_groups
fix/restrict-android-bg-worker
feat/android-periodic-worker
fix-remote-sync-clean-up
refactor/timeline_move_ops
renovate/mapbox-mapbox-gl-rtl-text-0.x
fix/timeline_split_selectable
feat/keyboard_actions_help_modal
feat/static_frontend
feat/notification-warnign-android
feat/plugins2
feat/plugins
test/create-workflow-token-action
fix/docs-force
debug/search-result-similarity
debug/cf-chunked-uploads
feat/eslint_rule
feat/search-filter-album/web
refactor/timeline_photostream
refactor/timelineasset_asset
feat/session-permissions
feat/timeline_photostream_assetnav
feat/timeline_minor_optimize
feat/timeline_perf_nocomp
feat/timeline_search_results_actions
feat/timeline_search_results_page
fix/timeline_padding
fix/timeline_search_reactivity_warnings
feat/timeline_scrollbar
feat/timeline_stream_withviewer
fix/timeline_back_forth_nav
refactor/timeline_photostream_component
fix/generated-files-checks
fix/locate-button-local
chore/base-image-mimalloc
refactor/timeline_assetlayout
refactor/timeline_selectable
refactor/timeline_aware_actions
refactor/timeline_monthsegment
feat/remove-old-pages
chore/deps-gradle
tmp_photostream
tmp/lcms
feat/mobile-dynamic-thumbnails
fix/mobile-finer-thumbnail-concurrency
refactor/timeline1
refactor/extract_photostream
refactor/rename_load_api
refactor/timeline2
refactor/timeline3
feat/multi-select-asset-viewer
feat-no-thumbhash-cache
refactor/asset_grid
feat/faster-access-checks
fix/18991
fix/19543
chore/temp-remove
fix/21419
feat/mobile-hdr-images
chore/update-mise-lockfile
feat/mise-server-checks
feat/mise-ci
feat/windows-2025
feat/dev_cli
refactor/mobile-migrate-clients
fix/map-theme
fix/require-checkbox
chore/use_swc
feat/efficient-thumbnail-decoding
refactor/mobile-thumbhash
refactor/mobile-thumbhash-new
fix/mobile-uncached-zoom
feat/beta-background-upload
fix/beta-timeline-memories-setting
fix/failed-uploads-not-removed
feat/mobile-shared-album
feat/groups
drift-map-page
drift-auth-user-sync
fix/disable-memory
feat/add-to-album-action
edit-date-time-action
drift-people-page
sqlite-remove-isIn
feat/inline-storage-columns
chore/required-reviewers
refact/asset-manager
fix/folder-sort
pnpm
feat/widget-multiple-server-urls
chore/medium-tests-dbname
fix/web-no-iterator-find
fix/map-pan-interruption
track-livephotos
timeline_events
chore/oxlint-migration
feat/maintenance-worker
feat/dav
chore/demo-snapshot
refactor/server-side-dedupe
feat/integrity-checks
dev/recognition-eval
lighter_buckets_test
perf/postgres-queue
postgres-queue
focus_rings
refactor/web-stores-1
refactor/add-to-taken
feat/sort-places
feat/sidecar-asset-file
vet
tmp/demo-snapshot-preview
fix/server-migration-file-extension
refactor/mobile-v2
fix/asset-update-race-condition
rknn-toolkit-lite2
refactor/mobile-split-up-search-page
feature/Add-rocm-support-for-machine-learning
feat/rocm
chore/async-hash-file
feat/shared-link-view-count
feat/rotation
feat/graphql
feat/job-ids
feat/ignore-library-permission-error
feat/docker-compose-builder
feat/kysely-typeorm
mobile/onboarding
no-video-player
fix/server-qsv-output-format
chore/server-geodata-tweaks
mobile/native-video-player-no-hero
feat/xxhash
fix/docs-concurrency
feat/preload-ml-textual-model
feat/local-tileserver
refactor/exif-orientation
original-path-infix
refactor/mobile/login-form-1
feat/server-editor-endpoints
fix/server-qsv-vbr
fix-mobile-db-problems
feat/ml-armnn-conversion
feat/mobile/backup-with-album-info
feat/fast-initial-sync-1
chore/handle-output_dims
feat/server-more-robust-generation
feat/unassign-faces
feat/shortcuts-on-asset-grid
feat/background-upload
feat/capacitor-mobile-app-poc
feat/server-nvenc-hw-decoding
release/v1.105
fix/mobile-fetch-non-archive
feat/fine-grained-access-controls
web/automation-ui
feat/mobile-server-endpoint-save-dropdown
feat/blurhash-thumbnail
object-storage
feat/memories-animations
dev/metrics
ml/tflite
feat/ml-export-cli
v2.5.3
v2.5.2
v2.5.1
v2.5.0
v2.4.1
v2.4.0
v2.3.1
v2.3.0
v2.2.3
v2.2.2
v2.2.1
v2.2.0
v2.1.0
v2.0.1
v2.0.0
v1.144.1
v1.144.0
v1.143.1
v1.143.0
v1.142.1
v1.142.0
v1.141.1
v1.141.0
v1.140.1
v1.140.0
v1.139.4
v1.139.3
v1.139.2
v1.139.1
v1.139.0
v1.138.1
v1.138.0
v1.137.3
v1.137.2
v1.137.1
v1.137.0
v1.136.0
v1.135.3
v1.135.2
v1.135.1
v1.135.0
v1.134.0
v1.133.1
v1.133.0
v1.132.3
v1.132.2
v1.132.1
v1.132.0
v1.131.3
v1.131.2
v1.131.1
v1.131.0
v1.130.3
v1.130.2
v1.130.1
v1.130.0
v1.129.0
v1.128.0
v1.127.0
v1.126.1
v1.126.0
v1.125.7
v1.125.6
v1.125.5
v1.125.4
v1.125.3
v1.125.2
v1.125.1
v1.125.0
v1.124.2
v1.124.1
v1.124.0
v1.123.0
v1.122.3
v1.122.2
v1.122.1
v1.122.0
v1.121.0
v1.120.2
v1.120.1
v1.120.0
v1.119.1
v1.119.0
v1.118.2
v1.118.1
v1.118.0
v1.117.0
v1.116.2
v1.116.1
v1.116.0
v1.115.0
v1.114.0
v1.113.1
v1.113.0
v1.112.1
v1.112.0
v1.111.0
v1.110.0
v1.109.2
v1.109.1
v1.109.0
v1.108.0
v1.107.2
v1.107.1
v1.107.0
v1.106.4
v1.106.3
v1.106.2
v1.106.1
v1.106.0
v1.105.1
v1.105.0
v1.104.0
v1.103.1
v1.103.0
v1.102.3
v1.102.2
v1.102.1
v1.102.0
v1.101.0
v1.100.0
v1.99.0
v1.98.2
v1.98.1
v1.98.0
v1.97.0
v1.96.0
v1.95.1
v1.95.0
v1.94.1
v1.94.0
v1.93.3
v1.93.2
v1.93.1
v1.93.0
v1.92.1
v1.92.0
v1.91.4
v1.91.3
v1.91.2
v1.91.1
v1.91.0
v1.90.2
v1.90.1
v1.90.0
v1.89.0
v1.88.2
v1.88.1
v1.88.0
v1.87.0
v1.86.0
v1.85.0
v1.84.0
v1.83.0
v1.82.1
v1.82.0
v1.81.1
v1.81.0
v1.80.0
v1.79.1
v1.79.0
v1.78.1
v1.78.0
v1.77.0
v1.76.1
v1.76.0
v1.75.2
v1.75.1
v1.75.0
v1.74.0
v1.73.0
v1.72.2
v1.72.1
v1.72.0
v1.71.0
v1.70.0
v1.69.0
v1.68.0
v1.67.2
v1.67.1
v1.67.0
v1.66.1
v1.66.0
v1.65.0
v1.64.0
v1.63.2
v1.63.1
v1.63.0
v1.62.1
v1.62.0
v1.61.0
v1.60.0
v1.59.1
v1.59.0
v1.58.0
v1.57.1
v1.57.0
v1.56.2
v1.56.1
v1.56.0
v1.55.1
v1.55.0
v1.54.1
v1.54.0
v1.53.0
v1.52.1
v1.52.0
v1.51.2
v1.51.1
v1.51.0
v1.50.1
v1.50.0
v1.49.0
v1.48.1
v1.48.0
v1.47.3
v1.47.2
v1.47.1
v1.47.0
v1.46.1
v1.46.0
v1.45.0
v1.44.0
v1.43.1
v1.43.0
v1.42.0_65-dev
v1.41.1_64-dev
v1.41.0_64-dev
v1.40.1_63-dev
v1.40.0_63-dev
v1.39.0_61-dev
v1.38.2_60-dev
v1.38.1_60-dev
v1.38.0_60-dev
v1.37.0_58-dev
v1.36.2_56-dev
v1.36.1_55-dev
v1.36.0_55-dev
v1.35.0_54-dev
v1.34.0_53-dev
v1.33.1_52-dev
v1.33.0_52-dev
v1.32.1_51-dev
v1.32.0_50-dev
v1.31.1_49-dev
v1.31.0_49-dev
v1.30.2_48-dev
v1.30.0_46-dev
v1.29.6_45-dev
v1.29.6_44-dev
v1.29.5_44-dev
v1.29.4_44-dev
v1.29.3_43-dev
v1.29.2_43-dev
v1.29.1_43-dev
v1.29.0_42-dev
v1.28.4_41-dev
v1.28.4_42-dev
v1.28.3_41-dev
v1.28.2_40-dev
v1.28.1_39-dev
v1.28.0_38-dev
v1.27.0_37-dev
v1.26.0_36-dev
v1.25.0_35-dev
v1.24.0_34-dev
v1.23.0_33-dev
v1.22.0_32-dev
v1.21.1_31-dev
v1.21.0_31-dev
v1.20.3_30-dev
v1.20.2_30-dev
v1.20.1_30-dev
v1.20.0_30-dev
v1.19.1_29-dev
v1.19.0_29-dev
v1.18.0_27-dev
v1.17.0_25-dev
v1.16.0_23-dev
v1.15.1_21-dev
v1.15.0_21-dev
v1.14.0_21-dev
v1.13.0_20-dev
v1.12.0_18-dev
v1.11.0_17-dev
v1.10.0_15-dev
v1.9.1_14-dev
v1.9.0_13-dev
v1.8.0_12-dev
v1.7.0_11-dev
v1.6.0_10-dev
v1.5.1+9-dev
v1.5.0+8-dev
v1.4.0+7-dev
v1.4.0+6-dev
v1.4.0-dev
v1.3.0-dev
v1.3.1-dev
v0.6-dev
v0.5-dev
v0.4-dev
v0.3-dev
v0.2-dev
first-android-release
Milestone
No items
No Milestone
Projects
Clear projects
No project
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: immich-app/immich#886
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @alextran1502 on GitHub (May 25, 2023).
Originally assigned to: @alextran1502 on GitHub.
Now that the support for client-side hashing has been merged into the server.
It is time to look at some long-standing issues with uploading assets from the mobile app that have been reported, such as
The plan is to refactor the uploading code to make it cleaner as well as include new hashing and error handling mechanism
@Dental1347 commented on GitHub (May 26, 2023):
May I add some things? I don't know if they're in scope of this issue:
If it is not, feel free to ignore my suggestions.
@Sherlock1979 commented on GitHub (May 29, 2023):
I have experienced number 3 several times.
@Vcele commented on GitHub (May 29, 2023):
I would also love to see two way sync, so that if I delete a photo on the web it also gets removed on my phone. Maybe one could implement an out of sync warning like GPhotos does 😁
@alextran1502 commented on GitHub (May 29, 2023):
@Vcele That would be a separate feature which we will implement in the future
@phrodide commented on GitHub (May 31, 2023):
it seems #1 is linked to file size. 1GB or more is suspect.
@Dental1347 commented on GitHub (Jun 1, 2023):
I just came across something which I orignally never thought of. I myself don't have this, but my direct family does. They have albums on their phones which span over multiple years. It is currently absolutely impossible to add all these pictures manually to the album that has to be manually created within immich. The photos cross around many years. If, the albums were directly created on upload and the the assets automatically added (Also future assets for that album), that would make immich so incredibly powerful for mobile backups.
Originated from general discussion within discord.
@chriexpe commented on GitHub (Jun 21, 2023):
I just wanted to add another thing, to attach a tag to the photo with the name of the album/folder it came from, so you could later create a album or filter out just the pictures that you took (DCIM>Camera) or screenshots (DCIM>Screenshots).
@jeverling commented on GitHub (Jul 11, 2023):
Please make this feature optional 🙃
@codeinabox commented on GitHub (Aug 4, 2023):
I too have experienced the negative counter, is there any way to fix it? As it's negative, it's unclear if any photos still need to be backed up or not
@alextran1502 commented on GitHub (Aug 4, 2023):
@codeinabox you can fix it by either clear the app cache or reinstall the app
@yurividal commented on GitHub (Oct 30, 2023):
Please consider option to pause a current upload. This is useful when the user is in an area with low cell coverage, and takes a video.
I had barely any service, and shot a video.
Immich kept trying to upload that video for hours, consuming all of the little bandwidth i had.
@alexchomiak commented on GitHub (Jan 29, 2024):
Peeking in :) ( I love this project )
These features would be amazing, and is the only thing stopping me from downloading Immich on all of my devices at the moment.
Downloading Immich on multiple IOS devices leads to the entire library having to be re-synced. (even though duplicates aren't created. Waiting on the full file uploads for a MD5 Hash check is killing a ton of time)
With the recent launch of external libraries, this would be amazing for quickly syncing iCloud. (as I recently corrupted my Immich Postgres database & have had to resync my app. (leading to the same upload/hash check loop)
Update: This is probably a better issue for me to track on my end:
https://github.com/orgs/immich-app/projects/1/views/1?pane=issue&itemId=29492098
@SandiyosDev commented on GitHub (Apr 14, 2024):
@alexchomiak You can indeed sync iCloud by binding the photo.photolibrary-Originals folder as a read-only external library in Immich, enable the watcher and it will sync automatically, though some exif-less photo's creation date will be wrong because its based on the date its synced from icloud, and not its original capture date.
@Serinus1 commented on GitHub (Jun 7, 2024):
Like whe ln you're in a tourism area taking pictures? Yes, a snooze or pause button the notification would be very nice. This could be a separate issue.
Posting live from use case #jungfrau
@TobiPeterG commented on GitHub (Jun 22, 2024):
Hey there, I'm not sure if this issue has already been reported, at least I didn't find a similar issue.
On my Android phone, the synchronization doesn't seem to work properly. For about 2 weeks, my phone has been trying to sync my photos and Videos (I didn't take any new) and the counter of to be synced Videos sometimes increases, but stays at around 624.
Also, it seems that the app continues to sync with mobile data, even though this option is disabled (the app used 9GB of mobile data this month lol)
Are you aware of these issues? Do you need any additional information?
@xdaniel9 commented on GitHub (Jul 8, 2024):
It would be great to add the feature to select upload destination for mobile app for users have more than one device, eg iphone, ipad, android phones
@TriplEight commented on GitHub (Dec 10, 2024):
While Remainder == 0, I have several videos stuck in the upload queue. Some videos 100-900 Mb just keep being uploaded over and over.
No logs on the server side.
I have not negative, but Total amount < Backup in Android app.
@TriplEight commented on GitHub (Dec 16, 2024):
Uploading the files that are stuck leads to an error:
Renaming these files won't help.
Verbose log of the server app has nothing useful about this.
@bo0tzz commented on GitHub (Dec 16, 2024):
You're using something with a body size limit in front of Immich. Usually either a reverse proxy or Cloudflare. See https://immich.app/docs/administration/reverse-proxy
@TriplEight commented on GitHub (Dec 17, 2024):
@bo0tzz yes I use cloudflared w default config. And you were right, it was the cause.
I'll leave a workaround for this here:
@suzucappo commented on GitHub (Feb 28, 2025):
Similar/Same issue here on two different phones.
Edit: I first found issue 5994 which seemed to be pushed over to here, but was closed (I think due to it being related to CloudFlare issues) However as I noted below I am strictly using local network access for testing and have turned off the domain link in the app for those purposes. If this needs to go somewhere else please let me know.
Server Version
1.127.0
Mobile App Version
1.127.0 b.185
Galaxy S23 Ultra
Unrestricted battery usage
Location access all the time
Background mobile data usage enabled
DCIM/Camera directory selected as backup location
Pixel 9 Pro (GrapheneOS)
Unrestricted battery usage
Location access all the time
Background mobile data usage enabled
DCIM/Camera directory selected as backup location (through storage scope)
Both devices function exactly the same in terms of the issue.
I do have a proxy through CloudFlare to my domain but for testing purposes am using local network access.
Failover to domain works when not on local network, and proceeding to use local network when it is recognized is working when the app is opened.
Unrestricted battery usage is for sure working on the Pixel as I have some other apps that run in the background for work and school notifications etc.
Here are a couple of logs from my Pixel
App running in background (still in the open apps drawer) >> took 3 pictures and there is a change in the log that seems to imply that the app is trying or waiting to backup files.
`02-28 19:33:28.923 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:33:39.212 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:34:00.218 27257 1392 D BackupWorker: enqueueBackupWorker: BackupWorker enqueued
02-28 19:34:16.358 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:34:32.240 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:34:39.219 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:34:44.897 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:34:47.995 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:35:03.881 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:35:07.045 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:35:22.843 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:35:32.403 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:35:32.946 27257 27905 D BackupWorker: enqueueBackupWorker: BackupWorker enqueued
02-28 19:35:39.227 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:35:54.583 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.`
The above JobService output continues until this time stamp.
02-28 19:36:54.731 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.Brought app to foreground >> Backup service starts > Files backed up > Flip over to the home screen so immich is in the background and the JobService output starts again.
`--------- switch to events
02-28 19:37:08.509 27257 27257 I wm_on_restart_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=performRestart,time=0ms]
02-28 19:37:08.511 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=applyTransactionOnDraw applyImmediately]
02-28 19:37:08.511 27257 27257 I wm_on_start_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=handleStartActivity,time=1ms]
02-28 19:37:08.519 27257 27257 I wm_on_resume_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=RESUME_ACTIVITY,time=1ms]
02-28 19:37:08.519 27257 27257 I wm_on_top_resumed_gained_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=topWhenResuming]
02-28 19:37:08.520 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=applyTransactionOnDraw applyImmediately]
--------- switch to main
02-28 19:37:08.523 27257 27291 I flutter : [APP STATE] hidden
02-28 19:37:08.524 27257 27291 I flutter : [APP STATE] inactive
--------- switch to events
02-28 19:37:08.533 27257 27257 I surfaceview_layout: [window=SV[162700059 MainActivity],format=4,width=960,height=2142,z=-2,sizeFrom=layout,attached=1,lifecycleStrategy=0,viewVisible=1]
02-28 19:37:08.535 27257 27257 I surfaceview_callback: [window=SV[162700059 MainActivity],callback=surfaceCreated]
02-28 19:37:08.537 27257 27257 I surfaceview_callback: [window=SV[162700059 MainActivity],callback=surfaceChanged -- format=4 w=960 h=2142]
02-28 19:37:08.537 27257 27257 I surfaceview_callback: [window=SV[162700059 MainActivity],callback=surfaceRedrawNeeded]
02-28 19:37:08.538 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=Start draw after previous draw not visible]
02-28 19:37:08.555 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=reportDrawFinished seqId=0]
--------- switch to main
02-28 19:37:08.580 27257 27291 I flutter : [APP STATE] resumed
02-28 19:37:08.631 27257 27291 I flutter : [INFO] [2025-02-28 11:37:08.631070] [_resumeBackup] Start back up
02-28 19:37:08.631 27257 27291 I flutter : Start backup process
02-28 19:37:08.659 27257 27291 I flutter : [INFO] [2025-02-28 11:37:08.659477] Found 2 local albums
02-28 19:37:08.708 27257 27291 I flutter : [INFO] [2025-02-28 11:37:08.707949] _getBackupAlbumsInfo: Found 2 available albums
02-28 19:37:08.708 27257 27291 I flutter : _getBackupAlbumsInfo takes 76ms
02-28 19:37:10.365 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:37:11.605 27257 27257 D ContentObserverWorker: enabled ContentObserverWorker
02-28 19:37:11.792 27257 27291 I flutter : [INFO] [2025-02-28 11:37:11.792610] Upserted 6 assets into the DB
02-28 19:37:11.794 27257 27291 I flutter : refreshRemoteAssets full took 89ms
02-28 19:37:11.854 27257 27291 I flutter : [INFO] [2025-02-28 11:37:11.853990] Found 2 device albums
02-28 19:37:11.854 27257 27291 I flutter : [INFO] [2025-02-28 11:37:11.854353] 'Recents' is not selected, keeping only selected albums
02-28 19:37:12.114 27257 27291 I flutter : [INFO] [2025-02-28 11:37:12.114400] Synced changes of local album Camera to DB
02-28 19:37:12.172 27257 27291 I flutter : [INFO] [2025-02-28 11:37:12.172317] Removed 0 and updated 3 local assets from DB
02-28 19:37:12.172 27257 27291 I flutter : [INFO] [2025-02-28 11:37:12.172566] Syncing completed. Changes: true
02-28 19:37:12.172 27257 27291 I flutter : refreshDeviceAlbums took 378ms
02-28 19:37:12.172 27257 27291 I flutter : changedUsers: true, newRemote: true, newLocal: true
02-28 19:37:12.172 27257 27291 I flutter : [INFO] [2025-02-28 11:37:12.172668] Load assets: 556ms
02-28 19:37:12.172 27257 27291 I flutter : Attempting to connect to websocket
02-28 19:37:12.200 27257 27257 D ContentObserverWorker: enabled ContentObserverWorker
02-28 19:37:12.200 27257 27291 I flutter : Established Websocket Connection
02-28 19:37:12.717 27257 27270 W app.alextran.immich: Reducing the number of considered missed Gc histogram
windows from 315 to 100
--------- switch to events
02-28 19:37:14.780 27257 27257 I wm_on_top_resumed_lost_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=topStateChangedWhenResumed]
02-28 19:37:14.782 27257 27257 I wm_on_paused_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=performPause,time=0ms]
--------- switch to main
02-28 19:37:14.782 27257 27291 I flutter : [APP STATE] inactive
02-28 19:37:15.032 27257 27257 D VRI[MainActivity]: visibilityChanged oldVisibility=true newVisibility=false
--------- switch to events
02-28 19:37:15.035 27257 27257 I surfaceview_layout: [window=SV[162700059 MainActivity],format=4,width=960,height=2142,z=-2,sizeFrom=layout,attached=1,lifecycleStrategy=0,viewVisible=0]
02-28 19:37:15.036 27257 27257 I surfaceview_callback: [window=SV[162700059 MainActivity],callback=surfaceDestroyed]
02-28 19:37:15.054 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=applyTransactionOnDraw applyImmediately]
02-28 19:37:15.054 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=applyTransactionOnDraw applyImmediately]
02-28 19:37:15.055 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=Not drawing due to not visible. Reason=!mAppVisible && !mForceDecorViewVisibility]
02-28 19:37:15.060 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=applyTransactionOnDraw applyImmediately]
02-28 19:37:15.061 27257 27257 I wm_on_stop_called: [Token=#########,Component Name=app.alextran.immich.MainActivity,Reason=STOP_ACTIVITY_ITEM,time=2ms]
02-28 19:37:15.067 27257 27257 I viewroot_draw_event: [window=VRI[MainActivity],event=applyTransactionOnDraw applyImmediately]
--------- switch to main
02-28 19:37:15.158 27257 27291 I flutter : [APP STATE] hidden
02-28 19:37:15.158 27257 27291 I flutter : [APP STATE] paused
02-28 19:37:15.158 27257 27291 I flutter : Attempting to disconnect from websocket
02-28 19:37:15.159 27257 27291 I flutter : Disconnect to Websocket Connection
02-28 19:37:16.597 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.
02-28 19:37:19.756 27257 27257 W JobService: onNetworkChanged() not implemented in androidx.work.impl.background.systemjob.SystemJobService. Must override in a subclass.`
Please let me know if these are helpful in any way or if there are other logs I could grab that may assist in getting the background upload working.
@alextran1502 commented on GitHub (Feb 28, 2025):
@garcia1987 the bug you described is fixed and waiting on app store approval on v1.128.0
@suzucappo commented on GitHub (Feb 28, 2025):
Awesome, thank you for letting me know.
Great work you all are doing here!
@polaroidkidd commented on GitHub (May 31, 2025):
In the department of error reporting, are there plans to include any user feedback when an upload fails? I am asling because I recently started using immich and discovered that the uploads were all blocked by a cloudflare OWASP configuration.The gist is that the CF WAF assigns a number for certain characteristics of a request and a score to each of those. It adds them all up for each request and declinens it if it goes beyond a set threshold. The threshold is set by the user.
This all happens before the immich server is reached. CF does return an error code though.
Anyway, the app doesn't handle this currently. I propose to include the following for dealing with said scenario
I can provide the CF logs if you're interested. The post to /API/assets did trigger a larger number of warnings. Maybe that's something that should be evaluated as these WAF rules are OSWAP spec (I think?) and are in the same category as the "managed by cloudflare" rule set. Perhaps there's some credence to them, but I feel like that's a separate task.
Let me know. I'm willing to help out with this.
@tayl commented on GitHub (Jun 2, 2025):
This may be a relevant request for this.. have you thought about refactoring the upload process itself to allow for resuming failed uploads rather than restarting entirely? My mobile network coverage is pretty spotty, and I find that I'll have videos failing upload for days before finally making it up, either by sheer luck or because I happened to be back home and on wifi. Images and shorter videos are fine, it's just larger videos that take more time have a higher chance of the connection dropping.
A side effect of this issue is that my phone will burn through battery and data trying to upload these larger files. Luckily I have unlimited data, but if I didn't, I can see this being a major downside. From the battery and inconvenience standpoint alone it's a pretty big downside.
@bo0tzz commented on GitHub (Jun 2, 2025):
That would be #1674.
@tayl commented on GitHub (Jun 2, 2025):
Ah okay, thanks. I see that was closed and marked only as a "nice to have". For me (and others it seems), this is a pretty critical issue that Immich suffers from. Other solutions in the space don't have this same issue (i.e. Google Photos), so maybe it's still something to look at even as a stretch goal for this issue - IMO it's tech debt.
@bo0tzz commented on GitHub (Jun 2, 2025):
To clarify, it wasn't closed, just locked.
@ngdangtu-vn commented on GitHub (Jul 23, 2025):
I think in my case quota limit is partially a reason of broken. And it still happens after increasing the quota.
Log from server: