about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--app/lib/command_tag/commands/status_tools.rb6
-rw-r--r--app/lib/command_tag/processor.rb21
2 files changed, 27 insertions, 0 deletions
diff --git a/app/lib/command_tag/commands/status_tools.rb b/app/lib/command_tag/commands/status_tools.rb
index 23bdcbfc3..0e6524001 100644
--- a/app/lib/command_tag/commands/status_tools.rb
+++ b/app/lib/command_tag/commands/status_tools.rb
@@ -27,4 +27,10 @@ module CommandTag::Commands::StatusTools
 
   alias handle_v_before_save                      handle_visibility_before_save
   alias handle_privacy_before_save                handle_visibility_before_save
+
+  def handle_semiprivate_before_save(args)
+    return unless author_of_status?
+
+    @semiprivate = args.blank? || read_boolean_from(args[0])
+  end
 end
diff --git a/app/lib/command_tag/processor.rb b/app/lib/command_tag/processor.rb
index 6e740ba98..79b24eec3 100644
--- a/app/lib/command_tag/processor.rb
+++ b/app/lib/command_tag/processor.rb
@@ -59,6 +59,7 @@ class CommandTag::Processor
     elsif @status.destroyed?
       %w(after_destroy once_after_destroy).each { |suffix| execute_statements(suffix) }
     else
+      update_semiprivate_attribute
       @status.text = @text
       process_inline_images!
       if @status.save
@@ -174,6 +175,14 @@ class CommandTag::Processor
     @status.destroy unless @status.destroyed?
   end
 
+  def status_still_semiprivate?
+    @status.domain_permissions.exists? || @account.followers.where(domain: @account.domain_permissions.select(:domain)).exists?
+  end
+
+  def update_semiprivate_attribute
+    @status.semiprivate = @semiprivate.presence || status_still_semiprivate?
+  end
+
   def normalize(text)
     text.to_s.strip.downcase
   end
@@ -216,6 +225,18 @@ class CommandTag::Processor
     %w(public unlisted private limited direct).include?(arg) ? arg : nil
   end
 
+  def read_falsy_from(arg)
+    %w(false no off disable).include?(arg)
+  end
+
+  def read_truthy_from(arg)
+    %w(true yes on enable).include?(arg)
+  end
+
+  def read_boolean_from(arg)
+    arg.present? && (read_truthy_from(arg) || !read_falsy_from(arg))
+  end
+
   def normalize_domain(domain)
     return if domain&.strip.blank? || !domain.include?('.')