mirror of
https://github.com/actualbudget/actual.git
synced 2026-05-06 07:01:45 -05:00
[GH-ISSUE #7282] [Bug]: Initial bank sync account linking does not save last sync time #17271
Closed
opened 2026-04-14 20:10:24 -05:00 by GiteaMirror
·
7 comments
No Branch/Tag Specified
master
claude/hide-default-categories-1cwBZ
matiss/crdt-source-loading
youngcw/unlock-duplicates
matiss/crdt-protobuf
release/26.5.0
claude/update-issue-template-ykMNn
claude/fix-issue-7667-DPXi3
cursor/formula-feedback-improvements-4223
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/speed-up-vrt-workflow-ZAyI5
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
feature/enable-banking
cursor/transaction-table-rewrite-f077
pr-7454
claude/fix-issue-7410-LLLQ4
release/v100.0.0
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
release/vv26.4.0-pre
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
claude/release-notes-validation-X7rvR
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
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.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#17271
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 @JkBoyo on GitHub (Mar 25, 2026).
Original GitHub issue: https://github.com/actualbudget/actual/issues/7282
What happened?
I was trying to setup Actual with bank imports using just the SimpleFin bridge.
I expected the bank sync date to update when the accounts updated but it never has.
There were no errors displayed just Unknown on the bank sync screen for last sync date.
When I hovered the Unknown it showed what looks like the 0 date value in most time based libraries of Dec 31 1969 1900.
Feel free to ping me and ask me any questions.
I did test this on both Brave and Chrome as I was worried my browser of choice could be causing it and it wasn't.
How can we reproduce the issue?
Where are you hosting Actual?
Docker
What browsers are you seeing the problem on?
Other
Operating System
Linux
@youngcw commented on GitHub (Mar 25, 2026):
Does it update if you click "Bank sync" in the account page?
@JkBoyo commented on GitHub (Mar 25, 2026):
Sorry I haven't replied to this sooner.
I guess the weirdness to me is that the account transactions did update before before I clicked on Bank Sync. I don't know if it was triggered by importing new accounts and then the new transactions were also brought in but it seemed weird that linking wouldn't be considered a sync since it was a direct pull from the bank account.
Is there a reason we don't count the initial import as a
Bank Sync?@youngcw commented on GitHub (Mar 25, 2026):
You must have linked other accounts. I think that triggers a sync on all accounts.
It was never added to the code to save the time after linking an account. Thats what most things are in open source, it was just never added. Simple as that
@JkBoyo commented on GitHub (Mar 25, 2026):
Makes total sense. Are the functions pretty easy to find for the account linking?
I mainly know golang but would be willing to try to mess with the sqlite insert to get the initial link as a sync
@JkBoyo commented on GitHub (Mar 25, 2026):
Just didn't want to step on toes if there was another reason.
@matt-fidd commented on GitHub (Mar 25, 2026):
You're welcome to take a look!
Here's where the timestamp is saved in the normal flow, the initial linking flow mustn't go through this function.
acb339be90/packages/loot-core/src/server/accounts/app.ts (L843-L870)All of the linking functions are defined in the same file, using the SimpleFIN one as an example:
acb339be90/packages/loot-core/src/server/accounts/app.ts (L217-L287)The normal flow appears to use the response from
syncAccountand feed it back throughhandleSyncResponse. The linking functions don't seem to do that. There could be a reason we haven't done this, but putting it through would fix the timestamp thing.I haven't looked any deeper than finding the functions, but hopefully that's useful for you!
@JkBoyo commented on GitHub (Mar 26, 2026):
Looking through the code it seems like the simplest solution would be to capture the output of lines
acb339be90/packages/loot-core/src/server/accounts/app.ts (L199)acb339be90/packages/loot-core/src/server/accounts/app.ts (L271)And
acb339be90/packages/loot-core/src/server/accounts/app.ts (L343)Then run them through handleSyncResponse that you mentioned above.
However, it feels like for most of these 3 calls we could extract a majority of the logic and make it easier to setup another link function if we ever wanted to add another service or have to swap one out due to problems.
The one thing I couldn't fully wrap my head around was the full why behind simpleFinBatchSync on
acb339be90/packages/loot-core/src/server/accounts/app.ts (L1013).It really seemed initially like it would be nice and easy to just make all bankSyncs just do the db update and call it a day but that function uses the handleSyncResponse but not the bank sync function. This made me think that maybe we could do a localized wholeBankSync function that could wrap both so we just have one thing we're calling unless we're in the above simpleFinBatchSync.
So instead of trying to pick a direction on not my codebase I thought I'd ask your opinion 🫠.