0 Пользователей и 1 Гость просматривают эту тему.
  • 5 Ответов
  • 3444 Просмотров
*

eX

  • Захожу иногда
  • 256
  • 72 / 0
Предлагаю разработанное мной решение по удалению всех устаревших объявлений и их "хвостов" в виде фотографий, приаттаченных (добавленных) к соответствующим объявлениям.

Методика: Поиск и отбор истекших объявлений в базе по дате срока истечения актуальности, поиск соответствующих привязанных к ним фотографиям и "живое" удаление как из базы, так и с хоста.

Доработка заключается в правке файлов (бэкэнда) админской части компонента Adsmanager.
Вот собственно код:

1. Открываем \administrator\components\com_adsmanager
2. Файл admin.adsmanager.php
Ищем строку: case "tools":
Переписываем все что ниже таким образом:
Код
	case "tools":
{
switch($task) {
case "installjoomfish":
installJoomfish($option);
break;
case "installsef":
installSEF($option);
break;
case "displayMarketplace":
displayConvertMarketplace($option);
break;
case "importMarketplace":
importMarketplace($option);
break;
case "delexpads":
deleteExpAds($option);
break;

default:
displayTools($option);
break;
}
}

Таким образом мы добавили новый action для компонента delexpads.

3. Далее дописываем в конец файла новую функцию для обработки сего экшна.
Код
function deleteExpAds ($option ) {
global $database, $mosConfig_live_site, $mosConfig_absolute_path;

$database->setQuery( "SELECT * FROM #__adsmanager_config");
$database->loadObject($conf);

$nbImages = $conf->nb_images;

$sqlGetExpired = "SELECT a.id as id FROM #__adsmanager_ads as a WHERE a.date_recall < CURRENT_DATE ";
$database->setQuery($sqlGetExpired);
$expiredAds = $database->loadObjectList();

$countExp = sizeof($expiredAds);

if ($countExp > 0) {
$delSQL = array();
foreach($expiredAds as $row) {
$delSQL[] = $row->id;
for($i = 1 ;$i < $nbImages + 1; $i++) {
$ext_name = chr(ord('a')+$i-1);
$pic = $mosConfig_absolute_path."/images/com_adsmanager/foto/".$row->id.$ext_name.".jpg";
$pic2 = $mosConfig_absolute_path."/images/com_adsmanager/foto/".$row->id.$ext_name."_t.jpg";
print $pic.'<br>';
if ( file_exists( $pic)) {
@unlink($pic);
}
if ( file_exists( $pic2)) {
@unlink($pic2);
}

}
}
$sqlGoToDel = "DELETE FROM #__adsmanager_ads WHERE id IN (".implode(',',$delSQL).")";

$database->setQuery($sqlGoToDel);
$database->query();

mosRedirect( "index2.php?option=$option&act=tools", ADSMANAGER_TOOLS_EXDELETEEXPADS_DELETED);

} else {
mosRedirect( "index2.php?option=$option&act=tools", ADSMANAGER_TOOLS_EXDELETEEXPADS_NONE);
}

}
4. Открываем admin.adsmanager.html.php
Ищем строку:
Код
function displayTools($option){
?>
<?php HTML_adsmanager::header($option,ADSMANAGER_TOOLS_MAIN_PAGE); ?>
<div style="text-align:left">
<url>
...
</url>
Переписываем <ul>..</ul> на:
Код
<ul>
<li><b><a href="index2.php?option=<?php echo $option; ?>&act=tools&task=delexpads"><?php echo ADSMANAGER_TOOLS_EXDELETEEXPADS;?></a></b></li>
<li><a href="index2.php?option=<?php echo $option; ?>&act=tools&task=displayMarketplace"><?php echo ADSMANAGER_CONVERT_MARKETPLACE;?></a></li>
<li><a href="index2.php?option=<?php echo $option; ?>&act=tools&task=installjoomfish"><?php echo ADSMANAGER_INSTALL_JOOMFISH;?></a></li>
<li><a href="index2.php?option=<?php echo $option; ?>&act=tools&task=installsef"><?php echo ADSMANAGER_INSTALL_SEF;?></a></li>
</ul>

5. Открываем наши файлы локализации: \components\com_adsmanager\lang\lang_russian.php
Дописываем в конец файла:
Код
DEFINE('ADSMANAGER_TOOLS_EXDELETEEXPADS', 'Удалить УСТАРЕВШИЕ и ПРОСРОЧЕННЫЕ объявления');
DEFINE('ADSMANAGER_TOOLS_EXDELETEEXPADS_DELETED', 'УСТАРЕВШИЕ объявления были УДАЛЕНЫ!');
DEFINE('ADSMANAGER_TOOLS_EXDELETEEXPADS_NONE', 'УСТАРЕВШИХ объявления не найдено.');

Ну вот и готово. Теперь можно пользоваться доработкой.

P.S.: Далее можно автоматизировать данную функцию для запуска по cron-у. Отзывы и пожелания приветствуются.


« Последнее редактирование: 10.08.2009, 09:04:28 от eX »
*

MOHCTPUK

  • Захожу иногда
  • 50
  • 5 / 6
  • d[-_-]b
У меня стоит "AdsManager 2.5.0" Как сделать так что бы не удалялось, а снималось с публикации объявления.

А точнее:
В Админке и в базе уже вроде сделанно поле по которому администратор укажет дату по которой объявление истеканию срока удаляются, мне надо сделать что бы они больше не будет “Publish” т.е. автоматический оно станет «UnPublish»  Тоже самая система что и на статях материалов Joomla (Начало публикации и Конец публикации). Помоему можно сделать автоматом что бы считалось, т.е. автоматический вить заполняется в базе поле «date_created» (Дата создания объявления), вот и если ему прибавить поле «ad_daylimit» (Сколько дней хочет что бы пользователь публиковал своё объявление) и что бы это всё было ровно полю «date_recall» (т.е. конец публикации будет добавлятся автоматический)
*

DK-Scorp

  • Захожу иногда
  • 228
  • 6 / 0
  • Всегда готов! К чему только....? ХЗ.....
Версия 2.5 RC2 жустина 1.2 - не работает :(

В конфе в сроках указал:

Использовать срок размещения? - Да
Срок размещения (дней)            - 2

При запуске пишет - УСТАРЕВШИХ объявления не найдено.
Хотя сегодня 21.12 а в базе объявления от 17.12

*

savenko123

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
*

Doc

  • Захожу иногда
  • 456
  • 17 / 0
А вот такие хвосты http://remrai.ru уберет или нет ?
А то обьявление удалено, а в поисковиках оно есть и так отображается
Или может можно как то сделать, что бы было написано, ПРОДАНО
« Последнее редактирование: 25.01.2016, 12:43:34 от Doc »
*

girlwolf

  • Захожу иногда
  • 126
  • 3 / 0
Всё сделала, как нужно. Только не пойму как работает данная доработка? Она просто удаляет вместе с объявлениями и фото, когда истекает срок или как-то по-другому? А как мне теперь удалить старые фото с объявлений, срок которых истёк и они были автоматически удалены. В принципе, объявлени нет, только фото остались.

Заранее спасибо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Заглушки с http://placehold.it вместо картинок в списке объявлений

Автор efimov777

Ответов: 6
Просмотров: 1106
Последний ответ 12.04.2020, 07:25:59
от Pavel
Хочу уточнить, есть в AdsManager возможность загрузки объявлений с парсера?

Автор DomBeri

Ответов: 3
Просмотров: 5532
Последний ответ 28.03.2019, 17:20:10
от DomBeri
Удалить карту объявлений Google

Автор trel

Ответов: 7
Просмотров: 369
Последний ответ 25.03.2019, 09:02:25
от Technic
Вывод объявлений в случайном порядке

Автор Sabotage

Ответов: 3
Просмотров: 635
Последний ответ 28.09.2018, 14:21:05
от Sabotage
Поля в списке объявлений

Автор klekovkinandrey

Ответов: 0
Просмотров: 545
Последний ответ 17.01.2018, 10:18:34
от klekovkinandrey