mirror of
https://0xacab.org/sutty/sutty
synced 2025-01-19 08:13:37 +00:00
feat: poder reportar comentarios
This commit is contained in:
parent
67a56c540a
commit
ff428c6527
10 changed files with 58 additions and 28 deletions
|
@ -8,6 +8,7 @@ class ActivityPubsController < ApplicationController
|
|||
define_method(event) do
|
||||
authorize activity_pub
|
||||
|
||||
activity_pub.update(remote_flag_params(activity_pub)) if event == :report
|
||||
activity_pub.public_send(:"#{event}!") if activity_pub.public_send(:"may_#{event}?")
|
||||
|
||||
redirect_to_moderation_queue!
|
||||
|
@ -29,7 +30,9 @@ class ActivityPubsController < ApplicationController
|
|||
|
||||
ActivityPub.transaction do
|
||||
activity_pubs.find_each do |activity_pub|
|
||||
activity_pub.public_send(method) if activity_pub.public_send(may)
|
||||
next unless activity_pub.public_send(may)
|
||||
|
||||
activity_pub.public_send(method)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -9,7 +9,7 @@ class ActorModerationsController < ApplicationController
|
|||
authorize actor_moderation
|
||||
|
||||
# Crea una RemoteFlag si se envían los parámetros adecuados
|
||||
actor_moderation.update(actor_moderation_params(actor_moderation)) if actor_event == :report
|
||||
actor_moderation.update(remote_flag_params(actor_moderation)) if actor_event == :report
|
||||
|
||||
actor_moderation.public_send(:"#{actor_event}!") if actor_moderation.public_send(:"may_#{actor_event}?")
|
||||
|
||||
|
@ -51,26 +51,4 @@ class ActorModerationsController < ApplicationController
|
|||
def actor_moderation
|
||||
@actor_moderation ||= site.actor_moderations.find(params[:actor_moderation_id] || params[:id])
|
||||
end
|
||||
|
||||
# @return [String]
|
||||
def panel_actor_mention
|
||||
@panel_actor_mention ||= ENV.fetch('PANEL_ACTOR_MENTION', '@sutty@sutty.nl')
|
||||
end
|
||||
|
||||
# @return [Hash]
|
||||
def actor_moderation_params(actor_moderation)
|
||||
{ remote_flag_attributes: { id: actor_moderation.remote_flag_id, message: '' } }.tap do |p|
|
||||
p[:remote_flag_attributes][:site_id] = actor_moderation.site_id
|
||||
p[:remote_flag_attributes][:actor_id] = actor_moderation.actor_id
|
||||
|
||||
I18n.available_locales.each do |locale|
|
||||
p[:remote_flag_attributes][:message].tap do |m|
|
||||
m += I18n.t(locale)
|
||||
m += ': '
|
||||
m += I18n.t('actor_moderations.report_message', locale: locale, panel_actor_mention: panel_actor_mention)
|
||||
m += '\n\n'
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -9,5 +9,26 @@ module ModerationConcern
|
|||
def redirect_to_moderation_queue!
|
||||
redirect_back fallback_location: site_moderation_queue_path(**(session[:moderation_queue_filters] || {}))
|
||||
end
|
||||
|
||||
# @return [String]
|
||||
def panel_actor_mention
|
||||
@panel_actor_mention ||= ENV.fetch('PANEL_ACTOR_MENTION', '@sutty@sutty.nl')
|
||||
end
|
||||
|
||||
def remote_flag_params(model)
|
||||
{ remote_flag_attributes: { id: model.remote_flag_id, message: '' } }.tap do |p|
|
||||
p[:remote_flag_attributes][:site_id] = model.site_id
|
||||
p[:remote_flag_attributes][:actor_id] = model.actor_id
|
||||
|
||||
I18n.available_locales.each do |locale|
|
||||
p[:remote_flag_attributes][:message].tap do |m|
|
||||
m << I18n.t(locale)
|
||||
m << ': '
|
||||
m << I18n.t('remote_flags.report_message', locale: locale, panel_actor_mention: panel_actor_mention)
|
||||
m << '\n\n'
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -13,7 +13,7 @@ class ActivityPub
|
|||
self.priority = 30
|
||||
|
||||
def perform(remote_flag:)
|
||||
client = remote_flag.site.social_inbox.client_for(remote_flag.actor.content['inbox'])
|
||||
client = remote_flag.site.social_inbox.client_for(remote_flag.actor&.content['inbox'])
|
||||
response = client.post(endpoint: '', body: remote_flag.content)
|
||||
|
||||
raise 'No se pudo enviar el reporte' unless response.ok?
|
||||
|
|
|
@ -18,12 +18,15 @@ class ActivityPub < ApplicationRecord
|
|||
belongs_to :site
|
||||
belongs_to :object, polymorphic: true
|
||||
belongs_to :actor
|
||||
belongs_to :remote_flag, class_name: 'ActivityPub::RemoteFlag'
|
||||
has_many :activities
|
||||
|
||||
validates :site_id, presence: true
|
||||
validates :object_id, presence: true
|
||||
validates :aasm_state, presence: true, inclusion: { in: %w[paused approved rejected reported removed] }
|
||||
|
||||
accepts_nested_attributes_for :remote_flag
|
||||
|
||||
# Encuentra la URI de un objeto
|
||||
#
|
||||
# @return [String, nil]
|
||||
|
@ -83,6 +86,10 @@ class ActivityPub < ApplicationRecord
|
|||
# Solo podemos reportarla luego de rechazarla
|
||||
event :report do
|
||||
transitions from: :rejected, to: :reported
|
||||
|
||||
before do
|
||||
ActivityPub::RemoteFlagJob.perform_later(remote_flag: remote_flag)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -5,6 +5,11 @@ class ActivityPub
|
|||
belongs_to :actor
|
||||
belongs_to :site
|
||||
|
||||
has_one :actor_moderation
|
||||
has_many :activity_pubs
|
||||
# XXX: source_type es obligatorio para el `through`
|
||||
has_many :objects, through: :activity_pubs, source_type: 'ActivityPub::Object::Note'
|
||||
|
||||
# Genera la actividad a enviar
|
||||
def content
|
||||
{
|
||||
|
@ -13,7 +18,7 @@ class ActivityPub
|
|||
'type' => 'Flag',
|
||||
'actor' => ENV.fetch('PANEL_ACTOR_ID') { "https://#{ENV['SUTTY']}/about.jsonld" },
|
||||
'content' => message.to_s,
|
||||
'object' => [ actor.uri ]
|
||||
'object' => [ actor.uri ] + objects.pluck(:uri)
|
||||
}
|
||||
end
|
||||
end
|
||||
|
|
|
@ -116,6 +116,7 @@ en:
|
|||
profile_id: ID
|
||||
profile_published: Published
|
||||
profile_summary: Summary
|
||||
remote_flags:
|
||||
report_message: "Hi! Someone using Sutty CMS reported this account on your instance. We don't have support for customized report messages yet, but we will soon. You can reach us at %{panel_actor_mention}."
|
||||
moderation_queue:
|
||||
everything: 'Select all'
|
||||
|
|
|
@ -115,6 +115,7 @@ es:
|
|||
profile_id: ID
|
||||
profile_published: Publicada
|
||||
profile_summary: Presentación
|
||||
remote_flags:
|
||||
report_message: "¡Hola! Une usuarie de Sutty CMS reportó esta cuenta en tu instancia. Todavía no tenemos soporte para mensajes personalizados. Podés contactarnos en %{panel_actor_mention}."
|
||||
moderation_queue:
|
||||
everything: 'Seleccionar todo'
|
||||
|
|
12
db/migrate/20240305164653_change_remote_flags.rb
Normal file
12
db/migrate/20240305164653_change_remote_flags.rb
Normal file
|
@ -0,0 +1,12 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
# Agrega relaciones en las remote flags
|
||||
class ChangeRemoteFlags < ActiveRecord::Migration[6.1]
|
||||
def up
|
||||
add_column :activity_pubs, :remote_flag_id, :uuid, index: true, null: true
|
||||
end
|
||||
|
||||
def down
|
||||
remove_column :activity_pubs, :remote_flag_id
|
||||
end
|
||||
end
|
|
@ -573,7 +573,8 @@ CREATE TABLE public.activity_pubs (
|
|||
object_type character varying NOT NULL,
|
||||
aasm_state character varying NOT NULL,
|
||||
instance_id uuid,
|
||||
actor_id uuid
|
||||
actor_id uuid,
|
||||
remote_flag_id uuid
|
||||
);
|
||||
|
||||
|
||||
|
@ -2695,6 +2696,7 @@ INSERT INTO "schema_migrations" (version) VALUES
|
|||
('20240229201155'),
|
||||
('20240301181224'),
|
||||
('20240301194154'),
|
||||
('20240301202955');
|
||||
('20240301202955'),
|
||||
('20240305164653');
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue