From abb8f5837ee1fa72d13d255cf29f4ade35f53ece Mon Sep 17 00:00:00 2001 From: Eugen Rochko Date: Sun, 23 Oct 2016 11:56:04 +0200 Subject: Fix public channel --- app/models/follow_suggestion.rb | 46 +++++++++++++++++++++-------------------- app/models/media_attachment.rb | 40 ++++++++++++++++++----------------- 2 files changed, 45 insertions(+), 41 deletions(-) (limited to 'app/models') diff --git a/app/models/follow_suggestion.rb b/app/models/follow_suggestion.rb index 22084612f..cfb0887d5 100644 --- a/app/models/follow_suggestion.rb +++ b/app/models/follow_suggestion.rb @@ -1,8 +1,9 @@ class FollowSuggestion - def self.get(for_account_id, limit = 10) - neo = Neography::Rest.new + class << self + def get(for_account_id, limit = 10) + neo = Neography::Rest.new - query = <(b)-[:follows]->(c) WHERE a <> c @@ -12,30 +13,30 @@ ORDER BY count(b) DESC, c.nodeRank DESC LIMIT {limit} END - results = neo.execute_query(query, id: for_account_id, limit: limit) + results = neo.execute_query(query, id: for_account_id, limit: limit) - if results.empty? || results['data'].empty? - results = fallback(for_account_id, limit) - elsif results['data'].size < limit - results['data'] = (results['data'] + fallback(for_account_id, limit - results['data'].size)['data']).uniq - end + if results.empty? || results['data'].empty? + results = fallback(for_account_id, limit) + elsif results['data'].size < limit + results['data'] = (results['data'] + fallback(for_account_id, limit - results['data'].size)['data']).uniq + end - account_ids = results['data'].map(&:first) - blocked_ids = Block.where(account_id: for_account_id).pluck(:target_account_id) - accounts_map = Account.where(id: account_ids - blocked_ids).with_counters.map { |a| [a.id, a] }.to_h + account_ids = results['data'].map(&:first) + blocked_ids = Block.where(account_id: for_account_id).pluck(:target_account_id) + accounts_map = Account.where(id: account_ids - blocked_ids).with_counters.map { |a| [a.id, a] }.to_h - account_ids.map { |id| accounts_map[id] }.compact - rescue Neography::NeographyError, Excon::Error::Socket => e - Rails.logger.error e - return [] - end + account_ids.map { |id| accounts_map[id] }.compact + rescue Neography::NeographyError, Excon::Error::Socket => e + Rails.logger.error e + return [] + end - private + private - def self.fallback(for_account_id, limit) - neo = Neography::Rest.new + def fallback(for_account_id, limit) + neo = Neography::Rest.new - query = < b @@ -45,6 +46,7 @@ ORDER BY b.nodeRank DESC LIMIT {limit} END - neo.execute_query(query, id: for_account_id, limit: limit) + neo.execute_query(query, id: for_account_id, limit: limit) + end end end diff --git a/app/models/media_attachment.rb b/app/models/media_attachment.rb index 008147a08..55eabc226 100644 --- a/app/models/media_attachment.rb +++ b/app/models/media_attachment.rb @@ -34,26 +34,28 @@ class MediaAttachment < ApplicationRecord image? ? 'image' : 'video' end - private - - def self.file_styles(f) - if f.instance.image? - { - original: '100%', - small: '510x680>' - } - else - { - small: { - convert_options: { - output: { - vf: 'scale=\'min(510\, iw):min(680\, ih)\':force_original_aspect_ratio=decrease' - } - }, - format: 'png', - time: 1 + class << self + private + + def file_styles(f) + if f.instance.image? + { + original: '100%', + small: '510x680>' } - } + else + { + small: { + convert_options: { + output: { + vf: 'scale=\'min(510\, iw):min(680\, ih)\':force_original_aspect_ratio=decrease' + } + }, + format: 'png', + time: 1 + } + } + end end end end -- cgit