mirror of
https://github.com/actualbudget/actual.git
synced 2026-05-11 01:18:59 -05:00
[Bug]: Synced files don't belong in synced locations #1178
Closed
opened 2026-02-28 19:35:02 -06:00 by GiteaMirror
·
9 comments
No Branch/Tag Specified
master
cursor/transaction-table-rewrite-f077
cursor/formula-feedback-improvements-4223
MatissJanis-patch-1
claude/hide-default-categories-1cwBZ
claude/fix-mobile-sync-indicators-ustTO
ai/stabilize-bundle-size-compare
ai/release-custom-themes
feature/enable-banking
fix/backend-init-failure-recovery
matiss/crdt-source-loading
release/v26.5.2
release/v26.5.1
claude/plan-ci-secure-context-OtEe1
matiss/crdt-protobuf
release/26.5.0
claude/fix-issue-7667-DPXi3
cursor/resolve-pr-7449-ee11
claude/fix-typescript-build-error-JPtZ5
jfdoming/api-tokens-part-3
jfdoming/api-tokens-part-2
jfdoming/api-tokens-part-1
claude/crdt-version-auto-publish-Ph1BH
copilot/add-repository-configs-to-packages
worktree-compressed-drifting-ritchie
worktree-mellow-strolling-dawn
matiss/browser-api
claude/api-consumer-verification-kfz1K
pr-7454
claude/fix-issue-7410-LLLQ4
revert-7350-trim-deps
revert-7220-sankey-report
revert-7242-fix/split-parent-update-corruption
revert-7281-generate-icons
claude/electron-to-tauri-migration-LjBN8
worktree-remotion
claude/browser-compatible-api-QbhHh
claude/improve-cli-transactions-waTUY
claude/publish-react-native-ios-j8qoT
js-proxy
claude/fix-flaky-ci-job-5gDdz
react-query-rules
react-query-useSchedules
claude/nightly-theme-validation-scan-DzOGD
claude/debug-simplefin-error-ZuKzB
matiss/desktop-client-subpath-imports
claude/fix-simplefin-ssrf-T31gX
add-claude-github-actions-1772738270730
cursor/sync-performance-notification-9899
react-query-prefs
matiss/chunked-sync-and-progress-ux
v26.2.1
copilot/sub-pr-6880
fix-react-query-clear-on-close-budget
copilot/sub-pr-6140
feat/auto-note
feat/scoped-bank-sync
cursor/desktop-transactions-react-table-1d0c
fix-exhaustive-deps-App
copilot/fix-find-replace-bug
matiss/browser-tests
mobile-fix-drag-and-drop-across-groups
budget-table-v2
PayeeAutocomplete2
pglite
bugfix/plugins/fix-plugins-sw
feat/plugins/plugins-core-package
matiss/unicode-minus-fix
cursor/fix-actual-github-issue-6206-gemini-3-pro-preview-9c37
TransactionFormPage
cursor/implement-mortgage-and-loan-account-type-78ca
tests-update-fill-with-pressSequentially
mobile/link-modal
deps/25.11
cursor/fix-update-vrt-apply-ci-job-dispatch-b324
sync-server-plugins
cursor/propose-patch-for-github-issue-5680-2a18
fix/compiler-preserve-inner-dollar-escapes
cursor/analyze-actual-budget-issue-and-propose-fix-5b70
coderabbitai/docstrings/0c070e5
cursor/add-wip-prefix-and-comment-to-prs-d78d
jfdoming/08-21-auto-focus-on-navigate-in-all-browsers
show-totals-on-mobile-budget-banners
allow-child-transactions-make-transfer
mobile-calculator-keyboard
payee-geolocation
enhance/restore_scroll_position
dm-fix-second-click-on-mobile-new-transaction-2
scrollToLocationBudget
alert-autofix-38
tsconfig-composite
mobile-fix-uncategorized-transactions-on-tracking-budgets
server-budget-handlers
fix-sql-injection-in-cleanup-template
non-chrome-draggable-workaround
mobile-budget-page-swipe-navigation
ts-db-all
stable
dark-theme-with-brand-colors
fix-mobile-delete-group
ts-db-select
UnderKoen/reconcile-context-menu
master-before-server-merge
v25.2.1
ts-runQuery
rename-redux-hooks
UnderKoen/3557-persist-state-in-history
remove-redux-CLOSE_BUDGET
fix-exhaustive-deps-errors-FinancesApp
redux-toolkit-createSlice-backup
accounts-function-component
ts-useSplitsExpanded
loot-core-server-package
useTransactios-in-TransactionEdit
react-aria-input
move-redux-to-desktop-client
QueryState-type
fix-themes-applied-late
mobile-vrts
revert-3295-spendingCardFix
react-aria-button-4
split-payee-on-mobile
twk3/pin-apis-crdt
notes-tag-autocomplete
ts-LoadBackup
dnd-kit
package-upgrades
v26.5.2
v26.5.1
v26.5.0
v26.4.0
v26.3.0
v26.2.1
v26.2.0
v26.1.0
v25.12.0
v25.11.0
v25.10.0
v25.9.0
v25.8.0
v25.7.1
v25.7.0
v25.6.1
v25.6.0
v25.5.0
v25.4.0
v25.3.1
v25.3.0
v25.2.1
v25.2.0
v25.1.0
v24.12.0
v24.11.0
v24.10.1
v24.10.0
v24.9.0
v24.8.0
v24.7.0
v24.6.0
v24.5.0
v24.4.0
v24.3.0
v24.2.0
v24.1.0
v23.12.0
v23.11.0
v23.10.0
v23.9.0
v23.8.1
v23.8.0
v23.7.2
v23.7.1
v23.7.0
v23.6.0
v23.5.0
v23.4.2
v23.4.1
v23.4.0
v23.3.2
v23.3.0
v23.2.9
v23.2.5
v23.1.12
v22.12.9
Labels
Clear labels
AI generated
API
bank sync
budgeting
bug
can’t replicate
dependencies
docker
documentation
electron
experimental feature
feature
feedback
goal templates
good first issue
help wanted
importers
maintenance
needs info
needs testing
needs triage
needs votes
openid
payees
pull-request
regression
reports
responsive
rules
schedules
server
✨ merged
split transactions
tech debt
theme
transaction import
transaction reconciliation
transactions
translations
upstream
user interface
✅ approved
wontfix
Mirrored from GitHub Pull Request
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: github-starred/actual#1178
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 @MikeBishop on GitHub (Jun 29, 2024).
Verified issue does not already exist?
What happened?
Now that the desktop client is back, #317 is relevant again. The Actual Desktop client stores the files in Documents. However, the Documents folder is often a synced location under Windows; I presume other OSes do something similar. Having Windows/OneDrive syncing the files while Actual is also trying to sync the files is asking for trouble.
The right place to put files like this on Windows is %LOCALAPPDATA%, a location for data which Windows should maintain locally for the user without attempting to sync it.
Where are you hosting Actual?
Docker
What browsers are you seeing the problem on?
Desktop App (Electron)
Operating System
Windows 11
@MikesGlitch commented on GitHub (Jun 30, 2024):
This is a good point.
I've been wanting the ability to configure where the data directory and backup directory are located, maybe that deserves it's own ticket.
We could have a default, which would take the OS default and an override allowing you to put it somewhere else.
I use Google drive to sync but it's always one way for Actual so I don't get the conflicts.
@MikesGlitch commented on GitHub (Jul 25, 2024):
I have a partial fix for this here:
https://github.com/actualbudget/actual/pull/3133
We can't change where the files are for existing budgets - it would freak the user out if we started moving existing files without consent.
Instead we have this data dir location picker (visible on electron in the Settings page):

It will change the directory where Actual looks for the files. This should allow you to move your budget files to wherever you want (away from folders that may be synced).
In a future PR
We can change the default directory on Windows, and ensure existing budgets still look in the directory they were created in.
@MikesGlitch commented on GitHub (Sep 4, 2024):
I've changed my opinion on this. We've enabled the functionality to change the users data directory so I don't think this is a problem anymore.
The default location is the
Documentsdirectory, which is easy for the user to find and navigate to.If we set the default directory to
C:\Users\THEUSER\AppData\Local\Actualit would be much harder to find (AppData is a hidden folder and most people don't go digging in there).I'm going to close this. If anyone feels like this is the wrong approach please comment and we can reopen & discuss.
@MikeBishop commented on GitHub (Sep 4, 2024):
I feel like the right answer depends on whether you're connected to a server or not. If you're running stand-alone, then the files should be somewhere user-accessible in case they want to relocate them. Documents is probably correct.
But if you're syncing from a server, the server is the authoritative copy and the local version is a cache / for temporary offline use. There's no need for the user to find these files on the client; only on the server. That's what belongs in AppData, and putting them in Documents is asking for sync errors.
Is it possible to flip the default based on whether Actual is using a server or not, perhaps?
@MikesGlitch commented on GitHub (Sep 4, 2024):
Actual works in a "local first" way, so the local copy of the database is the authoritative copy. The server may or may not have the most up to date data. We'll always need the files on the Electron client - Electron doesn't use indexdb to store its data.
I don't see how syncing your Budget via OneDrive/whatever would cause sync errors. Even if your Document directory was being synced to the data directory on your server, there shouldn't be sync errors because the files are different.
I'm not sure this makes sense because of the point above.
I might be missing something, let me know.
@MikeBishop commented on GitHub (Sep 4, 2024):
To be clear, it doesn't cause sync errors in Actual. It causes sync errors in OneDrive or whatever is syncing the files.
When Documents is being synced between two computers, each of which has a local copy of the file and can makes changes. If Actual is using a sync server, it can upload the changes to the server and fetch changes uploaded by other clients, folding the contents together through its own sync process. OneDrive will just create two copies of the file and tell you to go fix it.
I think my larger point is that if there's a sync server, you always want that server to be the one intermediating between clients; storing the file in a synced location has a third-party who can't interpret the file doing that instead. Better than nothing, but worse than a sync server.
@MikesGlitch commented on GitHub (Sep 4, 2024):
Ahh OK, I see what you mean now. You've got two syncs going on - Actual's server sync and another file system sync. If two clients are running at the same time and listening to the file system sync while also syncing to Actual Server you get conflicts.
OK I'm torn. This seems like an edge case but your saying that OneDrive two-way syncs the Documents directory by default?
If so, that's annoying and might catch out non-techie users if they run Actual on multiple clients with OneDrive syncing.
I still don't like the idea of putting the users budget in the hidden AppData folder.
I can see a middle ground here. Maybe the solution is to prompt the user when they first create the budget asking "Where would you like to store this budget?". They select a file location, and we warn them about the dangers of using both file system sync and the server sync at the same time. And the dangers of using file system sync at all for that matter.
This would require a bit of work because currently all budgets are stored in the same folder.
If you're happy with this and think it'll solve the issue, I can create a new feature request.
@MikeBishop commented on GitHub (Sep 5, 2024):
Yes, I think that would cover it. A few thoughts on that approach:
@MikesGlitch commented on GitHub (Sep 5, 2024):
Cool, I've made the feature request here: https://github.com/actualbudget/actual/issues/3371
Feel free to provide feedback on the ticket & vote up!