mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-08-05 13:35:21 +02:00
Improve account sync performance, handle concurrent market data syncing (#2236)
* PlaidConnectable concern * Remove bad abstraction * Put sync implementations in own concerns * Sync strategies * Move sync orchestration to Sync class * Clean up sync class, add state machine * Basic market data sync cron * Fix price sync * Improve sync window column names, add timestamps * 30 day syncs by default * Clean up market data methods * Report high duplicate sync counts to Sentry * Add sync states throughout app * account tab session * Persistent account tab selections * Remove manual sleep * Add migration to clear stale syncs on self hosted apps * Tweak sync states * Sync completion event broadcasts * Fix timezones in tests * Cleanup * More cleanup * Plaid item UI broadcasts for sync * Fix account ID namespace conflict * Sync broadcasters * Smoother account sync refreshes * Remove test sync delay
This commit is contained in:
parent
9793cc74f9
commit
10dd9e061a
97 changed files with 1837 additions and 949 deletions
65
db/migrate/20250512171654_update_sync_timestamps.rb
Normal file
65
db/migrate/20250512171654_update_sync_timestamps.rb
Normal file
|
@ -0,0 +1,65 @@
|
|||
class UpdateSyncTimestamps < ActiveRecord::Migration[7.2]
|
||||
def change
|
||||
# Timestamps, managed by aasm
|
||||
add_column :syncs, :pending_at, :datetime
|
||||
add_column :syncs, :syncing_at, :datetime
|
||||
add_column :syncs, :completed_at, :datetime
|
||||
add_column :syncs, :failed_at, :datetime
|
||||
|
||||
add_column :syncs, :window_start_date, :date
|
||||
add_column :syncs, :window_end_date, :date
|
||||
|
||||
reversible do |dir|
|
||||
dir.up do
|
||||
execute <<-SQL
|
||||
UPDATE syncs
|
||||
SET
|
||||
completed_at = CASE
|
||||
WHEN status = 'completed' THEN last_ran_at
|
||||
ELSE NULL
|
||||
END,
|
||||
failed_at = CASE
|
||||
WHEN status = 'failed' THEN last_ran_at
|
||||
ELSE NULL
|
||||
END
|
||||
SQL
|
||||
|
||||
execute <<-SQL
|
||||
UPDATE syncs
|
||||
SET window_start_date = start_date
|
||||
SQL
|
||||
|
||||
# Due to some recent bugs, some self hosters have syncs that are stuck.
|
||||
# This manually fails those syncs so they stop seeing syncing UI notices.
|
||||
if Rails.application.config.app_mode.self_hosted?
|
||||
puts "Self hosted: Fail syncs older than 2 hours"
|
||||
execute <<-SQL
|
||||
UPDATE syncs
|
||||
SET status = 'failed'
|
||||
WHERE (
|
||||
status = 'syncing' AND
|
||||
created_at < NOW() - INTERVAL '2 hours'
|
||||
)
|
||||
SQL
|
||||
end
|
||||
end
|
||||
|
||||
dir.down do
|
||||
execute <<-SQL
|
||||
UPDATE syncs
|
||||
SET
|
||||
last_ran_at = COALESCE(completed_at, failed_at)
|
||||
SQL
|
||||
|
||||
execute <<-SQL
|
||||
UPDATE syncs
|
||||
SET start_date = window_start_date
|
||||
SQL
|
||||
end
|
||||
end
|
||||
|
||||
remove_column :syncs, :start_date, :date
|
||||
remove_column :syncs, :last_ran_at, :datetime
|
||||
remove_column :syncs, :error_backtrace, :text, array: true
|
||||
end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue