2019-07-22 19:12:54 -07:00
|
|
|
module AutorejectHelper
|
|
|
|
def should_reject?(uri = nil)
|
|
|
|
if uri.nil?
|
|
|
|
if @object
|
|
|
|
uri = object_uri.start_with?('http') ? object_uri : @object['url']
|
|
|
|
elsif @json
|
|
|
|
uri = @json['id']
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
return if uri.nil?
|
|
|
|
|
|
|
|
domain = uri.scan(/[\w\-]+\.[\w\-]+(?:\.[\w\-]+)*/).first
|
|
|
|
blocks = DomainBlock.suspend
|
2019-07-30 11:54:13 -07:00
|
|
|
return :domain if blocks.where(domain: domain).or(blocks.where('domain LIKE ?', "%.#{domain}")).exists?
|
2019-07-22 19:12:54 -07:00
|
|
|
|
2019-07-22 20:49:07 -07:00
|
|
|
return unless @json || @object
|
|
|
|
|
|
|
|
context = @object['@context'] if @object
|
|
|
|
|
|
|
|
if @json
|
|
|
|
oid = @json['id']
|
|
|
|
if oid
|
2019-07-24 17:37:00 -07:00
|
|
|
return :id_starts_with if ENV.fetch('REJECT_IF_ID_STARTS_WITH', '').split.any? { |r| oid.start_with?(r) }
|
|
|
|
return :id_contains if ENV.fetch('REJECT_IF_ID_CONTAINS', '').split.any? { |r| r.in?(oid) }
|
2019-07-22 20:49:07 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
username = @json['preferredUsername'] || @json['username']
|
|
|
|
if username && username.is_a?(String)
|
|
|
|
username = (@json['actor'] && @json['actor'].is_a?(String)) ? @json['actor'] : ''
|
2019-07-22 20:52:28 -07:00
|
|
|
username = username.scan(/(?<=\/user\/|\/@|\/users\/)([^\s\/]+)/).first
|
2019-07-22 20:49:07 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
unless username.blank?
|
|
|
|
username.downcase!
|
2019-07-24 17:37:00 -07:00
|
|
|
return :username if ENV.fetch('REJECT_IF_USERNAME_EQUALS', '').split.any? { |r| r == username }
|
|
|
|
return :username_starts_with if ENV.fetch('REJECT_IF_USERNAME_STARTS_WITH', '').split.any? { |r| username.start_with?(r) }
|
|
|
|
return :username_contains if ENV.fetch('REJECT_IF_USERNAME_CONTAINS', '').split.any? { |r| r.in?(username) }
|
2019-07-22 20:49:07 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
context = @json['@context'] unless @object && context
|
2019-07-22 19:12:54 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
return unless context
|
|
|
|
|
|
|
|
if context.is_a?(Array)
|
|
|
|
inline_context = context.find { |item| item.is_a?(Hash) }
|
|
|
|
if inline_context
|
|
|
|
keys = inline_context.keys
|
2019-07-24 17:37:00 -07:00
|
|
|
return :context if ENV.fetch('REJECT_IF_CONTEXT_EQUALS', '').split.any? { |r| r.in?(keys) }
|
|
|
|
return :context_starts_with if ENV.fetch('REJECT_IF_CONTEXT_STARTS_WITH', '').split.any? { |r| keys.any? { |k| k.start_with?(r) } }
|
|
|
|
return :context_contains if ENV.fetch('REJECT_IF_CONTEXT_CONTAINS', '').split.any? { |r| keys.any? { |k| r.in?(k) } }
|
2019-07-22 19:12:54 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-07-24 17:37:00 -07:00
|
|
|
nil
|
|
|
|
end
|
|
|
|
|
|
|
|
def reject_reason(reason)
|
|
|
|
case reason
|
|
|
|
when :domain
|
|
|
|
"the origin domain is blocked"
|
|
|
|
when :id_starts_with
|
|
|
|
"the object's URI starts with a blocked phrase"
|
|
|
|
when :id_contains
|
|
|
|
"the object's URI contains a blocked phrase"
|
|
|
|
when :username
|
|
|
|
"the author's username is blocked"
|
|
|
|
when :username_starts_with
|
|
|
|
"the author's username starts with a blocked phrase"
|
|
|
|
when :username_contains
|
|
|
|
"the author's username contains a blocked phrase"
|
|
|
|
when :context
|
|
|
|
"the object's JSON-LD context has a key matching a blocked phrase"
|
|
|
|
when :context_starts_with
|
|
|
|
"the object's JSON-LD context has a key starting with a blocked phrase"
|
|
|
|
when :context_contains
|
|
|
|
"the object's JSON-LD context has a key containing a blocked phrase"
|
|
|
|
else
|
|
|
|
"of an undefined reason"
|
|
|
|
end
|
2019-07-22 19:12:54 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
def autoreject?(uri = nil)
|
2019-07-23 17:18:52 -07:00
|
|
|
return false if @options && @options[:imported]
|
2019-07-24 17:37:00 -07:00
|
|
|
reason = should_reject?(uri)
|
|
|
|
if reason
|
|
|
|
reason = reject_reason(reason)
|
2019-07-22 22:10:58 -07:00
|
|
|
if @json
|
2019-07-30 11:54:13 -07:00
|
|
|
Rails.logger.info("Rejected an incoming '#{@json['type']}#{@object && " #{@object['type']}".rstrip}' from #{@json['id']} because #{reason}.")
|
2019-07-22 22:10:58 -07:00
|
|
|
elsif uri
|
2019-07-30 11:54:13 -07:00
|
|
|
Rails.logger.info("Rejected an outgoing request to #{uri} because #{reason}.")
|
2019-07-22 22:10:58 -07:00
|
|
|
end
|
2019-07-22 19:12:54 -07:00
|
|
|
return true
|
|
|
|
end
|
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|