2024-11-15 13:49:37 -05:00
|
|
|
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!
|
|
|
|
|
2024-11-20 11:01:52 -05:00
|
|
|
begin
|
2024-12-02 12:04:54 -05:00
|
|
|
data = syncable.sync_data(start_date: start_date)
|
|
|
|
update!(data: data) if data
|
2024-11-20 11:01:52 -05:00
|
|
|
complete!
|
|
|
|
rescue StandardError => error
|
|
|
|
fail! error
|
|
|
|
raise error if Rails.env.development?
|
|
|
|
ensure
|
|
|
|
syncable.post_sync
|
|
|
|
end
|
2024-11-15 13:49:37 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
def start!
|
|
|
|
update! status: :syncing
|
|
|
|
end
|
|
|
|
|
|
|
|
def complete!
|
|
|
|
update! status: :completed, last_ran_at: Time.current
|
|
|
|
end
|
|
|
|
|
|
|
|
def fail!(error)
|
2024-12-02 12:04:54 -05:00
|
|
|
Sentry.capture_exception(error) do |scope|
|
|
|
|
scope.set_context("sync", { id: id })
|
|
|
|
end
|
|
|
|
|
2024-12-30 16:04:05 +01:00
|
|
|
update!(
|
|
|
|
status: :failed,
|
|
|
|
error: error.message,
|
|
|
|
error_backtrace: error.backtrace&.first(10),
|
|
|
|
last_ran_at: Time.current
|
|
|
|
)
|
2024-11-15 13:49:37 -05:00
|
|
|
end
|
|
|
|
end
|