diff options
Diffstat (limited to 'app/models/error_tracking')
-rw-r--r-- | app/models/error_tracking/error.rb | 23 | ||||
-rw-r--r-- | app/models/error_tracking/error_event.rb | 11 | ||||
-rw-r--r-- | app/models/error_tracking/project_error_tracking_setting.rb | 2 |
3 files changed, 36 insertions, 0 deletions
diff --git a/app/models/error_tracking/error.rb b/app/models/error_tracking/error.rb new file mode 100644 index 00000000000..012dcc4418f --- /dev/null +++ b/app/models/error_tracking/error.rb @@ -0,0 +1,23 @@ +# frozen_string_literal: true + +class ErrorTracking::Error < ApplicationRecord + belongs_to :project + + has_many :events, class_name: 'ErrorTracking::ErrorEvent' + + validates :project, presence: true + validates :name, presence: true + validates :description, presence: true + validates :actor, presence: true + + def self.report_error(name:, description:, actor:, platform:, timestamp:) + safe_find_or_create_by( + name: name, + description: description, + actor: actor, + platform: platform + ) do |error| + error.update!(last_seen_at: timestamp) + end + end +end diff --git a/app/models/error_tracking/error_event.rb b/app/models/error_tracking/error_event.rb new file mode 100644 index 00000000000..ed14a1bce41 --- /dev/null +++ b/app/models/error_tracking/error_event.rb @@ -0,0 +1,11 @@ +# frozen_string_literal: true + +class ErrorTracking::ErrorEvent < ApplicationRecord + belongs_to :error, counter_cache: :events_count + + validates :payload, json_schema: { filename: 'error_tracking_event_payload' } + + validates :error, presence: true + validates :description, presence: true + validates :occurred_at, presence: true +end diff --git a/app/models/error_tracking/project_error_tracking_setting.rb b/app/models/error_tracking/project_error_tracking_setting.rb index 956b5d6470f..c729b002852 100644 --- a/app/models/error_tracking/project_error_tracking_setting.rb +++ b/app/models/error_tracking/project_error_tracking_setting.rb @@ -24,6 +24,8 @@ module ErrorTracking self.reactive_cache_key = ->(setting) { [setting.class.model_name.singular, setting.project_id] } self.reactive_cache_work_type = :external_dependency + self.table_name = 'project_error_tracking_settings' + belongs_to :project validates :api_url, length: { maximum: 255 }, public_url: { enforce_sanitization: true, ascii_only: true }, allow_nil: true |