1
0
Fork 0
mirror of https://github.com/maybe-finance/maybe.git synced 2025-07-22 22:59:39 +02:00
Maybe/app/models/sync.rb
Tony Vincent 9d217afb9f
feat: Save error backtrace for sync errors for better debugging (#1578)
Co-authored-by: Tony Vincent Yesudas <tony.yesudas@raisenow.com>
2024-12-30 10:04:05 -05:00

44 lines
972 B
Ruby

class Sync < ApplicationRecord
belongs_to :syncable, polymorphic: true
enum :status, { pending: "pending", syncing: "syncing", completed: "completed", failed: "failed" }
scope :ordered, -> { order(created_at: :desc) }
def perform
start!
begin
data = syncable.sync_data(start_date: start_date)
update!(data: data) if data
complete!
rescue StandardError => error
fail! error
raise error if Rails.env.development?
ensure
syncable.post_sync
end
end
private
def start!
update! status: :syncing
end
def complete!
update! status: :completed, last_ran_at: Time.current
end
def fail!(error)
Sentry.capture_exception(error) do |scope|
scope.set_context("sync", { id: id })
end
update!(
status: :failed,
error: error.message,
error_backtrace: error.backtrace&.first(10),
last_ran_at: Time.current
)
end
end