discourse-ai/lib/modules/toxicity/post_classifier.rb

29 lines
697 B
Ruby
Raw Normal View History

2023-02-22 18:46:53 -05:00
# frozen_string_literal: true
module ::DiscourseAI
module Toxicity
class PostClassifier < Classifier
private
def content(post)
post.post_number == 1 ? "#{post.topic.title}\n#{post.raw}" : post.raw
2023-02-22 18:46:53 -05:00
end
def store_classification(post, classification)
2023-02-22 18:46:53 -05:00
PostCustomField.create!(
post_id: post.id,
2023-02-22 18:46:53 -05:00
name: "toxicity",
value: {
classification: classification,
2023-02-22 18:46:53 -05:00
model: SiteSetting.ai_toxicity_inference_service_api_model,
}.to_json,
)
end
def flag!(target, toxic_labels)
::DiscourseAI::FlagManager.new(target, reasons: toxic_labels).flag!
2023-02-22 18:46:53 -05:00
end
end
end
end