Fix #10736 - Change data export to be available for non-functional accounts - Change non-functional accounts to include redirecting accounts
		
			
				
	
	
		
			42 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| # == Schema Information
 | |
| #
 | |
| # Table name: account_aliases
 | |
| #
 | |
| #  id         :bigint(8)        not null, primary key
 | |
| #  account_id :bigint(8)
 | |
| #  acct       :string           default(""), not null
 | |
| #  uri        :string           default(""), not null
 | |
| #  created_at :datetime         not null
 | |
| #  updated_at :datetime         not null
 | |
| #
 | |
| 
 | |
| class AccountAlias < ApplicationRecord
 | |
|   belongs_to :account
 | |
| 
 | |
|   validates :acct, presence: true, domain: { acct: true }
 | |
|   validates :uri, presence: true
 | |
| 
 | |
|   before_validation :set_uri
 | |
|   after_create :add_to_account
 | |
|   after_destroy :remove_from_account
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def set_uri
 | |
|     target_account = ResolveAccountService.new.call(acct)
 | |
|     self.uri       = ActivityPub::TagManager.instance.uri_for(target_account) unless target_account.nil?
 | |
|   rescue Goldfinger::Error, HTTP::Error, OpenSSL::SSL::SSLError, Mastodon::Error
 | |
|     # Validation will take care of it
 | |
|   end
 | |
| 
 | |
|   def add_to_account
 | |
|     account.update(also_known_as: account.also_known_as + [uri])
 | |
|   end
 | |
| 
 | |
|   def remove_from_account
 | |
|     account.update(also_known_as: account.also_known_as.reject { |x| x == uri })
 | |
|   end
 | |
| end
 |