the class object is created when a visitor add a comment
and, of course, for each call of akismet to signalize a SPAM.
so I need a new object on each comment, don't you think ?
I do some tests but I am unable to verify the improvement (I can't see if the function submitSpam() is called by the filter).
Is there a way to add some trace for debugging the code (to generate zp-date/debug.log or something like that) ?
thanks for your help
ok, I have found and I have set DEBUG_PLUGINS and DEBUG_FILTERS to true in global-definitions.
I can't see a call of the hook 'comment_disapprove' when I choose a comment as a Spam.
I can see the registration, only if I go to admin/options/comment.
could you help me ?
not sure it is the only problem.
with DEBUG_FILTERS, I can see :
the function submitSpam is only registred when I navigate on admin/options/comment.
wathever I do, the test if ( !isset($_zp_filters[$hook]) ) on function zp_apply_filter is false, so my function is not triggered.
I really need some help on that subject
You are supposed to be able to attach class methods to filters, but I do not know if anyone has ever really done that.
Also, it seems that because the spam filters do not follow the normal filter implementation there is an issue of the filter not getting loaded.
A work-around would be to create a new plugin that contains the filtering code. It would have to do the "require_once" on the spam filter to get it loaded. Otherwise your code could pretty much stay as above.
`require_once(SERVERPATH.'/'.USER_PLUGIN_FOLDER.'/spamfilters/akismet_php5.php');
zp_register_filter('comment_disapprove', 'submitSpam');
function submitSpam($comment) {
[...]
$spamfilter = new SpamFilter();
$spamfilter->feedbackMessage($author, $email, $website, $body, false);
return $comment;
}'
Really what is needed is to recast the spam filters into normal plugins. But that is a 1.4.3 issue. Still, I think we will do that, so be on notice that the akismit filter will probably need to be change then.
I will look further to see if some other method will work. I will keep you posted.
It seems we have the same idea :-)
I will have a look as soon as possible
just a question : what is the need to add "$spamfilter = new SpamFilter();" in the code above ?
I was thinking the 1st part was necessary.
21 if (!(false === ($requirePath = getPlugin('spamfilters/'.getOption('spam_filter').'.php')))) { 22 require_once($requirePath); 23 $spamfilter = new SpamFilter(); 24 }