Commit 38a7ea698ef6daa4f175bdd180ff0b81dc44fa81
Committed by
Daniela Feitosa
1 parent
e17f85d6
Exists in
master
and in
29 other branches
Removing Spaminator from AntiSpam Plugin to start it independently
Showing
2 changed files
with
0 additions
and
168 deletions
Show diff stats
plugins/anti_spam/lib/anti_spam_plugin/spaminator.rb
@@ -1,115 +0,0 @@ | @@ -1,115 +0,0 @@ | ||
1 | -require 'benchmark' | ||
2 | - | ||
3 | -class AntiSpamPlugin::Spaminator | ||
4 | - | ||
5 | - class << self | ||
6 | - def run(environment) | ||
7 | - instance = new(environment) | ||
8 | - instance.run | ||
9 | - end | ||
10 | - | ||
11 | - def benchmark(environment) | ||
12 | - puts Benchmark.measure { run(environment) } | ||
13 | - end | ||
14 | - end | ||
15 | - | ||
16 | - | ||
17 | - def initialize(environment) | ||
18 | - @environment = environment | ||
19 | - end | ||
20 | - | ||
21 | - def run | ||
22 | - start_time = Time.now | ||
23 | - | ||
24 | - process_all_comments | ||
25 | - process_all_people | ||
26 | - process_people_without_network | ||
27 | - | ||
28 | - finish(start_time) | ||
29 | - end | ||
30 | - | ||
31 | - protected | ||
32 | - | ||
33 | - def finish(start_time) | ||
34 | - @environment.settings[:spaminator_last_run] = start_time | ||
35 | - @environment.save! | ||
36 | - end | ||
37 | - | ||
38 | - def conditions(table) | ||
39 | - last_run = @environment.settings[:spaminator_last_run] | ||
40 | - if last_run | ||
41 | - ["profiles.environment_id = ? AND #{table}.created_at > ?", @environment.id, last_run] | ||
42 | - else | ||
43 | - [ "profiles.environment_id = ?", @environment.id] | ||
44 | - end | ||
45 | - end | ||
46 | - | ||
47 | - def process_all_comments | ||
48 | - puts 'Processing comments ...' | ||
49 | - i = 0 | ||
50 | - comments = Comment.joins("JOIN articles ON (comments.source_id = articles.id AND comments.source_type = 'Article') JOIN profiles ON (profiles.id = articles.profile_id)").where(conditions(:comments)) | ||
51 | - total = comments.count | ||
52 | - comments.find_each do |comment| | ||
53 | - puts "Comment #{i += 1}/#{total} (#{100*i/total}%)" | ||
54 | - process_comment(comment) | ||
55 | - end | ||
56 | - end | ||
57 | - | ||
58 | - def process_all_people | ||
59 | - puts 'Processing people ...' | ||
60 | - i = 0 | ||
61 | - people = Person.where(conditions(:profiles)) | ||
62 | - total = people.count | ||
63 | - people.find_each do |person| | ||
64 | - puts "Person #{i += 1}/#{total} (#{100*i/total}%)" | ||
65 | - process_person(person) | ||
66 | - end | ||
67 | - end | ||
68 | - | ||
69 | - def process_comment(comment) | ||
70 | - comment.check_for_spam | ||
71 | - | ||
72 | - # TODO several comments with the same content: | ||
73 | - # → disable author | ||
74 | - # → mark all of them as spam | ||
75 | - | ||
76 | - # TODO check comments that contains URL's | ||
77 | - end | ||
78 | - | ||
79 | - def process_person(person) | ||
80 | - # person is author of more than 2 comments marked as spam | ||
81 | - # → burn | ||
82 | - # | ||
83 | - number_of_spam_comments = Comment.spam.where(author_id => person.id).count | ||
84 | - if number_of_spam_comments > 2 | ||
85 | - mark_as_spammer(person) | ||
86 | - end | ||
87 | - end | ||
88 | - | ||
89 | - def process_people_without_network | ||
90 | - # people who signed up more than one month ago, have no friends and <= 1 | ||
91 | - # communities | ||
92 | - # | ||
93 | - # → burn | ||
94 | - # → mark their comments as spam | ||
95 | - # | ||
96 | - Person.where(:environment_id => @environment.id).where(['created_at < ?', Time.now - 1.month]).find_each do |person| | ||
97 | - # TODO progress indicator - see process_all_people above | ||
98 | - number_of_friends = person.friends.count | ||
99 | - number_of_communities = person.communities.count | ||
100 | - if number_of_friends == 0 && number_of_communities <= 1 | ||
101 | - mark_as_spammer(person) | ||
102 | - Comment.where(:author_id => person.id).find_each do |comment| | ||
103 | - comment.spam! | ||
104 | - end | ||
105 | - end | ||
106 | - end | ||
107 | - end | ||
108 | - | ||
109 | - def mark_as_spammer(person) | ||
110 | - # FIXME create an AbuseComplaint and finish instead of calling | ||
111 | - # Person#disable directly | ||
112 | - person.disable | ||
113 | - end | ||
114 | - | ||
115 | -end |
plugins/anti_spam/test/unit/anti_spam_plugin/spaminator_test.rb
@@ -1,53 +0,0 @@ | @@ -1,53 +0,0 @@ | ||
1 | -require 'test_helper' | ||
2 | - | ||
3 | -class AntiSpamPluginSpaminatorTest < ActiveSupport::TestCase | ||
4 | - | ||
5 | - def setup | ||
6 | - @environment = Environment.new | ||
7 | - @environment.id = 99 | ||
8 | - @spaminator = AntiSpamPlugin::Spaminator.new(@environment) | ||
9 | - @spaminator.stubs(:puts) | ||
10 | - @now = Time.now | ||
11 | - Time.stubs(:now).returns(@now) | ||
12 | - end | ||
13 | - | ||
14 | - should 'search everything in the first run' do | ||
15 | - assert_equal(['profiles.environment_id = ?',99], @spaminator.send(:conditions, nil)) | ||
16 | - end | ||
17 | - | ||
18 | - should 'search using recorded last date' do | ||
19 | - @environment.settings[:spaminator_last_run] = @now | ||
20 | - assert_equal(['profiles.environment_id = ? AND table.created_at > ?', 99, @now], @spaminator.send(:conditions, 'table')) | ||
21 | - end | ||
22 | - | ||
23 | - should 'record time of last run in environment' do | ||
24 | - @spaminator.expects(:process_all_comments) | ||
25 | - @spaminator.expects(:process_all_people) | ||
26 | - @environment.stubs(:save!) | ||
27 | - @spaminator.run | ||
28 | - assert_equal @now, @environment.settings[:spaminator_last_run] | ||
29 | - end | ||
30 | - | ||
31 | - should 'find all comments' do | ||
32 | - @spaminator.stubs(:process_comment) | ||
33 | - @spaminator.send :process_all_comments | ||
34 | - end | ||
35 | - | ||
36 | - should 'find all people' do | ||
37 | - @spaminator.stubs(:process_person) | ||
38 | - @spaminator.send :process_all_people | ||
39 | - end | ||
40 | - | ||
41 | - should 'find all comments newer than a date' do | ||
42 | - @environment.settings[:spaminator_last_run] = Time.now - 1.month | ||
43 | - @spaminator.stubs(:process_comment) | ||
44 | - @spaminator.send :process_all_comments | ||
45 | - end | ||
46 | - | ||
47 | - should 'find all people newer than a date' do | ||
48 | - @environment.settings[:spaminator_last_run] = Time.now - 1.month | ||
49 | - @spaminator.stubs(:process_person) | ||
50 | - @spaminator.send :process_all_people | ||
51 | - end | ||
52 | - | ||
53 | -end |