3 namespace wcf\system\importer
;
8 * Imports conversation users.
11 * @copyright 2001-2019 WoltLab GmbH
12 * @license GNU Lesser General Public License <http://opensource.org/licenses/lgpl-license.php>
13 * @package WoltLabSuite\Core\System\Importer
15 class ConversationUserImporter
extends AbstractImporter
20 public function import($oldID, array $data, array $additionalData = [])
22 $data['conversationID'] = ImportHandler
::getInstance()
23 ->getNewID('com.woltlab.wcf.conversation', $data['conversationID']);
24 if (!$data['conversationID']) {
27 $data['participantID'] = ImportHandler
::getInstance()->getNewID('com.woltlab.wcf.user', $data['participantID']);
29 $sql = "INSERT INTO wcf" . WCF_N
. "_conversation_to_user
30 (conversationID, participantID, username, hideConversation, isInvisible, lastVisitTime)
31 VALUES (?, ?, ?, ?, ?, ?)
32 ON DUPLICATE KEY UPDATE hideConversation = IF(hideConversation > 0 AND hideConversation = VALUES(hideConversation),hideConversation,0),
33 isInvisible = IF(isInvisible AND VALUES(isInvisible),1,0),
34 lastVisitTime = GREATEST(lastVisitTime,VALUES(lastVisitTime))";
35 $statement = WCF
::getDB()->prepareStatement($sql);
37 $data['conversationID'],
38 $data['participantID'],
40 $data['hideConversation'],
42 $data['lastVisitTime'],
46 if ($data['participantID'] && !empty($additionalData['labelIDs'])) {
47 $sql = "INSERT IGNORE INTO wcf" . WCF_N
. "_conversation_label_to_object
48 (labelID, conversationID)
50 $statement = WCF
::getDB()->prepareStatement($sql);
51 foreach ($additionalData['labelIDs'] as $labelID) {
52 $labelID = ImportHandler
::getInstance()->getNewID('com.woltlab.wcf.conversation.label', $labelID);
54 $statement->execute([$labelID, $data['conversationID']]);