mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-09 19:52:56 -05:00
[Bug]: Time disagreement causes sync to fail without explanation #1566
Closed
opened 2026-02-28 19:47:20 -06:00 by GiteaMirror
·
6 comments
No Branch/Tag Specified
master
claude/fix-simplefin-batch-sync-O8LcD
matiss/modal-and-server-refactor
claude/fix-simplefin-ssrf-T31gX
claude/release-notes-validation-X7rvR
ai/custom-theme-dual-prefs
matiss/fix-6804
add-claude-github-actions-1772738270730
react-query-rules
react-query-useSchedules
matiss/separate-lint-format
dependabot/npm_and_yarn/ajv-6.14.0
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
release/v26.2.0-pre
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
prerelease
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.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#1566
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 (Nov 4, 2024).
Originally assigned to: @MatissJanis, @Copilot on GitHub.
Verified issue does not already exist?
What happened?
Due to external confluence of circumstances, my laptop wound up being an hour off from the correct time. When Actual attempted to sync, it told me that there was a "problem syncing your changes" but didn't give any information about what the problem was. If the file was deleted locally, attempting to redownload produced this message:

It would be preferable to display something about time disagreement, etc. to point the user in the direction of identifying the failure. I don't think Actual needs to create custom error messages for this specific case, but if the error that appears in the browser console (something about "maximum clock drift exceeded") made it a little higher in the stack, this would have been much easier to find and fix.
Where are you hosting Actual?
Docker
What browsers are you seeing the problem on?
Chrome, Desktop App (Electron)
Operating System
Windows 11
@jmuzina commented on GitHub (Jan 31, 2025):
I'm having this issue as well. I have a server hosted on Pika Pods, and a dual boot setup with Ubuntu & Windows 11. I use Firefox to access a web client. I was initially editing the budget on Ubuntu.
I switched to the Windows partition, and began editing my budget. At some point, I noticed that my Windows time was 5 hours ahead the real time (I live in UTC -5 timezone) due to the difference in how Linux & Windows sync their clocks to the hardware clock (see article for more).
I disabled and re-enabled the Windows "Set time automatically" setting to fix my clock.
Then, whenever I make any change in the Actual client, the following toast appears:
This error is printed to the console:
Restarting the server on PikaPods did not help, nor did restarting my computer.
This is probably related to https://github.com/actualbudget/actual/issues/1040
Looks like the error is thrown here:
64df0e107c/packages/crdt/src/crdt/timestamp.ts (L214-L216)@egozalor commented on GitHub (Mar 31, 2025):
I'm facing this bug as well.
Re-synced my Windows 10 time to match the new daylight savings time with the Actual desktop app open and now I'm experiencing the same error. I can't sync changes from any device or OS. Restarting the Pikapods server or the computer did indeed not help, nor did going back to the previous time.
Has anyoned found a fix? I'm afraid that my budget file has been permanently affected. I'm no developer, but those comments about the Merkle tree in https://github.com/actualbudget/actual/issues/1040 sound scary.
@egozalor commented on GitHub (Apr 2, 2025):
I don't know what happened but after a couple of days everything has gone back to normal. I tried editing my budget from my Linux client today, and no error was thrown. Now it works from all other devices, including my Windows install where the error started.
I have no clue what fixed it, but I'm happy to support troubleshooting if I can contribute in any way.
@justinberry commented on GitHub (May 11, 2025):
I just came across this issue with one of my devices having its time set too far in the future. In general I think the issue is reproducible via:
Given any client of Actual
When the time is too far forward in the future (just set the clock forward manually)
And the client submits anything
Then any subsequent submissions from any client with a time greater than 5 minutes before this incorrect future date will fail to sync.
Hacky fix
Hack the
configvariable in timestamp.ts to cover the drift in time:Now I will simply wait until until the drift time has elapsed in real time then undo the hack, then I'm hoping it all just works again 🤞
An actual fix?
I'm not too familiar with Merkle trees but I suspect the tree might need reconstruction to fix this properly? Could this be a possible maintenance action that the user could choose to do?
Otherwise I suppose the server might need to act as an authoritative source of time and block anything too far in the future?
Happy to submit a PR to address this.
@MikeBishop commented on GitHub (Nov 10, 2025):
Yes, I think this is the correct fix. The block occurs too late -- the malformed data is already in the tree by the time the server realizes there's a problem. We need to prevent the submission of updates by a client whose view of time diverges from the server too much, so only clients with a bad clock hit the error rather than only clients with a correct clock.
@bijeebuss commented on GitHub (Nov 11, 2025):
ok I seem to have gotten myself into this situation. Im running v25.11.0 on both server and client. In the console I see
I did have my timezone set wrong on my Mac but now its fixed and Im still getting this error on all devices