2023-02-22 18:46:53 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module ::DiscourseAI
|
|
|
|
module Toxicity
|
|
|
|
class PostClassifier < Classifier
|
2023-02-24 05:53:43 -05:00
|
|
|
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
|
|
|
|
|
2023-02-24 05:53:43 -05:00
|
|
|
def store_classification(post, classification)
|
2023-02-22 18:46:53 -05:00
|
|
|
PostCustomField.create!(
|
2023-02-24 05:53:43 -05:00
|
|
|
post_id: post.id,
|
2023-02-22 18:46:53 -05:00
|
|
|
name: "toxicity",
|
|
|
|
value: {
|
2023-02-24 05:53:43 -05:00
|
|
|
classification: classification,
|
2023-02-22 18:46:53 -05:00
|
|
|
model: SiteSetting.ai_toxicity_inference_service_api_model,
|
|
|
|
}.to_json,
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
2023-02-24 05:53:43 -05:00
|
|
|
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
|