]> cat aescling's git repositories - mastodon.git/commitdiff
Addition of update activity distribution by alias, minor correction (#11905)
authorTakeshi Umeda <noel.yoshiba@gmail.com>
Sat, 21 Sep 2019 07:11:21 +0000 (16:11 +0900)
committerEugen Rochko <eugen@zeonfederated.com>
Sat, 21 Sep 2019 07:11:21 +0000 (09:11 +0200)
* Addition of update activity distribution by alias, minor correction

* Distribute Update activity after adding alias
* Add uniqueness verification to alias uri
* accept acct starting with @

* fix double-quoted to single-quoted

app/controllers/settings/aliases_controller.rb
app/models/account_alias.rb

index da0a4a9fa674d428f3564cadb1636a6fd84e39ce..b7c9a409d1f8d7fb18adadbfcce531118d9c8a31 100644 (file)
@@ -15,6 +15,7 @@ class Settings::AliasesController < Settings::BaseController
     @alias = current_account.aliases.build(resource_params)
 
     if @alias.save
+      ActivityPub::UpdateDistributionWorker.perform_async(current_account.id)
       redirect_to settings_aliases_path, notice: I18n.t('aliases.created_msg')
     else
       render :index
index e9a0dd79e035db89bebb8db9a478a4df747b861f..66f8ce40953c9a8e5b2b9198bbb899610c3cb6de 100644 (file)
@@ -17,11 +17,17 @@ class AccountAlias < ApplicationRecord
 
   validates :acct, presence: true, domain: { acct: true }
   validates :uri, presence: true
+  validates :uri, uniqueness: { scope: :account_id }
 
   before_validation :set_uri
   after_create :add_to_account
   after_destroy :remove_from_account
 
+  def acct=(val)
+    val = val.to_s.strip
+    super(val.start_with?('@') ? val[1..-1] : val)
+  end
+
   private
 
   def set_uri