Spamalyser
Author Message
In short, Spamalyser tries to detect spam posts (not spam registrations) through a number of means and can perform some actions on detected spam.
Note that this plugin isn't exactly "complete", but should be "good enough" to use.

How is this different to other anti-spam plugins?
There are a number of other MyBB plugins which try to prevent spam.  However, I find that most of these can get rather pedantic and can easily block legitimate users with little, if any, means of them working around the block.
The aim of this plugin was to be somewhat more permissive than restrictive, as well as not have to rely on external services (although this plugin is capable of utilising information pulled from them).  This tries to deny as little as possible to legit users - for example, a solution such as blocking link posting for new users means that all users need to have a number of posts before they are able to post links, whereas Spamalyser allows this activity as long as it doesn't look spammy.

Stop Forum Spam and Fassim plugins, for example, seem to only perform blocks on user registration (before they even register, in fact).  As Spamalyser is more permissive, it only performs checks on posting (this also has the slight benefit of being able to work if guest posting is enabled, although Spamalyser isn't as effective with guests than it is with registered users).  Also, performing spam analysis on posts means that Spamalyser is able to use a greater number of inputs to judge whether a post is spam or not.
Of course, the downside is that Spamalyser will not try to do anything about spam registrations.

Can this be used with other anti-spam plugins?
Most of them yes.  I'm not sure whether this works with the Akismet plugin or not (although it's somewhat pointless to do so, because Spamalyser supports Akismet lookups).
If you use it with the Stop Forum Spam plugin, you may wish to disable SFS lookups in Spamalyser.

How does this plugin work?
When a user tries to post a new thread or reply, or edit a post, the plugin will check whether the user passes a number of thresholds (such as post count) and if so, deems the user "safe" and stops there.
If the user fails to pass the threshold test, the main Spamalyser engine kicks in and analyses the post to determine a "spam weighting" (likeliness of it being spam).  It then compares this weighting against some configurable action thresholds to decide on whether it should do anything to the post.  If the weighting meets the thresholds, Spamalyser can currently (depending on what you enable):
  • Report the post,
  • Unapprove the post, or
  • Block the post (displays an error when user tries to submit the post)
All weighting calculations are logged and can be viewed via ACP -> Tools -> Spamalyser Log

How is the "spam weighting" calculated?
Quite a number of means, but most of the code is link analysis.  Spammers ultimately want to post links, so it seems like a good place to start.  Every link posted will add to the weighting, and links with similar keywords or to the same domain get penalised more heavily.
Spamalyser can also make some judgements based on the poster's online time and other factors, and has a number of features to attempt to reduce the number of false positives (for example, by examining the user's previous posts).
External lookups to services such as Stop Forum Spam and Akismet are also supported, and you can specify the amount of weighting to give to these services.

You can try looking in the Spamalyser settings which show all the methods used by this plugin to detect spam.

Configuring Spamalyser
Spamalyser has quite a number of options, designed to give the administrator a fair amount of control over the spam analysis process.
The defaults are relatively permissive.  From my testing, you can probably reduce the Unapprove Threshold from 10 to 5 and capture a lot more spam.
Note that, by default, external lookups are disabled for localhost installs, but enabled for non-localhost installs.

I know there are a lot of options so it may be difficult to get your head around what they all do.  You can try inspecting the log (clicking on the weighting will show how it's calculated) to see how some posts' weights are determined and perhaps get a rough idea of what some of the options do.

Disable Link Analysis
If you wish to, you can completely disable the internal link analysis routine.  To do so, set the following three settings to 0:
  • Weight Per Simple Link
  • Weight Per Complex Link
  • Duplicate Keyword Bias

Akismet Note
To enable Akismet, you must enter in an API key - and you must ensure that this key is valid because Spamalyser won't check it.  Also, your server must be able to either make requests via cURL or fsockopen()

Upgrading
I'm not going to bother maintaining upgrade paths for this plugin.  This means that if you wish to upgrade to a newer version, you'll have to uninstall the old version, upload the files for the new version, then install it.
Obviously this means that you'll lose any setting changes you've made, as well as log entries, so you may wish to note down any custom settings you've set before uninstalling.  Do note that the meaning of some settings may change in the future, so refer to the changelog to ensure your custom settings have the same meaning.


Performance Issues
As this plugin performs external lookups by default, for all analysed posts, posting may be slower for posts which are examined.  Although the services queried (SFS, Akismet and Google) should have reasonably fast servers, you can choose to disable these lookups if you wish. [lookups are performed through MyBB's fetch_remote_file() function]
As for internal link analysis, the algorithm isn't exactly fast (still should be significantly faster than MyBB's post parser), but should be acceptable, especially since it's only done during posting.

Limitations
  • The plugin assumes that MyCode is always enabled (so only detects [url] type links), which is probably in-line with the assumptions made by most spammers
  • Google searching behaviour is somewhat erratic - it's a bit difficult to generate a representative search query from a post.  Can be tweaked, though I'm not too worried because spammers can theoretically bypass this by slightly varying their posts across forums
  • Reports currently only go to the database regardless of what reporting medium you have selected
(This post was last modified: 08-18-2011 08:28 PM by ZiNgA BuRgA.)
Find all posts by this user
Quote this message in a reply
Download: spamalyser-0.93.7z (25.85 KB)
Plugin Version: 0.93
Last Updated: 08-18-2011, 08:28 PM

Downloads: 3,799
MyBB Compatibility: 1.4.x, 1.6.x
Plugin License: GPLv3
Uploader: ZiNgA BuRgA
Sama34 Offline
Senior Member
****
Posts: 490
Joined: May 2011
Post: #71
RE: Spamalyser
The error message in that image implies you did not applied the code change.

Support PM's will be ignored. Yipi
Plugins: Announcement Bars - Custom Reputation - Mark PM As Unread
(This post was last modified: 03-23-2015 01:30 PM by Sama34.)
03-06-2015 04:56 PM
Visit this user's website Find all posts by this user Quote this message in a reply
Hamster24 Offline
Member
***
Posts: 69
Joined: Sep 2014
Post: #72
RE: Spamalyser
omg yeah sama i just manually looked the code and changed the two lines but now when i exactly copied and pasted your code it is working now.
03-06-2015 08:03 PM
Find all posts by this user Quote this message in a reply
Hamster24 Offline
Member
***
Posts: 69
Joined: Sep 2014
Post: #73
RE: Spamalyser
ok so the error was showing very nicely that you have tripped spam filter and the plugin dont let post people with too many links.
but if they reduce the links and publish the post then they get sql error please help i have changed the code exactly

Query:
SELECT rid FROM mybb_reportedposts WHERE pid=19721 AND reportstatus=0 LIMIT 1


let me rephrase the plugin works to stop someone add to many links but if they reduce the link and the thread is published and the plugin have to create a report in the report center the error comes up

here is what i have currently
[Image: kAbd5G3.png]
(This post was last modified: 03-21-2015 09:22 PM by Hamster24.)
03-21-2015 09:04 PM
Find all posts by this user Quote this message in a reply
Sama34 Offline
Senior Member
****
Posts: 490
Joined: May 2011
Post: #74
RE: Spamalyser
Knowing the error may help.

Support PM's will be ignored. Yipi
Plugins: Announcement Bars - Custom Reputation - Mark PM As Unread
03-22-2015 06:00 AM
Visit this user's website Find all posts by this user Quote this message in a reply
Hamster24 Offline
Member
***
Posts: 69
Joined: Sep 2014
Post: #75
RE: Spamalyser
its the same  i was getting earlier
http://i.imgur.com/ah0eT7P.png
SQL error 1146
(This post was last modified: 03-22-2015 03:30 PM by Hamster24.)
03-22-2015 03:30 PM
Find all posts by this user Quote this message in a reply
Sama34 Offline
Senior Member
****
Posts: 490
Joined: May 2011
Post: #76
RE: Spamalyser
Oh there is another line in the plugin that should be updated. Find:

PHP Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
	if($settings['spamalyser_report_nodupe']) {
		// check for attached unread reports
		if($db->fetch_field($db->simple_select('reportedposts', 'rid', 'pid='.$pid.' AND reportstatus=0', array('limit' => 1)), 'rid')) return false;
	}
	$lang->load('spamalyser');
	$post = get_post($pid);
	$db->insert_query('reportedposts', array(
		'pid' => $pid,
		'tid' => $post['tid'],
		'fid' => $post['fid'],
		'uid' => (int)$settings['spamalyser_report_uid'],
		'dateline' => TIME_NOW,
		'reportstatus' => 0,
		'reason' => $db->escape_string($lang->sprintf($lang->spamalyser_report_msg, $thresh))
	));


Change to:

PHP Code:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
	if($settings['spamalyser_report_nodupe']) {
		// check for attached unread reports
		if($db->fetch_field($db->simple_select('reportedcontent', 'rid', 'id='.$pid.' AND reportstatus=0 AND (type="post" OR type="")', array('limit' => 1)), 'rid')) return false;
	}
	$lang->load('spamalyser');
	$post = get_post($pid);
	$db->insert_query('reportedcontent', array(
		'id' => $pid,
		'id2' => $post['tid'],
		'id3' => $post['fid'],
		'type' => 'post',
		'uid' => (int)$settings['spamalyser_report_uid'],
		'dateline' => TIME_NOW,
		'reportstatus' => 0,
		'reason' => $db->escape_string($lang->sprintf($lang->spamalyser_report_msg, $thresh))
	));


Support PM's will be ignored. Yipi
Plugins: Announcement Bars - Custom Reputation - Mark PM As Unread
03-23-2015 01:39 PM
Visit this user's website Find all posts by this user Quote this message in a reply
Hamster24 Offline
Member
***
Posts: 69
Joined: Sep 2014
Post: #77
RE: Spamalyser
changed the code. thanks sama for the help
03-23-2015 04:35 PM
Find all posts by this user Quote this message in a reply
metulburr Offline
Junior Member
**
Posts: 6
Joined: Oct 2015
Post: #78
RE: Spamalyser
Says not compatable with mybb 1.8.6
10-19-2015 11:14 AM
Find all posts by this user Quote this message in a reply
Grey Ghost Offline
Junior Member
**
Posts: 10
Joined: Nov 2014
Post: #79
RE: Spamalyser
(10-19-2015 11:14 AM)metulburr Wrote:  Says not compatable with mybb 1.8.6

You can just change the compatibility line in sp_admin.php to include 1.8:

'compatibility' => '14*,15*,16*,18*',

However it doesn't work properly, and not even really need as 1.8 has it's own spam functions built in now.

[Image: TVGF_signature.png]
10-21-2015 05:57 AM
Find all posts by this user Quote this message in a reply
mikew Offline
Junior Member
**
Posts: 2
Joined: Aug 2016
Post: #80
RE: Spamalyser
(03-05-2015 04:20 AM)Hamster24 Wrote:  Please update this to 1.8 version

I have added the 2 fixes that Sama34 posted for mybb1.8

full download here:
https://github.com/mmikeww/mybb-spamalys...https://github.com/mmikeww/mybb-spamalyser/archive/


(03-05-2015 06:58 PM)Hamster24 Wrote:  also in spamalyser logs what is /admin/spamalyser_img/action_.gif i what does it symbolize as i am getting a broken image (404) so don't know what this image means.
other images such as /admin/spamalyser_img/action_blocked.gif is showing fine.

I'm seeing this too. As you said, for posts that get 'blocked', they correctly display the red X image. But for posts that get 'reported', or posts that are allowed through, I get the 404 image.
(This post was last modified: 08-23-2016 12:23 AM by mikew.)
08-21-2016 07:15 AM
Find all posts by this user Quote this message in a reply


Forum Jump: