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

Kintim

  • Осваиваюсь на форуме
  • 39
  • 1 / 0
Доброго времени суток .
Уважаемые форумчане подскажите пожалуйста, как мне добавить в письмо Администратору (что высылается, для активации пользователей) данные из другой таблицы БД??
(JOOMLA 1.7) Читал вот эту статью: http://joomlaforum.ru/index.php?topic=130409.0, не помогла  :(

В общем, ситуация такая. При регистрации данные юзера пишутся в разные таблицы, __users и __k2_users, причем в К2 полнее информация.
А система авторизации вся заточена под __users, ну там токены, блокировки, время когда был/ушел и т.п.
Так, вот, нашел я вот это место, в com_users\models\registration.php :
Код
$db->setQuery(
'SELECT `id` FROM `#__users`' .
' WHERE `activation` = '.$db->Quote($token).
' AND `block` = 1' .
' AND `lastvisitDate` = '.$db->Quote($db->getNullDate())
);
Тут расписан запрос к БД функции активации пользователя..
Ну и соответственно дальше по коду, отправляется письмо администратору:
Код
$data = $user->getProperties();
$data['activation'] = JUtility::getHash(JUserHelper::genRandomPassword());
$user->set('activation', $data['activation']);
$data['siteurl'] = JUri::base();
$base = $uri->toString(array('scheme', 'user', 'pass', 'host', 'port'));
$data['activate'] = $base.JRoute::_('index.php?option=com_users&task=registration.activate&token='.$data['activation'], false);
$data['fromname'] = $config->get('fromname');
$data['mailfrom'] = $config->get('mailfrom');
$data['sitename'] = $config->get('sitename');
$user->setParam('activate', 1);
$emailSubject = JText::sprintf(
'COM_USERS_EMAIL_ACTIVATE_WITH_ADMIN_ACTIVATION_SUBJECT',
$data['name'],
$data['sitename']
);

$emailBody = JText::sprintf(
'COM_USERS_EMAIL_ACTIVATE_WITH_ADMIN_ACTIVATION_BODY',
$data['sitename'],
$data['name'],
$data['email'],
$data['username'],
$data['siteurl'].'index.php?option=com_users&task=registration.activate&token='.$data['activation']
);
Так вот, тут у меня вопрос?
Как мне в письмо администратору добавить поля формы регистрации, что записались в __k2_users в БД?
« Последнее редактирование: 20.12.2012, 23:08:00 от b2z »
*

Kintim

  • Осваиваюсь на форуме
  • 39
  • 1 / 0
Я попытался объединить таблички вот таким вот образом:
Код
$db->setQuery(
'SELECT user.`id`,
FROM `#__users` AS user JOIN `#__k2_users` AS userID ON user.`id`=userID.`userID`'.
' WHERE `activation` = '.$db->Quote($token).
' AND `block` = 1' .
' AND `lastvisitDate` = '.$db->Quote($db->getNullDate())
);
Теперь ссылка из письма проверки e-mail-а, та что с ТОКЕН-ом, ведет на главную страницу и пишет что ТОКЕН не верен.

Скорее всего изменились адреса, вот эти:
Код
$data['siteurl'].'index.php?option=com_users&task=registration.activate&token='.$data['activation']

$data['..............'] - где то в этом месте. Я ДУМАЮ.

Подскажите как мне поправить код, чтобы заработало?
*

Kintim

  • Осваиваюсь на форуме
  • 39
  • 1 / 0
Т.к. ни кто не стремится помогать, отвечаю на свой вопрос сам.
И так..
Ни чего объединять не нужно (я имею в виду таблицы БД, что я привел выше). Оставляем как есть в com_users\models\registration.php, т.е. так:
Код
public function activate($token).......
$db->setQuery(
'SELECT `id` FROM `#__users`' .
' WHERE `activation` = '.$db->Quote($token).
' AND `block` = 1' .
' AND `lastvisitDate` = '.$db->Quote($db->getNullDate())
);
Все так и должно быть..
А если хочется вывести дополнительную информацию из БД (допустим у вас так же как у меня информация о зарегистрированном пользователе пишется в 2 таблицы), то я сделал так. Добавил еще одну выборку из БД:
Код
//дополнительная выгрузка полей из формы
$db=& JFactory::getDBO();
$qgfm="SELECT * \n"
. "FROM `#__users` AS user JOIN `#__k2_users` AS userID ON user.`id`=userID.`userID`\n"
. "WHERE `userID` = '$userId'";
 
$db->setQuery($qgfm);
$dop_field_mail = $db->loadObject();
$result_1 = $dop_field_mail;

Ну и конечно же вывел их в теле письма администратору, добавив строки здесь:

Код
$emailBody = JText::sprintf(
'COM_USERS_EMAIL_ACTIVATE_WITH_ADMIN_ACTIVATION_BODY',
$data['sitename'],
$data['name'],
$data['email'],
$result_1->username,//начало вывода дополнительных полей
$result_1->phone,
$result_1->spec,
$result_1->address,
$result_1->company,
$result_1->city,
$result_1->brand,//окончание вывода дополнительных полей
$data['siteurl'].'index.php?option=com_users&task=registration.activate&token='.$data['activation']
);

Где "phone, spec, address...." это названия столбцов таблицы "k2_users".
Все приходит на почту... что и нужно было сделать.
*

Kintim

  • Осваиваюсь на форуме
  • 39
  • 1 / 0
Ах, да чтобы все поля вывелись так как нужно, не забываем поправить файл language/ru-RU/ru-RU.com_users.ini
Я правил то место где идет расшифровка "COM_USERS_EMAIL_ACTIVATE_WITH_ADMIN_ACTIVATION_BODY"
Привожу вариант своего форматирования:

Код
COM_USERS_EMAIL_ACTIVATE_WITH_ADMIN_ACTIVATION_BODY="Здравствуйте, уважаемый администратор!\n\n
Новый пользователь только что зарегистрировался на сайте «%s».\n
Пользователь подтвердил e-mail и просит активировать его учётную запись.\n
В этом письме содержатся его регистрационные данные:\n\n
Имя: %s \n
E-mail: %s \n
Логин: %s \n
Телефон: %s \n
Специальность: %s \n
Адрес: %s \n
Компания: %s \n
Город: %s \n
Бренд: %s \n\n
Вы можете активировать учётную запись пользователя, перейдя по следующей ссылке:\n %s \n"
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] title материалов и категорий без пунктов меню

Автор pharaoh

Ответов: 269
Просмотров: 58906
Последний ответ 03.02.2022, 02:45:26
от globus812
Расширение поля контента

Автор Atalla

Ответов: 12
Просмотров: 905
Последний ответ 13.06.2019, 07:44:02
от anatol81n
Переадресация после регистрации Joomla 2.5

Автор Наталик

Ответов: 21
Просмотров: 20552
Последний ответ 29.10.2018, 21:37:29
от Elena91
Как найти страницу регистрации для пользователей? Подскажите, пожалуйста

Автор cosmotion

Ответов: 11
Просмотров: 6098
Последний ответ 19.07.2018, 09:56:57
от vad78
Убрать поле подтверждения e-mail при регистрации

Автор cartgen

Ответов: 5
Просмотров: 7832
Последний ответ 01.05.2018, 16:56:07
от kasper9820