e9df0680e835309501b2baaa7a73757fd0e546bd
2 namespace wcf\system\importer
;
6 * Imports conversation users.
9 * @copyright 2001-2016 WoltLab GmbH
10 * @license GNU Lesser General Public License <http://opensource.org/licenses/lgpl-license.php>
11 * @package com.woltlab.wcf.conversation
12 * @subpackage system.importer
13 * @category Community Framework
15 class ConversationUserImporter
extends AbstractImporter
{
19 public function import($oldID, array $data, array $additionalData = []) {
20 $data['conversationID'] = ImportHandler
::getInstance()->getNewID('com.woltlab.wcf.conversation', $data['conversationID']);
21 if (!$data['conversationID']) return 0;
22 $data['participantID'] = ImportHandler
::getInstance()->getNewID('com.woltlab.wcf.user', $data['participantID']);
24 $sql = "INSERT INTO wcf".WCF_N
."_conversation_to_user
25 (conversationID, participantID, username, hideConversation, isInvisible, lastVisitTime)
26 VALUES (?, ?, ?, ?, ?, ?)
27 ON DUPLICATE KEY UPDATE hideConversation = IF(hideConversation > 0 AND hideConversation = VALUES(hideConversation),hideConversation,0),
28 isInvisible = IF(isInvisible AND VALUES(isInvisible),1,0),
29 lastVisitTime = GREATEST(lastVisitTime,VALUES(lastVisitTime))";
30 $statement = WCF
::getDB()->prepareStatement($sql);
32 $data['conversationID'],
33 $data['participantID'],
35 $data['hideConversation'],
37 $data['lastVisitTime']
41 if ($data['participantID'] && !empty($additionalData['labelIDs'])) {
42 $sql = "INSERT IGNORE INTO wcf".WCF_N
."_conversation_label_to_object
43 (labelID, conversationID)
45 $statement = WCF
::getDB()->prepareStatement($sql);
46 foreach ($additionalData['labelIDs'] as $labelID) {
47 $labelID = ImportHandler
::getInstance()->getNewID('com.woltlab.wcf.conversation.label', $labelID);
48 if ($labelID) $statement->execute([$labelID, $data['conversationID']]);