mirror of
https://github.com/discourse/discourse-ai.git
synced 2025-03-09 11:48:47 +00:00
36 lines
871 B
Ruby
36 lines
871 B
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
class ModelAccuracy < ActiveRecord::Base
|
||
|
def self.adjust_model_accuracy(new_status, reviewable)
|
||
|
return unless %i[approved rejected].include?(new_status)
|
||
|
return unless [ReviewableAIPost, ReviewableAIChatMessage].include?(reviewable.class)
|
||
|
|
||
|
verdicts = reviewable.payload.to_h["verdicts"] || {}
|
||
|
|
||
|
verdicts.each do |model_name, verdict|
|
||
|
accuracy_model = find_by(model: model_name)
|
||
|
|
||
|
attribute =
|
||
|
if verdict
|
||
|
new_status == :approved ? :flags_agreed : :flags_disagreed
|
||
|
else
|
||
|
new_status == :rejected ? :flags_agreed : :flags_disagreed
|
||
|
end
|
||
|
|
||
|
accuracy_model.increment!(attribute)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
def calculate_accuracy
|
||
|
return 0 if total_flags.zero?
|
||
|
|
||
|
(flags_agreed * 100) / total_flags
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def total_flags
|
||
|
flags_agreed + flags_disagreed
|
||
|
end
|
||
|
end
|