* Change: #737 tanukeyなど小規模Misskeyフォークも、対Misskey配送制限設定対象にする * Fix test * Add cache * Remove caches
This commit is contained in:
parent
ae0d35a4fe
commit
a7d9fd1e56
8 changed files with 88 additions and 42 deletions
|
@ -79,13 +79,9 @@ class StatusesController < ApplicationController
|
||||||
@misskey_software = false
|
@misskey_software = false
|
||||||
|
|
||||||
return false if !@status.local? || signed_request_account&.domain.blank? || !@status.sending_maybe_compromised_privacy?
|
return false if !@status.local? || signed_request_account&.domain.blank? || !@status.sending_maybe_compromised_privacy?
|
||||||
|
|
||||||
return @misskey_software = true if DomainBlock.detect_invalid_subscription?(signed_request_account.domain)
|
return @misskey_software = true if DomainBlock.detect_invalid_subscription?(signed_request_account.domain)
|
||||||
|
|
||||||
info = InstanceInfo.find_by(domain: signed_request_account.domain)
|
@misskey_software = InstanceInfo.invalid_subscription_software?(signed_request_account.domain)
|
||||||
return false if info.nil?
|
|
||||||
|
|
||||||
@misskey_software = %w(misskey calckey cherrypick sharkey).include?(info.software)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def status_activity_serializer
|
def status_activity_serializer
|
||||||
|
|
|
@ -27,9 +27,6 @@ module FollowHelper
|
||||||
def proxyable_software?(account)
|
def proxyable_software?(account)
|
||||||
return false if account.local?
|
return false if account.local?
|
||||||
|
|
||||||
info = InstanceInfo.find_by(domain: account.domain)
|
InstanceInfo.proxy_account_software?(account.domain)
|
||||||
return false if info.nil?
|
|
||||||
|
|
||||||
%w(misskey calckey firefish meisskey cherrypick sharkey).include?(info.software)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -161,14 +161,7 @@ class AccountStatusesFilter
|
||||||
|
|
||||||
def misskey_software?
|
def misskey_software?
|
||||||
return false if @account.nil? || @account.local?
|
return false if @account.nil? || @account.local?
|
||||||
return false if instance_info.nil?
|
|
||||||
|
|
||||||
%w(misskey cherrypick).include?(instance_info.software)
|
InstanceInfo.invalid_subscription_software?(@account.domain)
|
||||||
end
|
|
||||||
|
|
||||||
def instance_info
|
|
||||||
return @instance_info if defined?(@instance_info)
|
|
||||||
|
|
||||||
@instance_info = InstanceInfo.find_by(domain: @account.domain)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -103,7 +103,7 @@ class ActivityPub::Parser::StatusParser
|
||||||
return from_audience if from_audience
|
return from_audience if from_audience
|
||||||
return nil if default_searchability_from_bio?
|
return nil if default_searchability_from_bio?
|
||||||
|
|
||||||
searchability_from_bio || (misskey_software? ? misskey_searchability : nil)
|
searchability_from_bio || (invalid_subscription_software? ? misskey_searchability : nil)
|
||||||
end
|
end
|
||||||
|
|
||||||
def limited_scope
|
def limited_scope
|
||||||
|
@ -120,7 +120,7 @@ class ActivityPub::Parser::StatusParser
|
||||||
end
|
end
|
||||||
|
|
||||||
def language
|
def language
|
||||||
lang = raw_language_code || (misskey_software? ? 'ja' : nil)
|
lang = raw_language_code || (no_language_flag_software? ? 'ja' : nil)
|
||||||
lang.presence && NORMALIZED_LOCALE_NAMES.fetch(lang.downcase.to_sym, lang)
|
lang.presence && NORMALIZED_LOCALE_NAMES.fetch(lang.downcase.to_sym, lang)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -162,15 +162,12 @@ class ActivityPub::Parser::StatusParser
|
||||||
@object['nameMap'].is_a?(Hash) && !@object['nameMap'].empty?
|
@object['nameMap'].is_a?(Hash) && !@object['nameMap'].empty?
|
||||||
end
|
end
|
||||||
|
|
||||||
def instance_info
|
def no_language_flag_software?
|
||||||
@instance_info ||= InstanceInfo.find_by(domain: @account.domain)
|
InstanceInfo.no_language_flag_software?(@account.domain)
|
||||||
end
|
end
|
||||||
|
|
||||||
def misskey_software?
|
def invalid_subscription_software?
|
||||||
info = instance_info
|
InstanceInfo.invalid_subscription_software?(@account.domain)
|
||||||
return false if info.nil?
|
|
||||||
|
|
||||||
%w(misskey calckey).include?(info.software)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def misskey_searchability
|
def misskey_searchability
|
||||||
|
|
|
@ -220,7 +220,7 @@ class StatusReachFinder
|
||||||
def banned_domains_for_misskey_of_status(status)
|
def banned_domains_for_misskey_of_status(status)
|
||||||
return [] if status.public_searchability?
|
return [] if status.public_searchability?
|
||||||
|
|
||||||
from_info = InstanceInfo.where(software: %w(misskey calckey cherrypick sharkey)).pluck(:domain)
|
from_info = InstanceInfo.where(software: InstanceInfo::INVALID_SUBSCRIPTION_SOFTWARES).pluck(:domain)
|
||||||
from_domain_block = DomainBlock.where(detect_invalid_subscription: true).pluck(:domain)
|
from_domain_block = DomainBlock.where(detect_invalid_subscription: true).pluck(:domain)
|
||||||
(from_info + from_domain_block).uniq
|
(from_info + from_domain_block).uniq
|
||||||
end
|
end
|
||||||
|
|
|
@ -37,19 +37,43 @@ class InstanceInfo < ApplicationRecord
|
||||||
|
|
||||||
CIRCLE_AVAILABLE_SOFTWARES = %w(fedibird).freeze
|
CIRCLE_AVAILABLE_SOFTWARES = %w(fedibird).freeze
|
||||||
|
|
||||||
|
MISSKEY_FORKS = %w(
|
||||||
|
calckey
|
||||||
|
cherrypick
|
||||||
|
firefish
|
||||||
|
iceshrimp
|
||||||
|
meisskey
|
||||||
|
misskey
|
||||||
|
rosekey
|
||||||
|
sharkey
|
||||||
|
tanukey
|
||||||
|
).freeze
|
||||||
|
|
||||||
|
INVALID_SUBSCRIPTION_SOFTWARES = MISSKEY_FORKS - %w(firefish)
|
||||||
|
|
||||||
|
PROXY_ACCOUNT_SOFTWARES = MISSKEY_FORKS
|
||||||
|
|
||||||
|
NO_LANGUAGE_FLAG_SOFTWARES = MISSKEY_FORKS - %w(firefish)
|
||||||
|
|
||||||
class << self
|
class << self
|
||||||
def emoji_reaction_available?(domain)
|
|
||||||
return Setting.enable_emoji_reaction if domain.nil?
|
|
||||||
|
|
||||||
Rails.cache.fetch("emoji_reaction_available_domain:#{domain}") { load_emoji_reaction_available(domain) }
|
|
||||||
end
|
|
||||||
|
|
||||||
def available_features(domain)
|
def available_features(domain)
|
||||||
return local_features if domain.nil?
|
return local_features if domain.nil?
|
||||||
|
|
||||||
Rails.cache.fetch("domain_available_features:#{domain}") { load_available_features(domain) }
|
Rails.cache.fetch("domain_available_features:#{domain}") { load_available_features(domain) }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def invalid_subscription_software?(domain)
|
||||||
|
INVALID_SUBSCRIPTION_SOFTWARES.include?(software_name(domain))
|
||||||
|
end
|
||||||
|
|
||||||
|
def proxy_account_software?(domain)
|
||||||
|
PROXY_ACCOUNT_SOFTWARES.include?(software_name(domain))
|
||||||
|
end
|
||||||
|
|
||||||
|
def no_language_flag_software?(domain)
|
||||||
|
NO_LANGUAGE_FLAG_SOFTWARES.include?(software_name(domain))
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def load_available_features(domain)
|
def load_available_features(domain)
|
||||||
|
@ -77,7 +101,7 @@ class InstanceInfo < ApplicationRecord
|
||||||
def feature_available?(info, softwares, feature_name)
|
def feature_available?(info, softwares, feature_name)
|
||||||
return false if info.nil?
|
return false if info.nil?
|
||||||
|
|
||||||
softwares.include?(software_name(info)) || metadata_features(info)&.include?(feature_name) || false
|
softwares.include?(info.software) || metadata_features(info)&.include?(feature_name) || false
|
||||||
end
|
end
|
||||||
|
|
||||||
def metadata_features(info)
|
def metadata_features(info)
|
||||||
|
@ -86,7 +110,16 @@ class InstanceInfo < ApplicationRecord
|
||||||
info.data['metadata']['features']
|
info.data['metadata']['features']
|
||||||
end
|
end
|
||||||
|
|
||||||
def software_name(info)
|
def software_name(domain)
|
||||||
|
Rails.cache.fetch("software_name:#{domain}") { load_software_name(domain) }
|
||||||
|
end
|
||||||
|
|
||||||
|
def load_software_name(domain)
|
||||||
|
return 'threads' if domain == 'threads.net'
|
||||||
|
|
||||||
|
info = InstanceInfo.find_by(domain: domain)
|
||||||
|
return nil if info.nil?
|
||||||
|
|
||||||
info.software
|
info.software
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -94,7 +127,7 @@ class InstanceInfo < ApplicationRecord
|
||||||
private
|
private
|
||||||
|
|
||||||
def reset_cache
|
def reset_cache
|
||||||
Rails.cache.delete("emoji_reaction_available_domain:#{domain}")
|
|
||||||
Rails.cache.delete("domain_available_features:#{domain}")
|
Rails.cache.delete("domain_available_features:#{domain}")
|
||||||
|
Rails.cache.delete("software_name:#{domain}")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -286,7 +286,7 @@ class ActivityPub::ProcessAccountService < BaseService
|
||||||
bio = searchability_from_bio
|
bio = searchability_from_bio
|
||||||
return bio unless bio.nil?
|
return bio unless bio.nil?
|
||||||
|
|
||||||
return misskey_software? ? misskey_searchability_from_indexable : :direct
|
return invalid_subscription_software? ? misskey_searchability_from_indexable : :direct
|
||||||
end
|
end
|
||||||
|
|
||||||
if audience_searchable_by.any? { |uri| ActivityPub::TagManager.instance.public_collection?(uri) }
|
if audience_searchable_by.any? { |uri| ActivityPub::TagManager.instance.public_collection?(uri) }
|
||||||
|
@ -328,11 +328,8 @@ class ActivityPub::ProcessAccountService < BaseService
|
||||||
@instance_info ||= InstanceInfo.find_by(domain: @domain)
|
@instance_info ||= InstanceInfo.find_by(domain: @domain)
|
||||||
end
|
end
|
||||||
|
|
||||||
def misskey_software?
|
def invalid_subscription_software?
|
||||||
info = instance_info
|
InstanceInfo.invalid_subscription_software?(@domain)
|
||||||
return false if info.nil?
|
|
||||||
|
|
||||||
%w(misskey calckey).include?(info.software)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def subscribable_by
|
def subscribable_by
|
||||||
|
|
|
@ -59,4 +59,37 @@ RSpec.describe InstanceInfo do
|
||||||
expect(subject).to be true
|
expect(subject).to be true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '.software_name' do
|
||||||
|
before do
|
||||||
|
Fabricate(:instance_info, domain: 'misskey.io', software: 'misskey')
|
||||||
|
Fabricate(:instance_info, domain: 'novelskey.tarbin.net', software: 'tanukey')
|
||||||
|
Fabricate(:instance_info, domain: 'mastodon.social', software: 'mastodon')
|
||||||
|
Fabricate(:instance_info, domain: 'firefish.social', software: 'firefish')
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'detect invalid subscription domains' do
|
||||||
|
expect(described_class.invalid_subscription_software?('misskey.io')).to be true
|
||||||
|
expect(described_class.invalid_subscription_software?('novelskey.tarbin.net')).to be true
|
||||||
|
expect(described_class.invalid_subscription_software?('mastodon.social')).to be false
|
||||||
|
expect(described_class.invalid_subscription_software?('firefish.social')).to be false
|
||||||
|
expect(described_class.invalid_subscription_software?('ohagi.social')).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'detect proxy account software domains' do
|
||||||
|
expect(described_class.proxy_account_software?('misskey.io')).to be true
|
||||||
|
expect(described_class.proxy_account_software?('novelskey.tarbin.net')).to be true
|
||||||
|
expect(described_class.proxy_account_software?('mastodon.social')).to be false
|
||||||
|
expect(described_class.proxy_account_software?('firefish.social')).to be true
|
||||||
|
expect(described_class.proxy_account_software?('ohagi.social')).to be false
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'detect no language software domains' do
|
||||||
|
expect(described_class.no_language_flag_software?('misskey.io')).to be true
|
||||||
|
expect(described_class.no_language_flag_software?('novelskey.tarbin.net')).to be true
|
||||||
|
expect(described_class.no_language_flag_software?('mastodon.social')).to be false
|
||||||
|
expect(described_class.no_language_flag_software?('firefish.social')).to be false
|
||||||
|
expect(described_class.no_language_flag_software?('ohagi.social')).to be false
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue