2 * Copyright (c) 2014 Samsung Electronics Co., Ltd. All rights reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
20 #include <tr1/unordered_set>
24 #include <boost/filesystem.hpp>
25 #include <boost/chrono/detail/system.hpp>
28 #include "MsgUtilFile.h"
29 #include "MsgContact.h"
30 #include "MsgCppTypes.h"
31 #include "MsgGconfWrapper.h"
32 #include "MsgUtilFunction.h"
33 #include "MsgUtilStorage.h"
34 #include "MsgException.h"
37 static int msgCntLimit[MSG_COUNT_LIMIT_MAILBOX_TYPE_MAX][MSG_COUNT_LIMIT_MSG_TYPE_MAX] = {{10, 10, 0, 10, 10}, {5, 10, 0, 0, 0}, {10, 10, 0, 0, 0}, {10, 10, 0, 0, 0}, {0, 0, 10, 0, 0}};
41 #define CHECK_SIZE 1 * 1024 * 1024 * 1024
42 #define RESERVE 100 * 1024 * 1024
43 #define RESERVE_LITE 5 * 1024 * 1024
45 /*==================================================================================================
46 FUNCTION IMPLEMENTATION
47 ==================================================================================================*/
49 unsigned int MsgStoAddMessageTable(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsgInfo)
53 msg_error_t err = MSG_SUCCESS;
55 msg_message_id_t msgId = 0;
57 err = pDbHandle->getRowId(MSGFW_MESSAGE_TABLE_NAME, &msgId);
59 if (err != MSG_SUCCESS)
64 char* pFileData = NULL;
65 unique_ptr<char*, void(*)(char**)> buf(&pFileData, unique_ptr_deleter);
68 if (pMsgInfo->bTextSms == false) {
69 if (MsgOpenAndReadFile(pMsgInfo->msgData, &pFileData, &fileSize) == false)
72 MSG_DEBUG("file size [%d]", fileSize);
75 char keyName[MAX_VCONFKEY_NAME_LEN];
76 memset(keyName, 0x00, sizeof(keyName));
77 snprintf(keyName, sizeof(keyName), "%s/%d", MSG_SIM_SUBS_ID, pMsgInfo->sim_idx);
80 if (MsgSettingGetString(keyName, &imsi) != MSG_SUCCESS) {
81 MSG_INFO("MsgSettingGetString() is failed");
85 char sqlQuery[MAX_QUERY_LEN+1];
87 memset(sqlQuery, 0x00, sizeof(sqlQuery));
88 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, %d, %d, %d, %d, %d, %u, %d, %d, %d, %d, %d, %d, %d, %d, ?, '', '', ?, 0, %d, '%s', %d);",
89 MSGFW_MESSAGE_TABLE_NAME, msgId, pMsgInfo->threadId, pMsgInfo->folderId, pMsgInfo->storageId, pMsgInfo->msgType.mainType,
90 pMsgInfo->msgType.subType, (unsigned int)pMsgInfo->displayTime, pMsgInfo->dataSize, pMsgInfo->networkStatus, pMsgInfo->bRead, pMsgInfo->bProtected,
91 pMsgInfo->priority, pMsgInfo->direction, 0, pMsgInfo->bBackup, pMsgInfo->sim_idx, imsi, pMsgInfo->bRestricted);
93 MSG_DEBUG("QUERY : %s", sqlQuery);
98 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
101 pDbHandle->bindText(pMsgInfo->subject, 1);
103 if (pMsgInfo->msgType.subType == MSG_NOTIFICATIONIND_MMS) {
104 pDbHandle->bindText("", 2);
106 if (pMsgInfo->bTextSms == false)
107 pDbHandle->bindText(pFileData, 2);
109 pDbHandle->bindText(pMsgInfo->msgText, 2);
112 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
113 pDbHandle->finalizeQuery();
117 pDbHandle->finalizeQuery();
123 msg_error_t MsgStoSetReadStatus(MsgDbHandler *pDbHandle, msg_message_id_t msgId, bool bRead)
125 char sqlQuery[MAX_QUERY_LEN+1];
127 memset(sqlQuery, 0x00, sizeof(sqlQuery));
128 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET READ_STATUS = %d WHERE MSG_ID = %d;",
129 MSGFW_MESSAGE_TABLE_NAME, (int)bRead, msgId);
131 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS)
132 return MSG_ERR_DB_EXEC;
134 /* Get MAIN_TYPE, SUB_TYPE, STORAGE_ID */
135 memset(sqlQuery, 0x00, sizeof(sqlQuery));
136 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.MAIN_TYPE, A.SUB_TYPE, B.CONV_ID \
137 FROM %s A, %s B WHERE A.MSG_ID = %d AND A.CONV_ID = B.CONV_ID;",
138 MSGFW_MESSAGE_TABLE_NAME, MSGFW_CONVERSATION_TABLE_NAME, msgId);
140 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
141 return MSG_ERR_DB_PREPARE;
143 MSG_MESSAGE_TYPE_S msgType;
144 msg_thread_id_t convId;
146 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
147 msgType.mainType = pDbHandle->columnInt(0);
148 msgType.subType = pDbHandle->columnInt(1);
149 convId = pDbHandle->columnInt(2);
151 pDbHandle->finalizeQuery();
152 return MSG_ERR_DB_STEP;
155 pDbHandle->finalizeQuery();
157 MSG_DEBUG("Main Type:[%d] SubType:[%d] ConvId:[%d]", msgType.mainType, msgType.subType, convId);
159 if (MsgStoUpdateConversation(pDbHandle, convId) != MSG_SUCCESS) {
160 MSG_DEBUG("MsgStoUpdateConversation() Error");
161 return MSG_ERR_STORAGE_ERROR;
168 msg_error_t MsgStoGetOldestMessage(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsgInfo, msg_message_id_t *pMsgId)
170 char sqlQuery[MAX_QUERY_LEN+1];
172 memset(sqlQuery, 0x00, sizeof(sqlQuery));
174 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s \
175 WHERE SUB_TYPE = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND PROTECTED = 0 \
176 ORDER BY DISPLAY_TIME ASC",
177 MSGFW_MESSAGE_TABLE_NAME, pMsgInfo->msgType.subType, pMsgInfo->folderId, MSG_STORAGE_PHONE);
179 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
180 return MSG_ERR_DB_PREPARE;
182 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
183 *pMsgId = pDbHandle->columnInt(0);
185 pDbHandle->finalizeQuery();
186 return MSG_ERR_DB_STEP;
189 pDbHandle->finalizeQuery();
195 msg_error_t MsgStoCheckMsgCntFull(MsgDbHandler *pDbHandle, const MSG_MESSAGE_TYPE_S* pMsgType, msg_folder_id_t folderId)
199 msg_error_t err = MSG_SUCCESS;
201 boost::system::error_code ec;
202 boost::filesystem::space_info si = boost::filesystem::space(TZ_SYS_HOME_PATH, ec);
203 long long int available = 0;
206 MSG_ERR("Failed to get space info [%s]", ec.message().c_str());
207 return MSG_ERR_STORAGE_ERROR;
209 if (si.capacity < CHECK_SIZE)
210 available = si.available - RESERVE_LITE;
212 available = si.available - RESERVE;
217 MSG_DEBUG("Free space of storage is [%llu] Bytes.", available);
219 if (available < SMS_MINIMUM_SPACE && pMsgType->mainType == MSG_SMS_TYPE)
220 err = MSG_ERR_MESSAGE_COUNT_FULL;
221 else if (available < MMS_MINIMUM_SPACE && pMsgType->mainType == MSG_MMS_TYPE)
222 err = MSG_ERR_MESSAGE_COUNT_FULL;
231 msg_error_t MsgStoCountMsgByLimitCategory(MsgDbHandler *pDbHandle, const MSG_MESSAGE_TYPE_S *pMsgType, int *pMsgCount, msg_folder_id_t folderId)
233 if (pMsgType == NULL) {
234 MSG_DEBUG("pMsgType is NULL");
235 return MSG_ERR_NULL_POINTER;
240 char sqlQuery[MAX_QUERY_LEN+1];
241 memset(sqlQuery, 0x00, sizeof(sqlQuery));
243 if ((pMsgType->mainType == MSG_SMS_TYPE) && (pMsgType->subType == MSG_WAP_SI_SMS ||pMsgType->subType == MSG_WAP_SL_SMS)) { /* PUSH */
244 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d, %d) AND FOLDER_ID = %d;",
245 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_WAP_SI_SMS, MSG_WAP_SL_SMS, MSG_INBOX_ID);
246 } else if ((pMsgType->mainType == MSG_SMS_TYPE) && (pMsgType->subType == MSG_CB_SMS)) { /* CB */
247 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d) AND FOLDER_ID = %d;",
248 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_CB_SMS, MSG_CBMSGBOX_ID);
249 } else if ((pMsgType->mainType == MSG_SMS_TYPE) && (pMsgType->subType == MSG_SYNCML_CP)) { /* Provision */
250 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d) AND FOLDER_ID = %d;",
251 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_SYNCML_CP, MSG_INBOX_ID);
252 } else if ((pMsgType->mainType == MSG_SMS_TYPE)) { /* SMS */
253 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE NOT IN (%d, %d, %d, %d) AND FOLDER_ID = %d;",
254 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_WAP_SI_SMS, MSG_WAP_SL_SMS, MSG_CB_SMS, MSG_SYNCML_CP, MSG_INBOX_ID); /* etc SMS */
255 } else if ((pMsgType->mainType == MSG_MMS_TYPE) &&
256 (pMsgType->subType == MSG_SENDREQ_MMS || pMsgType->subType == MSG_SENDCONF_MMS || pMsgType->subType == MSG_RETRIEVE_AUTOCONF_MMS ||
257 pMsgType->subType == MSG_RETRIEVE_MANUALCONF_MMS || pMsgType->subType == MSG_NOTIFICATIONIND_MMS)) { /* MMS */
258 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d, %d, %d, %d, %d) AND FOLDER_ID = %d;",
259 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_SENDREQ_MMS, MSG_SENDCONF_MMS, MSG_RETRIEVE_AUTOCONF_MMS, MSG_RETRIEVE_MANUALCONF_MMS, MSG_NOTIFICATIONIND_MMS, folderId);
261 return MSG_ERR_INVALID_PARAMETER;
264 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
265 return MSG_ERR_DB_PREPARE;
267 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
268 *pMsgCount = pDbHandle->columnInt(0);
270 pDbHandle->finalizeQuery();
271 return MSG_ERR_DB_STEP;
274 pDbHandle->finalizeQuery();
280 int MsgStoCheckMsgCntLimit(const MSG_MESSAGE_TYPE_S* pMsgType, msg_folder_id_t folderId)
287 msgboxType = MSG_COUNT_LIMIT_INBOX_TYPE;
291 msgboxType = MSG_COUNT_LIMIT_OUTBOX_TYPE;
294 case MSG_SENTBOX_ID :
295 msgboxType = MSG_COUNT_LIMIT_SENTBOX_TYPE;
299 msgboxType = MSG_COUNT_LIMIT_DRAFTBOX_TYPE;
302 case MSG_CBMSGBOX_ID :
303 msgboxType = MSG_COUNT_LIMIT_CBMSGBOX_TYPE;
307 MSG_DEBUG("Unknown mailbox Type [%d]", folderId);
311 switch (pMsgType->subType) {
313 case MSG_REPLACE_TYPE1_SMS:
314 case MSG_REPLACE_TYPE2_SMS:
315 case MSG_REPLACE_TYPE3_SMS:
316 case MSG_REPLACE_TYPE4_SMS:
317 case MSG_REPLACE_TYPE5_SMS:
318 case MSG_REPLACE_TYPE6_SMS:
319 case MSG_REPLACE_TYPE7_SMS:
320 case MSG_MWI_VOICE_SMS:
321 case MSG_MWI_FAX_SMS:
322 case MSG_MWI_EMAIL_SMS:
323 case MSG_MWI_OTHER_SMS:
324 case MSG_STATUS_REPORT_SMS:
325 msgType = MSG_COUNT_LIMIT_SMS_TYPE;
329 msgType = MSG_COUNT_LIMIT_CB_TYPE;
334 msgType = MSG_COUNT_LIMIT_WAPPUSH_TYPE;
338 msgType = MSG_COUNT_LIMIT_PROVISION_TYPE;
341 case MSG_SENDREQ_MMS:
342 case MSG_SENDCONF_MMS:
343 case MSG_NOTIFICATIONIND_MMS:
344 case MSG_RETRIEVE_AUTOCONF_MMS:
345 case MSG_RETRIEVE_MANUALCONF_MMS:
346 msgType = MSG_COUNT_LIMIT_MMS_TYPE;
350 MSG_DEBUG("Unknown Message Type [%d]", pMsgType->subType);
354 return msgCntLimit[msgboxType][msgType];
358 msg_error_t MsgStocheckMemoryStatus()
360 msg_error_t err = MSG_SUCCESS;
361 boost::system::error_code ec;
362 boost::filesystem::space_info si = boost::filesystem::space(TZ_SYS_HOME_PATH, ec);
363 long long int available = 0;
366 MSG_ERR("Failed to get space info [%s]", ec.message().c_str());
367 return MSG_ERR_STORAGE_ERROR;
370 if (si.capacity < CHECK_SIZE)
371 available = si.available - RESERVE_LITE;
373 available = si.available - RESERVE;
378 MSG_DEBUG("Free space of storage is [%llu] Bytes.", available);
380 if (available < SMS_MINIMUM_SPACE)
381 err = MSG_ERR_MESSAGE_COUNT_FULL;
383 MSG_DEBUG("Memory status =[%d]", err);
389 msg_error_t MsgStoAddAddress(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t *pConvId)
391 msg_error_t err = MSG_SUCCESS;
393 char sqlQuery[MAX_QUERY_LEN+1];
395 /* Check if new address or not */
396 if (MsgExistAddress(pDbHandle, pMsg, pConvId) == true) {
397 MSG_DEBUG("The address already exists. Conversation ID : [%d]", *pConvId);
398 MsgStoUpdateAddress(pDbHandle, pMsg, *pConvId);
403 *pConvId = pMsg->threadId;
405 /* conversation insert */
406 err = MsgStoAddConversation(pDbHandle, pConvId);
407 if (err != MSG_SUCCESS) {
408 MSG_DEBUG("MsgStoAddConversation() fail [%d]", err);
412 /* insert address in loop */
413 for (int i = 0; i < pMsg->nAddressCnt; i++) {
415 MSG_CONTACT_INFO_S contactInfo;
416 memset(&contactInfo, 0x00, sizeof(MSG_CONTACT_INFO_S));
418 /* Get Contact Info */
420 if (MsgGetContactInfo(&(pMsg->addressList[i]), &contactInfo) != MSG_SUCCESS) {
421 MSG_DEBUG("MsgGetContactInfo() fail.");
425 err = pDbHandle->getRowId(MSGFW_ADDRESS_TABLE_NAME, &addrId);
426 if (err != MSG_SUCCESS) {
427 MSG_DEBUG("pDbHandle->getRowId fail. [%d]", err);
432 memset(sqlQuery, 0x00, sizeof(sqlQuery));
433 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, %d, %d, %d, '%s', %d, %d, ?, ?, ?, ?, ?, '%s', 0);",
434 MSGFW_ADDRESS_TABLE_NAME, addrId, *pConvId, pMsg->addressList[i].addressType, pMsg->addressList[i].recipientType, pMsg->addressList[i].addressVal,
435 contactInfo.contactId, contactInfo.addrbookId, contactInfo.imagePath);
437 MSG_SEC_DEBUG("Add Address Info. [%s]", sqlQuery);
439 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
440 return MSG_ERR_DB_PREPARE;
442 pDbHandle->bindText(contactInfo.firstName, 1);
443 pDbHandle->bindText(contactInfo.lastName, 2);
444 pDbHandle->bindText(contactInfo.middleName, 3);
445 pDbHandle->bindText(contactInfo.prefix, 4);
446 pDbHandle->bindText(contactInfo.suffix, 5);
448 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
449 pDbHandle->finalizeQuery();
450 return MSG_ERR_DB_STEP;
453 pDbHandle->finalizeQuery();
457 /* set conversation display name by conv id */
458 MsgStoSetConversationDisplayName(pDbHandle, *pConvId);
463 msg_error_t MsgStoGetAddressByMsgId(MsgDbHandler *pDbHandle, msg_message_id_t msgId, int *nAddressCnt, MSG_ADDRESS_INFO_S **pAddress)
465 char sqlQuery[MAX_QUERY_LEN+1];
466 int rowCnt = 0, index = 0;
470 memset(sqlQuery, 0x00, sizeof(sqlQuery));
471 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
476 "WHERE A.CONV_ID = B.CONV_ID "
477 "AND B.MSG_ID = %d;",
478 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
481 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
483 if (err == MSG_ERR_DB_NORECORD) {
484 pDbHandle->freeTable();
486 } else if (err != MSG_SUCCESS) {
487 MSG_DEBUG("Fail to getTable().");
488 pDbHandle->freeTable();
492 *nAddressCnt = rowCnt;
494 MSG_DEBUG("*nAddressCnt [%d]", *nAddressCnt);
496 MSG_ADDRESS_INFO_S *tmpAddressList = (MSG_ADDRESS_INFO_S *)new char[sizeof(MSG_ADDRESS_INFO_S) * rowCnt];
497 memset(tmpAddressList, 0x00, sizeof(MSG_ADDRESS_INFO_S) * rowCnt);
498 *pAddress = tmpAddressList;
500 for (int i = 0; i < rowCnt; i++) {
501 tmpAddressList[i].addressType = pDbHandle->getColumnToInt(index++);
502 tmpAddressList[i].recipientType = pDbHandle->getColumnToInt(index++);
503 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, tmpAddressList[i].addressVal);
505 strncpy(tmpAddressList[i].displayName, tmpAddressList[i].addressVal, MAX_DISPLAY_NAME_LEN);
507 pDbHandle->freeTable();
512 msg_error_t MsgStoGetAddressByMsgId(MsgDbHandler *pDbHandle, msg_message_id_t msgId, msg_struct_list_s *pAddress)
514 char sqlQuery[MAX_QUERY_LEN+1];
516 int rowCnt = 0, index = 0;
518 pAddress->nCount = 0;
519 pAddress->msg_struct_info = NULL;
521 msg_struct_s *pTmp = NULL;
522 MSG_ADDRESS_INFO_S *pAddr = NULL;
524 pAddress->msg_struct_info = (msg_struct_t *)calloc(MAX_TO_ADDRESS_CNT, sizeof(msg_struct_t));
525 if (pAddress->msg_struct_info == NULL)
526 return MSG_ERR_MEMORY_ERROR;
528 for (int i = 0; i < MAX_TO_ADDRESS_CNT; i++) {
529 pAddress->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
530 pTmp = (msg_struct_s *)pAddress->msg_struct_info[i];
531 pTmp->type = MSG_STRUCT_ADDRESS_INFO;
532 pTmp->data = new MSG_ADDRESS_INFO_S;
533 memset(pTmp->data, 0x00, sizeof(MSG_ADDRESS_INFO_S));
536 memset(sqlQuery, 0x00, sizeof(sqlQuery));
537 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
542 "WHERE A.CONV_ID = B.CONV_ID "
543 "AND B.MSG_ID = %d;",
544 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
547 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
549 if (err == MSG_ERR_DB_NORECORD) {
550 pDbHandle->freeTable();
552 } else if (err != MSG_SUCCESS) {
553 MSG_DEBUG("Fail to getTable().");
554 pDbHandle->freeTable();
558 rowCnt = (rowCnt > 10)? MAX_TO_ADDRESS_CNT: rowCnt;
559 pAddress->nCount = rowCnt;
561 for (int i = 0; i < rowCnt; i++) {
562 pTmp = (msg_struct_s *)pAddress->msg_struct_info[i];
563 pAddr = (MSG_ADDRESS_INFO_S *)pTmp->data;
565 pAddr->addressType = pDbHandle->getColumnToInt(index++);
566 pAddr->recipientType = pDbHandle->getColumnToInt(index++);
568 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, pAddr->addressVal);
570 strncpy(pAddr->displayName, pAddr->addressVal, MAX_DISPLAY_NAME_LEN);
573 pDbHandle->freeTable();
579 msg_error_t MsgStoGetAddressByConvId(MsgDbHandler *pDbHandle, msg_thread_id_t convId, msg_struct_list_s *pAddrlist)
581 char sqlQuery[MAX_QUERY_LEN+1];
583 int rowCnt = 0, index = 0;
585 pAddrlist->nCount = 0;
586 pAddrlist->msg_struct_info = NULL;
588 memset(sqlQuery, 0x00, sizeof(sqlQuery));
589 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
593 "FROM %s WHERE CONV_ID = %d;",
594 MSGFW_ADDRESS_TABLE_NAME, convId);
596 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
598 if (err == MSG_ERR_DB_NORECORD) {
599 pDbHandle->freeTable();
601 } else if (err != MSG_SUCCESS) {
602 MSG_DEBUG("Fail to getTable().");
603 pDbHandle->freeTable();
607 pAddrlist->nCount = rowCnt;
609 MSG_DEBUG("pAddrlist->nCount [%d]", pAddrlist->nCount);
611 msg_struct_s *pTmp = NULL;
612 MSG_ADDRESS_INFO_S *pAddr = NULL;
614 pAddrlist->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
616 for (int i = 0; i < rowCnt; i++) {
617 pAddrlist->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
618 pTmp = (msg_struct_s *)pAddrlist->msg_struct_info[i];
619 pTmp->type = MSG_STRUCT_ADDRESS_INFO;
620 pTmp->data = new MSG_ADDRESS_INFO_S;
621 memset(pTmp->data, 0x00, sizeof(MSG_ADDRESS_INFO_S));
624 /* rowCnt = (rowCnt > 10)? MAX_TO_ADDRESS_CNT: rowCnt; */
626 for (int i = 0; i < rowCnt; i++) {
627 pTmp = (msg_struct_s *)pAddrlist->msg_struct_info[i];
628 pAddr = (MSG_ADDRESS_INFO_S *)pTmp->data;
630 pAddr->addressType = pDbHandle->getColumnToInt(index++);
631 pAddr->recipientType = pDbHandle->getColumnToInt(index++);
632 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, pAddr->addressVal);
634 strncpy(pAddr->displayName, pAddr->addressVal, MAX_DISPLAY_NAME_LEN);
636 pDbHandle->freeTable();
641 /* Have to use trigger for this function. */
642 msg_error_t MsgStoUpdateConversation(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
646 char sqlQuery[MAX_QUERY_LEN];
647 unsigned int tmpSize = 0;
649 #ifdef MSG_NOTI_INTEGRATION
650 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
651 snprintf(sqlQuery, sizeof(sqlQuery),
654 "WHERE CONV_ID = %d "
655 "AND FOLDER_ID > %d AND FOLDER_ID < %d "
656 "AND STORAGE_ID = %d;",
657 MSGFW_MESSAGE_TABLE_NAME,
659 MSG_ALLBOX_ID, MSG_SPAMBOX_ID,
662 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
663 snprintf(sqlQuery, sizeof(sqlQuery),
666 "WHERE CONV_ID = %d "
667 "AND FOLDER_ID > %d AND FOLDER_ID < %d "
668 "AND STORAGE_ID = %d;",
669 MSGFW_MESSAGE_TABLE_NAME,
671 MSG_ALLBOX_ID, MSG_CBMSGBOX_ID,
675 msg_error_t err = pDbHandle->prepareQuery(sqlQuery);
676 if (err != MSG_SUCCESS) {
677 MSG_DEBUG("Fail to prepareQuery().");
678 pDbHandle->finalizeQuery();
682 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
683 pDbHandle->finalizeQuery();
685 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
686 snprintf(sqlQuery, sizeof(sqlQuery),
687 "SELECT MAIN_TYPE, SUB_TYPE, MSG_DIRECTION, DISPLAY_TIME, LENGTH(SUBJECT), SUBJECT, MSG_TEXT "
689 "WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND DPM_RESTRICTED = 0 AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC;",
690 MSGFW_MESSAGE_TABLE_NAME,
691 convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
693 err = pDbHandle->prepareQuery(sqlQuery);
694 if (err != MSG_SUCCESS) {
695 MSG_DEBUG("Fail to prepareQuery().");
699 err = pDbHandle->stepQuery();
700 if (err == MSG_ERR_DB_DONE) {
701 pDbHandle->finalizeQuery();
703 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
704 snprintf(sqlQuery, sizeof(sqlQuery),
705 "SELECT MAIN_TYPE, SUB_TYPE, MSG_DIRECTION, DISPLAY_TIME, 0, '', '' "
707 "WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC;",
708 MSGFW_MESSAGE_TABLE_NAME,
709 convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
711 err = pDbHandle->prepareQuery(sqlQuery);
712 if (err != MSG_SUCCESS) {
713 MSG_DEBUG("Fail to prepareQuery().");
717 err = pDbHandle->stepQuery();
718 if (err != MSG_ERR_DB_ROW) {
719 MSG_DEBUG("Fail to stepQuery().");
720 pDbHandle->finalizeQuery();
724 } else if (err != MSG_ERR_DB_ROW) {
725 MSG_DEBUG("Fail to stepQuery().");
726 pDbHandle->finalizeQuery();
730 int main_type = pDbHandle->columnInt(0);
731 int sub_type = pDbHandle->columnInt(1);
732 int msg_direction = pDbHandle->columnInt(2);
733 time_t disp_time = (time_t)pDbHandle->columnInt(3);
734 int subject_length = pDbHandle->columnInt(4);
735 char subject[MAX_SUBJECT_LEN+1] = {0, };
736 snprintf(subject, sizeof(subject), "%s", pDbHandle->columnText(5));
737 char msg_text[MAX_MSG_TEXT_LEN+1] = {0, };
738 snprintf(msg_text, sizeof(msg_text), "%s", pDbHandle->columnText(6));
740 pDbHandle->finalizeQuery();
741 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
742 snprintf(sqlQuery, sizeof(sqlQuery),
744 MSGFW_CONVERSATION_TABLE_NAME);
746 tmpSize = strlen(sqlQuery);
747 #ifdef MSG_NOTI_INTEGRATION
748 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
749 "UNREAD_CNT = (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND (FOLDER_ID = %d OR FOLDER_ID = %d) AND STORAGE_ID = %d AND READ_STATUS = 0 AND DPM_RESTRICTED = 0), ",
750 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
752 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
753 "UNREAD_CNT = (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND READ_STATUS = 0), ",
754 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_STORAGE_PHONE);
757 tmpSize = strlen(sqlQuery);
758 #ifdef MSG_NOTI_INTEGRATION
759 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
760 "SMS_CNT = (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND MAIN_TYPE = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d), ",
761 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_SMS_TYPE, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
763 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
764 "SMS_CNT = (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND MAIN_TYPE = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d), ",
765 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_SMS_TYPE, MSG_ALLBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
768 tmpSize = strlen(sqlQuery);
769 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
770 "MMS_CNT = (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND MAIN_TYPE = %d AND SUB_TYPE NOT IN (%d, %d, %d) AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d), ",
771 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_MMS_TYPE, MSG_DELIVERYIND_MMS, MSG_READRECIND_MMS, MSG_READORGIND_MMS, MSG_ALLBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
774 tmpSize = strlen(sqlQuery);
775 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
776 "MAIN_TYPE = (SELECT MAIN_TYPE FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME DESC), ",
777 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
779 tmpSize = strlen(sqlQuery);
780 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
781 "SUB_TYPE = (SELECT SUB_TYPE FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME DESC), ",
782 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
784 tmpSize = strlen(sqlQuery);
785 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
786 "MSG_DIRECTION = (SELECT MSG_DIRECTION FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME DESC), ",
787 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
789 tmpSize = strlen(sqlQuery);
791 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
792 "DISPLAY_TIME = CASE "
793 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC) > 0 "
794 "THEN (SELECT DISPLAY_TIME FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC) "
797 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
798 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
800 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
801 "DISPLAY_TIME = CASE "
802 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND READ_STATUS = 0) > 0 "
803 "THEN (SELECT DISPLAY_TIME FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND READ_STATUS = 0 ORDER BY DISPLAY_TIME DESC) "
804 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d) > 0 "
805 "THEN (SELECT DISPLAY_TIME FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME DESC) "
806 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND NETWORK_STATUS = %d) > 0 "
807 "THEN (SELECT DISPLAY_TIME FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND NETWORK_STATUS = %d ORDER BY DISPLAY_TIME DESC) "
808 "ELSE (SELECT DISPLAY_TIME FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME DESC) "
810 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_STORAGE_PHONE,
811 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_STORAGE_PHONE,
812 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_DRAFT_ID, MSG_STORAGE_PHONE,
813 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_DRAFT_ID, MSG_STORAGE_PHONE,
814 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_OUTBOX_ID, MSG_STORAGE_PHONE, MSG_NETWORK_SEND_FAIL,
815 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_OUTBOX_ID, MSG_STORAGE_PHONE, MSG_NETWORK_SEND_FAIL,
816 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
820 tmpSize = strlen(sqlQuery);
821 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
823 "WHEN %d > 0 THEN ? ELSE ? "
827 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
829 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC) > 0 "
831 "WHEN (SELECT LENGTH(SUBJECT) FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC) > 0 "
832 "THEN (SELECT SUBJECT FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC) "
833 "ELSE (SELECT MSG_TEXT FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d AND SCHEDULED_TIME = 0 ORDER BY DISPLAY_TIME DESC) "
836 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
837 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
838 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
839 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
841 tmpSize = strlen(sqlQuery);
842 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
843 "MAIN_TYPE = %d, SUB_TYPE = %d, MSG_DIRECTION = %d, DISPLAY_TIME = %lu ",
844 main_type, sub_type, msg_direction, disp_time);
846 tmpSize = strlen(sqlQuery);
847 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
848 "WHERE CONV_ID = %d;",
850 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
851 MSG_DEBUG("Query Failed [%s]", sqlQuery);
852 return MSG_ERR_DB_PREPARE;
855 pDbHandle->bindText(subject, 1);
856 pDbHandle->bindText(msg_text, 2);
858 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
859 MSG_DEBUG("stepQuery() Failed");
860 pDbHandle->finalizeQuery();
861 return MSG_ERR_DB_STEP;
864 pDbHandle->finalizeQuery();
866 pDbHandle->finalizeQuery();
868 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
869 snprintf(sqlQuery, sizeof(sqlQuery),
870 "UPDATE %s SET UNREAD_CNT = 0, SMS_CNT = 0, MMS_CNT = 0, MAIN_TYPE = 0, SUB_TYPE = 0, MSG_DIRECTION = 0, DISPLAY_TIME = 0, MSG_TEXT = '' "
871 "WHERE CONV_ID = %d;",
872 MSGFW_CONVERSATION_TABLE_NAME, convId);
874 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
875 MSG_DEBUG("Query Failed [%s]", sqlQuery);
876 return MSG_ERR_DB_EXEC;
886 /* consider to replcae this function to trigger. */
887 msg_error_t MsgStoClearConversationTable(MsgDbHandler *pDbHandle)
889 msg_error_t err = MSG_SUCCESS;
891 char sqlQuery[MAX_QUERY_LEN+1];
893 memset(sqlQuery, 0x00, sizeof(sqlQuery));
895 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s "
896 "WHERE CONV_ID NOT IN (SELECT CONV_ID FROM %s) AND CONV_ID <> 0;",
897 MSGFW_CONVERSATION_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME);
899 err = pDbHandle->execQuery(sqlQuery);
901 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s WHERE CONV_ID NOT IN (SELECT CONV_ID FROM %s);",
902 MSGFW_ADDRESS_TABLE_NAME, MSGFW_CONVERSATION_TABLE_NAME);
904 err = pDbHandle->execQuery(sqlQuery);
910 msg_thread_id_t MsgGetThreadId(MsgDbHandler *pDbHandle, msg_message_id_t msgId)
912 msg_thread_id_t conv_id = 0;
914 char sqlQuery[MAX_QUERY_LEN+1];
915 memset(sqlQuery, 0x00, sizeof(sqlQuery));
916 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CONV_ID FROM %s WHERE MSG_ID = %d;",
917 MSGFW_MESSAGE_TABLE_NAME, msgId);
919 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
922 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
923 conv_id = pDbHandle->columnInt(0);
926 pDbHandle->finalizeQuery();
931 /* Change the function name to conversation related. */
932 bool MsgExistAddress(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t *pConvId)
934 msg_error_t err = MSG_SUCCESS;
936 char sqlQuery[MAX_QUERY_LEN+1];
937 unsigned int tmpSize = 0;
941 memset(sqlQuery, 0x00, sizeof(sqlQuery));
942 snprintf(sqlQuery, sizeof(sqlQuery),
943 "SELECT CONV_ID FROM ( SELECT CONV_ID FROM %s WHERE ( ",
944 MSGFW_ADDRESS_TABLE_NAME);
946 for (int i = 0; i < pMsg->nAddressCnt; i++) {
947 if (strlen(pMsg->addressList[i].addressVal) >= (unsigned int)MsgContactGetMinMatchDigit()
948 && pMsg->addressList[i].addressType != MSG_ADDRESS_TYPE_EMAIL
949 && MsgIsNumber(pMsg->addressList[i].addressVal)) {
950 int addrSize = strlen(pMsg->addressList[i].addressVal);
951 char newPhoneNum[addrSize+1];
952 memset(newPhoneNum, 0x00, sizeof(newPhoneNum));
953 MsgConvertNumber(pMsg->addressList[i].addressVal, newPhoneNum, addrSize);
955 tmpSize = strlen(sqlQuery);
956 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
957 "ADDRESS_VAL LIKE '%%%%%s' ",
960 if ((pMsg->nAddressCnt-1) == i) break;
962 tmpSize = strlen(sqlQuery);
963 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize, " OR ");
966 tmpSize = strlen(sqlQuery);
967 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
968 "ADDRESS_VAL LIKE '%s' ",
969 pMsg->addressList[i].addressVal);
971 if ((pMsg->nAddressCnt-1) == i) break;
973 tmpSize = strlen(sqlQuery);
974 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize, " OR ");
978 tmpSize = strlen(sqlQuery);
979 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
980 ") AND CONV_ID IN (SELECT CONV_ID FROM %s GROUP BY CONV_ID HAVING COUNT(CONV_ID)=%d) ",
981 MSGFW_ADDRESS_TABLE_NAME, pMsg->nAddressCnt);
984 tmpSize = strlen(sqlQuery);
985 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
986 ") GROUP BY CONV_ID HAVING COUNT(CONV_ID)=%d;",
992 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
994 /* No record or other error */
995 if (err != MSG_SUCCESS) {
996 MSG_DEBUG("Fail to getTable().");
997 pDbHandle->freeTable();
1001 convId = pDbHandle->getColumnToInt(1);
1004 MSG_DEBUG("Success to get convId [%d]", convId);
1006 pDbHandle->freeTable();
1010 pDbHandle->freeTable();
1016 int MsgStoGetUnreadCnt(MsgDbHandler *pDbHandle, MSG_MAIN_TYPE_T msgType)
1020 char sqlQuery[MAX_QUERY_LEN+1];
1022 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1024 if (msgType == MSG_SMS_TYPE) {
1025 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s "
1026 "WHERE MAIN_TYPE = %d "
1027 "AND (SUB_TYPE IN (%d, %d, %d, %d, %d, %d, %d) OR (SUB_TYPE >= %d AND SUB_TYPE <= %d)) "
1028 "AND FOLDER_ID = %d AND READ_STATUS = 0 AND STORAGE_ID = %d;",
1029 MSGFW_MESSAGE_TABLE_NAME,
1031 MSG_NORMAL_SMS, MSG_STATUS_REPORT_SMS, MSG_CONCAT_SIM_SMS, MSG_WAP_SI_SMS, MSG_WAP_SL_SMS, MSG_MWI_VOICE_SMS, MSG_SYNCML_CP,
1032 MSG_REPLACE_TYPE1_SMS, MSG_REPLACE_TYPE7_SMS,
1033 MSG_INBOX_ID, MSG_STORAGE_PHONE);
1034 } else if (msgType == MSG_MMS_TYPE) {
1035 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s "
1036 "WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d, %d, %d) "
1037 "AND FOLDER_ID = %d AND READ_STATUS = 0 AND STORAGE_ID = %d;",
1038 MSGFW_MESSAGE_TABLE_NAME,
1040 MSG_RETRIEVE_AUTOCONF_MMS, MSG_RETRIEVE_MANUALCONF_MMS, MSG_NOTIFICATIONIND_MMS,
1041 MSG_INBOX_ID, MSG_STORAGE_PHONE);
1044 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
1047 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
1048 msgCnt = pDbHandle->columnInt(0);
1050 pDbHandle->finalizeQuery();
1054 pDbHandle->finalizeQuery();
1060 msg_error_t MsgStoGetMmsRawFilePath(MsgDbHandler *pDbHandle, msg_message_id_t msgId, char *pFilePath)
1062 char sqlQuery[MAX_QUERY_LEN+1];
1064 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1066 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.FILE_PATH FROM %s A, %s B \
1067 WHERE A.MSG_ID = B.MSG_ID AND B.MSG_ID = %d;",
1068 MMS_PLUGIN_MESSAGE_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME, msgId);
1070 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
1071 return MSG_ERR_DB_PREPARE;
1073 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
1074 if (pDbHandle->columnText(0) != NULL)
1075 strncpy(pFilePath, (char*)pDbHandle->columnText(0), MSG_FILEPATH_LEN_MAX);
1077 pDbHandle->finalizeQuery();
1078 return MSG_ERR_DB_STEP;
1081 pDbHandle->finalizeQuery();
1087 bool MsgStoCheckReadReportRequested(MsgDbHandler *pDbHandle, msg_message_id_t msgId)
1089 msg_error_t err = MSG_SUCCESS;
1091 char sqlQuery[MAX_QUERY_LEN+1];
1093 bool bReadReportRequested = false;
1095 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1097 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.ASK_READ_REPLY FROM %s A, %s B \
1098 WHERE A.MSG_ID = B.MSG_ID AND B.MSG_ID = %d;",
1099 MMS_PLUGIN_MESSAGE_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME, msgId);
1101 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1103 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
1104 pDbHandle->freeTable();
1105 MSG_DEBUG("[Error]Failed to Get Table");
1106 return bReadReportRequested;
1110 pDbHandle->freeTable();
1111 MSG_DEBUG("[Error]MSG_ERR_DB_NORECORD");
1112 return bReadReportRequested;
1115 bReadReportRequested = pDbHandle->getColumnToInt(1);
1117 pDbHandle->freeTable();
1119 return bReadReportRequested;
1123 bool MsgStoCheckReadReportIsSent(MsgDbHandler *pDbHandle, msg_message_id_t msgId)
1125 msg_error_t err = MSG_SUCCESS;
1127 char sqlQuery[MAX_QUERY_LEN+1];
1130 bool bReadReportIsSent = true;
1132 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1134 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.READ_REPORT_SENT FROM %s A, %s B \
1135 WHERE A.MSG_ID = B.MSG_ID AND B.MSG_ID = %d;",
1136 MMS_PLUGIN_MESSAGE_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME, msgId);
1138 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1140 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
1141 pDbHandle->freeTable();
1142 MSG_DEBUG("[Error]Failed to Get Table");
1143 return bReadReportIsSent;
1147 pDbHandle->freeTable();
1148 MSG_DEBUG("[Error]MSG_ERR_DB_NORECORD");
1149 return bReadReportIsSent;
1152 bReadReportIsSent = (bool)pDbHandle->getColumnToInt(1);
1154 pDbHandle->freeTable();
1156 return bReadReportIsSent;
1160 msg_error_t MsgStoAddConversation(MsgDbHandler *pDbHandle, msg_thread_id_t *pConvId)
1162 char sqlQuery[MAX_QUERY_LEN+1];
1165 if (pDbHandle->getRowId(MSGFW_CONVERSATION_TABLE_NAME, pConvId) != MSG_SUCCESS) {
1166 return MSG_ERR_DB_EXEC;
1169 /* Add Conversation */
1170 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1171 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, 0, 0, 0, 0, 0, 0, 0, '', '');",
1172 MSGFW_CONVERSATION_TABLE_NAME, *pConvId);
1174 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1175 MSG_DEBUG("Query Failed. [%s]", sqlQuery);
1176 return MSG_ERR_DB_EXEC;
1183 msg_error_t MsgStoSetConversationDisplayName(MsgDbHandler *pDbHandle, int contactId)
1185 msg_error_t err = MSG_SUCCESS;
1187 char displayName[MAX_DISPLAY_NAME_LEN+1];
1188 char sqlQuery[MAX_QUERY_LEN+1];
1190 MSG_DEBUG("contactId [%d]", contactId);
1192 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1193 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT DISTINCT(CONV_ID) FROM %s WHERE CONTACT_ID = %d;",
1194 MSGFW_ADDRESS_TABLE_NAME, contactId);
1196 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1198 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
1199 pDbHandle->freeTable();
1200 MSG_DEBUG("Fail to getTable().");
1204 msg_struct_s *pAddrInfo = NULL;
1205 MSG_ADDRESS_INFO_S *address = NULL;
1207 for (int i = 1; i <= rowCnt; i++) {
1208 memset(displayName, 0x00, sizeof(displayName));
1209 MsgDbHandler tmpDbHandle;
1210 msg_struct_list_s addressList = {0, };
1211 MsgStoGetAddressByConvId(&tmpDbHandle, (msg_thread_id_t)pDbHandle->getColumnToInt(i), &addressList);
1213 for (int j = 0; j < addressList.nCount; j++) {
1215 strncat(displayName, ", ", MAX_DISPLAY_NAME_LEN-strlen(displayName));
1217 pAddrInfo = (msg_struct_s *)addressList.msg_struct_info[j];
1218 address = (MSG_ADDRESS_INFO_S *)pAddrInfo->data;
1220 if (address->displayName[0] == '\0')
1221 strncat(displayName, address->addressVal, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1223 strncat(displayName, address->displayName, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1226 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1227 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET DISPLAY_NAME = ? WHERE CONV_ID = %d;",
1228 MSGFW_CONVERSATION_TABLE_NAME, pDbHandle->getColumnToInt(i));
1230 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
1231 pDbHandle->freeTable();
1232 MSG_DEBUG("Query Failed [%s]", sqlQuery);
1233 return MSG_ERR_DB_PREPARE;
1236 pDbHandle->bindText(displayName, 1);
1238 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
1239 pDbHandle->freeTable();
1240 pDbHandle->finalizeQuery();
1241 MSG_SEC_DEBUG("Update Conversation disply name. Fail [%s]", sqlQuery);
1242 return MSG_ERR_DB_STEP;
1245 pDbHandle->finalizeQuery();
1247 /* free address list */
1248 for (int j = 0; j < addressList.nCount; j++) {
1249 msg_struct_s *pStruct = (msg_struct_s *)addressList.msg_struct_info[j];
1250 delete (MSG_ADDRESS_INFO_S *)pStruct->data;
1251 delete (msg_struct_s *)pStruct;
1254 if (addressList.msg_struct_info != NULL) {
1255 g_free((msg_struct_t *)addressList.msg_struct_info);
1259 pDbHandle->freeTable();
1265 msg_error_t MsgStoSetConversationDisplayName(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
1267 msg_error_t err = MSG_SUCCESS;
1269 char displayName[MAX_DISPLAY_NAME_LEN+1];
1270 char sqlQuery[MAX_QUERY_LEN+1];
1272 msg_struct_list_s addressList = {0, };
1274 msg_struct_s *pAddrInfo = NULL;
1275 MSG_ADDRESS_INFO_S *address = NULL;
1277 memset(displayName, 0x00, sizeof(displayName));
1279 MsgStoGetAddressByConvId(pDbHandle, convId, &addressList);
1281 for (int j = 0; j < addressList.nCount; j++) {
1283 strncat(displayName, ", ", MAX_DISPLAY_NAME_LEN-strlen(displayName));
1285 pAddrInfo = (msg_struct_s *)addressList.msg_struct_info[j];
1286 address = (MSG_ADDRESS_INFO_S *)pAddrInfo->data;
1288 if (address->displayName[0] == '\0')
1289 strncat(displayName, address->addressVal, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1291 strncat(displayName, address->displayName, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1294 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1295 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET DISPLAY_NAME = ? WHERE CONV_ID = %d;",
1296 MSGFW_CONVERSATION_TABLE_NAME, convId);
1298 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
1299 MSG_DEBUG("Query Failed [%s]", sqlQuery);
1300 return MSG_ERR_DB_PREPARE;
1303 pDbHandle->bindText(displayName, 1);
1305 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
1306 pDbHandle->finalizeQuery();
1307 MSG_SEC_DEBUG("Update Conversation disply name. Fail [%s]", sqlQuery);
1308 return MSG_ERR_DB_STEP;
1311 pDbHandle->finalizeQuery();
1313 for (int j = 0; j < addressList.nCount; j++) {
1314 msg_struct_s *pStruct = (msg_struct_s *)addressList.msg_struct_info[j];
1315 delete (MSG_ADDRESS_INFO_S *)pStruct->data;
1316 delete (msg_struct_s *)pStruct;
1319 if (addressList.msg_struct_info != NULL) {
1320 g_free((msg_struct_t *)addressList.msg_struct_info);
1326 msg_error_t MsgStoUpdateNetworkStatus(MsgDbHandler *pDbHandle, MSG_MESSAGE_INFO_S *pMsgInfo, msg_network_status_t status)
1328 msg_error_t err = MSG_SUCCESS;
1330 char sqlQuery[MAX_QUERY_LEN+1];
1332 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1334 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET NETWORK_STATUS = %d WHERE MSG_ID = %d;",
1335 MSGFW_MESSAGE_TABLE_NAME, status, pMsgInfo->msgId);
1337 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS)
1338 err = MSG_ERR_DB_EXEC;
1340 pDbHandle->finalizeQuery();
1345 bool MsgExistConversation(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
1347 msg_error_t err = MSG_SUCCESS;
1349 char sqlQuery[MAX_QUERY_LEN+1];
1353 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1355 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CONV_ID FROM %s WHERE CONV_ID = %d;",
1356 MSGFW_CONVERSATION_TABLE_NAME, convId);
1358 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1360 if (err == MSG_ERR_DB_NORECORD) {
1361 pDbHandle->freeTable();
1363 } else if (err != MSG_SUCCESS) {
1364 pDbHandle->freeTable();
1367 pDbHandle->freeTable();
1372 bool MsgExistMessage(MsgDbHandler *pDbHandle, MSG_MESSAGE_INFO_S *pMsg)
1374 msg_error_t err = MSG_SUCCESS;
1376 char sqlQuery[MAX_QUERY_LEN+1];
1381 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1383 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s WHERE CONV_ID = %ud AND DISPLAY_TIME = %ud;",
1384 MSGFW_MESSAGE_TABLE_NAME, pMsg->threadId, (int)pMsg->displayTime);
1386 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1389 if (err != MSG_SUCCESS) {
1390 pDbHandle->freeTable();
1395 pMsg->msgId = pDbHandle->getColumnToInt(1);
1397 pDbHandle->freeTable();
1403 bool MsgExistAddress(MsgDbHandler *pDbHandle, MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t convId, int index)
1405 msg_error_t err = MSG_SUCCESS;
1407 char sqlQuery[MAX_QUERY_LEN+1];
1412 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1414 if (strlen(pMsg->addressList[index].addressVal) > (unsigned int)MsgContactGetMinMatchDigit()) {
1415 int addrSize = strlen(pMsg->addressList[index].addressVal);
1416 char newPhoneNum[addrSize+1];
1417 memset(newPhoneNum, 0x00, sizeof(newPhoneNum));
1418 MsgConvertNumber(pMsg->addressList[index].addressVal, newPhoneNum, addrSize);
1420 snprintf(sqlQuery, sizeof(sqlQuery),
1421 "SELECT ADDRESS_ID FROM %s WHERE ADDRESS_VAL LIKE '%%%%%s' AND CONV_ID= %d;",
1422 MSGFW_ADDRESS_TABLE_NAME, newPhoneNum, convId);
1424 snprintf(sqlQuery, sizeof(sqlQuery),
1425 "SELECT ADDRESS_ID FROM %s WHERE ADDRESS_VAL = '%s' AND CONV_ID= %d;",
1426 MSGFW_ADDRESS_TABLE_NAME, pMsg->addressList[index].addressVal, convId);
1429 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1431 if (err == MSG_ERR_DB_NORECORD) {
1432 pDbHandle->freeTable();
1434 } else if (err != MSG_SUCCESS) {
1435 pDbHandle->freeTable();
1438 pDbHandle->freeTable();
1444 void MsgStoUpdateAddress(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t convId)
1447 msg_error_t err = MSG_SUCCESS;
1449 char sqlQuery[MAX_QUERY_LEN+1];
1451 for (int i = 0; i < pMsg->nAddressCnt; i++) {
1452 if (strlen(pMsg->addressList[i].addressVal) > (unsigned int)MsgContactGetMinMatchDigit() && pMsg->addressList[i].addressType == MSG_ADDRESS_TYPE_PLMN) {
1453 int addrSize = strlen(pMsg->addressList[i].addressVal);
1454 char newPhoneNum[addrSize+1];
1455 memset(newPhoneNum, 0x00, sizeof(newPhoneNum));
1456 MsgConvertNumber(pMsg->addressList[i].addressVal, newPhoneNum, addrSize);
1458 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1459 snprintf(sqlQuery, sizeof(sqlQuery),
1461 "ADDRESS_VAL = '%s', "
1462 "ADDRESS_TYPE = %d, "
1463 "RECIPIENT_TYPE = %d "
1464 "WHERE CONV_ID = %d "
1465 "AND ADDRESS_VAL LIKE '%%%%%s';",
1466 MSGFW_ADDRESS_TABLE_NAME, pMsg->addressList[i].addressVal,
1467 pMsg->addressList[i].addressType, pMsg->addressList[i].recipientType, convId, newPhoneNum);
1469 err = pDbHandle->execQuery(sqlQuery);
1470 if (err != MSG_SUCCESS) MSG_DEBUG("Fail to execQuery(). [%s]", sqlQuery);
1472 pDbHandle->finalizeQuery();
1479 msg_error_t MsgStoAddCBChannelInfo(MsgDbHandler *pDbHandle, MSG_CB_CHANNEL_S *pCBChannel, msg_sim_slot_id_t simIndex)
1481 #ifndef FEATURE_SMS_CDMA
1484 char sqlQuery[MAX_QUERY_LEN] = {0, };
1486 pDbHandle->beginTrans();
1488 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1489 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s WHERE SIM_INDEX = %d;", MSGFW_CB_CHANNEL_INFO_TABLE_NAME, simIndex);
1491 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1492 pDbHandle->endTrans(false);
1493 return MSG_ERR_DB_EXEC;
1496 for (int i = 0; i < pCBChannel->channelCnt; i++) {
1498 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1499 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s(CHANNEL_ACTIVATION, CHANNEL_FROM, CHANNEL_TO, CHANNEL_NAME, SIM_INDEX) VALUES (?, ?, ?, ?, ?);",
1500 MSGFW_CB_CHANNEL_INFO_TABLE_NAME);
1502 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
1503 pDbHandle->endTrans(false);
1504 return MSG_ERR_DB_PREPARE;
1506 pDbHandle->bindInt(pCBChannel->channelInfo[i].bActivate, index++);
1507 pDbHandle->bindInt(pCBChannel->channelInfo[i].from, index++);
1508 pDbHandle->bindInt(pCBChannel->channelInfo[i].to, index++);
1509 pDbHandle->bindText(pCBChannel->channelInfo[i].name, index++);
1510 pDbHandle->bindInt(simIndex, index++);
1512 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
1513 pDbHandle->finalizeQuery();
1514 pDbHandle->endTrans(false);
1515 return MSG_ERR_DB_STEP;
1518 pDbHandle->finalizeQuery();
1521 pDbHandle->endTrans(true);
1526 #else /* TODO: Add multisim for CDMA */
1529 char sqlQuery[MAX_QUERY_LEN] = {0, };
1531 pDbHandle->beginTrans();
1533 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1534 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s;", MSGFW_CDMA_CB_CHANNEL_INFO_TABLE_NAME);
1536 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1537 pDbHandle->endTrans(false);
1538 return MSG_ERR_DB_EXEC;
1541 for (int i = 0; i < pCBChannel->channelCnt; i++) {
1542 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1543 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, %d, %d, %d, '%s');", MSGFW_CDMA_CB_CHANNEL_INFO_TABLE_NAME,
1544 i, pCBChannel->channelInfo[i].bActivate, pCBChannel->channelInfo[i].ctg,
1545 pCBChannel->channelInfo[i].lang, pCBChannel->channelInfo[i].name);
1547 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1548 pDbHandle->endTrans(false);
1549 return MSG_ERR_DB_EXEC;
1553 pDbHandle->endTrans(true);
1562 msg_error_t MsgStoGetCBChannelInfo(MsgDbHandler *pDbHandle, MSG_CB_CHANNEL_S *pCBChannel, msg_sim_slot_id_t simIndex)
1564 #ifndef FEATURE_SMS_CDMA
1567 int rowCnt = 0, index = 0;
1569 char sqlQuery[MAX_QUERY_LEN] = {0, };
1571 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1572 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CHANNEL_ACTIVATION, CHANNEL_FROM, CHANNEL_TO, CHANNEL_NAME FROM %s WHERE SIM_INDEX = %d;", MSGFW_CB_CHANNEL_INFO_TABLE_NAME, simIndex);
1574 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1576 pCBChannel->channelCnt = rowCnt;
1578 if (err == MSG_ERR_DB_NORECORD) {
1579 pDbHandle->freeTable();
1580 return MSG_ERR_DB_NORECORD;
1581 } else if (err != MSG_SUCCESS) {
1582 MSG_DEBUG("Fail to getTable().");
1583 pDbHandle->freeTable();
1584 return MSG_ERR_DB_GETTABLE;
1587 for (int i = 0; i < rowCnt; i++) {
1588 pCBChannel->channelInfo[i].bActivate = pDbHandle->getColumnToInt(index++);
1589 pCBChannel->channelInfo[i].from = pDbHandle->getColumnToInt(index++);
1590 pCBChannel->channelInfo[i].to = pDbHandle->getColumnToInt(index++);
1591 pDbHandle->getColumnToString(index++, CB_CHANNEL_NAME_MAX, pCBChannel->channelInfo[i].name);
1593 MSG_DEBUG("CH_ACT = %d", pCBChannel->channelInfo[i].bActivate);
1594 MSG_DEBUG("CH_FROM = %d", pCBChannel->channelInfo[i].from);
1595 MSG_DEBUG("CH_TO = %d", pCBChannel->channelInfo[i].to);
1596 MSG_DEBUG("CH_NAME = %s", pCBChannel->channelInfo[i].name);
1599 pDbHandle->freeTable();
1604 #else /* TODO: Add multisim for CDMA */
1607 int rowCnt = 0, index = 0;
1609 char sqlQuery[MAX_QUERY_LEN] = {0, };
1611 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1612 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CHANNEL_ACTIVATION, CHANNEL_CATEGORY, CHANNEL_LANGUAGE, CHANNEL_NAME FROM %s;", MSGFW_CDMA_CB_CHANNEL_INFO_TABLE_NAME);
1614 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1616 pCBChannel->channelCnt = rowCnt;
1618 if (err == MSG_ERR_DB_NORECORD) {
1619 pDbHandle->freeTable();
1620 return MSG_ERR_DB_NORECORD;
1621 } else if (err != MSG_SUCCESS) {
1622 MSG_DEBUG("Fail to getTable().");
1623 pDbHandle->freeTable();
1624 return MSG_ERR_DB_GETTABLE;
1627 for (int i = 0; i < rowCnt; i++) {
1628 pCBChannel->channelInfo[i].bActivate = pDbHandle->getColumnToInt(index++);
1629 pCBChannel->channelInfo[i].ctg = pDbHandle->getColumnToInt(index++);
1630 pCBChannel->channelInfo[i].lang = pDbHandle->getColumnToInt(index++);
1631 pDbHandle->getColumnToString(index++, CB_CHANNEL_NAME_MAX, pCBChannel->channelInfo[i].name);
1633 MSG_DEBUG("CH_ACT = %d", pCBChannel->channelInfo[i].bActivate);
1634 MSG_DEBUG("CH_CTG = %d", pCBChannel->channelInfo[i].ctg);
1635 MSG_DEBUG("CH_LANG = %d", pCBChannel->channelInfo[i].lang);
1636 MSG_DEBUG("CH_NAME = %s", pCBChannel->channelInfo[i].name);
1639 pDbHandle->freeTable();
1647 msg_error_t MsgStoGetThreadViewList(const MSG_SORT_RULE_S *pSortRule, msg_struct_list_s *pThreadViewList)
1649 MsgDbHandler *dbHandle = getDbHandle();
1650 dbHandle->connectReadOnly();
1652 pThreadViewList->nCount = 0;
1653 pThreadViewList->msg_struct_info = NULL;
1655 int rowCnt = 0, index = 0;
1657 char sqlQuery[MAX_QUERY_LEN+1];
1658 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1660 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.CONV_ID, A.UNREAD_CNT, A.SMS_CNT, A.MMS_CNT, A.MAIN_TYPE, A.SUB_TYPE, "
1661 "A.MSG_DIRECTION, A.DISPLAY_TIME, A.DISPLAY_NAME, A.MSG_TEXT, "
1662 "(COUNT(CASE WHEN B.PROTECTED = 1 THEN 1 END)) AS PROTECTED, "
1663 "(COUNT(CASE WHEN B.FOLDER_ID = %d THEN 1 END)) AS DRAFT, "
1664 "(COUNT(CASE WHEN B.NETWORK_STATUS = %d THEN 1 END)) AS FAILED, "
1665 "(COUNT(CASE WHEN B.NETWORK_STATUS = %d THEN 1 END)) AS SENDING "
1666 "FROM %s A, %s B ON A.SMS_CNT + A.MMS_CNT > 0 AND B.CONV_ID = A.CONV_ID "
1667 "GROUP BY A.CONV_ID ORDER BY A.DISPLAY_TIME DESC;",
1669 MSG_NETWORK_SEND_FAIL,
1670 MSG_NETWORK_SENDING,
1671 MSGFW_CONVERSATION_TABLE_NAME,
1672 MSGFW_MESSAGE_TABLE_NAME);
1674 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1676 if (err == MSG_ERR_DB_NORECORD) {
1677 dbHandle->freeTable();
1679 } else if (err != MSG_SUCCESS) {
1680 MSG_DEBUG("Fail to getTable().");
1681 dbHandle->freeTable();
1686 MSG_DEBUG("rowCnt is %d", rowCnt);
1687 dbHandle->freeTable();
1691 pThreadViewList->nCount = rowCnt;
1693 MSG_DEBUG("pThreadViewList->nCount [%d]", pThreadViewList->nCount);
1695 pThreadViewList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
1697 MSG_THREAD_VIEW_S *pTmp = NULL;
1698 msg_struct_s *thread_t = NULL;
1700 for (int i = 0; i < rowCnt; i++) {
1701 thread_t = (msg_struct_s *)new msg_struct_s;
1702 pThreadViewList->msg_struct_info[i] = (msg_struct_t)thread_t;
1704 thread_t->type = MSG_STRUCT_THREAD_INFO;
1705 thread_t->data = new MSG_THREAD_VIEW_S;
1707 pTmp = (MSG_THREAD_VIEW_S *)thread_t->data;
1708 memset(pTmp, 0x00, sizeof(MSG_THREAD_VIEW_S));
1710 pTmp->threadId = dbHandle->getColumnToInt(index++);
1712 pTmp->unreadCnt = dbHandle->getColumnToInt(index++);
1713 pTmp->smsCnt = dbHandle->getColumnToInt(index++);
1714 pTmp->mmsCnt = dbHandle->getColumnToInt(index++);
1716 pTmp->mainType = dbHandle->getColumnToInt(index++);
1717 pTmp->subType = dbHandle->getColumnToInt(index++);
1719 pTmp->direction = dbHandle->getColumnToInt(index++);
1720 pTmp->threadTime = (time_t)dbHandle->getColumnToInt(index++);
1722 memset(pTmp->threadName, 0x00, sizeof(pTmp->threadName));
1723 dbHandle->getColumnToString(index++, MAX_THREAD_NAME_LEN, pTmp->threadName);
1725 memset(pTmp->threadData, 0x00, sizeof(pTmp->threadData));
1726 dbHandle->getColumnToString(index++, MAX_THREAD_DATA_LEN, pTmp->threadData);
1728 int protectedCnt = dbHandle->getColumnToInt(index++);
1729 if (protectedCnt > 0)
1730 pTmp->bProtected = true;
1732 int draftCnt = dbHandle->getColumnToInt(index++);
1734 pTmp->bDraft = true;
1736 int failedCnt = dbHandle->getColumnToInt(index++);
1738 pTmp->bSendFailed = true;
1740 int sendingCnt = dbHandle->getColumnToInt(index++);
1742 pTmp->bSending = true;
1745 dbHandle->freeTable();
1751 msg_error_t MsgStoGetConversationPreview(MsgDbHandler *pDbHandle, MSG_CONVERSATION_VIEW_S *pConv)
1753 char sqlQuery[MAX_QUERY_LEN + 1];
1754 int rowCnt = 0, index = 0;
1755 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1758 return MSG_ERR_NULL_POINTER;
1760 pConv->tcs_bc_level = -1; /* init */
1762 /*(MSG_ID INTEGER, TYPE INTEGER, VALUE TEXT, COUNT INTEGER) */
1763 snprintf(sqlQuery, sizeof(sqlQuery),
1764 "SELECT TYPE, VALUE, COUNT "
1765 "FROM %s WHERE MSG_ID=%d;",
1766 MSGFW_MMS_PREVIEW_TABLE_NAME, pConv->msgId);
1768 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1769 if (err == MSG_SUCCESS) {
1770 for (int i = 0; i < rowCnt; i++) {
1771 int type = pDbHandle->getColumnToInt(index++);
1772 if (type == MSG_MMS_ITEM_TYPE_IMG) {
1773 pDbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, pConv->imageThumbPath);
1774 pDbHandle->getColumnToInt(index++);
1775 } else if (type == MSG_MMS_ITEM_TYPE_VIDEO) {
1776 pDbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, pConv->videoThumbPath);
1777 pDbHandle->getColumnToInt(index++);
1778 } else if (type == MSG_MMS_ITEM_TYPE_AUDIO) {
1779 pDbHandle->getColumnToString(index++, MSG_FILENAME_LEN_MAX, pConv->audioFileName);
1780 pDbHandle->getColumnToInt(index++);
1781 } else if (type == MSG_MMS_ITEM_TYPE_ATTACH) {
1782 pDbHandle->getColumnToString(index++, MSG_FILENAME_LEN_MAX, pConv->attachFileName);
1783 pConv->attachCount = pDbHandle->getColumnToInt(index++);
1784 } else if (type == MSG_MMS_ITEM_TYPE_PAGE) {
1786 pConv->pageCount = pDbHandle->getColumnToInt(index++);
1787 } else if (type == MSG_MMS_ITEM_TYPE_MALWARE) {
1789 pConv->tcs_bc_level = pDbHandle->getColumnToInt(index++);
1790 } else if (type == MSG_MMS_ITEM_TYPE_1ST_MEDIA) {
1791 pDbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, pConv->firstMediaPath);
1792 pDbHandle->getColumnToInt(index++);
1794 MSG_DEBUG("Unknown item type [%d]", type);
1800 pDbHandle->freeTable();
1804 msg_error_t MsgStoGetConversationMultipart(MsgDbHandler *pDbHandle, MSG_CONVERSATION_VIEW_S *pConv)
1806 char sqlQuery[MAX_QUERY_LEN + 1];
1807 int rowCnt = 0, index = 0;
1808 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1811 return MSG_ERR_NULL_POINTER;
1813 snprintf(sqlQuery, sizeof(sqlQuery),
1814 "SELECT CONTENT_TYPE, NAME, FILE_PATH, CONTENT_ID, CONTENT_LOCATION, TCS_LEVEL, MALWARE_ALLOW, THUMB_FILE_PATH "
1815 "FROM %s WHERE MSG_ID=%d;",
1816 MSGFW_MMS_MULTIPART_TABLE_NAME, pConv->msgId);
1818 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1819 if (err == MSG_SUCCESS) {
1820 GList *multipart_list = NULL;
1821 for (int i = 0; i < rowCnt; i++) {
1822 msg_struct_s *multipart_struct_s = new msg_struct_s;
1823 multipart_struct_s->type = MSG_STRUCT_MULTIPART_INFO;
1824 multipart_struct_s->data = new MMS_MULTIPART_DATA_S;
1825 memset(multipart_struct_s->data, 0x00, sizeof(MMS_MULTIPART_DATA_S));
1827 MMS_MULTIPART_DATA_S *multipart = (MMS_MULTIPART_DATA_S *)multipart_struct_s->data;
1829 pDbHandle->getColumnToString(index++, sizeof(multipart->szContentType), multipart->szContentType);
1830 pDbHandle->getColumnToString(index++, sizeof(multipart->szFileName), multipart->szFileName);
1831 pDbHandle->getColumnToString(index++, sizeof(multipart->szFilePath), multipart->szFilePath);
1832 pDbHandle->getColumnToString(index++, sizeof(multipart->szContentID), multipart->szContentID);
1833 pDbHandle->getColumnToString(index++, sizeof(multipart->szContentLocation), multipart->szContentLocation);
1835 multipart->tcs_bc_level = pDbHandle->getColumnToInt(index++);
1836 multipart->malware_allow = pDbHandle->getColumnToInt(index++);
1837 pDbHandle->getColumnToString(index++, sizeof(multipart->szThumbFilePath), multipart->szThumbFilePath);
1839 multipart_list = g_list_append(multipart_list, multipart_struct_s);
1841 pConv->multipart_list = (msg_list_handle_t)multipart_list;
1844 pDbHandle->freeTable();
1848 msg_error_t MsgStoGetConversationViewItem(msg_message_id_t msgId, MSG_CONVERSATION_VIEW_S *pConv)
1850 MsgDbHandler *dbHandle = getDbHandle();
1851 dbHandle->connectReadOnly();
1853 int rowCnt = 0, index = 0;
1855 char sqlQuery[MAX_QUERY_LEN+1];
1857 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1859 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONV_ID, FOLDER_ID, STORAGE_ID, MAIN_TYPE, SUB_TYPE, \
1860 DISPLAY_TIME, DATA_SIZE, NETWORK_STATUS, READ_STATUS, PROTECTED, \
1861 MSG_DIRECTION, DPM_RESTRICTED, SCHEDULED_TIME, SUBJECT, MSG_TEXT, ATTACHMENT_COUNT, SIM_INDEX\
1862 FROM %s WHERE MSG_ID = %d;",
1863 MSGFW_MESSAGE_TABLE_NAME, msgId);
1865 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1867 if (err == MSG_ERR_DB_NORECORD) {
1868 dbHandle->freeTable();
1870 } else if (err != MSG_SUCCESS) {
1871 MSG_DEBUG("Fail to getTable().");
1872 dbHandle->freeTable();
1876 memset(pConv, 0x00, sizeof(MSG_CONVERSATION_VIEW_S));
1877 pConv->pText = NULL;
1879 pConv->msgId = dbHandle->getColumnToInt(index++);
1880 pConv->threadId = dbHandle->getColumnToInt(index++);
1881 pConv->folderId = dbHandle->getColumnToInt(index++);
1882 pConv->storageId = dbHandle->getColumnToInt(index++);
1883 pConv->mainType = dbHandle->getColumnToInt(index++);
1884 pConv->subType = dbHandle->getColumnToInt(index++);
1885 pConv->displayTime = (time_t)dbHandle->getColumnToInt(index++);
1886 pConv->textSize = dbHandle->getColumnToInt(index++);
1887 pConv->networkStatus = dbHandle->getColumnToInt(index++);
1888 pConv->bRead = dbHandle->getColumnToInt(index++);
1889 pConv->bProtected = dbHandle->getColumnToInt(index++);
1890 pConv->direction = dbHandle->getColumnToInt(index++);
1891 pConv->bRestricted = dbHandle->getColumnToInt(index++);
1892 pConv->scheduledTime = (time_t)dbHandle->getColumnToInt(index++);
1894 dbHandle->getColumnToString(index++, MAX_SUBJECT_LEN, pConv->subject);
1895 char *tmpText = g_strdup(dbHandle->getColumnToString(index++));
1897 /*It does Not need to Get attach count in MSG_MESSAGE_TABLE. see MsgStoGetConversationPreview */
1898 /*pConv->attachCount = dbHandle->getColumnToInt(index++); */
1900 if (pConv->bRestricted == true) {
1901 pConv->textSize = 0;
1902 memset(pConv->subject, 0x00, sizeof(pConv->subject));
1906 pConv->simIndex = dbHandle->getColumnToInt(index++);
1908 dbHandle->freeTable();
1910 if (pConv->mainType == MSG_MMS_TYPE &&
1911 (pConv->networkStatus == MSG_NETWORK_RETRIEVING || pConv->networkStatus == MSG_NETWORK_RETRIEVE_FAIL || pConv->subType == MSG_NOTIFICATIONIND_MMS)) {
1912 pConv->pText = NULL;
1913 pConv->textSize = 0;
1915 if (pConv->mainType == MSG_SMS_TYPE) {
1916 pConv->pText = new char[pConv->textSize+2];
1917 memset(pConv->pText, 0x00, pConv->textSize+2);
1918 snprintf(pConv->pText, pConv->textSize+1, "%s", tmpText);
1919 } else if (pConv->mainType == MSG_MMS_TYPE) {
1921 pConv->textSize = strlen(tmpText);
1923 pConv->pText = new char[pConv->textSize+1];
1924 memset(pConv->pText, 0x00, pConv->textSize+1);
1926 strncpy(pConv->pText, tmpText, pConv->textSize);
1929 MsgStoGetConversationPreview(dbHandle, pConv);
1930 MsgStoGetConversationMultipart(dbHandle, pConv);
1945 msg_error_t MsgStoGetConversationViewList(msg_thread_id_t threadId, msg_struct_list_s *pConvViewList)
1949 MsgDbHandler *dbHandle = getDbHandle();
1950 dbHandle->connectReadOnly();
1952 pConvViewList->nCount = 0;
1953 pConvViewList->msg_struct_info = NULL;
1955 int rowCnt = 0, index = 0;
1957 char sqlQuery[MAX_QUERY_LEN+1];
1959 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1961 #ifdef MSG_NOTI_INTEGRATION
1962 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONV_ID, FOLDER_ID, STORAGE_ID, MAIN_TYPE, SUB_TYPE, \
1963 DISPLAY_TIME, DATA_SIZE, NETWORK_STATUS, READ_STATUS, PROTECTED, \
1964 MSG_DIRECTION, DPM_RESTRICTED, SCHEDULED_TIME, SUBJECT, MSG_TEXT, ATTACHMENT_COUNT, SIM_INDEX \
1965 FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME, MSG_ID ASC;",
1966 MSGFW_MESSAGE_TABLE_NAME, threadId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
1968 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONV_ID, FOLDER_ID, STORAGE_ID, MAIN_TYPE, SUB_TYPE, \
1969 DISPLAY_TIME, DATA_SIZE, NETWORK_STATUS, READ_STATUS, PROTECTED, \
1970 MSG_DIRECTION, DPM_RESTRICTED, SCHEDULED_TIME, SUBJECT, MSG_TEXT, ATTACHMENT_COUNT \
1971 FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME, MSG_ID ASC;",
1972 MSGFW_MESSAGE_TABLE_NAME, threadId, MSG_ALLBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
1975 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1977 if (err == MSG_ERR_DB_NORECORD) {
1978 dbHandle->freeTable();
1980 } else if (err != MSG_SUCCESS) {
1981 MSG_DEBUG("Fail to getTable().");
1982 dbHandle->freeTable();
1986 pConvViewList->nCount = rowCnt;
1987 char *tmpText[rowCnt] = {NULL};
1989 MSG_DEBUG("pConvViewList->nCount [%d]", pConvViewList->nCount);
1991 pConvViewList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
1992 memset(pConvViewList->msg_struct_info, 0x00, sizeof(msg_struct_t) * rowCnt);
1994 msg_struct_s *conv = NULL;
1995 MSG_CONVERSATION_VIEW_S *pTmp = NULL;
1997 for (int i = 0; i < rowCnt; i++) {
1998 pConvViewList->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
1999 memset(pConvViewList->msg_struct_info[i], 0x00, sizeof(msg_struct_s));
2001 conv = (msg_struct_s *)pConvViewList->msg_struct_info[i];
2003 conv->type = MSG_STRUCT_CONV_INFO;
2004 conv->data = new MSG_CONVERSATION_VIEW_S;
2005 memset(conv->data, 0x00, sizeof(MSG_CONVERSATION_VIEW_S));
2007 pTmp = (MSG_CONVERSATION_VIEW_S *)conv->data;
2011 pTmp->msgId = dbHandle->getColumnToInt(index++);
2012 pTmp->threadId = dbHandle->getColumnToInt(index++);
2013 pTmp->folderId = dbHandle->getColumnToInt(index++);
2014 pTmp->storageId = dbHandle->getColumnToInt(index++);
2015 pTmp->mainType = dbHandle->getColumnToInt(index++);
2016 pTmp->subType = dbHandle->getColumnToInt(index++);
2017 pTmp->displayTime = (time_t)dbHandle->getColumnToInt(index++);
2018 pTmp->textSize = dbHandle->getColumnToInt(index++);
2019 pTmp->networkStatus = dbHandle->getColumnToInt(index++);
2020 pTmp->bRead = dbHandle->getColumnToInt(index++);
2021 pTmp->bProtected = dbHandle->getColumnToInt(index++);
2022 pTmp->direction = dbHandle->getColumnToInt(index++);
2023 pTmp->bRestricted = dbHandle->getColumnToInt(index++);
2024 index++; /* This field is reserved. */
2026 dbHandle->getColumnToString(index++, MAX_SUBJECT_LEN, pTmp->subject);
2027 tmpText[i] = g_strdup(dbHandle->getColumnToString(index++));
2029 /*It does Not need to Get attach count in MSG_MESSAGE_TABLE. see MsgStoGetConversationPreview */
2030 /*pTmp->attachCount = dbHandle->getColumnToInt(index++); */
2033 if (pTmp->bRestricted == true) {
2035 memset(pTmp->subject, 0x00, sizeof(pTmp->subject));
2036 tmpText[i][0] = '\0';
2038 pTmp->simIndex = dbHandle->getColumnToInt(index++);
2040 dbHandle->freeTable();
2042 for (int i = 0; i < pConvViewList->nCount; i++) {
2043 conv = (msg_struct_s *)pConvViewList->msg_struct_info[i];
2044 pTmp = (MSG_CONVERSATION_VIEW_S *)conv->data;
2046 if (pTmp->mainType == MSG_MMS_TYPE &&
2047 (pTmp->networkStatus == MSG_NETWORK_RETRIEVING || pTmp->networkStatus == MSG_NETWORK_RETRIEVE_FAIL || pTmp->subType == MSG_NOTIFICATIONIND_MMS)) {
2051 if (pTmp->mainType == MSG_SMS_TYPE) {
2052 pTmp->pText = new char[pTmp->textSize+2];
2053 memset(pTmp->pText, 0x00, pTmp->textSize+2);
2054 snprintf(pTmp->pText, pTmp->textSize+1, "%s", tmpText[i]);
2055 } else if (pTmp->mainType == MSG_MMS_TYPE) {
2057 pTmp->textSize = strlen(tmpText[i]);
2059 pTmp->pText = new char[pTmp->textSize+1];
2060 memset(pTmp->pText, 0x00, pTmp->textSize+1);
2062 strncpy(pTmp->pText, tmpText[i], pTmp->textSize);
2065 MsgStoGetConversationPreview(dbHandle, pTmp);
2066 MsgStoGetConversationMultipart(dbHandle, pTmp);
2081 msg_error_t MsgStoSearchMessage(const char *pSearchString, msg_struct_list_s *pThreadViewList, int contactCount)
2084 return MSG_ERR_NULL_POINTER;
2086 MsgDbHandler *dbHandle = getDbHandle();
2087 dbHandle->connectReadOnly();
2088 char *escapeAddressStr = NULL;
2090 /* Clear Out Parameter */
2091 pThreadViewList->nCount = 0;
2092 pThreadViewList->msg_struct_info = NULL;
2094 tr1::unordered_set<msg_thread_id_t> IdList;
2095 queue<MSG_THREAD_VIEW_S> searchList;
2097 MSG_THREAD_VIEW_S threadView;
2099 char sqlQuery[MAX_QUERY_LEN+1];
2101 /* Search - Address, Name */
2102 memset(sqlQuery, 0x00, MAX_QUERY_LEN+1);
2103 snprintf(sqlQuery, MAX_QUERY_LEN, "SELECT A.CONV_ID, A.UNREAD_CNT, A.SMS_CNT, A.MMS_CNT, A.DISPLAY_NAME, "
2104 "A.MAIN_TYPE, A.SUB_TYPE, A.MSG_DIRECTION, A.DISPLAY_TIME, A.MSG_TEXT, "
2105 "(SELECT COUNT(*) FROM %s B WHERE B.CONV_ID = A.CONV_ID AND B.PROTECTED = 1) AS PROTECTED, "
2106 "(SELECT COUNT(*) FROM %s B WHERE B.CONV_ID = A.CONV_ID AND B.FOLDER_ID = %d) AS DRAFT, "
2107 "(SELECT COUNT(*) FROM %s B WHERE B.CONV_ID = A.CONV_ID AND B.NETWORK_STATUS = %d) AS FAILED, "
2108 "(SELECT COUNT(*) FROM %s B WHERE B.CONV_ID = A.CONV_ID AND B.NETWORK_STATUS = %d) AS SENDING "
2109 "FROM %s A WHERE (A.SMS_CNT > 0 OR A.MMS_CNT > 0) "
2111 "(SELECT DISTINCT(CONV_ID) FROM %s WHERE "
2112 "ADDRESS_VAL LIKE ? ESCAPE '%c' ",
2113 MSGFW_MESSAGE_TABLE_NAME,
2114 MSGFW_MESSAGE_TABLE_NAME, MSG_DRAFT_ID,
2115 MSGFW_MESSAGE_TABLE_NAME, MSG_NETWORK_SEND_FAIL,
2116 MSGFW_MESSAGE_TABLE_NAME, MSG_NETWORK_SENDING,
2117 MSGFW_CONVERSATION_TABLE_NAME,
2118 MSGFW_ADDRESS_TABLE_NAME,
2119 MSGFW_DB_ESCAPE_CHAR);
2121 unsigned int tmpSize = 0;
2122 if (contactCount > 0) {
2123 tmpSize = strlen(sqlQuery);
2124 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
2125 "OR ADDRESS_VAL IN (SELECT C.ADDRESS_VAL FROM %s C JOIN %s D ON (C.ADDRESS_VAL LIKE D.ADDRESS_VAL))"
2126 , MSGFW_ADDRESS_TABLE_NAME, MSGFW_ADDRESS_TEMP_TABLE_NAME);
2129 tmpSize = strlen(sqlQuery);
2130 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
2131 ") ORDER BY A.DISPLAY_TIME DESC;");
2133 MSG_DEBUG("sqlQuery=[%s]", sqlQuery);
2135 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
2136 MSG_DEBUG("Prepare query fail.");
2137 return MSG_ERR_DB_PREPARE;
2140 MsgConvertStrWithEscape(pSearchString, &escapeAddressStr);
2141 MSG_DEBUG("escapeAddressStr [%s]", escapeAddressStr);
2142 dbHandle->bindText(escapeAddressStr, 1);
2143 /*dbHandle->bindText(escapeAddressStr, 2); */
2144 /*dbHandle->bindText(escapeAddressStr, 3); */
2145 /*dbHandle->bindText(escapeAddressStr, 4); */
2147 while (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
2148 memset(&threadView, 0x00, sizeof(threadView));
2150 threadView.threadId = dbHandle->columnInt(0);
2151 threadView.unreadCnt = dbHandle->columnInt(1);
2152 threadView.smsCnt = dbHandle->columnInt(2);
2153 threadView.mmsCnt = dbHandle->columnInt(3);
2155 if (dbHandle->columnText(4))
2156 strncpy(threadView.threadName, (char *)dbHandle->columnText(4), MAX_THREAD_NAME_LEN);
2158 threadView.mainType = dbHandle->columnInt(5);
2159 threadView.subType = dbHandle->columnInt(6);
2161 threadView.direction = dbHandle->columnInt(7);
2162 threadView.threadTime = (time_t)dbHandle->columnInt(8);
2164 if (dbHandle->columnText(9))
2165 strncpy(threadView.threadData, (char *)dbHandle->columnText(9), MAX_THREAD_DATA_LEN);
2167 int protectedCnt = dbHandle->columnInt(10);
2168 if (protectedCnt > 0)
2169 threadView.bProtected = true;
2171 int draftCnt = dbHandle->columnInt(11);
2173 threadView.bDraft = true;
2175 int failedCnt = dbHandle->columnInt(12);
2177 threadView.bSendFailed = true;
2179 int sendingCnt = dbHandle->columnInt(13);
2181 threadView.bSending = true;
2183 tr1::unordered_set<msg_thread_id_t>::iterator it;
2185 it = IdList.find(threadView.threadId);
2187 if (it == IdList.end()) {
2188 IdList.insert(threadView.threadId);
2189 searchList.push(threadView);
2193 dbHandle->finalizeQuery();
2195 if (escapeAddressStr) {
2196 free(escapeAddressStr);
2197 escapeAddressStr = NULL;
2201 /* Add data to Out Parameter */
2202 pThreadViewList->nCount = searchList.size();
2203 pThreadViewList->msg_struct_info = (msg_struct_t *)calloc(searchList.size(), sizeof(msg_struct_t));
2204 if (pThreadViewList->msg_struct_info == NULL)
2205 return MSG_ERR_MEMORY_ERROR;
2207 MSG_THREAD_VIEW_S *pTmp = NULL;
2208 msg_struct_s *thread_t = NULL;
2212 while (!searchList.empty()) {
2213 thread_t = (msg_struct_s *)new msg_struct_s;
2214 pThreadViewList->msg_struct_info[index] = (msg_struct_t)thread_t;
2216 thread_t->type = MSG_STRUCT_THREAD_INFO;
2217 thread_t->data = new MSG_THREAD_VIEW_S;
2219 pTmp = (MSG_THREAD_VIEW_S *)thread_t->data;
2220 memset(pTmp, 0x00, sizeof(MSG_THREAD_VIEW_S));
2222 memcpy(pTmp, &(searchList.front()), sizeof(MSG_THREAD_VIEW_S));
2233 msg_error_t MsgStoGetRejectMsgList(const char *pNumber, msg_struct_list_s *pRejectMsgList)
2235 MsgDbHandler *dbHandle = getDbHandle();
2236 dbHandle->connectReadOnly();
2238 /* Clear Out Parameter */
2239 pRejectMsgList->nCount = 0;
2240 pRejectMsgList->msg_struct_info = NULL;
2242 int rowCnt = 0, index = 0;
2244 char sqlQuery[MAX_QUERY_LEN+1];
2246 /* Search Reject Msg */
2247 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2249 if (pNumber != NULL) {
2250 int addrSize = strlen(pNumber);
2251 char phoneNumber[addrSize+1];
2252 memset(phoneNumber, 0x00, sizeof(phoneNumber));
2254 if (addrSize > MsgContactGetMinMatchDigit())
2255 MsgConvertNumber(pNumber, phoneNumber, addrSize);
2257 strncpy(phoneNumber, pNumber, addrSize);
2259 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
2264 "WHERE A.CONV_ID = B.CONV_ID "
2265 "AND B.MAIN_TYPE = %d "
2266 "AND B.SUB_TYPE = %d "
2267 "AND A.ADDRESS_VAL LIKE '%%%s' "
2268 "ORDER BY B.DISPLAY_TIME DESC;",
2269 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
2274 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
2279 "WHERE A.CONV_ID = B.CONV_ID "
2280 "AND B.MAIN_TYPE = %d "
2281 "AND B.SUB_TYPE = %d "
2282 "ORDER BY B.DISPLAY_TIME DESC;",
2283 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
2288 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
2290 if (err != MSG_SUCCESS) {
2291 MSG_DEBUG("Fail to getTable().");
2292 dbHandle->freeTable();
2296 pRejectMsgList->nCount = rowCnt;
2298 MSG_DEBUG("pRejectMsgList->nCount [%d]", pRejectMsgList->nCount);
2300 pRejectMsgList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(MSG_REJECT_MSG_INFO_S *));
2302 msg_struct_s* pTmp = NULL;
2304 for (int i = 0; i < rowCnt; i++) {
2305 pRejectMsgList->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
2307 pTmp = (msg_struct_s *)pRejectMsgList->msg_struct_info[i];
2308 pTmp->type = MSG_STRUCT_REJECT_MSG_INFO;
2309 pTmp->data = new MSG_REJECT_MSG_INFO_S;
2310 MSG_REJECT_MSG_INFO_S * pMsg = (MSG_REJECT_MSG_INFO_S *)pTmp->data;
2311 memset(pMsg, 0x00, sizeof(MSG_REJECT_MSG_INFO_S));
2313 pMsg->msgId = dbHandle->getColumnToInt(index++);
2314 memset(pMsg->msgText, 0x00, sizeof(pMsg->msgText));
2315 dbHandle->getColumnToString(index++, MAX_MSG_TEXT_LEN, pMsg->msgText);
2317 pMsg->displayTime = (time_t)dbHandle->getColumnToInt(index++);
2320 dbHandle->freeTable();
2326 msg_error_t MsgStoGetAddressList(const msg_thread_id_t threadId, msg_struct_list_s *pAddrList)
2328 MsgDbHandler *dbHandle = getDbHandle();
2329 dbHandle->connectReadOnly();
2331 msg_error_t err = MSG_SUCCESS;
2333 err = MsgStoGetAddressByConvId(dbHandle, threadId, pAddrList);
2339 msg_error_t MsgStoGetMessageList(const MSG_LIST_CONDITION_S *pListCond, msg_struct_list_s *pMsgList, int contactCount)
2341 MsgDbHandler *dbHandle = getDbHandle();
2342 dbHandle->connectReadOnly();
2344 /* Clear Out Parameter */
2345 pMsgList->nCount = 0;
2346 pMsgList->msg_struct_info = NULL;
2349 int multipartCnt = 0;
2351 char sqlQuery[MAX_QUERY_LEN+1];
2352 char sqlQuerySubset[(MAX_QUERY_LEN/5)+1];
2354 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2355 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(*) FROM %s;", MSGFW_MMS_MULTIPART_TABLE_NAME);
2357 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
2358 return MSG_ERR_DB_PREPARE;
2360 if (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
2361 multipartCnt = dbHandle->columnInt(0);
2363 dbHandle->finalizeQuery();
2364 return MSG_ERR_DB_STEP;
2367 dbHandle->finalizeQuery();
2369 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2370 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT DISTINCT "
2379 "A.NETWORK_STATUS, "
2385 "A.SCHEDULED_TIME, "
2388 "A.ATTACHMENT_COUNT, "
2392 "B.RECIPIENT_TYPE, "
2395 if (pListCond->pTextVal != NULL && multipartCnt > 0) {
2396 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2397 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "FROM %s C, %s B, %s A WHERE A.CONV_ID > 0 AND A.CONV_ID = B.CONV_ID ",
2398 MSGFW_MMS_MULTIPART_TABLE_NAME, MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME);
2400 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2401 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "FROM %s B, %s A WHERE A.CONV_ID > 0 AND A.CONV_ID = B.CONV_ID ",
2402 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME);
2405 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2407 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2408 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.DPM_RESTRICTED = 0 ");
2409 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2412 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2414 if (pListCond->folderId == MSG_ALLBOX_ID)
2415 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.FOLDER_ID > 0 AND A.FOLDER_ID < %d ", MSG_SPAMBOX_ID);
2416 else if (pListCond->folderId == MSG_IOSBOX_ID)
2417 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.FOLDER_ID > 0 AND A.FOLDER_ID < %d ", MSG_DRAFT_ID);
2419 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.FOLDER_ID = %d ", pListCond->folderId);
2421 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2425 if (pListCond->threadId > 0) {
2426 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2427 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.CONV_ID = %d ", pListCond->threadId);
2428 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2433 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2435 switch (pListCond->msgType) {
2437 if (pListCond->pAddressVal == NULL)
2438 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d ", MSG_SMS_TYPE);
2440 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_SMS_TYPE, MSG_NORMAL_SMS);
2444 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d ", MSG_MMS_TYPE);
2447 case MSG_TYPE_MMS_JAVA:
2448 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_MMS_TYPE, MSG_SENDREQ_JAVA_MMS);
2451 case MSG_TYPE_SMS_SYNCML:
2452 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_SMS_TYPE, MSG_SYNCML_CP);
2454 case MSG_TYPE_SMS_REJECT:
2455 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_SMS_TYPE, MSG_REJECT_SMS);
2459 MSG_DEBUG("msg type is not set.");
2463 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2467 if (pListCond->storageId > MSG_STORAGE_UNKNOWN) {
2468 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2469 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.STORAGE_ID = %d ", pListCond->storageId);
2470 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2475 if (pListCond->bProtected) {
2476 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2477 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.PROTECTED = %d ", pListCond->bProtected);
2478 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2483 if (pListCond->bScheduled) {
2484 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2485 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.SCHEDULED_TIME > 0 ");
2486 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2491 if (pListCond->simIndex > 0) {
2492 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2493 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.SIM_INDEX = %d ", pListCond->simIndex);
2494 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2499 if (pListCond->fromTime > 0) {
2500 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2501 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.DISPLAY_TIME >= %u ", (unsigned int)pListCond->fromTime);
2502 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2505 if (pListCond->toTime > 0) {
2506 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2507 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.DISPLAY_TIME <= %u ", (unsigned int)pListCond->toTime);
2508 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2511 if (pListCond->pAddressVal == NULL) {
2513 if (pListCond->pTextVal != NULL) {
2514 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2515 if (multipartCnt > 0) {
2516 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2517 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c' OR (C.NAME LIKE ? ESCAPE '%c' AND A.MSG_ID = C.MSG_ID AND C.CONTENT_TYPE <> 'application/smil'))) ",
2518 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2520 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2521 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c')) ",
2522 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2524 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2528 if (pListCond->pTextVal != NULL) {
2529 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2530 if (multipartCnt > 0) {
2531 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2532 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c' OR (C.NAME LIKE ? ESCAPE '%c' AND A.MSG_ID = C.MSG_ID AND C.CONTENT_TYPE <> 'application/smil')) ",
2533 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2535 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2536 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c') ",
2537 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2539 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2541 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2542 if (pListCond->bAnd) {
2543 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND ");
2545 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "OR ");
2547 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2550 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2551 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2552 "(B.ADDRESS_VAL LIKE ? ESCAPE '%c' ", MSGFW_DB_ESCAPE_CHAR);
2553 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2555 if (contactCount > 0) {
2556 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2557 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2558 "OR B.ADDRESS_VAL IN (SELECT D.ADDRESS_VAL FROM %s D JOIN %s E ON (D.ADDRESS_VAL LIKE E.ADDRESS_VAL)) "
2559 , MSGFW_ADDRESS_TABLE_NAME, MSGFW_ADDRESS_TEMP_TABLE_NAME);
2560 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2563 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2564 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ")) ");
2565 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2568 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2569 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2570 "AND (B.ADDRESS_VAL LIKE ? ESCAPE '%c' ", MSGFW_DB_ESCAPE_CHAR);
2571 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2573 if (contactCount > 0) {
2574 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2575 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2576 "OR B.ADDRESS_VAL IN (SELECT D.ADDRESS_VAL FROM %s D JOIN %s E ON (D.ADDRESS_VAL LIKE E.ADDRESS_VAL)) "
2577 , MSGFW_ADDRESS_TABLE_NAME, MSGFW_ADDRESS_TEMP_TABLE_NAME);
2578 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2581 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2582 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ") ");
2583 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2587 msg_struct_s *pSortRule = (msg_struct_s *)pListCond->sortRule;
2589 if (pSortRule->type != MSG_STRUCT_SORT_RULE) {
2591 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2592 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.DISPLAY_TIME ");
2594 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2597 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2598 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "DESC ");
2600 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2602 MSG_SORT_RULE_S *pTmp = (MSG_SORT_RULE_S *)pSortRule->data;
2603 /* order : TODO: have to finish this */
2604 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2605 switch (pTmp->sortType) {
2606 case MSG_SORT_BY_MSG_TYPE:
2607 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.MAIN_TYPE ");
2609 case MSG_SORT_BY_READ_STATUS:
2610 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.READ_STATUS ");
2612 case MSG_SORT_BY_STORAGE_TYPE:
2613 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.STORAGE_ID ");
2616 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.DISPLAY_TIME ");
2619 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2622 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2623 if (pTmp->bAscending)
2624 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ASC ");
2626 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "DESC ");
2628 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2631 /* offset & limit */
2632 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2633 if (pListCond->offset >= 0 && pListCond->limit > 0)
2634 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "LIMIT %d OFFSET %d;", pListCond->limit, pListCond->offset);
2636 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ";");
2638 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2641 /* 'til here sqlQuery is complete. */
2643 queue<MSG_MESSAGE_HIDDEN_S*> searchList;
2645 MSG_DEBUG("[%s]", sqlQuery);
2647 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
2648 MSG_DEBUG("Prepare query fail.");
2649 return MSG_ERR_DB_PREPARE;
2652 char *escapeTextStr = NULL;
2653 char *escapeAddressStr = NULL;
2655 if (pListCond->pAddressVal == NULL) {
2657 if (pListCond->pTextVal != NULL) {
2658 MsgConvertStrWithEscape(pListCond->pTextVal, &escapeTextStr);
2659 MSG_DEBUG("escapeTextStr [%s]", escapeTextStr);
2660 dbHandle->bindText(escapeTextStr, 1);
2661 dbHandle->bindText(escapeTextStr, 2);
2662 if (multipartCnt > 0) dbHandle->bindText(escapeTextStr, 3);
2666 if (pListCond->pTextVal != NULL) {
2667 MsgConvertStrWithEscape(pListCond->pTextVal, &escapeTextStr);
2668 MSG_DEBUG("escapeTestStr [%s]", escapeTextStr);
2671 MsgConvertStrWithEscape(pListCond->pAddressVal, &escapeAddressStr);
2672 MSG_DEBUG("escapeAddressStr [%s]", escapeAddressStr);
2674 dbHandle->bindText(escapeTextStr, 1);
2675 dbHandle->bindText(escapeTextStr, 2);
2676 if (multipartCnt > 0) {
2677 dbHandle->bindText(escapeTextStr, 3);
2678 dbHandle->bindText(escapeAddressStr, 4);
2680 dbHandle->bindText(escapeAddressStr, 3);
2685 MsgConvertStrWithEscape(pListCond->pAddressVal, &escapeAddressStr);
2686 MSG_DEBUG("escapeAddressStr [%s]", escapeAddressStr);
2687 dbHandle->bindText(escapeAddressStr, 1);
2692 MSG_MESSAGE_HIDDEN_S *pTmp = NULL;
2693 int lastMsgId = 0; /* for comparing same msg id. */
2695 while (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
2698 int msgid = dbHandle->columnInt(index++);
2699 MSG_DEBUG("msgid [%d]", msgid);
2701 if (lastMsgId != msgid) {
2702 MSG_DEBUG("lastMsgId != msgid");
2706 pTmp = new MSG_MESSAGE_HIDDEN_S;
2709 memset(pTmp, 0x00, sizeof(MSG_MESSAGE_HIDDEN_S));
2712 pTmp->pMmsData = NULL;
2713 pTmp->addressList = NULL;
2715 pTmp->msgId = msgid;
2717 pTmp->threadId = dbHandle->columnInt(index++);
2718 pTmp->folderId = dbHandle->columnInt(index++);
2719 pTmp->storageId = dbHandle->columnInt(index++);
2720 pTmp->mainType = dbHandle->columnInt(index++);
2721 pTmp->subType = dbHandle->columnInt(index++);
2722 pTmp->displayTime = (time_t)dbHandle->columnInt(index++);
2723 pTmp->dataSize = dbHandle->columnInt(index++);
2724 pTmp->networkStatus = dbHandle->columnInt(index++);
2725 pTmp->bRead = dbHandle->columnInt(index++);
2726 pTmp->bProtected = dbHandle->columnInt(index++);
2727 pTmp->bBackup = dbHandle->columnInt(index++);
2728 pTmp->priority = dbHandle->columnInt(index++);
2729 pTmp->direction = dbHandle->columnInt(index++);
2730 index++; /* This field is reserved. */
2732 strncpy(pTmp->subject, (char *)dbHandle->columnText(index++), MAX_SUBJECT_LEN);
2734 if (pTmp->mainType == MSG_MMS_TYPE &&
2735 (pTmp->networkStatus == MSG_NETWORK_RETRIEVING || pTmp->networkStatus == MSG_NETWORK_RETRIEVE_FAIL || pTmp->subType == MSG_NOTIFICATIONIND_MMS)) {
2739 pTmp->pData = (void *)new char[pTmp->dataSize+2];
2740 memset(pTmp->pData, 0x00, pTmp->dataSize+2);
2742 strncpy((char *)pTmp->pData, (char *)dbHandle->columnText(index++), pTmp->dataSize+1);
2745 pTmp->attachCount = dbHandle->columnInt(index++);
2747 strncpy(pTmp->thumbPath, (char *)dbHandle->columnText(index++), MSG_FILEPATH_LEN_MAX);
2749 pTmp->simIndex = dbHandle->columnInt(index++);
2751 pTmp->addr_list = (msg_struct_list_s *)new msg_struct_list_s;
2752 pTmp->addr_list->nCount = 0;
2753 pTmp->addr_list->msg_struct_info = (msg_struct_t *)calloc(MAX_TO_ADDRESS_CNT, sizeof(msg_struct_t));
2754 for (int i = 0; i < MAX_TO_ADDRESS_CNT; i++) {
2755 pTmp->addr_list->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
2756 memset(pTmp->addr_list->msg_struct_info[i], 0x00, sizeof(msg_struct_s));
2759 searchList.push(pTmp);
2763 MSG_DEBUG("lastMsgId == msgid");
2768 MSG_ADDRESS_INFO_S *pAddr = new MSG_ADDRESS_INFO_S;
2769 memset(pAddr, 0x00, sizeof(MSG_ADDRESS_INFO_S));
2771 pAddr->addressType = dbHandle->columnInt(index++);
2772 pAddr->recipientType = dbHandle->columnInt(index++);
2774 strncpy(pAddr->addressVal, (char *)dbHandle->columnText(index++), MAX_ADDRESS_VAL_LEN);
2776 strncpy(pAddr->displayName, pAddr->addressVal, MAX_DISPLAY_NAME_LEN);
2778 /* For GList *addressList */
2779 msg_struct_s *addr_info_s = new msg_struct_s;
2780 memset(addr_info_s, 0x00, sizeof(msg_struct_s));
2781 addr_info_s->type = MSG_STRUCT_ADDRESS_INFO;
2782 addr_info_s->data = new MSG_ADDRESS_INFO_S;
2783 memset(addr_info_s->data, 0x00, sizeof(MSG_ADDRESS_INFO_S));
2784 MSG_ADDRESS_INFO_S *addr_info = (MSG_ADDRESS_INFO_S *)addr_info_s->data;
2785 addr_info->addressType = pAddr->addressType;
2786 addr_info->recipientType = pAddr->recipientType;
2787 addr_info->contactId = pAddr->contactId;
2788 strncpy(addr_info->addressVal, pAddr->addressVal, MAX_ADDRESS_VAL_LEN);
2789 strncpy(addr_info->displayName, pAddr->displayName, MAX_DISPLAY_NAME_LEN);
2790 addr_info->displayName[MAX_DISPLAY_NAME_LEN] = '\0';
2792 pTmp->addressList = g_list_append(pTmp->addressList, addr_info_s);
2794 if (pTmp->addr_list->nCount >= MAX_TO_ADDRESS_CNT) {
2798 msg_struct_s *pStruct = (msg_struct_s *)pTmp->addr_list->msg_struct_info[pTmp->addr_list->nCount];
2799 pTmp->addr_list->nCount++;
2800 pStruct->type = MSG_STRUCT_ADDRESS_INFO;
2801 pStruct->data = pAddr;
2806 dbHandle->finalizeQuery();
2808 pMsgList->nCount = searchList.size();
2809 MSG_DEBUG("pMsgList->nCount [%d]", pMsgList->nCount);
2811 pMsgList->msg_struct_info = (msg_struct_t *)calloc(pMsgList->nCount, sizeof(msg_struct_t));
2812 if (pMsgList->msg_struct_info == NULL)
2813 return MSG_ERR_MEMORY_ERROR;
2816 while (!searchList.empty()) {
2817 msg_struct_s *msg = new msg_struct_s;
2819 pMsgList->msg_struct_info[offset++] = (msg_struct_t)msg;
2821 msg->type = MSG_STRUCT_MESSAGE_INFO;
2822 msg->data = searchList.front();
2829 free(escapeTextStr);
2831 if (escapeAddressStr)
2832 free(escapeAddressStr);
2838 msg_error_t MsgStoGetMediaList(const msg_thread_id_t threadId, msg_list_handle_t *pMediaList)
2841 msg_error_t err = MSG_SUCCESS;
2842 MsgDbHandler *dbHandle = getDbHandle();
2843 dbHandle->connectReadOnly();
2844 char sqlQuery[MAX_QUERY_LEN+1];
2847 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2848 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s WHERE MAIN_TYPE = %d AND DPM_RESTRICTED = 0 AND CONV_ID = %d;",
2849 MSGFW_MESSAGE_TABLE_NAME, MSG_MMS_TYPE, threadId);
2851 MSG_DEBUG("sqlQuery = [%s]", sqlQuery);
2853 err = dbHandle->getTable(sqlQuery, &msgIdCnt, NULL);
2854 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
2855 dbHandle->freeTable();
2857 } else if (err == MSG_ERR_DB_NORECORD) {
2858 dbHandle->freeTable();
2862 msg_message_id_t msgIds[msgIdCnt];
2864 for (int i = 1; i <= msgIdCnt; i++) {
2865 msgIds[i-1] = dbHandle->getColumnToInt(i);
2868 dbHandle->freeTable();
2870 GList *media_list = NULL;
2872 for (int i = 0; i < msgIdCnt; i++) {
2873 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2874 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONTENT_TYPE, FILE_PATH, THUMB_FILE_PATH "
2875 "FROM %s WHERE MSG_ID = %d AND SEQ <> -1 AND (TCS_LEVEL = -1 OR MALWARE_ALLOW = 1);",
2876 MSGFW_MMS_MULTIPART_TABLE_NAME, msgIds[i]);
2878 int rowCnt = 0, msg_id = 0, index = 0;
2880 err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
2882 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
2883 dbHandle->freeTable();
2887 MSG_MEDIA_INFO_S *pMedia = NULL;
2888 char mime_type[MAX_MIME_TYPE_LEN+1], media_item[MSG_FILEPATH_LEN_MAX+1], thumb_path[MSG_FILEPATH_LEN_MAX+1];
2890 for (int j = 0; j < rowCnt; j++) {
2891 msg_id = dbHandle->getColumnToInt(index++);
2892 memset(mime_type, 0x00, sizeof(mime_type));
2893 dbHandle->getColumnToString(index++, MAX_MIME_TYPE_LEN, mime_type);
2894 memset(media_item, 0x00, sizeof(media_item));
2895 dbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, media_item);
2896 memset(thumb_path, 0x00, sizeof(thumb_path));
2897 dbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, thumb_path);
2899 if (strstr(mime_type, "image") || strstr(mime_type, "video")) {
2900 msg_struct_s *media_struct_s = new msg_struct_s;
2901 media_struct_s->type = MSG_STRUCT_MEDIA_INFO;
2902 media_struct_s->data = new MSG_MEDIA_INFO_S;
2903 memset(media_struct_s->data, 0x00, sizeof(MSG_MEDIA_INFO_S));
2905 pMedia = (MSG_MEDIA_INFO_S *)media_struct_s->data;
2907 pMedia->msg_id = msg_id;
2908 snprintf(pMedia->mime_type, MAX_MIME_TYPE_LEN, "%s", mime_type);
2909 snprintf(pMedia->media_item, MSG_FILEPATH_LEN_MAX, "%s", media_item);
2910 snprintf(pMedia->thumb_path, MSG_FILEPATH_LEN_MAX, "%s", thumb_path);
2912 media_list = g_list_append(media_list, media_struct_s);
2916 dbHandle->freeTable();
2918 *pMediaList = (msg_list_handle_t)media_list;
2926 msg_error_t MsgStoDbSelectWithQuery(const char *szQuery, char ***db_res, int *row_count, int *col_count)
2930 msg_error_t err = MSG_SUCCESS;
2932 MsgDbHandler *dbHandle = getDbHandle();
2933 err = dbHandle->connectReadOnly();
2934 if (err != MSG_SUCCESS) {
2935 MSG_ERR("db connect (read only) is failed [%d]", err);
2939 char *zSQL = sqlite3_mprintf("SELECT %q;", szQuery);
2942 err = dbHandle->getTableWithResult((const char *)zSQL, db_res, row_count, col_count);
2946 THROW(MsgException::INVALID_RESULT, "sqlite3_mprintf() is failed");
2949 MSG_DEBUG("getTableWithResult :: row_count=[%d], col_count=[%d]", *row_count, *col_count);
2951 if (err == MSG_ERR_DB_NORECORD) {
2952 dbHandle->freeTable(*db_res);
2955 } else if (err != MSG_SUCCESS) {
2956 MSG_DEBUG("Fail to getTable().");
2957 dbHandle->freeTable(*db_res);
2965 void MsgStoDbFree(char **db_res)
2967 MsgDbHandler *dbHandle = getDbHandle();
2968 dbHandle->freeTable(db_res);
2972 #ifdef FEATURE_SMS_CDMA
2973 msg_error_t MsgStoClearUniquenessTable()
2977 msg_error_t err = MSG_SUCCESS;
2979 MsgDbHandler *dbHandle = getDbHandle();
2981 char sqlQuery[MAX_QUERY_LEN+1] = {0, };
2982 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s WHERE MSG_ID = 0", MSGFW_UNIQUENESS_INFO_TABLE_NAME);
2984 err = dbHandle->execQuery(sqlQuery);