Release status: stable
|Description||Uses stopforumspam.com to prevent spam|
|Latest version||0.3.0 (2019-02-07)|
|License||GNU General Public License 2.0 or later|
|Translate the StopForumSpam extension if it is available at translatewiki.net|
|Check usage and version matrix.|
|Issues||Open tasks · Report a bug|
The StopForumSpam extension allows wikis to utilize and contribute data to stopforumspam.com.
It features automatic IP blocking and an easy interface for administrators to submit data.
Use of the IP blacklist requires that you use some kind of object caching.
It won't work if you have $wgMainCacheType set to CACHE_NONE.
If neither APC or Memcached is an option, the simplest approach is to fallback to storing the object cache in your MySQL database.
The following preset (in LocalSettings.php) will do that:
$wgMainCacheType = CACHE_DB;
- Download and place the file(s) in a directory called
- Add the following code at the bottom of your LocalSettings.php:
wfLoadExtension( 'StopForumSpam' );
- Configure as required.
- Done – Navigate to Special:Version on your wiki to verify that the extension is successfully installed.
$wgSFSIPListLocation- location of an unzipped IP address blacklist
$wgSFSReportOnly- enables a mode where users are not blocked from non-read actions after tripping the blacklist
sfsblock-bypass- allows users to bypass blacklisted IP blocks
To log reports about who StopForumSpam is exempting and blocking, you can enable the "StopForumSpam" channel in your structured logging configuration. All reports for the extension are logged at a level of INFO. If you do not have structured logging configured, you can log to a file by configuring $wgDebugLogGroups in your LocalSettings.php, like so:
$wgDebugLogGroups['StopForumSpam'] = '/var/log/mediawiki/stopforumspam.log';
This will write the log to a file located in
MediaWiki will need access to write to this log file and the file should not accessible via the web as it will contain private details of your users (such as usernames, page names, and IP addresses).
The simple logging using
$wgDebugLogGroups will omit details compared to using a structured logging solution such as monolog.
When using the AbuseFilter, a variable named "sfs_blocked" is added. The value is false if the user is not a spammer, and true if they are a spammer.
You can download IP blacklists, and import them using the
StopForumSpam has several lists; we recommend using the "listed_ip_30_all" list.
Once you choose the list you want, download and extract it to somewhere on your server, then point
$wgSFSIPListLocation in the LocalSettings.php file at it.
We recommend setting up a nightly cron job to download and extract new versions of the list and subsequently running the updateBlacklist maintenance script.
If that IP tries to edit, or a user tries to edit through that IP address, they will be prevented from editing.
To exempt a user from being blocked, give them the
sfsblock-bypass user right.