Log in

View Full Version : create cron to delete thread an post logicaly delete


developpez.com
09-13-2007, 02:27 PM
Hello

I try to create a cron php file to physical delete all thread and post logicaly delete and have more than 2 month.

in a first time i just try to create a SQL as :
DELETE * FROM vb_post WHERE visible = 2 ....

But the post have more than one only table in the database. and i think that delete directly the post in the database is the wrong way .

So i try to create the next file, can you correct this ?
<?php

error_reporting(E_ALL & ~E_NOTICE);
if (!is_object($vbulletin->db))
{
exit;
}

// tentative d'adaptation pour les Posts
// delete logical delete post
// note netah : mettre a jour ou en variable la condition de temps exemple avec 4 jours ...

$posts = $vbulletin->db->query_read("
SELECT postid
FROM " . TABLE_PREFIX . "post
WHERE visible='2' AND dateline < " . intval(TIMENOW - 345600) . "
");

while ($post = $vbulletin->db->fetch_array($posts))
{
$post['open'] = 10;
$postman =& datamanager_init('Post', $vbulletin, ERRTYPE_SILENT, 'threadpost');
$postman->set_existing($post);
$postman->delete(false, true, NULL, false);
unset($postman);
}
// fin de la tentative que nous esperons tous pas veine ....

// delete logical delete thread
// note netah : mettre a jour ou en variable la condition de temps exemple avec 4 jours ...
$threads = $vbulletin->db->query_read("
SELECT threadid
FROM " . TABLE_PREFIX . "thread
WHERE visible='2' AND dateline < " . intval(TIMENOW - 345600) . "
");

while ($thread = $vbulletin->db->fetch_array($threads))
{
$thread['open'] = 10;
$threadman =& datamanager_init('Thread', $vbulletin, ERRTYPE_SILENT, 'threadpost');
$threadman->set_existing($thread);
$threadman->delete(false, true, NULL, false);
unset($threadman);
}

($hook = vBulletinHook::fetch_hook('cron_script_cleanlogica ldelete')) ? eval($hook) : false;

log_cron_action('', $nextitem, 1);

?>

i'm ready to explian anything you want about this problem ...

Best reguards !

netah