5
0
Fork 0
mirror of https://0xacab.org/sutty/sutty synced 2025-01-19 08:03:38 +00:00

feat: gestionar listas de bloqueo desde el panel

This commit is contained in:
f 2024-02-27 16:39:02 -03:00
parent 6f66bd43e5
commit 4bc11c7007
No known key found for this signature in database
9 changed files with 93 additions and 11 deletions

View file

@ -0,0 +1,40 @@
# frozen_string_literal: true
# Estado de las listas de bloqueo en cada sitio
class FediblockStatesController < ApplicationController
# Realiza cambios en las listas de bloqueo
def action_on_several
if fediblock_states_ids.present?
# Encontrar todas y deshabilitar las que no se enviaron
site.fediblock_states.all.find_each do |fediblock_state|
if fediblock_states_ids.include? fediblock_state.id
fediblock_state.enable! if fediblock_state.may_enable?
elsif fediblock_state.may_disable?
fediblock_state.disable!
end
end
end
# Bloquear otras instancias
if custom_blocklist.present?
ActivityPub::InstanceModerationJob.perform_later(site: site, hostnames: custom_blocklist)
end
redirect_to site_moderation_queue_path
end
private
def fediblock_states_ids
params[:fediblock_states_ids] || []
end
# La lista de hostnames
def custom_blocklist
@custom_blocklist ||= fediblocks_states_params[:custom_blocklist].split("\n").map(&:strip).select(&:present?)
end
def fediblocks_states_params
@fediblocks_states_params ||= params.permit(:custom_blocklist, fediblock_states_ids: [])
end
end

View file

@ -0,0 +1,29 @@
# frozen_string_literal: true
class ActivityPub
# Bloquea varias instancias de una sola vez
class InstanceModerationJob < ApplicationJob
# @param :site [Site]
# @param :hostnames [Array<String>]
def perform(site:, hostnames:)
# Crear las instancias que no existan todavía
hostnames.each do |hostname|
ActivityPub::Instance.find_or_create_by(hostname: hostname)
end
instances = ActivityPub::Instance.where(hostname: hostnames)
Site.transaction do
# Crea todas las moderaciones de instancia con un estado por
# defecto si no existen
instances.find_each do |instance|
# Esto bloquea cada una individualmente en la Social Inbox,
# idealmente son pocas instancias las que aparecen.
site.instance_moderations.find_or_create_by(instance: instance).tap do |instance_moderation|
instance_moderation.block! if instance_moderation.may_block?
end
end
end
end
end
end

View file

@ -13,6 +13,7 @@ class Site
has_many :activity_pubs
has_many :instance_moderations
has_many :fediblock_states
has_many :instances, through: :instance_moderations
before_save :generate_private_key_pem!, unless: :private_key_pem?

View file

@ -1,8 +1,12 @@
-# Componente Listas de bloqueo de Instancias
- know_more = t('.know_more')
.card.mt-3.mb-3
.card-body
.d-flex.flex-row
= render 'components/checkbox', id: state.id, checked: state.enabled? do
%span.h4= blocklist.title
%p.mb-0
%a{ href: blocklist.url }= t('.more')
= render 'components/checkbox', id: state.id, name: 'fediblock_states_ids[]', value: state.id, checked: state.enabled? do
%span.h4.mb-0= blocklist.title
%dl.mb-0
%dt.d-inline= t('.instances_blocked')
%dd.d-inline.font-weight-normal= blocklist.instances.count
%p.mb-0.font-weight-normal
%a{ href: blocklist.url }= know_more

View file

@ -1,5 +1,3 @@
.form-group
= label_tag "custom_blocklist", t('moderation_queue.instances.custom_block')
= text_area_tag "custom_blocklist", nil, class: 'form-control'
%button.btn.btn-secondary.mt-3{ type: 'submit' }= t('moderation_queue.instances.submit')
= label_tag 'custom_blocklist', t('moderation_queue.instances.custom_block')
= text_area_tag 'custom_blocklist', nil, class: 'form-control'

View file

@ -19,5 +19,10 @@
%div
%h3.mt-5= t('moderation_queue.instances.title')
%lead= t('moderation_queue.instances.description')
= render 'components/block_lists', blocklists: fediblock_states
= render 'moderation_queue/block_instances_textarea'
= form_tag site_fediblock_states_action_on_several_path, method: :patch do
= render 'components/block_lists', blocklists: fediblock_states
= render 'moderation_queue/block_instances_textarea'
.form-group
%button.btn.btn-secondary.mt-3{ type: 'submit' }= t('moderation_queue.instances.submit')

View file

@ -50,6 +50,8 @@ en:
pm: pm
format: '%-I:%M %p'
components:
block_list:
know_more: Know more
instances_filters:
text_show: Show
text_checked: With selected

View file

@ -50,6 +50,8 @@ es:
pm: pm
format: '%-H:%M'
components:
block_list:
know_more: Saber más (en inglés)
instances_filters:
text_show: Ver
text_checked: Con los marcados

View file

@ -69,6 +69,7 @@ Rails.application.routes.draw do
end
patch :instance_moderations_action_on_several, to: 'instance_moderations#action_on_several'
patch :fediblock_states_action_on_several, to: 'fediblock_states#action_on_several'
# Gestionar artículos según idioma
nested do