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"
36 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}};
40 #define CHECK_SIZE 1 * 1024 * 1024 * 1024
41 #define RESERVE 100 * 1024 * 1024
42 #define RESERVE_LITE 5 * 1024 * 1024
44 /*==================================================================================================
45 FUNCTION IMPLEMENTATION
46 ==================================================================================================*/
48 unsigned int MsgStoAddMessageTable(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsgInfo)
52 msg_error_t err = MSG_SUCCESS;
54 msg_message_id_t msgId = 0;
56 err = pDbHandle->getRowId(MSGFW_MESSAGE_TABLE_NAME, &msgId);
58 if (err != MSG_SUCCESS)
63 char* pFileData = NULL;
64 unique_ptr<char*, void(*)(char**)> buf(&pFileData, unique_ptr_deleter);
67 if (pMsgInfo->bTextSms == false) {
68 if (MsgOpenAndReadFile(pMsgInfo->msgData, &pFileData, &fileSize) == false)
71 MSG_DEBUG("file size [%d]", fileSize);
74 char keyName[MAX_VCONFKEY_NAME_LEN];
75 memset(keyName, 0x00, sizeof(keyName));
76 snprintf(keyName, sizeof(keyName), "%s/%d", MSG_SIM_SUBS_ID, pMsgInfo->sim_idx);
79 if (MsgSettingGetString(keyName, &imsi) != MSG_SUCCESS) {
80 MSG_INFO("MsgSettingGetString() is failed");
84 char sqlQuery[MAX_QUERY_LEN+1];
86 memset(sqlQuery, 0x00, sizeof(sqlQuery));
87 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, %d, %d, %d, %d, %d, %lu, %zu, %d, %d, %d, %d, %d, %d, %d, ?, '', '', ?, 0, %d, '%s', %d);",
88 MSGFW_MESSAGE_TABLE_NAME, msgId, pMsgInfo->threadId, pMsgInfo->folderId, pMsgInfo->storageId, pMsgInfo->msgType.mainType,
89 pMsgInfo->msgType.subType, pMsgInfo->displayTime, pMsgInfo->dataSize, pMsgInfo->networkStatus, pMsgInfo->bRead, pMsgInfo->bProtected,
90 pMsgInfo->priority, pMsgInfo->direction, 0, pMsgInfo->bBackup, pMsgInfo->sim_idx, imsi, pMsgInfo->bRestricted);
92 MSG_DEBUG("QUERY : %s", sqlQuery);
97 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
100 pDbHandle->bindText(pMsgInfo->subject, 1);
102 if (pMsgInfo->msgType.subType == MSG_NOTIFICATIONIND_MMS) {
103 pDbHandle->bindText("", 2);
105 if (pMsgInfo->bTextSms == false)
106 pDbHandle->bindText(pFileData, 2);
108 pDbHandle->bindText(pMsgInfo->msgText, 2);
111 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
112 pDbHandle->finalizeQuery();
116 pDbHandle->finalizeQuery();
122 msg_error_t MsgStoSetReadStatus(MsgDbHandler *pDbHandle, msg_message_id_t msgId, bool bRead)
124 char sqlQuery[MAX_QUERY_LEN+1];
126 memset(sqlQuery, 0x00, sizeof(sqlQuery));
127 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET READ_STATUS = %d WHERE MSG_ID = %d;",
128 MSGFW_MESSAGE_TABLE_NAME, (int)bRead, msgId);
130 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS)
131 return MSG_ERR_DB_EXEC;
133 /* Get MAIN_TYPE, SUB_TYPE, STORAGE_ID */
134 memset(sqlQuery, 0x00, sizeof(sqlQuery));
135 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.MAIN_TYPE, A.SUB_TYPE, B.CONV_ID \
136 FROM %s A, %s B WHERE A.MSG_ID = %d AND A.CONV_ID = B.CONV_ID;",
137 MSGFW_MESSAGE_TABLE_NAME, MSGFW_CONVERSATION_TABLE_NAME, msgId);
139 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
140 return MSG_ERR_DB_PREPARE;
142 MSG_MESSAGE_TYPE_S msgType;
143 msg_thread_id_t convId;
145 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
146 msgType.mainType = pDbHandle->columnInt(0);
147 msgType.subType = pDbHandle->columnInt(1);
148 convId = pDbHandle->columnInt(2);
150 pDbHandle->finalizeQuery();
151 return MSG_ERR_DB_STEP;
154 pDbHandle->finalizeQuery();
156 MSG_DEBUG("Main Type:[%d] SubType:[%d] ConvId:[%d]", msgType.mainType, msgType.subType, convId);
158 if (MsgStoUpdateConversation(pDbHandle, convId) != MSG_SUCCESS) {
159 MSG_DEBUG("MsgStoUpdateConversation() Error");
160 return MSG_ERR_STORAGE_ERROR;
167 msg_error_t MsgStoGetOldestMessage(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsgInfo, msg_message_id_t *pMsgId)
169 char sqlQuery[MAX_QUERY_LEN+1];
171 memset(sqlQuery, 0x00, sizeof(sqlQuery));
173 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s \
174 WHERE SUB_TYPE = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND PROTECTED = 0 \
175 ORDER BY DISPLAY_TIME ASC",
176 MSGFW_MESSAGE_TABLE_NAME, pMsgInfo->msgType.subType, pMsgInfo->folderId, MSG_STORAGE_PHONE);
178 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
179 return MSG_ERR_DB_PREPARE;
181 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
182 *pMsgId = pDbHandle->columnInt(0);
184 pDbHandle->finalizeQuery();
185 return MSG_ERR_DB_STEP;
188 pDbHandle->finalizeQuery();
194 msg_error_t MsgStoCheckMsgCntFull(MsgDbHandler *pDbHandle, const MSG_MESSAGE_TYPE_S* pMsgType, msg_folder_id_t folderId)
198 msg_error_t err = MSG_SUCCESS;
200 boost::system::error_code ec;
201 boost::filesystem::space_info si = boost::filesystem::space(TZ_SYS_HOME_PATH, ec);
202 long long int available = 0;
205 MSG_ERR("Failed to get space info [%s]", ec.message().c_str());
206 return MSG_ERR_STORAGE_ERROR;
208 if (si.capacity < CHECK_SIZE)
209 available = si.available - RESERVE_LITE;
211 available = si.available - RESERVE;
216 MSG_DEBUG("Free space of storage is [%llu] Bytes.", available);
218 if (available < SMS_MINIMUM_SPACE && pMsgType->mainType == MSG_SMS_TYPE)
219 err = MSG_ERR_MESSAGE_COUNT_FULL;
220 else if (available < MMS_MINIMUM_SPACE && pMsgType->mainType == MSG_MMS_TYPE)
221 err = MSG_ERR_MESSAGE_COUNT_FULL;
230 msg_error_t MsgStoCountMsgByLimitCategory(MsgDbHandler *pDbHandle, const MSG_MESSAGE_TYPE_S *pMsgType, int *pMsgCount, msg_folder_id_t folderId)
232 if (pMsgType == NULL) {
233 MSG_DEBUG("pMsgType is NULL");
234 return MSG_ERR_NULL_POINTER;
239 char sqlQuery[MAX_QUERY_LEN+1];
240 memset(sqlQuery, 0x00, sizeof(sqlQuery));
242 if ((pMsgType->mainType == MSG_SMS_TYPE) && (pMsgType->subType == MSG_WAP_SI_SMS ||pMsgType->subType == MSG_WAP_SL_SMS)) { /* PUSH */
243 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d, %d) AND FOLDER_ID = %d;",
244 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_WAP_SI_SMS, MSG_WAP_SL_SMS, MSG_INBOX_ID);
245 } else if ((pMsgType->mainType == MSG_SMS_TYPE) && (pMsgType->subType == MSG_CB_SMS)) { /* CB */
246 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d) AND FOLDER_ID = %d;",
247 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_CB_SMS, MSG_CBMSGBOX_ID);
248 } else if ((pMsgType->mainType == MSG_SMS_TYPE) && (pMsgType->subType == MSG_SYNCML_CP)) { /* Provision */
249 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d) AND FOLDER_ID = %d;",
250 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_SYNCML_CP, MSG_INBOX_ID);
251 } else if ((pMsgType->mainType == MSG_SMS_TYPE)) { /* SMS */
252 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;",
253 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 */
254 } else if ((pMsgType->mainType == MSG_MMS_TYPE) &&
255 (pMsgType->subType == MSG_SENDREQ_MMS || pMsgType->subType == MSG_SENDCONF_MMS || pMsgType->subType == MSG_RETRIEVE_AUTOCONF_MMS ||
256 pMsgType->subType == MSG_RETRIEVE_MANUALCONF_MMS || pMsgType->subType == MSG_NOTIFICATIONIND_MMS)) { /* MMS */
257 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;",
258 MSGFW_MESSAGE_TABLE_NAME, pMsgType->mainType, MSG_SENDREQ_MMS, MSG_SENDCONF_MMS, MSG_RETRIEVE_AUTOCONF_MMS, MSG_RETRIEVE_MANUALCONF_MMS, MSG_NOTIFICATIONIND_MMS, folderId);
260 return MSG_ERR_INVALID_PARAMETER;
263 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
264 return MSG_ERR_DB_PREPARE;
266 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
267 *pMsgCount = pDbHandle->columnInt(0);
269 pDbHandle->finalizeQuery();
270 return MSG_ERR_DB_STEP;
273 pDbHandle->finalizeQuery();
279 int MsgStoCheckMsgCntLimit(const MSG_MESSAGE_TYPE_S* pMsgType, msg_folder_id_t folderId)
286 msgboxType = MSG_COUNT_LIMIT_INBOX_TYPE;
290 msgboxType = MSG_COUNT_LIMIT_OUTBOX_TYPE;
293 case MSG_SENTBOX_ID :
294 msgboxType = MSG_COUNT_LIMIT_SENTBOX_TYPE;
298 msgboxType = MSG_COUNT_LIMIT_DRAFTBOX_TYPE;
301 case MSG_CBMSGBOX_ID :
302 msgboxType = MSG_COUNT_LIMIT_CBMSGBOX_TYPE;
306 MSG_DEBUG("Unknown mailbox Type [%d]", folderId);
310 switch (pMsgType->subType) {
312 case MSG_REPLACE_TYPE1_SMS:
313 case MSG_REPLACE_TYPE2_SMS:
314 case MSG_REPLACE_TYPE3_SMS:
315 case MSG_REPLACE_TYPE4_SMS:
316 case MSG_REPLACE_TYPE5_SMS:
317 case MSG_REPLACE_TYPE6_SMS:
318 case MSG_REPLACE_TYPE7_SMS:
319 case MSG_MWI_VOICE_SMS:
320 case MSG_MWI_FAX_SMS:
321 case MSG_MWI_EMAIL_SMS:
322 case MSG_MWI_OTHER_SMS:
323 case MSG_STATUS_REPORT_SMS:
324 msgType = MSG_COUNT_LIMIT_SMS_TYPE;
328 msgType = MSG_COUNT_LIMIT_CB_TYPE;
333 msgType = MSG_COUNT_LIMIT_WAPPUSH_TYPE;
337 msgType = MSG_COUNT_LIMIT_PROVISION_TYPE;
340 case MSG_SENDREQ_MMS:
341 case MSG_SENDCONF_MMS:
342 case MSG_NOTIFICATIONIND_MMS:
343 case MSG_RETRIEVE_AUTOCONF_MMS:
344 case MSG_RETRIEVE_MANUALCONF_MMS:
345 msgType = MSG_COUNT_LIMIT_MMS_TYPE;
349 MSG_DEBUG("Unknown Message Type [%d]", pMsgType->subType);
353 return msgCntLimit[msgboxType][msgType];
357 msg_error_t MsgStocheckMemoryStatus()
359 msg_error_t err = MSG_SUCCESS;
360 boost::system::error_code ec;
361 boost::filesystem::space_info si = boost::filesystem::space(TZ_SYS_HOME_PATH, ec);
362 long long int available = 0;
365 MSG_ERR("Failed to get space info [%s]", ec.message().c_str());
366 return MSG_ERR_STORAGE_ERROR;
369 if (si.capacity < CHECK_SIZE)
370 available = si.available - RESERVE_LITE;
372 available = si.available - RESERVE;
377 MSG_DEBUG("Free space of storage is [%llu] Bytes.", available);
379 if (available < SMS_MINIMUM_SPACE)
380 err = MSG_ERR_MESSAGE_COUNT_FULL;
382 MSG_DEBUG("Memory status =[%d]", err);
388 msg_error_t MsgStoAddAddress(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t *pConvId)
390 msg_error_t err = MSG_SUCCESS;
392 char sqlQuery[MAX_QUERY_LEN+1];
394 /* Check if new address or not */
395 if (MsgExistAddress(pDbHandle, pMsg, pConvId) == true) {
396 MSG_DEBUG("The address already exists. Conversation ID : [%d]", *pConvId);
397 MsgStoUpdateAddress(pDbHandle, pMsg, *pConvId);
402 *pConvId = pMsg->threadId;
404 /* conversation insert */
405 err = MsgStoAddConversation(pDbHandle, pConvId);
406 if (err != MSG_SUCCESS) {
407 MSG_DEBUG("MsgStoAddConversation() fail [%d]", err);
411 /* insert address in loop */
412 for (int i = 0; i < pMsg->nAddressCnt; i++) {
414 MSG_CONTACT_INFO_S contactInfo;
415 memset(&contactInfo, 0x00, sizeof(MSG_CONTACT_INFO_S));
417 /* Get Contact Info */
419 if (MsgGetContactInfo(&(pMsg->addressList[i]), &contactInfo) != MSG_SUCCESS) {
420 MSG_DEBUG("MsgGetContactInfo() fail.");
424 err = pDbHandle->getRowId(MSGFW_ADDRESS_TABLE_NAME, &addrId);
425 if (err != MSG_SUCCESS) {
426 MSG_DEBUG("pDbHandle->getRowId fail. [%d]", err);
431 memset(sqlQuery, 0x00, sizeof(sqlQuery));
432 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, %d, %d, %d, '%s', %d, %d, ?, ?, ?, ?, ?, '%s', 0);",
433 MSGFW_ADDRESS_TABLE_NAME, addrId, *pConvId, pMsg->addressList[i].addressType, pMsg->addressList[i].recipientType, pMsg->addressList[i].addressVal,
434 contactInfo.contactId, contactInfo.addrbookId, contactInfo.imagePath);
436 MSG_SEC_DEBUG("Add Address Info. [%s]", sqlQuery);
438 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
439 return MSG_ERR_DB_PREPARE;
441 pDbHandle->bindText(contactInfo.firstName, 1);
442 pDbHandle->bindText(contactInfo.lastName, 2);
443 pDbHandle->bindText(contactInfo.middleName, 3);
444 pDbHandle->bindText(contactInfo.prefix, 4);
445 pDbHandle->bindText(contactInfo.suffix, 5);
447 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
448 pDbHandle->finalizeQuery();
449 return MSG_ERR_DB_STEP;
452 pDbHandle->finalizeQuery();
456 /* set conversation display name by conv id */
457 MsgStoSetConversationDisplayName(pDbHandle, *pConvId);
462 msg_error_t MsgStoGetAddressByMsgId(MsgDbHandler *pDbHandle, msg_message_id_t msgId, int *nAddressCnt, MSG_ADDRESS_INFO_S **pAddress)
464 char sqlQuery[MAX_QUERY_LEN+1];
465 int rowCnt = 0, index = 0;
469 memset(sqlQuery, 0x00, sizeof(sqlQuery));
470 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
475 "WHERE A.CONV_ID = B.CONV_ID "
476 "AND B.MSG_ID = %d;",
477 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
480 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
482 if (err == MSG_ERR_DB_NORECORD) {
483 pDbHandle->freeTable();
485 } else if (err != MSG_SUCCESS) {
486 MSG_DEBUG("Fail to getTable().");
487 pDbHandle->freeTable();
491 *nAddressCnt = rowCnt;
493 MSG_DEBUG("*nAddressCnt [%d]", *nAddressCnt);
495 MSG_ADDRESS_INFO_S *tmpAddressList = (MSG_ADDRESS_INFO_S *)new char[sizeof(MSG_ADDRESS_INFO_S) * rowCnt];
496 memset(tmpAddressList, 0x00, sizeof(MSG_ADDRESS_INFO_S) * rowCnt);
497 *pAddress = tmpAddressList;
499 for (int i = 0; i < rowCnt; i++) {
500 tmpAddressList[i].addressType = pDbHandle->getColumnToInt(index++);
501 tmpAddressList[i].recipientType = pDbHandle->getColumnToInt(index++);
502 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, tmpAddressList[i].addressVal);
504 strncpy(tmpAddressList[i].displayName, tmpAddressList[i].addressVal, MAX_DISPLAY_NAME_LEN);
506 pDbHandle->freeTable();
511 msg_error_t MsgStoGetAddressByMsgId(MsgDbHandler *pDbHandle, msg_message_id_t msgId, msg_struct_list_s *pAddress)
513 char sqlQuery[MAX_QUERY_LEN+1];
515 int rowCnt = 0, index = 0;
517 pAddress->nCount = 0;
518 pAddress->msg_struct_info = NULL;
520 msg_struct_s *pTmp = NULL;
521 MSG_ADDRESS_INFO_S *pAddr = NULL;
523 pAddress->msg_struct_info = (msg_struct_t *)calloc(MAX_TO_ADDRESS_CNT, sizeof(msg_struct_t));
524 if (pAddress->msg_struct_info == NULL)
525 return MSG_ERR_MEMORY_ERROR;
527 for (int i = 0; i < MAX_TO_ADDRESS_CNT; i++) {
528 pAddress->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
529 pTmp = (msg_struct_s *)pAddress->msg_struct_info[i];
530 pTmp->type = MSG_STRUCT_ADDRESS_INFO;
531 pTmp->data = new MSG_ADDRESS_INFO_S;
532 memset(pTmp->data, 0x00, sizeof(MSG_ADDRESS_INFO_S));
535 memset(sqlQuery, 0x00, sizeof(sqlQuery));
536 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
541 "WHERE A.CONV_ID = B.CONV_ID "
542 "AND B.MSG_ID = %d;",
543 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
546 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
548 if (err == MSG_ERR_DB_NORECORD) {
549 pDbHandle->freeTable();
551 } else if (err != MSG_SUCCESS) {
552 MSG_DEBUG("Fail to getTable().");
553 pDbHandle->freeTable();
557 rowCnt = (rowCnt > 10)? MAX_TO_ADDRESS_CNT: rowCnt;
558 pAddress->nCount = rowCnt;
560 for (int i = 0; i < rowCnt; i++) {
561 pTmp = (msg_struct_s *)pAddress->msg_struct_info[i];
562 pAddr = (MSG_ADDRESS_INFO_S *)pTmp->data;
564 pAddr->addressType = pDbHandle->getColumnToInt(index++);
565 pAddr->recipientType = pDbHandle->getColumnToInt(index++);
567 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, pAddr->addressVal);
569 strncpy(pAddr->displayName, pAddr->addressVal, MAX_DISPLAY_NAME_LEN);
572 pDbHandle->freeTable();
578 msg_error_t MsgStoGetRecipientsByMsgId(MsgDbHandler *pDbHandle, msg_message_id_t msgId, int *nAddressCnt, MSG_ADDRESS_INFO_S **pAddress)
580 char sqlQuery[MAX_QUERY_LEN+1];
581 int rowCnt = 0, index = 0;
585 memset(sqlQuery, 0x00, sizeof(sqlQuery));
586 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT ADDRESS_TYPE, RECIPIENT_TYPE, ADDRESS_VAL FROM %s WHERE MSG_ID = %d;",
587 MSGFW_MMS_RECIPIENTS_TABLE_NAME, msgId);
589 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
591 if (err == MSG_ERR_DB_NORECORD) {
592 pDbHandle->freeTable();
594 } else if (err != MSG_SUCCESS) {
595 MSG_DEBUG("Fail to getTable().");
596 pDbHandle->freeTable();
600 *nAddressCnt = rowCnt;
602 MSG_DEBUG("*nAddressCnt [%d]", *nAddressCnt);
604 MSG_ADDRESS_INFO_S *tmpAddressList = (MSG_ADDRESS_INFO_S *)new char[sizeof(MSG_ADDRESS_INFO_S) * rowCnt];
605 memset(tmpAddressList, 0x00, sizeof(MSG_ADDRESS_INFO_S) * rowCnt);
606 *pAddress = tmpAddressList;
608 for (int i = 0; i < rowCnt; i++) {
609 tmpAddressList[i].addressType = pDbHandle->getColumnToInt(index++);
610 tmpAddressList[i].recipientType = pDbHandle->getColumnToInt(index++);
611 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, tmpAddressList[i].addressVal);
612 strncpy(tmpAddressList[i].displayName, tmpAddressList[i].addressVal, MAX_DISPLAY_NAME_LEN);
614 pDbHandle->freeTable();
620 msg_error_t MsgStoGetAddressByConvId(MsgDbHandler *pDbHandle, msg_thread_id_t convId, msg_struct_list_s *pAddrlist)
622 char sqlQuery[MAX_QUERY_LEN+1];
624 int rowCnt = 0, index = 0;
626 pAddrlist->nCount = 0;
627 pAddrlist->msg_struct_info = NULL;
629 memset(sqlQuery, 0x00, sizeof(sqlQuery));
630 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
634 "FROM %s WHERE CONV_ID = %d;",
635 MSGFW_ADDRESS_TABLE_NAME, convId);
637 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
639 if (err == MSG_ERR_DB_NORECORD) {
640 pDbHandle->freeTable();
642 } else if (err != MSG_SUCCESS) {
643 MSG_DEBUG("Fail to getTable().");
644 pDbHandle->freeTable();
648 pAddrlist->nCount = rowCnt;
650 MSG_DEBUG("pAddrlist->nCount [%d]", pAddrlist->nCount);
652 msg_struct_s *pTmp = NULL;
653 MSG_ADDRESS_INFO_S *pAddr = NULL;
655 pAddrlist->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
657 for (int i = 0; i < rowCnt; i++) {
658 pAddrlist->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
659 pTmp = (msg_struct_s *)pAddrlist->msg_struct_info[i];
660 pTmp->type = MSG_STRUCT_ADDRESS_INFO;
661 pTmp->data = new MSG_ADDRESS_INFO_S;
662 memset(pTmp->data, 0x00, sizeof(MSG_ADDRESS_INFO_S));
665 /* rowCnt = (rowCnt > 10)? MAX_TO_ADDRESS_CNT: rowCnt; */
667 for (int i = 0; i < rowCnt; i++) {
668 pTmp = (msg_struct_s *)pAddrlist->msg_struct_info[i];
669 pAddr = (MSG_ADDRESS_INFO_S *)pTmp->data;
671 pAddr->addressType = pDbHandle->getColumnToInt(index++);
672 pAddr->recipientType = pDbHandle->getColumnToInt(index++);
673 pDbHandle->getColumnToString(index++, MAX_ADDRESS_VAL_LEN, pAddr->addressVal);
675 strncpy(pAddr->displayName, pAddr->addressVal, MAX_DISPLAY_NAME_LEN);
677 pDbHandle->freeTable();
682 /* Have to use trigger for this function. */
683 msg_error_t MsgStoUpdateConversation(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
687 char sqlQuery[MAX_QUERY_LEN];
688 unsigned int tmpSize = 0;
690 #ifdef MSG_NOTI_INTEGRATION
691 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
692 snprintf(sqlQuery, sizeof(sqlQuery),
695 "WHERE CONV_ID = %d "
696 "AND FOLDER_ID > %d AND FOLDER_ID < %d "
697 "AND STORAGE_ID = %d;",
698 MSGFW_MESSAGE_TABLE_NAME,
700 MSG_ALLBOX_ID, MSG_SPAMBOX_ID,
703 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
704 snprintf(sqlQuery, sizeof(sqlQuery),
707 "WHERE CONV_ID = %d "
708 "AND FOLDER_ID > %d AND FOLDER_ID < %d "
709 "AND STORAGE_ID = %d;",
710 MSGFW_MESSAGE_TABLE_NAME,
712 MSG_ALLBOX_ID, MSG_CBMSGBOX_ID,
716 msg_error_t err = pDbHandle->prepareQuery(sqlQuery);
717 if (err != MSG_SUCCESS) {
718 MSG_DEBUG("Fail to prepareQuery().");
719 pDbHandle->finalizeQuery();
723 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
724 pDbHandle->finalizeQuery();
726 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
727 snprintf(sqlQuery, sizeof(sqlQuery),
728 "SELECT MAIN_TYPE, SUB_TYPE, MSG_DIRECTION, MSG_ID, DISPLAY_TIME, LENGTH(SUBJECT), SUBJECT, MSG_TEXT, DPM_RESTRICTED "
730 "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;",
731 MSGFW_MESSAGE_TABLE_NAME,
732 convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
734 err = pDbHandle->prepareQuery(sqlQuery);
735 if (err != MSG_SUCCESS) {
736 MSG_DEBUG("Fail to prepareQuery().");
740 err = pDbHandle->stepQuery();
741 if (err != MSG_ERR_DB_ROW) {
742 MSG_DEBUG("Fail to stepQuery().");
743 pDbHandle->finalizeQuery();
747 int main_type = pDbHandle->columnInt(0);
748 int sub_type = pDbHandle->columnInt(1);
749 int msg_direction = pDbHandle->columnInt(2);
750 int last_msg_id = pDbHandle->columnInt(3);
751 time_t disp_time = (time_t)pDbHandle->columnInt(4);
752 int subject_length = pDbHandle->columnInt(5);
753 bool dpm_restricted = pDbHandle->columnInt(8);
754 char subject[MAX_SUBJECT_LEN+1] = {0, };
755 char msg_text[MAX_MSG_TEXT_LEN+1] = {0, };
756 if (!dpm_restricted) {
757 snprintf(subject, sizeof(subject), "%s", pDbHandle->columnText(6));
758 snprintf(msg_text, sizeof(msg_text), "%s", pDbHandle->columnText(7));
760 snprintf(subject, sizeof(subject), "restricted message");
761 snprintf(msg_text, sizeof(msg_text), "restricted message");
764 pDbHandle->finalizeQuery();
765 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
766 snprintf(sqlQuery, sizeof(sqlQuery),
768 MSGFW_CONVERSATION_TABLE_NAME);
770 tmpSize = strlen(sqlQuery);
771 #ifdef MSG_NOTI_INTEGRATION
772 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
773 "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), ",
774 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
776 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
777 "UNREAD_CNT = (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND READ_STATUS = 0), ",
778 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_STORAGE_PHONE);
781 tmpSize = strlen(sqlQuery);
782 #ifdef MSG_NOTI_INTEGRATION
783 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
784 "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), ",
785 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_SMS_TYPE, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
787 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
788 "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), ",
789 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_SMS_TYPE, MSG_ALLBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
792 tmpSize = strlen(sqlQuery);
793 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
794 "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), ",
795 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);
798 tmpSize = strlen(sqlQuery);
799 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
800 "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), ",
801 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
803 tmpSize = strlen(sqlQuery);
804 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
805 "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), ",
806 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
808 tmpSize = strlen(sqlQuery);
809 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
810 "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), ",
811 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
813 tmpSize = strlen(sqlQuery);
815 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
816 "DISPLAY_TIME = CASE "
817 "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 "
818 "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) "
821 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
822 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
824 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
825 "DISPLAY_TIME = CASE "
826 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND READ_STATUS = 0) > 0 "
827 "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) "
828 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d) > 0 "
829 "THEN (SELECT DISPLAY_TIME FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d ORDER BY DISPLAY_TIME DESC) "
830 "WHEN (SELECT COUNT(MSG_ID) FROM %s WHERE CONV_ID = %d AND FOLDER_ID = %d AND STORAGE_ID = %d AND NETWORK_STATUS = %d) > 0 "
831 "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) "
832 "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) "
834 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_STORAGE_PHONE,
835 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_INBOX_ID, MSG_STORAGE_PHONE,
836 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_DRAFT_ID, MSG_STORAGE_PHONE,
837 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_DRAFT_ID, MSG_STORAGE_PHONE,
838 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_OUTBOX_ID, MSG_STORAGE_PHONE, MSG_NETWORK_SEND_FAIL,
839 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_OUTBOX_ID, MSG_STORAGE_PHONE, MSG_NETWORK_SEND_FAIL,
840 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
844 tmpSize = strlen(sqlQuery);
845 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
847 "WHEN %d > 0 THEN ? ELSE ? "
851 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
853 "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 "
855 "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 "
856 "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) "
857 "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) "
860 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
861 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
862 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE,
863 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
865 tmpSize = strlen(sqlQuery);
866 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
867 "MAIN_TYPE = %d, SUB_TYPE = %d, MSG_DIRECTION = %d, DISPLAY_TIME = %lu, LAST_MSG_ID = %d ",
868 main_type, sub_type, msg_direction, disp_time, last_msg_id);
870 tmpSize = strlen(sqlQuery);
871 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
872 "WHERE CONV_ID = %d;",
874 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
875 MSG_DEBUG("Query Failed [%s]", sqlQuery);
876 return MSG_ERR_DB_PREPARE;
879 pDbHandle->bindText(subject, 1);
880 pDbHandle->bindText(msg_text, 2);
882 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
883 MSG_DEBUG("stepQuery() Failed");
884 pDbHandle->finalizeQuery();
885 return MSG_ERR_DB_STEP;
888 pDbHandle->finalizeQuery();
890 pDbHandle->finalizeQuery();
892 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
893 snprintf(sqlQuery, sizeof(sqlQuery),
894 "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 = '' "
895 "WHERE CONV_ID = %d;",
896 MSGFW_CONVERSATION_TABLE_NAME, convId);
898 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
899 MSG_DEBUG("Query Failed [%s]", sqlQuery);
900 return MSG_ERR_DB_EXEC;
910 /* consider to replcae this function to trigger. */
911 msg_error_t MsgStoClearConversationTable(MsgDbHandler *pDbHandle)
913 msg_error_t err = MSG_SUCCESS;
915 char sqlQuery[MAX_QUERY_LEN+1];
917 memset(sqlQuery, 0x00, sizeof(sqlQuery));
919 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s "
920 "WHERE CONV_ID NOT IN (SELECT CONV_ID FROM %s) AND CONV_ID <> 0;",
921 MSGFW_CONVERSATION_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME);
923 err = pDbHandle->execQuery(sqlQuery);
925 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s WHERE CONV_ID NOT IN (SELECT CONV_ID FROM %s);",
926 MSGFW_ADDRESS_TABLE_NAME, MSGFW_CONVERSATION_TABLE_NAME);
928 err = pDbHandle->execQuery(sqlQuery);
934 msg_thread_id_t MsgGetThreadId(MsgDbHandler *pDbHandle, msg_message_id_t msgId)
936 msg_thread_id_t conv_id = 0;
938 char sqlQuery[MAX_QUERY_LEN+1];
939 memset(sqlQuery, 0x00, sizeof(sqlQuery));
940 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CONV_ID FROM %s WHERE MSG_ID = %d;",
941 MSGFW_MESSAGE_TABLE_NAME, msgId);
943 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
946 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
947 conv_id = pDbHandle->columnInt(0);
950 pDbHandle->finalizeQuery();
955 /* Change the function name to conversation related. */
956 bool MsgExistAddress(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t *pConvId)
958 msg_error_t err = MSG_SUCCESS;
960 char sqlQuery[MAX_QUERY_LEN+1];
961 unsigned int tmpSize = 0;
965 memset(sqlQuery, 0x00, sizeof(sqlQuery));
966 snprintf(sqlQuery, sizeof(sqlQuery),
967 "SELECT CONV_ID FROM ( SELECT CONV_ID FROM %s WHERE ( ",
968 MSGFW_ADDRESS_TABLE_NAME);
970 for (int i = 0; i < pMsg->nAddressCnt; i++) {
971 if (strlen(pMsg->addressList[i].addressVal) >= (unsigned int)MsgContactGetMinMatchDigit()
972 && pMsg->addressList[i].addressType != MSG_ADDRESS_TYPE_EMAIL
973 && MsgIsNumber(pMsg->addressList[i].addressVal)) {
974 int addrSize = strlen(pMsg->addressList[i].addressVal);
975 char newPhoneNum[addrSize+1];
976 memset(newPhoneNum, 0x00, sizeof(newPhoneNum));
977 MsgConvertNumber(pMsg->addressList[i].addressVal, newPhoneNum, addrSize);
979 tmpSize = strlen(sqlQuery);
980 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
981 "ADDRESS_VAL LIKE '%%%%%s' ",
984 if ((pMsg->nAddressCnt-1) == i) break;
986 tmpSize = strlen(sqlQuery);
987 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize, " OR ");
990 tmpSize = strlen(sqlQuery);
991 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
992 "ADDRESS_VAL LIKE '%s' ",
993 pMsg->addressList[i].addressVal);
995 if ((pMsg->nAddressCnt-1) == i) break;
997 tmpSize = strlen(sqlQuery);
998 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize, " OR ");
1002 tmpSize = strlen(sqlQuery);
1003 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
1004 ") AND CONV_ID IN (SELECT CONV_ID FROM %s GROUP BY CONV_ID HAVING COUNT(CONV_ID)=%d) ",
1005 MSGFW_ADDRESS_TABLE_NAME, pMsg->nAddressCnt);
1008 tmpSize = strlen(sqlQuery);
1009 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
1010 ") GROUP BY CONV_ID HAVING COUNT(CONV_ID)=%d;",
1016 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1018 /* No record or other error */
1019 if (err != MSG_SUCCESS) {
1020 MSG_DEBUG("Fail to getTable().");
1021 pDbHandle->freeTable();
1025 convId = pDbHandle->getColumnToInt(1);
1028 MSG_DEBUG("Success to get convId [%d]", convId);
1030 pDbHandle->freeTable();
1034 pDbHandle->freeTable();
1040 int MsgStoGetUnreadCnt(MsgDbHandler *pDbHandle, MSG_MAIN_TYPE_T msgType)
1044 char sqlQuery[MAX_QUERY_LEN+1];
1046 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1048 if (msgType == MSG_SMS_TYPE) {
1049 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s "
1050 "WHERE MAIN_TYPE = %d "
1051 "AND (SUB_TYPE IN (%d, %d, %d, %d, %d, %d, %d) OR (SUB_TYPE >= %d AND SUB_TYPE <= %d)) "
1052 "AND FOLDER_ID = %d AND READ_STATUS = 0 AND STORAGE_ID = %d;",
1053 MSGFW_MESSAGE_TABLE_NAME,
1055 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,
1056 MSG_REPLACE_TYPE1_SMS, MSG_REPLACE_TYPE7_SMS,
1057 MSG_INBOX_ID, MSG_STORAGE_PHONE);
1058 } else if (msgType == MSG_MMS_TYPE) {
1059 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(MSG_ID) FROM %s "
1060 "WHERE MAIN_TYPE = %d AND SUB_TYPE IN (%d, %d, %d) "
1061 "AND FOLDER_ID = %d AND READ_STATUS = 0 AND STORAGE_ID = %d;",
1062 MSGFW_MESSAGE_TABLE_NAME,
1064 MSG_RETRIEVE_AUTOCONF_MMS, MSG_RETRIEVE_MANUALCONF_MMS, MSG_NOTIFICATIONIND_MMS,
1065 MSG_INBOX_ID, MSG_STORAGE_PHONE);
1068 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
1071 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
1072 msgCnt = pDbHandle->columnInt(0);
1074 pDbHandle->finalizeQuery();
1078 pDbHandle->finalizeQuery();
1084 msg_error_t MsgStoGetMmsRawFilePath(MsgDbHandler *pDbHandle, msg_message_id_t msgId, char *pFilePath)
1086 char sqlQuery[MAX_QUERY_LEN+1];
1088 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1090 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.FILE_PATH FROM %s A, %s B \
1091 WHERE A.MSG_ID = B.MSG_ID AND B.MSG_ID = %d;",
1092 MMS_PLUGIN_MESSAGE_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME, msgId);
1094 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
1095 return MSG_ERR_DB_PREPARE;
1097 if (pDbHandle->stepQuery() == MSG_ERR_DB_ROW) {
1098 if (pDbHandle->columnText(0) != NULL)
1099 strncpy(pFilePath, (char*)pDbHandle->columnText(0), MSG_FILEPATH_LEN_MAX);
1101 pDbHandle->finalizeQuery();
1102 return MSG_ERR_DB_STEP;
1105 pDbHandle->finalizeQuery();
1111 bool MsgStoCheckReadReportRequested(MsgDbHandler *pDbHandle, msg_message_id_t msgId)
1113 msg_error_t err = MSG_SUCCESS;
1115 char sqlQuery[MAX_QUERY_LEN+1];
1117 bool bReadReportRequested = false;
1119 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1121 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.ASK_READ_REPLY FROM %s A, %s B \
1122 WHERE A.MSG_ID = B.MSG_ID AND B.MSG_ID = %d;",
1123 MMS_PLUGIN_MESSAGE_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME, msgId);
1125 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1127 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
1128 pDbHandle->freeTable();
1129 MSG_DEBUG("[Error]Failed to Get Table");
1130 return bReadReportRequested;
1134 pDbHandle->freeTable();
1135 MSG_DEBUG("[Error]MSG_ERR_DB_NORECORD");
1136 return bReadReportRequested;
1139 bReadReportRequested = pDbHandle->getColumnToInt(1);
1141 pDbHandle->freeTable();
1143 return bReadReportRequested;
1147 bool MsgStoCheckReadReportIsSent(MsgDbHandler *pDbHandle, msg_message_id_t msgId)
1149 msg_error_t err = MSG_SUCCESS;
1151 char sqlQuery[MAX_QUERY_LEN+1];
1154 bool bReadReportIsSent = true;
1156 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1158 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.READ_REPORT_SENT FROM %s A, %s B \
1159 WHERE A.MSG_ID = B.MSG_ID AND B.MSG_ID = %d;",
1160 MMS_PLUGIN_MESSAGE_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME, msgId);
1162 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1164 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
1165 pDbHandle->freeTable();
1166 MSG_DEBUG("[Error]Failed to Get Table");
1167 return bReadReportIsSent;
1171 pDbHandle->freeTable();
1172 MSG_DEBUG("[Error]MSG_ERR_DB_NORECORD");
1173 return bReadReportIsSent;
1176 bReadReportIsSent = (bool)pDbHandle->getColumnToInt(1);
1178 pDbHandle->freeTable();
1180 return bReadReportIsSent;
1184 msg_error_t MsgStoAddConversation(MsgDbHandler *pDbHandle, msg_thread_id_t *pConvId)
1186 char sqlQuery[MAX_QUERY_LEN+1];
1189 if (pDbHandle->getRowId(MSGFW_CONVERSATION_TABLE_NAME, pConvId) != MSG_SUCCESS) {
1190 return MSG_ERR_DB_EXEC;
1193 /* Add Conversation */
1194 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1195 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, 0, 0, 0, 0, 0, 0, 0, '', '', 0);",
1196 MSGFW_CONVERSATION_TABLE_NAME, *pConvId);
1198 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1199 MSG_DEBUG("Query Failed. [%s]", sqlQuery);
1200 return MSG_ERR_DB_EXEC;
1207 msg_error_t MsgStoSetConversationDisplayName(MsgDbHandler *pDbHandle, int contactId)
1209 msg_error_t err = MSG_SUCCESS;
1211 char displayName[MAX_DISPLAY_NAME_LEN+1];
1212 char sqlQuery[MAX_QUERY_LEN+1];
1214 MSG_DEBUG("contactId [%d]", contactId);
1216 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1217 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT DISTINCT(CONV_ID) FROM %s WHERE CONTACT_ID = %d;",
1218 MSGFW_ADDRESS_TABLE_NAME, contactId);
1220 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1222 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
1223 pDbHandle->freeTable();
1224 MSG_DEBUG("Fail to getTable().");
1228 msg_struct_s *pAddrInfo = NULL;
1229 MSG_ADDRESS_INFO_S *address = NULL;
1231 for (int i = 1; i <= rowCnt; i++) {
1232 memset(displayName, 0x00, sizeof(displayName));
1233 MsgDbHandler tmpDbHandle;
1234 msg_struct_list_s addressList = {0, };
1235 MsgStoGetAddressByConvId(&tmpDbHandle, (msg_thread_id_t)pDbHandle->getColumnToInt(i), &addressList);
1237 for (int j = 0; j < addressList.nCount; j++) {
1239 strncat(displayName, ", ", MAX_DISPLAY_NAME_LEN-strlen(displayName));
1241 pAddrInfo = (msg_struct_s *)addressList.msg_struct_info[j];
1242 address = (MSG_ADDRESS_INFO_S *)pAddrInfo->data;
1244 if (address->displayName[0] == '\0')
1245 strncat(displayName, address->addressVal, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1247 strncat(displayName, address->displayName, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1250 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1251 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET DISPLAY_NAME = ? WHERE CONV_ID = %d;",
1252 MSGFW_CONVERSATION_TABLE_NAME, pDbHandle->getColumnToInt(i));
1254 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
1255 pDbHandle->freeTable();
1256 MSG_DEBUG("Query Failed [%s]", sqlQuery);
1257 return MSG_ERR_DB_PREPARE;
1260 pDbHandle->bindText(displayName, 1);
1262 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
1263 pDbHandle->freeTable();
1264 pDbHandle->finalizeQuery();
1265 MSG_SEC_DEBUG("Update Conversation disply name. Fail [%s]", sqlQuery);
1266 return MSG_ERR_DB_STEP;
1269 pDbHandle->finalizeQuery();
1271 /* free address list */
1272 for (int j = 0; j < addressList.nCount; j++) {
1273 msg_struct_s *pStruct = (msg_struct_s *)addressList.msg_struct_info[j];
1274 delete (MSG_ADDRESS_INFO_S *)pStruct->data;
1275 delete (msg_struct_s *)pStruct;
1278 if (addressList.msg_struct_info != NULL) {
1279 g_free((msg_struct_t *)addressList.msg_struct_info);
1283 pDbHandle->freeTable();
1289 msg_error_t MsgStoSetConversationDisplayName(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
1291 msg_error_t err = MSG_SUCCESS;
1293 char displayName[MAX_DISPLAY_NAME_LEN+1];
1294 char sqlQuery[MAX_QUERY_LEN+1];
1296 msg_struct_list_s addressList = {0, };
1298 msg_struct_s *pAddrInfo = NULL;
1299 MSG_ADDRESS_INFO_S *address = NULL;
1301 memset(displayName, 0x00, sizeof(displayName));
1303 MsgStoGetAddressByConvId(pDbHandle, convId, &addressList);
1305 for (int j = 0; j < addressList.nCount; j++) {
1307 strncat(displayName, ", ", MAX_DISPLAY_NAME_LEN-strlen(displayName));
1309 pAddrInfo = (msg_struct_s *)addressList.msg_struct_info[j];
1310 address = (MSG_ADDRESS_INFO_S *)pAddrInfo->data;
1312 if (address->displayName[0] == '\0')
1313 strncat(displayName, address->addressVal, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1315 strncat(displayName, address->displayName, MAX_DISPLAY_NAME_LEN-strlen(displayName));
1318 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1319 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET DISPLAY_NAME = ? WHERE CONV_ID = %d;",
1320 MSGFW_CONVERSATION_TABLE_NAME, convId);
1322 for (int j = 0; j < addressList.nCount; j++) {
1323 msg_struct_s *pStruct = (msg_struct_s *)addressList.msg_struct_info[j];
1324 delete (MSG_ADDRESS_INFO_S *)pStruct->data;
1325 delete (msg_struct_s *)pStruct;
1328 if (addressList.msg_struct_info != NULL) {
1329 g_free((msg_struct_t *)addressList.msg_struct_info);
1332 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
1333 MSG_DEBUG("Query Failed [%s]", sqlQuery);
1334 return MSG_ERR_DB_PREPARE;
1337 pDbHandle->bindText(displayName, 1);
1339 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
1340 pDbHandle->finalizeQuery();
1341 MSG_SEC_DEBUG("Update Conversation disply name. Fail [%s]", sqlQuery);
1342 return MSG_ERR_DB_STEP;
1345 pDbHandle->finalizeQuery();
1350 msg_error_t MsgStoUpdateNetworkStatus(MsgDbHandler *pDbHandle, MSG_MESSAGE_INFO_S *pMsgInfo, msg_network_status_t status)
1352 msg_error_t err = MSG_SUCCESS;
1354 char sqlQuery[MAX_QUERY_LEN+1];
1356 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1358 snprintf(sqlQuery, sizeof(sqlQuery), "UPDATE %s SET NETWORK_STATUS = %d WHERE MSG_ID = %d;",
1359 MSGFW_MESSAGE_TABLE_NAME, status, pMsgInfo->msgId);
1361 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS)
1362 err = MSG_ERR_DB_EXEC;
1364 pDbHandle->finalizeQuery();
1369 bool MsgExistConversation(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
1371 msg_error_t err = MSG_SUCCESS;
1373 char sqlQuery[MAX_QUERY_LEN+1];
1377 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1379 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CONV_ID FROM %s WHERE CONV_ID = %d;",
1380 MSGFW_CONVERSATION_TABLE_NAME, convId);
1382 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1384 if (err == MSG_ERR_DB_NORECORD) {
1385 pDbHandle->freeTable();
1387 } else if (err != MSG_SUCCESS) {
1388 pDbHandle->freeTable();
1391 pDbHandle->freeTable();
1396 bool MsgExistInThreadViewList(MsgDbHandler *pDbHandle, msg_thread_id_t convId)
1398 msg_error_t err = MSG_SUCCESS;
1400 char sqlQuery[MAX_QUERY_LEN+1];
1404 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1406 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s WHERE CONV_ID = %d AND FOLDER_ID > %d AND FOLDER_ID < %d AND STORAGE_ID = %d;",
1407 MSGFW_MESSAGE_TABLE_NAME, convId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
1409 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1411 if (err == MSG_ERR_DB_NORECORD) {
1412 pDbHandle->freeTable();
1414 } else if (err != MSG_SUCCESS) {
1415 pDbHandle->freeTable();
1418 pDbHandle->freeTable();
1423 bool MsgExistMessage(MsgDbHandler *pDbHandle, MSG_MESSAGE_INFO_S *pMsg)
1425 msg_error_t err = MSG_SUCCESS;
1427 char sqlQuery[MAX_QUERY_LEN+1];
1432 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1434 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s WHERE CONV_ID = %ud AND DISPLAY_TIME = %ud;",
1435 MSGFW_MESSAGE_TABLE_NAME, pMsg->threadId, (int)pMsg->displayTime);
1437 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1440 if (err != MSG_SUCCESS) {
1441 pDbHandle->freeTable();
1446 pMsg->msgId = pDbHandle->getColumnToInt(1);
1448 pDbHandle->freeTable();
1454 bool MsgExistAddress(MsgDbHandler *pDbHandle, MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t convId, int index)
1456 msg_error_t err = MSG_SUCCESS;
1458 char sqlQuery[MAX_QUERY_LEN+1];
1463 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1465 if (strlen(pMsg->addressList[index].addressVal) > (unsigned int)MsgContactGetMinMatchDigit()) {
1466 int addrSize = strlen(pMsg->addressList[index].addressVal);
1467 char newPhoneNum[addrSize+1];
1468 memset(newPhoneNum, 0x00, sizeof(newPhoneNum));
1469 MsgConvertNumber(pMsg->addressList[index].addressVal, newPhoneNum, addrSize);
1471 snprintf(sqlQuery, sizeof(sqlQuery),
1472 "SELECT ADDRESS_ID FROM %s WHERE ADDRESS_VAL LIKE '%%%%%s' AND CONV_ID= %d;",
1473 MSGFW_ADDRESS_TABLE_NAME, newPhoneNum, convId);
1475 snprintf(sqlQuery, sizeof(sqlQuery),
1476 "SELECT ADDRESS_ID FROM %s WHERE ADDRESS_VAL = '%s' AND CONV_ID= %d;",
1477 MSGFW_ADDRESS_TABLE_NAME, pMsg->addressList[index].addressVal, convId);
1480 err = pDbHandle->getTable(sqlQuery, &rowCnt, NULL);
1482 if (err == MSG_ERR_DB_NORECORD) {
1483 pDbHandle->freeTable();
1485 } else if (err != MSG_SUCCESS) {
1486 pDbHandle->freeTable();
1489 pDbHandle->freeTable();
1495 void MsgStoUpdateAddress(MsgDbHandler *pDbHandle, const MSG_MESSAGE_INFO_S *pMsg, msg_thread_id_t convId)
1498 msg_error_t err = MSG_SUCCESS;
1500 char sqlQuery[MAX_QUERY_LEN+1];
1502 for (int i = 0; i < pMsg->nAddressCnt; i++) {
1503 if (strlen(pMsg->addressList[i].addressVal) > (unsigned int)MsgContactGetMinMatchDigit() && pMsg->addressList[i].addressType == MSG_ADDRESS_TYPE_PLMN) {
1504 int addrSize = strlen(pMsg->addressList[i].addressVal);
1505 char newPhoneNum[addrSize+1];
1506 memset(newPhoneNum, 0x00, sizeof(newPhoneNum));
1507 MsgConvertNumber(pMsg->addressList[i].addressVal, newPhoneNum, addrSize);
1509 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1510 snprintf(sqlQuery, sizeof(sqlQuery),
1512 "ADDRESS_VAL = '%s', "
1513 "ADDRESS_TYPE = %d, "
1514 "RECIPIENT_TYPE = %d "
1515 "WHERE CONV_ID = %d "
1516 "AND ADDRESS_VAL LIKE '%%%%%s';",
1517 MSGFW_ADDRESS_TABLE_NAME, pMsg->addressList[i].addressVal,
1518 pMsg->addressList[i].addressType, pMsg->addressList[i].recipientType, convId, newPhoneNum);
1520 err = pDbHandle->execQuery(sqlQuery);
1521 if (err != MSG_SUCCESS) MSG_DEBUG("Fail to execQuery(). [%s]", sqlQuery);
1523 pDbHandle->finalizeQuery();
1530 msg_error_t MsgStoAddCBChannelInfo(MsgDbHandler *pDbHandle, MSG_CB_CHANNEL_S *pCBChannel, msg_sim_slot_id_t simIndex)
1534 char sqlQuery[MAX_QUERY_LEN] = {0, };
1536 pDbHandle->beginTrans();
1538 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1539 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s WHERE SIM_INDEX = %d;", MSGFW_CB_CHANNEL_INFO_TABLE_NAME, simIndex);
1541 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1542 pDbHandle->endTrans(false);
1543 return MSG_ERR_DB_EXEC;
1546 for (int i = 0; i < pCBChannel->channelCnt; i++) {
1548 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1549 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s(CHANNEL_ACTIVATION, CHANNEL_FROM, CHANNEL_TO, CHANNEL_NAME, SIM_INDEX) VALUES (?, ?, ?, ?, ?);",
1550 MSGFW_CB_CHANNEL_INFO_TABLE_NAME);
1552 if (pDbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
1553 pDbHandle->endTrans(false);
1554 return MSG_ERR_DB_PREPARE;
1556 pDbHandle->bindInt(pCBChannel->channelInfo[i].bActivate, index++);
1557 pDbHandle->bindInt(pCBChannel->channelInfo[i].from, index++);
1558 pDbHandle->bindInt(pCBChannel->channelInfo[i].to, index++);
1559 pDbHandle->bindText(pCBChannel->channelInfo[i].name, index++);
1560 pDbHandle->bindInt(simIndex, index++);
1562 if (pDbHandle->stepQuery() != MSG_ERR_DB_DONE) {
1563 pDbHandle->finalizeQuery();
1564 pDbHandle->endTrans(false);
1565 return MSG_ERR_DB_STEP;
1568 pDbHandle->finalizeQuery();
1571 pDbHandle->endTrans(true);
1579 msg_error_t MsgStoGetCBChannelInfo(MsgDbHandler *pDbHandle, MSG_CB_CHANNEL_S *pCBChannel, msg_sim_slot_id_t simIndex)
1583 int rowCnt = 0, index = 0;
1585 char sqlQuery[MAX_QUERY_LEN] = {0, };
1587 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1588 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);
1590 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1592 pCBChannel->channelCnt = rowCnt;
1594 if (err == MSG_ERR_DB_NORECORD) {
1595 pDbHandle->freeTable();
1596 return MSG_ERR_DB_NORECORD;
1597 } else if (err != MSG_SUCCESS) {
1598 MSG_DEBUG("Fail to getTable().");
1599 pDbHandle->freeTable();
1600 return MSG_ERR_DB_GETTABLE;
1603 for (int i = 0; i < rowCnt; i++) {
1604 pCBChannel->channelInfo[i].bActivate = pDbHandle->getColumnToInt(index++);
1605 pCBChannel->channelInfo[i].from = pDbHandle->getColumnToInt(index++);
1606 pCBChannel->channelInfo[i].to = pDbHandle->getColumnToInt(index++);
1607 pDbHandle->getColumnToString(index++, CB_CHANNEL_NAME_MAX, pCBChannel->channelInfo[i].name);
1609 MSG_DEBUG("CH_ACT = %d", pCBChannel->channelInfo[i].bActivate);
1610 MSG_DEBUG("CH_FROM = %d", pCBChannel->channelInfo[i].from);
1611 MSG_DEBUG("CH_TO = %d", pCBChannel->channelInfo[i].to);
1612 MSG_DEBUG("CH_NAME = %s", pCBChannel->channelInfo[i].name);
1615 pDbHandle->freeTable();
1623 msg_error_t MsgStoAddCBChannelInfo(MsgDbHandler *pDbHandle, MSG_CB_CHANNEL_S *pCBChannel)
1627 char sqlQuery[MAX_QUERY_LEN] = {0,};
1629 pDbHandle->beginTrans();
1631 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1632 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s;", MSGFW_CDMA_CB_CHANNEL_INFO_TABLE_NAME);
1634 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1635 pDbHandle->endTrans(false);
1636 return MSG_ERR_DB_EXEC;
1639 for (int i = 0; i < pCBChannel->channelCnt; i++) {
1640 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1641 snprintf(sqlQuery, sizeof(sqlQuery), "INSERT INTO %s VALUES (%d, %d, %d, %d, '%s');", MSGFW_CDMA_CB_CHANNEL_INFO_TABLE_NAME,
1642 i, pCBChannel->channelInfo[i].bActivate, pCBChannel->channelInfo[i].ctg,
1643 pCBChannel->channelInfo[i].lang, pCBChannel->channelInfo[i].name);
1645 if (pDbHandle->execQuery(sqlQuery) != MSG_SUCCESS) {
1646 pDbHandle->endTrans(false);
1647 return MSG_ERR_DB_EXEC;
1651 pDbHandle->endTrans(true);
1659 msg_error_t MsgStoGetCBChannelInfo(MsgDbHandler *pDbHandle, MSG_CB_CHANNEL_S *pCBChannel)
1663 int rowCnt = 0, index = 0;
1665 char sqlQuery[MAX_QUERY_LEN] = {0, };
1667 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1668 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT CHANNEL_ACTIVATION, CHANNEL_CATEGORY, CHANNEL_LANGUAGE, CHANNEL_NAME FROM %s;", MSGFW_CDMA_CB_CHANNEL_INFO_TABLE_NAME);
1670 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1672 pCBChannel->channelCnt = rowCnt;
1674 if (err == MSG_ERR_DB_NORECORD) {
1675 pDbHandle->freeTable();
1676 return MSG_ERR_DB_NORECORD;
1677 } else if (err != MSG_SUCCESS) {
1678 MSG_ERR("Fail to getTable().");
1679 pDbHandle->freeTable();
1680 return MSG_ERR_DB_GETTABLE;
1683 for (int i = 0; i < rowCnt; i++) {
1684 pCBChannel->channelInfo[i].bActivate = pDbHandle->getColumnToInt(index++);
1685 pCBChannel->channelInfo[i].ctg = pDbHandle->getColumnToInt(index++);
1686 pCBChannel->channelInfo[i].lang = pDbHandle->getColumnToInt(index++);
1687 pDbHandle->getColumnToString(index++, CB_CHANNEL_NAME_MAX, pCBChannel->channelInfo[i].name);
1689 MSG_DEBUG("CH_ACT: [%d], CH_CTG: [%d], CH_LANG: [%d], CH_NAME: [%s]",
1690 pCBChannel->channelInfo[i].bActivate, pCBChannel->channelInfo[i].ctg, pCBChannel->channelInfo[i].lang, pCBChannel->channelInfo[i].name);
1693 pDbHandle->freeTable();
1702 msg_error_t MsgStoGetThreadViewList(const MSG_SORT_RULE_S *pSortRule, msg_struct_list_s *pThreadViewList)
1704 MsgDbHandler *dbHandle = getDbHandle();
1705 dbHandle->connectReadOnly();
1707 pThreadViewList->nCount = 0;
1708 pThreadViewList->msg_struct_info = NULL;
1710 int rowCnt = 0, index = 0;
1712 char sqlQuery[MAX_QUERY_LEN+1];
1713 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1715 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT A.CONV_ID, A.UNREAD_CNT, A.SMS_CNT, A.MMS_CNT, A.MAIN_TYPE, A.SUB_TYPE, "
1716 "A.MSG_DIRECTION, A.DISPLAY_TIME, A.DISPLAY_NAME, A.MSG_TEXT, "
1717 "(COUNT(CASE WHEN M.PROTECTED = 1 THEN 1 END)) AS PROTECTED, "
1718 "(CASE WHEN B.FOLDER_ID = %d THEN 1 END) AS DRAFT, "
1719 "(CASE WHEN B.NETWORK_STATUS = %d THEN 1 END) AS FAILED, "
1720 "(CASE WHEN B.NETWORK_STATUS = %d THEN 1 END) AS SENDING "
1722 "LEFT OUTER JOIN %s B ON A.LAST_MSG_ID = B.MSG_ID "
1723 "LEFT OUTER JOIN %s M ON A.CONV_ID = M.CONV_ID "
1724 "WHERE A.SMS_CNT + A.MMS_CNT > 0 "
1725 "GROUP BY A.CONV_ID ORDER BY A.DISPLAY_TIME DESC;",
1727 MSG_NETWORK_SEND_FAIL,
1728 MSG_NETWORK_SENDING,
1729 MSGFW_CONVERSATION_TABLE_NAME,
1730 MSGFW_MESSAGE_TABLE_NAME,
1731 MSGFW_MESSAGE_TABLE_NAME);
1733 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1735 if (err == MSG_ERR_DB_NORECORD) {
1736 dbHandle->freeTable();
1738 } else if (err != MSG_SUCCESS) {
1739 MSG_DEBUG("Fail to getTable().");
1740 dbHandle->freeTable();
1745 MSG_DEBUG("rowCnt is %d", rowCnt);
1746 dbHandle->freeTable();
1750 pThreadViewList->nCount = rowCnt;
1752 MSG_DEBUG("pThreadViewList->nCount [%d]", pThreadViewList->nCount);
1754 pThreadViewList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
1756 MSG_THREAD_VIEW_S *pTmp = NULL;
1757 msg_struct_s *thread_t = NULL;
1759 for (int i = 0; i < rowCnt; i++) {
1760 thread_t = (msg_struct_s *)new msg_struct_s;
1761 pThreadViewList->msg_struct_info[i] = (msg_struct_t)thread_t;
1763 thread_t->type = MSG_STRUCT_THREAD_INFO;
1764 thread_t->data = new MSG_THREAD_VIEW_S;
1766 pTmp = (MSG_THREAD_VIEW_S *)thread_t->data;
1767 memset(pTmp, 0x00, sizeof(MSG_THREAD_VIEW_S));
1769 pTmp->threadId = dbHandle->getColumnToInt(index++);
1771 pTmp->unreadCnt = dbHandle->getColumnToInt(index++);
1772 pTmp->smsCnt = dbHandle->getColumnToInt(index++);
1773 pTmp->mmsCnt = dbHandle->getColumnToInt(index++);
1775 pTmp->mainType = dbHandle->getColumnToInt(index++);
1776 pTmp->subType = dbHandle->getColumnToInt(index++);
1778 pTmp->direction = dbHandle->getColumnToInt(index++);
1779 pTmp->threadTime = (time_t)dbHandle->getColumnToInt(index++);
1781 memset(pTmp->threadName, 0x00, sizeof(pTmp->threadName));
1782 dbHandle->getColumnToString(index++, MAX_THREAD_NAME_LEN, pTmp->threadName);
1784 char tmpData[MAX_THREAD_DATA_LEN + 1] = {0};
1785 dbHandle->getColumnToString(index++, MAX_THREAD_DATA_LEN, tmpData);
1786 memset(pTmp->threadData, 0x00, sizeof(pTmp->threadData));
1788 if (g_utf8_validate(tmpData, -1, (const gchar **)&end) == true) {
1789 g_utf8_strncpy(pTmp->threadData, tmpData, g_utf8_strlen(tmpData, -1));
1791 g_utf8_strncpy(pTmp->threadData, tmpData, g_utf8_strlen(tmpData, end - tmpData));
1794 pTmp->bProtected = (dbHandle->getColumnToInt(index++) > 0) ? true : false;
1795 pTmp->bDraft = dbHandle->getColumnToInt(index++);
1796 pTmp->bSendFailed = dbHandle->getColumnToInt(index++);
1797 pTmp->bSending = dbHandle->getColumnToInt(index++);
1800 dbHandle->freeTable();
1806 msg_error_t MsgStoGetThreadViewListWithCondition(const MSG_SORT_RULE_S *pSortRule, const MSG_LIST_CONDITION_S *pListCond, msg_struct_list_s *pThreadViewList)
1808 msg_error_t err = MSG_SUCCESS;
1811 err = MsgStoGetThreadViewList(pSortRule, pThreadViewList);
1812 if (err != MSG_SUCCESS) {
1813 MSG_ERR("MsgStoGetThreadViewList() Error!!");
1819 MsgDbHandler *dbHandle = getDbHandle();
1820 dbHandle->connectReadOnly();
1822 pThreadViewList->nCount = 0;
1823 pThreadViewList->msg_struct_info = NULL;
1825 int rowCnt = 0, index = 0;
1827 char sqlQuery[MAX_QUERY_LEN+1];
1828 char sqlQuerySubset[MAX_QUERY_LEN+1];
1829 char conditionQuery[MAX_QUERY_LEN+1] = {0};
1831 if (pListCond->bProtected == true) {
1832 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
1833 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "PROTECTED = 1 AND ");
1834 strncat(conditionQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(conditionQuery));
1837 if (pListCond->folderId > MSG_ALLBOX_ID) {
1838 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
1839 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "FOLDER_ID = %d ", pListCond->folderId);
1840 strncat(conditionQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(conditionQuery));
1842 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
1843 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "FOLDER_ID > %d AND FOLDER_ID < %d ", MSG_ALLBOX_ID, MSG_SPAMBOX_ID);
1844 strncat(conditionQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(conditionQuery));
1847 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1848 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT DISTINCT(CONV_ID) FROM %s WHERE ", MSGFW_MESSAGE_TABLE_NAME);
1850 strncat(sqlQuery, conditionQuery, MAX_QUERY_LEN-strlen(sqlQuery));
1852 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
1853 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY DISPLAY_TIME DESC;");
1854 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
1857 err = dbHandle->getTable(sqlQuery, &rowCnt, NULL);
1858 if (err == MSG_ERR_DB_NORECORD) {
1860 } else if (err != MSG_SUCCESS) {
1861 MSG_ERR("Fail to getTable(). [%d]", err);
1862 dbHandle->freeTable();
1866 msg_thread_id_t conv_ids[rowCnt];
1867 for (int i = 1; i <= rowCnt; i++) {
1868 conv_ids[i - 1] = dbHandle->getColumnToInt(i);
1871 dbHandle->freeTable();
1873 pThreadViewList->nCount = rowCnt;
1874 MSG_DEBUG("pThreadViewList->nCount [%d]", pThreadViewList->nCount);
1876 pThreadViewList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
1877 if (pThreadViewList->msg_struct_info == NULL) {
1878 MSG_ERR("calloc failed");
1879 return MSG_ERR_MEMORY_ERROR;
1882 MSG_THREAD_VIEW_S *pTmp = NULL;
1883 msg_struct_s *thread_t = NULL;
1885 for (int i = 0; i < pThreadViewList->nCount; i++) {
1886 thread_t = (msg_struct_s *)new msg_struct_s;
1887 pThreadViewList->msg_struct_info[i] = (msg_struct_t)thread_t;
1888 thread_t->type = MSG_STRUCT_THREAD_INFO;
1889 thread_t->data = new MSG_THREAD_VIEW_S;
1891 pTmp = (MSG_THREAD_VIEW_S *)thread_t->data;
1892 memset(pTmp, 0x00, sizeof(MSG_THREAD_VIEW_S));
1894 pTmp->threadId = conv_ids[i];
1896 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1897 snprintf(sqlQuery, MAX_QUERY_LEN, "SELECT DISPLAY_NAME FROM %s WHERE CONV_ID = %d;",
1898 MSGFW_CONVERSATION_TABLE_NAME, conv_ids[i]);
1900 err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1901 if (err != MSG_SUCCESS) {
1902 MSG_ERR("Fail to getTable(). [%d]", err);
1903 dbHandle->freeTable();
1907 dbHandle->getColumnToString(index++, MAX_THREAD_NAME_LEN, pTmp->threadName);
1909 dbHandle->freeTable();
1911 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1912 snprintf(sqlQuery, MAX_QUERY_LEN, "SELECT "
1913 "(COUNT(DISTINCT(CASE WHEN READ_STATUS = 0 THEN MSG_ID END))) AS UNREAD_CNT, "
1914 "(COUNT(DISTINCT(CASE WHEN MAIN_TYPE = %d THEN MSG_ID END))) AS SMS_CNT, "
1915 "(COUNT(DISTINCT(CASE WHEN MAIN_TYPE = %d THEN MSG_ID END))) AS MMS_CNT "
1916 "FROM %s WHERE CONV_ID = %d AND ",
1919 MSGFW_MESSAGE_TABLE_NAME, conv_ids[i]);
1921 strncat(sqlQuery, conditionQuery, MAX_QUERY_LEN-strlen(sqlQuery));
1922 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ";");
1923 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
1925 err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1926 if (err != MSG_SUCCESS) {
1927 MSG_ERR("Fail to getTable(). [%d]", err);
1928 dbHandle->freeTable();
1932 pTmp->unreadCnt = dbHandle->getColumnToInt(index++);
1933 pTmp->smsCnt = dbHandle->getColumnToInt(index++);
1934 pTmp->mmsCnt = dbHandle->getColumnToInt(index++);
1936 dbHandle->freeTable();
1938 memset(sqlQuery, 0x00, MAX_QUERY_LEN);
1939 snprintf(sqlQuery, sizeof(sqlQuery),
1940 "SELECT MAIN_TYPE, SUB_TYPE, MSG_DIRECTION, DISPLAY_TIME, DPM_RESTRICTED, (CASE WHEN LENGTH(SUBJECT) > 0 THEN SUBJECT ELSE MSG_TEXT END) "
1941 "FROM %s WHERE CONV_ID = %d AND ",
1942 MSGFW_MESSAGE_TABLE_NAME, conv_ids[i]);
1944 strncat(sqlQuery, conditionQuery, MAX_QUERY_LEN-strlen(sqlQuery));
1945 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY DISPLAY_TIME DESC LIMIT 1;");
1946 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
1948 err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
1949 if (err != MSG_SUCCESS) {
1950 MSG_ERR("Fail to getTable(). [%d]", err);
1951 dbHandle->freeTable();
1955 pTmp->mainType = (MSG_MAIN_TYPE_T)dbHandle->getColumnToInt(index++);
1956 pTmp->subType = (MSG_SUB_TYPE_T)dbHandle->getColumnToInt(index++);
1957 pTmp->direction = (msg_direction_type_t)dbHandle->getColumnToInt(index++);
1958 pTmp->threadTime = (time_t)dbHandle->getColumnToInt(index++);
1959 bool dpm_restricted = dbHandle->getColumnToInt(index++);
1960 char tmpData[MAX_THREAD_DATA_LEN + 1] = {0};
1961 if (!dpm_restricted) {
1962 dbHandle->getColumnToString(index++, MAX_THREAD_DATA_LEN, tmpData);
1964 snprintf(tmpData, sizeof(tmpData), "restricted message");
1968 if (g_utf8_validate(tmpData, -1, (const gchar **)&end) == true) {
1969 g_utf8_strncpy(pTmp->threadData, tmpData, g_utf8_strlen(tmpData, -1));
1971 g_utf8_strncpy(pTmp->threadData, tmpData, g_utf8_strlen(tmpData, end - tmpData));
1974 dbHandle->freeTable();
1981 msg_error_t MsgStoGetConversationPreview(MsgDbHandler *pDbHandle, MSG_CONVERSATION_VIEW_S *pConv)
1983 char sqlQuery[MAX_QUERY_LEN + 1];
1984 int rowCnt = 0, index = 0;
1985 memset(sqlQuery, 0x00, sizeof(sqlQuery));
1988 return MSG_ERR_NULL_POINTER;
1990 pConv->tcs_bc_level = -1; /* init */
1992 /*(MSG_ID INTEGER, TYPE INTEGER, VALUE TEXT, COUNT INTEGER) */
1993 snprintf(sqlQuery, sizeof(sqlQuery),
1994 "SELECT TYPE, VALUE, COUNT "
1995 "FROM %s WHERE MSG_ID=%d;",
1996 MSGFW_MMS_PREVIEW_TABLE_NAME, pConv->msgId);
1998 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
1999 if (err == MSG_SUCCESS) {
2000 for (int i = 0; i < rowCnt; i++) {
2001 int type = pDbHandle->getColumnToInt(index++);
2002 if (type == MSG_MMS_ITEM_TYPE_IMG) {
2003 pDbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, pConv->imageThumbPath);
2004 pDbHandle->getColumnToInt(index++);
2005 } else if (type == MSG_MMS_ITEM_TYPE_VIDEO) {
2006 pDbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, pConv->videoThumbPath);
2007 pDbHandle->getColumnToInt(index++);
2008 } else if (type == MSG_MMS_ITEM_TYPE_AUDIO) {
2009 pDbHandle->getColumnToString(index++, MSG_FILENAME_LEN_MAX, pConv->audioFileName);
2010 pDbHandle->getColumnToInt(index++);
2011 } else if (type == MSG_MMS_ITEM_TYPE_ATTACH) {
2012 pDbHandle->getColumnToString(index++, MSG_FILENAME_LEN_MAX, pConv->attachFileName);
2013 pConv->attachCount = pDbHandle->getColumnToInt(index++);
2014 } else if (type == MSG_MMS_ITEM_TYPE_PAGE) {
2016 pConv->pageCount = pDbHandle->getColumnToInt(index++);
2017 } else if (type == MSG_MMS_ITEM_TYPE_MALWARE) {
2019 pConv->tcs_bc_level = pDbHandle->getColumnToInt(index++);
2020 } else if (type == MSG_MMS_ITEM_TYPE_1ST_MEDIA) {
2021 pDbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, pConv->firstMediaPath);
2022 pDbHandle->getColumnToInt(index++);
2024 MSG_DEBUG("Unknown item type [%d]", type);
2030 pDbHandle->freeTable();
2034 msg_error_t MsgStoGetConversationMultipart(MsgDbHandler *pDbHandle, MSG_CONVERSATION_VIEW_S *pConv)
2036 char sqlQuery[MAX_QUERY_LEN + 1];
2037 int rowCnt = 0, index = 0;
2038 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2041 return MSG_ERR_NULL_POINTER;
2043 snprintf(sqlQuery, sizeof(sqlQuery),
2044 "SELECT CONTENT_TYPE, NAME, FILE_PATH, CONTENT_ID, CONTENT_LOCATION, TCS_LEVEL, MALWARE_ALLOW, THUMB_FILE_PATH "
2045 "FROM %s WHERE MSG_ID=%d;",
2046 MSGFW_MMS_MULTIPART_TABLE_NAME, pConv->msgId);
2048 msg_error_t err = pDbHandle->getTable(sqlQuery, &rowCnt, &index);
2049 if (err == MSG_SUCCESS) {
2050 GList *multipart_list = NULL;
2051 for (int i = 0; i < rowCnt; i++) {
2052 msg_struct_s *multipart_struct_s = new msg_struct_s;
2053 multipart_struct_s->type = MSG_STRUCT_MULTIPART_INFO;
2054 multipart_struct_s->data = new MMS_MULTIPART_DATA_S;
2055 memset(multipart_struct_s->data, 0x00, sizeof(MMS_MULTIPART_DATA_S));
2057 MMS_MULTIPART_DATA_S *multipart = (MMS_MULTIPART_DATA_S *)multipart_struct_s->data;
2059 pDbHandle->getColumnToString(index++, sizeof(multipart->szContentType), multipart->szContentType);
2060 pDbHandle->getColumnToString(index++, sizeof(multipart->szFileName), multipart->szFileName);
2061 pDbHandle->getColumnToString(index++, sizeof(multipart->szFilePath), multipart->szFilePath);
2062 pDbHandle->getColumnToString(index++, sizeof(multipart->szContentID), multipart->szContentID);
2063 pDbHandle->getColumnToString(index++, sizeof(multipart->szContentLocation), multipart->szContentLocation);
2065 multipart->tcs_bc_level = pDbHandle->getColumnToInt(index++);
2066 multipart->malware_allow = pDbHandle->getColumnToInt(index++);
2067 pDbHandle->getColumnToString(index++, sizeof(multipart->szThumbFilePath), multipart->szThumbFilePath);
2069 multipart_list = g_list_append(multipart_list, multipart_struct_s);
2071 pConv->multipart_list = (msg_list_handle_t)multipart_list;
2074 pDbHandle->freeTable();
2078 msg_error_t MsgStoGetConversationViewItem(msg_message_id_t msgId, MSG_CONVERSATION_VIEW_S *pConv)
2080 MsgDbHandler *dbHandle = getDbHandle();
2081 dbHandle->connectReadOnly();
2083 int rowCnt = 0, index = 0;
2085 char sqlQuery[MAX_QUERY_LEN+1];
2087 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2089 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONV_ID, FOLDER_ID, STORAGE_ID, MAIN_TYPE, SUB_TYPE, \
2090 DISPLAY_TIME, DATA_SIZE, NETWORK_STATUS, READ_STATUS, PROTECTED, \
2091 MSG_DIRECTION, DPM_RESTRICTED, SCHEDULED_TIME, SUBJECT, MSG_TEXT, ATTACHMENT_COUNT, SIM_INDEX\
2092 FROM %s WHERE MSG_ID = %d;",
2093 MSGFW_MESSAGE_TABLE_NAME, msgId);
2095 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
2097 if (err == MSG_ERR_DB_NORECORD) {
2098 dbHandle->freeTable();
2100 } else if (err != MSG_SUCCESS) {
2101 MSG_DEBUG("Fail to getTable().");
2102 dbHandle->freeTable();
2106 memset(pConv, 0x00, sizeof(MSG_CONVERSATION_VIEW_S));
2107 pConv->pText = NULL;
2109 pConv->msgId = dbHandle->getColumnToInt(index++);
2110 pConv->threadId = dbHandle->getColumnToInt(index++);
2111 pConv->folderId = dbHandle->getColumnToInt(index++);
2112 pConv->storageId = dbHandle->getColumnToInt(index++);
2113 pConv->mainType = dbHandle->getColumnToInt(index++);
2114 pConv->subType = dbHandle->getColumnToInt(index++);
2115 pConv->displayTime = (time_t)dbHandle->getColumnToInt(index++);
2116 pConv->textSize = dbHandle->getColumnToInt(index++);
2117 pConv->networkStatus = dbHandle->getColumnToInt(index++);
2118 pConv->bRead = dbHandle->getColumnToInt(index++);
2119 pConv->bProtected = dbHandle->getColumnToInt(index++);
2120 pConv->direction = dbHandle->getColumnToInt(index++);
2121 pConv->bRestricted = dbHandle->getColumnToInt(index++);
2122 pConv->scheduledTime = (time_t)dbHandle->getColumnToInt(index++);
2124 dbHandle->getColumnToString(index++, MAX_SUBJECT_LEN, pConv->subject);
2125 char *tmpText = g_strdup(dbHandle->getColumnToString(index++));
2127 /*It does Not need to Get attach count in MSG_MESSAGE_TABLE. see MsgStoGetConversationPreview */
2128 /*pConv->attachCount = dbHandle->getColumnToInt(index++); */
2130 if (pConv->bRestricted == true) {
2131 pConv->textSize = 0;
2132 memset(pConv->subject, 0x00, sizeof(pConv->subject));
2137 pConv->simIndex = dbHandle->getColumnToInt(index++);
2139 dbHandle->freeTable();
2141 if (pConv->mainType == MSG_MMS_TYPE &&
2142 (pConv->networkStatus == MSG_NETWORK_RETRIEVING || pConv->networkStatus == MSG_NETWORK_RETRIEVE_FAIL || pConv->subType == MSG_NOTIFICATIONIND_MMS)) {
2143 pConv->pText = NULL;
2144 pConv->textSize = 0;
2146 if (pConv->mainType == MSG_SMS_TYPE) {
2147 pConv->pText = new char[pConv->textSize+2];
2148 memset(pConv->pText, 0x00, pConv->textSize+2);
2149 snprintf(pConv->pText, pConv->textSize+1, "%s", tmpText);
2150 } else if (pConv->mainType == MSG_MMS_TYPE) {
2152 pConv->textSize = strlen(tmpText);
2154 pConv->pText = new char[pConv->textSize+1];
2155 memset(pConv->pText, 0x00, pConv->textSize+1);
2157 strncpy(pConv->pText, tmpText, pConv->textSize);
2160 MsgStoGetConversationPreview(dbHandle, pConv);
2161 MsgStoGetConversationMultipart(dbHandle, pConv);
2176 msg_error_t MsgStoGetConversationViewList(msg_thread_id_t threadId, msg_struct_list_s *pConvViewList)
2180 MsgDbHandler *dbHandle = getDbHandle();
2181 dbHandle->connectReadOnly();
2183 pConvViewList->nCount = 0;
2184 pConvViewList->msg_struct_info = NULL;
2186 int rowCnt = 0, index = 0;
2188 char sqlQuery[MAX_QUERY_LEN+1];
2190 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2192 #ifdef MSG_NOTI_INTEGRATION
2193 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONV_ID, FOLDER_ID, STORAGE_ID, MAIN_TYPE, SUB_TYPE, \
2194 DISPLAY_TIME, DATA_SIZE, NETWORK_STATUS, READ_STATUS, PROTECTED, \
2195 MSG_DIRECTION, DPM_RESTRICTED, SCHEDULED_TIME, SUBJECT, MSG_TEXT, ATTACHMENT_COUNT, SIM_INDEX \
2196 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;",
2197 MSGFW_MESSAGE_TABLE_NAME, threadId, MSG_ALLBOX_ID, MSG_SPAMBOX_ID, MSG_STORAGE_PHONE);
2199 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, CONV_ID, FOLDER_ID, STORAGE_ID, MAIN_TYPE, SUB_TYPE, \
2200 DISPLAY_TIME, DATA_SIZE, NETWORK_STATUS, READ_STATUS, PROTECTED, \
2201 MSG_DIRECTION, DPM_RESTRICTED, SCHEDULED_TIME, SUBJECT, MSG_TEXT, ATTACHMENT_COUNT \
2202 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;",
2203 MSGFW_MESSAGE_TABLE_NAME, threadId, MSG_ALLBOX_ID, MSG_CBMSGBOX_ID, MSG_STORAGE_PHONE);
2206 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
2208 if (err == MSG_ERR_DB_NORECORD) {
2209 dbHandle->freeTable();
2211 } else if (err != MSG_SUCCESS) {
2212 MSG_DEBUG("Fail to getTable().");
2213 dbHandle->freeTable();
2217 pConvViewList->nCount = rowCnt;
2218 char *tmpText[rowCnt] = {NULL};
2220 MSG_DEBUG("pConvViewList->nCount [%d]", pConvViewList->nCount);
2222 pConvViewList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(msg_struct_t));
2223 memset(pConvViewList->msg_struct_info, 0x00, sizeof(msg_struct_t) * rowCnt);
2225 msg_struct_s *conv = NULL;
2226 MSG_CONVERSATION_VIEW_S *pTmp = NULL;
2228 for (int i = 0; i < rowCnt; i++) {
2229 pConvViewList->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
2230 memset(pConvViewList->msg_struct_info[i], 0x00, sizeof(msg_struct_s));
2232 conv = (msg_struct_s *)pConvViewList->msg_struct_info[i];
2234 conv->type = MSG_STRUCT_CONV_INFO;
2235 conv->data = new MSG_CONVERSATION_VIEW_S;
2236 memset(conv->data, 0x00, sizeof(MSG_CONVERSATION_VIEW_S));
2238 pTmp = (MSG_CONVERSATION_VIEW_S *)conv->data;
2242 pTmp->msgId = dbHandle->getColumnToInt(index++);
2243 pTmp->threadId = dbHandle->getColumnToInt(index++);
2244 pTmp->folderId = dbHandle->getColumnToInt(index++);
2245 pTmp->storageId = dbHandle->getColumnToInt(index++);
2246 pTmp->mainType = dbHandle->getColumnToInt(index++);
2247 pTmp->subType = dbHandle->getColumnToInt(index++);
2248 pTmp->displayTime = (time_t)dbHandle->getColumnToInt(index++);
2249 pTmp->textSize = dbHandle->getColumnToInt(index++);
2250 pTmp->networkStatus = dbHandle->getColumnToInt(index++);
2251 pTmp->bRead = dbHandle->getColumnToInt(index++);
2252 pTmp->bProtected = dbHandle->getColumnToInt(index++);
2253 pTmp->direction = dbHandle->getColumnToInt(index++);
2254 pTmp->bRestricted = dbHandle->getColumnToInt(index++);
2255 index++; /* This field is reserved. */
2257 dbHandle->getColumnToString(index++, MAX_SUBJECT_LEN, pTmp->subject);
2258 tmpText[i] = g_strdup(dbHandle->getColumnToString(index++));
2260 /*It does Not need to Get attach count in MSG_MESSAGE_TABLE. see MsgStoGetConversationPreview */
2261 /*pTmp->attachCount = dbHandle->getColumnToInt(index++); */
2264 if (pTmp->bRestricted == true) {
2266 memset(pTmp->subject, 0x00, sizeof(pTmp->subject));
2268 tmpText[i][0] = '\0';
2270 pTmp->simIndex = dbHandle->getColumnToInt(index++);
2272 dbHandle->freeTable();
2274 for (int i = 0; i < pConvViewList->nCount; i++) {
2275 conv = (msg_struct_s *)pConvViewList->msg_struct_info[i];
2276 pTmp = (MSG_CONVERSATION_VIEW_S *)conv->data;
2278 if (pTmp->mainType == MSG_MMS_TYPE &&
2279 (pTmp->networkStatus == MSG_NETWORK_RETRIEVING || pTmp->networkStatus == MSG_NETWORK_RETRIEVE_FAIL || pTmp->subType == MSG_NOTIFICATIONIND_MMS)) {
2283 if (pTmp->mainType == MSG_SMS_TYPE) {
2284 pTmp->pText = new char[pTmp->textSize+2];
2285 memset(pTmp->pText, 0x00, pTmp->textSize+2);
2286 snprintf(pTmp->pText, pTmp->textSize+1, "%s", tmpText[i]);
2287 } else if (pTmp->mainType == MSG_MMS_TYPE) {
2289 pTmp->textSize = strlen(tmpText[i]);
2291 pTmp->pText = new char[pTmp->textSize+1];
2292 memset(pTmp->pText, 0x00, pTmp->textSize+1);
2294 strncpy(pTmp->pText, tmpText[i], pTmp->textSize);
2297 MsgStoGetConversationPreview(dbHandle, pTmp);
2298 MsgStoGetConversationMultipart(dbHandle, pTmp);
2313 msg_error_t MsgStoSearchMessage(const char *pSearchString, msg_struct_list_s *pThreadViewList, int contactCount)
2316 return MSG_ERR_NULL_POINTER;
2318 MsgDbHandler *dbHandle = getDbHandle();
2319 dbHandle->connectReadOnly();
2320 char *escapeAddressStr = NULL;
2322 /* Clear Out Parameter */
2323 pThreadViewList->nCount = 0;
2324 pThreadViewList->msg_struct_info = NULL;
2326 tr1::unordered_set<msg_thread_id_t> IdList;
2327 queue<MSG_THREAD_VIEW_S> searchList;
2329 MSG_THREAD_VIEW_S threadView;
2331 char sqlQuery[MAX_QUERY_LEN+1];
2333 /* Search - Address, Name */
2334 memset(sqlQuery, 0x00, MAX_QUERY_LEN+1);
2335 snprintf(sqlQuery, MAX_QUERY_LEN, "SELECT A.CONV_ID, A.UNREAD_CNT, A.SMS_CNT, A.MMS_CNT, A.DISPLAY_NAME, "
2336 "A.MAIN_TYPE, A.SUB_TYPE, A.MSG_DIRECTION, A.DISPLAY_TIME, A.MSG_TEXT, "
2337 "(SELECT COUNT(*) FROM %s B WHERE B.CONV_ID = A.CONV_ID AND B.PROTECTED = 1) AS PROTECTED, "
2338 "(SELECT COUNT(*) FROM %s B WHERE B.MSG_ID = A.LAST_MSG_ID AND B.FOLDER_ID = %d) AS DRAFT, "
2339 "(SELECT COUNT(*) FROM %s B WHERE B.MSG_ID = A.LAST_MSG_ID AND B.NETWORK_STATUS = %d) AS FAILED, "
2340 "(SELECT COUNT(*) FROM %s B WHERE B.MSG_ID = A.LAST_MSG_ID AND B.NETWORK_STATUS = %d) AS SENDING "
2341 "FROM %s A WHERE (A.SMS_CNT > 0 OR A.MMS_CNT > 0) "
2343 "(SELECT DISTINCT(CONV_ID) FROM %s WHERE "
2344 "ADDRESS_VAL LIKE ? ESCAPE '%c' ",
2345 MSGFW_MESSAGE_TABLE_NAME,
2346 MSGFW_MESSAGE_TABLE_NAME, MSG_DRAFT_ID,
2347 MSGFW_MESSAGE_TABLE_NAME, MSG_NETWORK_SEND_FAIL,
2348 MSGFW_MESSAGE_TABLE_NAME, MSG_NETWORK_SENDING,
2349 MSGFW_CONVERSATION_TABLE_NAME,
2350 MSGFW_ADDRESS_TABLE_NAME,
2351 MSGFW_DB_ESCAPE_CHAR);
2353 unsigned int tmpSize = 0;
2354 if (contactCount > 0) {
2355 tmpSize = strlen(sqlQuery);
2356 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
2357 "OR ADDRESS_VAL IN (SELECT C.ADDRESS_VAL FROM %s C JOIN %s D ON (C.ADDRESS_VAL LIKE D.ADDRESS_VAL))"
2358 , MSGFW_ADDRESS_TABLE_NAME, MSGFW_ADDRESS_TEMP_TABLE_NAME);
2361 tmpSize = strlen(sqlQuery);
2362 snprintf(sqlQuery+tmpSize, MAX_QUERY_LEN-tmpSize,
2363 ") ORDER BY A.DISPLAY_TIME DESC;");
2365 MSG_DEBUG("sqlQuery=[%s]", sqlQuery);
2367 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
2368 MSG_DEBUG("Prepare query fail.");
2369 return MSG_ERR_DB_PREPARE;
2372 MsgConvertStrWithEscape(pSearchString, &escapeAddressStr);
2373 MSG_DEBUG("escapeAddressStr [%s]", escapeAddressStr);
2374 dbHandle->bindText(escapeAddressStr, 1);
2375 /*dbHandle->bindText(escapeAddressStr, 2); */
2376 /*dbHandle->bindText(escapeAddressStr, 3); */
2377 /*dbHandle->bindText(escapeAddressStr, 4); */
2379 while (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
2380 memset(&threadView, 0x00, sizeof(threadView));
2382 threadView.threadId = dbHandle->columnInt(0);
2383 threadView.unreadCnt = dbHandle->columnInt(1);
2384 threadView.smsCnt = dbHandle->columnInt(2);
2385 threadView.mmsCnt = dbHandle->columnInt(3);
2387 if (dbHandle->columnText(4))
2388 strncpy(threadView.threadName, (char *)dbHandle->columnText(4), MAX_THREAD_NAME_LEN);
2390 threadView.mainType = dbHandle->columnInt(5);
2391 threadView.subType = dbHandle->columnInt(6);
2393 threadView.direction = dbHandle->columnInt(7);
2394 threadView.threadTime = (time_t)dbHandle->columnInt(8);
2396 if (dbHandle->columnText(9))
2397 strncpy(threadView.threadData, (char *)dbHandle->columnText(9), MAX_THREAD_DATA_LEN);
2399 int protectedCnt = dbHandle->columnInt(10);
2400 if (protectedCnt > 0)
2401 threadView.bProtected = true;
2403 int draftCnt = dbHandle->columnInt(11);
2405 threadView.bDraft = true;
2407 int failedCnt = dbHandle->columnInt(12);
2409 threadView.bSendFailed = true;
2411 int sendingCnt = dbHandle->columnInt(13);
2413 threadView.bSending = true;
2415 tr1::unordered_set<msg_thread_id_t>::iterator it;
2417 it = IdList.find(threadView.threadId);
2419 if (it == IdList.end()) {
2420 IdList.insert(threadView.threadId);
2421 searchList.push(threadView);
2425 dbHandle->finalizeQuery();
2427 if (escapeAddressStr) {
2428 free(escapeAddressStr);
2429 escapeAddressStr = NULL;
2433 /* Add data to Out Parameter */
2434 pThreadViewList->nCount = searchList.size();
2435 pThreadViewList->msg_struct_info = (msg_struct_t *)calloc(searchList.size(), sizeof(msg_struct_t));
2436 if (pThreadViewList->msg_struct_info == NULL)
2437 return MSG_ERR_MEMORY_ERROR;
2439 MSG_THREAD_VIEW_S *pTmp = NULL;
2440 msg_struct_s *thread_t = NULL;
2444 while (!searchList.empty()) {
2445 thread_t = (msg_struct_s *)new msg_struct_s;
2446 pThreadViewList->msg_struct_info[index] = (msg_struct_t)thread_t;
2448 thread_t->type = MSG_STRUCT_THREAD_INFO;
2449 thread_t->data = new MSG_THREAD_VIEW_S;
2451 pTmp = (MSG_THREAD_VIEW_S *)thread_t->data;
2452 memset(pTmp, 0x00, sizeof(MSG_THREAD_VIEW_S));
2454 memcpy(pTmp, &(searchList.front()), sizeof(MSG_THREAD_VIEW_S));
2465 msg_error_t MsgStoGetRejectMsgList(const char *pNumber, msg_struct_list_s *pRejectMsgList)
2467 MsgDbHandler *dbHandle = getDbHandle();
2468 dbHandle->connectReadOnly();
2470 /* Clear Out Parameter */
2471 pRejectMsgList->nCount = 0;
2472 pRejectMsgList->msg_struct_info = NULL;
2474 int rowCnt = 0, index = 0;
2476 char sqlQuery[MAX_QUERY_LEN+1];
2478 /* Search Reject Msg */
2479 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2481 if (pNumber != NULL) {
2482 int addrSize = strlen(pNumber);
2483 char phoneNumber[addrSize+1];
2484 memset(phoneNumber, 0x00, sizeof(phoneNumber));
2486 if (addrSize > MsgContactGetMinMatchDigit())
2487 MsgConvertNumber(pNumber, phoneNumber, addrSize);
2489 strncpy(phoneNumber, pNumber, addrSize);
2491 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
2496 "WHERE A.CONV_ID = B.CONV_ID "
2497 "AND B.MAIN_TYPE = %d "
2498 "AND B.SUB_TYPE = %d "
2499 "AND A.ADDRESS_VAL LIKE '%%%s' "
2500 "ORDER BY B.DISPLAY_TIME DESC;",
2501 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
2506 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT "
2511 "WHERE A.CONV_ID = B.CONV_ID "
2512 "AND B.MAIN_TYPE = %d "
2513 "AND B.SUB_TYPE = %d "
2514 "ORDER BY B.DISPLAY_TIME DESC;",
2515 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME,
2520 msg_error_t err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
2522 if (err != MSG_SUCCESS) {
2523 MSG_DEBUG("Fail to getTable().");
2524 dbHandle->freeTable();
2528 pRejectMsgList->nCount = rowCnt;
2530 MSG_DEBUG("pRejectMsgList->nCount [%d]", pRejectMsgList->nCount);
2532 pRejectMsgList->msg_struct_info = (msg_struct_t *)calloc(rowCnt, sizeof(MSG_REJECT_MSG_INFO_S *));
2534 msg_struct_s* pTmp = NULL;
2536 for (int i = 0; i < rowCnt; i++) {
2537 pRejectMsgList->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
2539 pTmp = (msg_struct_s *)pRejectMsgList->msg_struct_info[i];
2540 pTmp->type = MSG_STRUCT_REJECT_MSG_INFO;
2541 pTmp->data = new MSG_REJECT_MSG_INFO_S;
2542 MSG_REJECT_MSG_INFO_S * pMsg = (MSG_REJECT_MSG_INFO_S *)pTmp->data;
2543 memset(pMsg, 0x00, sizeof(MSG_REJECT_MSG_INFO_S));
2545 pMsg->msgId = dbHandle->getColumnToInt(index++);
2546 memset(pMsg->msgText, 0x00, sizeof(pMsg->msgText));
2547 dbHandle->getColumnToString(index++, MAX_MSG_TEXT_LEN, pMsg->msgText);
2549 pMsg->displayTime = (time_t)dbHandle->getColumnToInt(index++);
2552 dbHandle->freeTable();
2558 msg_error_t MsgStoGetAddressList(const msg_thread_id_t threadId, msg_struct_list_s *pAddrList)
2560 MsgDbHandler *dbHandle = getDbHandle();
2561 dbHandle->connectReadOnly();
2563 msg_error_t err = MSG_SUCCESS;
2565 err = MsgStoGetAddressByConvId(dbHandle, threadId, pAddrList);
2571 msg_error_t MsgStoGetMessageList(const MSG_LIST_CONDITION_S *pListCond, msg_struct_list_s *pMsgList, int contactCount)
2573 MsgDbHandler *dbHandle = getDbHandle();
2574 dbHandle->connectReadOnly();
2576 /* Clear Out Parameter */
2577 pMsgList->nCount = 0;
2578 pMsgList->msg_struct_info = NULL;
2581 int multipartCnt = 0;
2583 char sqlQuery[MAX_QUERY_LEN+1];
2584 char sqlQuerySubset[(MAX_QUERY_LEN/5)+1];
2586 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2587 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT COUNT(*) FROM %s;", MSGFW_MMS_MULTIPART_TABLE_NAME);
2589 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS)
2590 return MSG_ERR_DB_PREPARE;
2592 if (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
2593 multipartCnt = dbHandle->columnInt(0);
2595 dbHandle->finalizeQuery();
2596 return MSG_ERR_DB_STEP;
2599 dbHandle->finalizeQuery();
2601 memset(sqlQuery, 0x00, sizeof(sqlQuery));
2602 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT DISTINCT "
2611 "A.NETWORK_STATUS, "
2617 "A.SCHEDULED_TIME, "
2620 "A.ATTACHMENT_COUNT, "
2624 "B.RECIPIENT_TYPE, "
2627 if (pListCond->pTextVal != NULL && multipartCnt > 0) {
2628 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2629 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "FROM %s C, %s B, %s A WHERE A.CONV_ID > 0 AND A.CONV_ID = B.CONV_ID ",
2630 MSGFW_MMS_MULTIPART_TABLE_NAME, MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME);
2632 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2633 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "FROM %s B, %s A WHERE A.CONV_ID > 0 AND A.CONV_ID = B.CONV_ID ",
2634 MSGFW_ADDRESS_TABLE_NAME, MSGFW_MESSAGE_TABLE_NAME);
2637 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2639 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2640 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.DPM_RESTRICTED = 0 ");
2641 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2644 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2646 if (pListCond->folderId == MSG_ALLBOX_ID)
2647 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.FOLDER_ID > 0 AND A.FOLDER_ID < %d ", MSG_SPAMBOX_ID);
2648 else if (pListCond->folderId == MSG_IOSBOX_ID)
2649 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.FOLDER_ID > 0 AND A.FOLDER_ID < %d ", MSG_DRAFT_ID);
2651 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.FOLDER_ID = %d ", pListCond->folderId);
2653 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2657 if (pListCond->threadId > 0) {
2658 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2659 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.CONV_ID = %d ", pListCond->threadId);
2660 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2665 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2667 switch (pListCond->msgType) {
2669 if (pListCond->pAddressVal == NULL)
2670 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d ", MSG_SMS_TYPE);
2672 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_SMS_TYPE, MSG_NORMAL_SMS);
2676 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d ", MSG_MMS_TYPE);
2679 case MSG_TYPE_MMS_JAVA:
2680 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_MMS_TYPE, MSG_SENDREQ_JAVA_MMS);
2683 case MSG_TYPE_SMS_SYNCML:
2684 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_SMS_TYPE, MSG_SYNCML_CP);
2686 case MSG_TYPE_SMS_REJECT:
2687 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.MAIN_TYPE = %d AND A.SUB_TYPE = %d ", MSG_SMS_TYPE, MSG_REJECT_SMS);
2691 MSG_DEBUG("msg type is not set.");
2695 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2699 if (pListCond->storageId > MSG_STORAGE_UNKNOWN) {
2700 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2701 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.STORAGE_ID = %d ", pListCond->storageId);
2702 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2707 if (pListCond->bProtected) {
2708 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2709 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.PROTECTED = %d ", pListCond->bProtected);
2710 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2715 if (pListCond->bScheduled) {
2716 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2717 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.SCHEDULED_TIME > 0 ");
2718 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2723 if (pListCond->simIndex > 0) {
2724 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2725 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.SIM_INDEX = %d ", pListCond->simIndex);
2726 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2731 if (pListCond->fromTime > 0) {
2732 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2733 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.DISPLAY_TIME >= %u ", (unsigned int)pListCond->fromTime);
2734 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2737 if (pListCond->toTime > 0) {
2738 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2739 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND A.DISPLAY_TIME <= %u ", (unsigned int)pListCond->toTime);
2740 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2743 if (pListCond->pAddressVal == NULL) {
2745 if (pListCond->pTextVal != NULL) {
2746 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2747 if (multipartCnt > 0) {
2748 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2749 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c' OR (C.TEXT LIKE ? ESCAPE '%c' AND A.MSG_ID = C.MSG_ID AND C.CONTENT_TYPE = 'text/plain'))) ",
2750 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2752 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2753 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c')) ",
2754 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2756 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2760 if (pListCond->pTextVal != NULL) {
2761 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2762 if (multipartCnt > 0) {
2763 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2764 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c' OR (C.TEXT LIKE ? ESCAPE '%c' AND A.MSG_ID = C.MSG_ID AND C.CONTENT_TYPE = 'text/plain')) ",
2765 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2767 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2768 "AND ((A.MSG_TEXT LIKE ? ESCAPE '%c' OR A.SUBJECT LIKE ? ESCAPE '%c') ",
2769 MSGFW_DB_ESCAPE_CHAR, MSGFW_DB_ESCAPE_CHAR);
2771 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2773 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2774 if (pListCond->bAnd) {
2775 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "AND ");
2777 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "OR ");
2779 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2782 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2783 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2784 "(B.ADDRESS_VAL LIKE ? ESCAPE '%c' ", MSGFW_DB_ESCAPE_CHAR);
2785 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2787 if (contactCount > 0) {
2788 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2789 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2790 "OR B.ADDRESS_VAL IN (SELECT D.ADDRESS_VAL FROM %s D JOIN %s E ON (D.ADDRESS_VAL LIKE E.ADDRESS_VAL)) "
2791 , MSGFW_ADDRESS_TABLE_NAME, MSGFW_ADDRESS_TEMP_TABLE_NAME);
2792 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2795 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2796 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ")) ");
2797 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2800 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2801 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2802 "AND (B.ADDRESS_VAL LIKE ? ESCAPE '%c' ", MSGFW_DB_ESCAPE_CHAR);
2803 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2805 if (contactCount > 0) {
2806 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2807 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset),
2808 "OR B.ADDRESS_VAL IN (SELECT D.ADDRESS_VAL FROM %s D JOIN %s E ON (D.ADDRESS_VAL LIKE E.ADDRESS_VAL)) "
2809 , MSGFW_ADDRESS_TABLE_NAME, MSGFW_ADDRESS_TEMP_TABLE_NAME);
2810 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2813 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2814 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ") ");
2815 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2819 msg_struct_s *pSortRule = (msg_struct_s *)pListCond->sortRule;
2821 if (pSortRule->type != MSG_STRUCT_SORT_RULE) {
2823 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2824 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.DISPLAY_TIME ");
2826 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2829 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2830 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "DESC ");
2832 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2834 MSG_SORT_RULE_S *pTmp = (MSG_SORT_RULE_S *)pSortRule->data;
2835 /* order : TODO: have to finish this */
2836 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2837 switch (pTmp->sortType) {
2838 case MSG_SORT_BY_MSG_TYPE:
2839 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.MAIN_TYPE ");
2841 case MSG_SORT_BY_READ_STATUS:
2842 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.READ_STATUS ");
2844 case MSG_SORT_BY_STORAGE_TYPE:
2845 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.STORAGE_ID ");
2848 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ORDER BY A.DISPLAY_TIME ");
2851 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2854 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2855 if (pTmp->bAscending)
2856 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "ASC ");
2858 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "DESC ");
2860 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2863 /* offset & limit */
2864 memset(sqlQuerySubset, 0x00, sizeof(sqlQuerySubset));
2865 if (pListCond->offset >= 0 && pListCond->limit > 0)
2866 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), "LIMIT %d OFFSET %d;", pListCond->limit, pListCond->offset);
2868 snprintf(sqlQuerySubset, sizeof(sqlQuerySubset), ";");
2870 strncat(sqlQuery, sqlQuerySubset, MAX_QUERY_LEN-strlen(sqlQuery));
2873 /* 'til here sqlQuery is complete. */
2875 queue<MSG_MESSAGE_HIDDEN_S*> searchList;
2877 MSG_DEBUG("[%s]", sqlQuery);
2879 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
2880 MSG_DEBUG("Prepare query fail.");
2881 return MSG_ERR_DB_PREPARE;
2884 char *escapeTextStr = NULL;
2885 char *escapeAddressStr = NULL;
2887 if (pListCond->pAddressVal == NULL) {
2889 if (pListCond->pTextVal != NULL) {
2890 MsgConvertStrWithEscape(pListCond->pTextVal, &escapeTextStr);
2891 MSG_DEBUG("escapeTextStr [%s]", escapeTextStr);
2892 dbHandle->bindText(escapeTextStr, 1);
2893 dbHandle->bindText(escapeTextStr, 2);
2894 if (multipartCnt > 0) dbHandle->bindText(escapeTextStr, 3);
2898 if (pListCond->pTextVal != NULL) {
2899 MsgConvertStrWithEscape(pListCond->pTextVal, &escapeTextStr);
2900 MSG_DEBUG("escapeTestStr [%s]", escapeTextStr);
2903 MsgConvertStrWithEscape(pListCond->pAddressVal, &escapeAddressStr);
2904 MSG_DEBUG("escapeAddressStr [%s]", escapeAddressStr);
2906 dbHandle->bindText(escapeTextStr, 1);
2907 dbHandle->bindText(escapeTextStr, 2);
2908 if (multipartCnt > 0) {
2909 dbHandle->bindText(escapeTextStr, 3);
2910 dbHandle->bindText(escapeAddressStr, 4);
2912 dbHandle->bindText(escapeAddressStr, 3);
2917 MsgConvertStrWithEscape(pListCond->pAddressVal, &escapeAddressStr);
2918 MSG_DEBUG("escapeAddressStr [%s]", escapeAddressStr);
2919 dbHandle->bindText(escapeAddressStr, 1);
2924 MSG_MESSAGE_HIDDEN_S *pTmp = NULL;
2925 int lastMsgId = 0; /* for comparing same msg id. */
2927 while (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
2930 int msgid = dbHandle->columnInt(index++);
2931 MSG_DEBUG("msgid [%d]", msgid);
2933 if (lastMsgId != msgid) {
2934 MSG_DEBUG("lastMsgId != msgid");
2938 pTmp = new MSG_MESSAGE_HIDDEN_S;
2941 memset(pTmp, 0x00, sizeof(MSG_MESSAGE_HIDDEN_S));
2944 pTmp->pMmsData = NULL;
2945 pTmp->addressList = NULL;
2947 pTmp->msgId = msgid;
2949 pTmp->threadId = dbHandle->columnInt(index++);
2950 pTmp->folderId = dbHandle->columnInt(index++);
2951 pTmp->storageId = dbHandle->columnInt(index++);
2952 pTmp->mainType = dbHandle->columnInt(index++);
2953 pTmp->subType = dbHandle->columnInt(index++);
2954 pTmp->displayTime = (time_t)dbHandle->columnInt(index++);
2955 pTmp->dataSize = dbHandle->columnInt(index++);
2956 pTmp->networkStatus = dbHandle->columnInt(index++);
2957 pTmp->bRead = dbHandle->columnInt(index++);
2958 pTmp->bProtected = dbHandle->columnInt(index++);
2959 pTmp->bBackup = dbHandle->columnInt(index++);
2960 pTmp->priority = dbHandle->columnInt(index++);
2961 pTmp->direction = dbHandle->columnInt(index++);
2962 index++; /* This field is reserved. */
2964 strncpy(pTmp->subject, (char *)dbHandle->columnText(index++), MAX_SUBJECT_LEN);
2966 if (pTmp->mainType == MSG_MMS_TYPE &&
2967 (pTmp->networkStatus == MSG_NETWORK_RETRIEVING || pTmp->networkStatus == MSG_NETWORK_RETRIEVE_FAIL || pTmp->subType == MSG_NOTIFICATIONIND_MMS)) {
2971 pTmp->pData = (void *)new char[pTmp->dataSize+2];
2972 memset(pTmp->pData, 0x00, pTmp->dataSize+2);
2974 strncpy((char *)pTmp->pData, (char *)dbHandle->columnText(index++), pTmp->dataSize+1);
2977 pTmp->attachCount = dbHandle->columnInt(index++);
2979 strncpy(pTmp->thumbPath, (char *)dbHandle->columnText(index++), MSG_FILEPATH_LEN_MAX);
2981 pTmp->simIndex = dbHandle->columnInt(index++);
2983 pTmp->addr_list = (msg_struct_list_s *)new msg_struct_list_s;
2984 pTmp->addr_list->nCount = 0;
2985 pTmp->addr_list->msg_struct_info = (msg_struct_t *)calloc(MAX_TO_ADDRESS_CNT, sizeof(msg_struct_t));
2986 for (int i = 0; i < MAX_TO_ADDRESS_CNT; i++) {
2987 pTmp->addr_list->msg_struct_info[i] = (msg_struct_t)new msg_struct_s;
2988 memset(pTmp->addr_list->msg_struct_info[i], 0x00, sizeof(msg_struct_s));
2991 searchList.push(pTmp);
2995 MSG_DEBUG("lastMsgId == msgid");
3000 MSG_ADDRESS_INFO_S *pAddr = new MSG_ADDRESS_INFO_S;
3001 memset(pAddr, 0x00, sizeof(MSG_ADDRESS_INFO_S));
3003 pAddr->addressType = dbHandle->columnInt(index++);
3004 pAddr->recipientType = dbHandle->columnInt(index++);
3006 strncpy(pAddr->addressVal, (char *)dbHandle->columnText(index++), MAX_ADDRESS_VAL_LEN);
3008 strncpy(pAddr->displayName, pAddr->addressVal, MAX_DISPLAY_NAME_LEN);
3010 /* For GList *addressList */
3011 msg_struct_s *addr_info_s = new msg_struct_s;
3012 memset(addr_info_s, 0x00, sizeof(msg_struct_s));
3013 addr_info_s->type = MSG_STRUCT_ADDRESS_INFO;
3014 addr_info_s->data = new MSG_ADDRESS_INFO_S;
3015 memset(addr_info_s->data, 0x00, sizeof(MSG_ADDRESS_INFO_S));
3016 MSG_ADDRESS_INFO_S *addr_info = (MSG_ADDRESS_INFO_S *)addr_info_s->data;
3017 addr_info->addressType = pAddr->addressType;
3018 addr_info->recipientType = pAddr->recipientType;
3019 addr_info->contactId = pAddr->contactId;
3020 strncpy(addr_info->addressVal, pAddr->addressVal, MAX_ADDRESS_VAL_LEN);
3021 strncpy(addr_info->displayName, pAddr->displayName, MAX_DISPLAY_NAME_LEN);
3022 addr_info->displayName[MAX_DISPLAY_NAME_LEN] = '\0';
3024 pTmp->addressList = g_list_append(pTmp->addressList, addr_info_s);
3026 if (pTmp->addr_list->nCount >= MAX_TO_ADDRESS_CNT) {
3030 msg_struct_s *pStruct = (msg_struct_s *)pTmp->addr_list->msg_struct_info[pTmp->addr_list->nCount];
3031 pTmp->addr_list->nCount++;
3032 pStruct->type = MSG_STRUCT_ADDRESS_INFO;
3033 pStruct->data = pAddr;
3038 dbHandle->finalizeQuery();
3040 pMsgList->nCount = searchList.size();
3041 MSG_DEBUG("pMsgList->nCount [%d]", pMsgList->nCount);
3043 pMsgList->msg_struct_info = (msg_struct_t *)calloc(pMsgList->nCount, sizeof(msg_struct_t));
3044 if (pMsgList->msg_struct_info == NULL)
3045 return MSG_ERR_MEMORY_ERROR;
3048 while (!searchList.empty()) {
3049 msg_struct_s *msg = new msg_struct_s;
3051 pMsgList->msg_struct_info[offset++] = (msg_struct_t)msg;
3053 msg->type = MSG_STRUCT_MESSAGE_INFO;
3054 msg->data = searchList.front();
3061 free(escapeTextStr);
3063 if (escapeAddressStr)
3064 free(escapeAddressStr);
3070 msg_error_t MsgStoGetMediaList(const msg_thread_id_t threadId, msg_list_handle_t *pMediaList)
3073 msg_error_t err = MSG_SUCCESS;
3074 MsgDbHandler *dbHandle = getDbHandle();
3075 dbHandle->connectReadOnly();
3076 char sqlQuery[MAX_QUERY_LEN+1];
3080 memset(sqlQuery, 0x00, sizeof(sqlQuery));
3081 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID FROM %s WHERE MAIN_TYPE = %d AND DPM_RESTRICTED = 0 AND CONV_ID = %d;",
3082 MSGFW_MESSAGE_TABLE_NAME, MSG_MMS_TYPE, threadId);
3084 MSG_DEBUG("sqlQuery = [%s]", sqlQuery);
3086 err = dbHandle->getTable(sqlQuery, &msgIdCnt, NULL);
3087 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
3088 dbHandle->freeTable();
3090 } else if (err == MSG_ERR_DB_NORECORD) {
3091 dbHandle->freeTable();
3095 msg_message_id_t msgIds[msgIdCnt];
3097 for (int i = 1; i <= msgIdCnt; i++) {
3098 msgIds[i-1] = dbHandle->getColumnToInt(i);
3101 dbHandle->freeTable();
3103 GList *media_list = NULL;
3105 for (int i = 0; i < msgIdCnt; i++) {
3106 memset(sqlQuery, 0x00, sizeof(sqlQuery));
3107 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT MSG_ID, TCS_LEVEL, MALWARE_ALLOW, CONTENT_TYPE, FILE_PATH, THUMB_FILE_PATH, TCS_LEVEL, MALWARE_ALLOW "
3108 "FROM %s WHERE MSG_ID = %d AND SEQ <> -1 AND (TCS_LEVEL = -1 OR MALWARE_ALLOW = 1);",
3109 MSGFW_MMS_MULTIPART_TABLE_NAME, msgIds[i]);
3111 int rowCnt = 0, msg_id = 0, index = 0;
3113 err = dbHandle->getTable(sqlQuery, &rowCnt, &index);
3115 if (err != MSG_SUCCESS && err != MSG_ERR_DB_NORECORD) {
3116 dbHandle->freeTable();
3120 MSG_MEDIA_INFO_S *pMedia = NULL;
3121 int tcs_level = -1, malware_allow = 0, thumb_tcs_level = -1, thumb_malware_allow = 0;
3122 char mime_type[MAX_MIME_TYPE_LEN+1], media_item[MSG_FILEPATH_LEN_MAX+1], thumb_path[MSG_FILEPATH_LEN_MAX+1];
3124 for (int j = 0; j < rowCnt; j++) {
3125 msg_id = dbHandle->getColumnToInt(index++);
3126 tcs_level = dbHandle->getColumnToInt(index++);
3127 malware_allow = dbHandle->getColumnToInt(index++);
3128 memset(mime_type, 0x00, sizeof(mime_type));
3129 dbHandle->getColumnToString(index++, MAX_MIME_TYPE_LEN, mime_type);
3130 memset(media_item, 0x00, sizeof(media_item));
3131 dbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, media_item);
3132 memset(thumb_path, 0x00, sizeof(thumb_path));
3133 dbHandle->getColumnToString(index++, MSG_FILEPATH_LEN_MAX, thumb_path);
3134 thumb_tcs_level = dbHandle->getColumnToInt(index++);
3135 thumb_malware_allow = dbHandle->getColumnToInt(index++);
3137 if (strstr(mime_type, "image") || strstr(mime_type, "video")) {
3138 msg_struct_s *media_struct_s = new msg_struct_s;
3139 media_struct_s->type = MSG_STRUCT_MEDIA_INFO;
3140 media_struct_s->data = new MSG_MEDIA_INFO_S;
3141 memset(media_struct_s->data, 0x00, sizeof(MSG_MEDIA_INFO_S));
3143 pMedia = (MSG_MEDIA_INFO_S *)media_struct_s->data;
3145 pMedia->msg_id = msg_id;
3146 pMedia->tcs_level = tcs_level;
3147 pMedia->malware_allow = malware_allow;
3148 wrn = snprintf(pMedia->mime_type, MAX_MIME_TYPE_LEN, "%s", mime_type);
3150 MSG_DEBUG("snprintf was failed");
3151 wrn = snprintf(pMedia->media_item, MSG_FILEPATH_LEN_MAX, "%s", media_item);
3153 MSG_DEBUG("snprintf was failed");
3154 wrn = snprintf(pMedia->thumb_path, MSG_FILEPATH_LEN_MAX, "%s", thumb_path);
3156 MSG_DEBUG("snprintf was failed");
3157 pMedia->thumb_tcs_level = thumb_tcs_level;
3158 pMedia->thumb_malware_allow = thumb_malware_allow;
3160 media_list = g_list_append(media_list, media_struct_s);
3164 dbHandle->freeTable();
3166 *pMediaList = (msg_list_handle_t)media_list;
3174 msg_error_t MsgStoDbSelectWithQuery(const char *szQuery, char ***db_res, int *row_count, int *col_count)
3178 msg_error_t err = MSG_SUCCESS;
3180 MsgDbHandler *dbHandle = getDbHandle();
3181 err = dbHandle->connectReadOnly();
3182 if (err != MSG_SUCCESS) {
3183 MSG_ERR("db connect (read only) is failed [%d]", err);
3187 char *zSQL = sqlite3_mprintf("SELECT %q;", szQuery);
3190 err = dbHandle->getTableWithResult((const char *)zSQL, db_res, row_count, col_count);
3194 THROW(MsgException::INVALID_RESULT, "sqlite3_mprintf() is failed");
3197 MSG_DEBUG("getTableWithResult :: row_count=[%d], col_count=[%d]", *row_count, *col_count);
3199 if (err == MSG_ERR_DB_NORECORD) {
3200 dbHandle->freeTable(*db_res);
3203 } else if (err != MSG_SUCCESS) {
3204 MSG_DEBUG("Fail to getTable().");
3205 dbHandle->freeTable(*db_res);
3213 void MsgStoDbFree(char **db_res)
3215 MsgDbHandler *dbHandle = getDbHandle();
3216 dbHandle->freeTable(db_res);
3220 msg_error_t MsgStoClearUniquenessTable()
3224 msg_error_t err = MSG_SUCCESS;
3226 MsgDbHandler *dbHandle = getDbHandle();
3228 char sqlQuery[MAX_QUERY_LEN+1] = {0, };
3229 snprintf(sqlQuery, sizeof(sqlQuery), "DELETE FROM %s WHERE MSG_ID = 0", MSGFW_UNIQUENESS_INFO_TABLE_NAME);
3231 err = dbHandle->execQuery(sqlQuery);
3239 msg_error_t MsgStoGetSimIndexByMsgId(msg_message_id_t msgId, int* simIndex)
3243 msg_error_t err = MSG_SUCCESS;
3245 MsgDbHandler *dbHandle = getDbHandle();
3247 char sqlQuery[MAX_QUERY_LEN+1];
3248 memset(sqlQuery, 0x00, sizeof(sqlQuery));
3249 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT SIM_INDEX FROM %s WHERE MSG_ID = %d;", MSGFW_MESSAGE_TABLE_NAME, msgId);
3251 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
3252 return MSG_ERR_DB_PREPARE;
3255 if (dbHandle->stepQuery() == MSG_ERR_DB_ROW) {
3256 *simIndex = dbHandle->columnInt(0);
3257 dbHandle->finalizeQuery();
3259 MSG_DEBUG("MsgStepQuery() Error [%s]", sqlQuery);
3260 dbHandle->finalizeQuery();
3261 err = MSG_ERR_DB_STEP;
3270 msg_error_t MsgStoGetNetworkStatusByMsgId(msg_message_id_t msgId, int *networkStatus)
3272 char sqlQuery[MAX_QUERY_LEN + 1] = {0,};
3273 MsgDbHandler *dbHandle = getDbHandle();
3275 snprintf(sqlQuery, sizeof(sqlQuery), "SELECT NETWORK_STATUS FROM %s WHERE MSG_ID = %d;",
3276 MSGFW_MESSAGE_TABLE_NAME, msgId);
3278 if (dbHandle->prepareQuery(sqlQuery) != MSG_SUCCESS) {
3279 return MSG_ERR_DB_PREPARE;
3282 if (dbHandle->stepQuery() != MSG_ERR_DB_ROW) {
3283 dbHandle->finalizeQuery();
3284 return MSG_ERR_STORAGE_ERROR;
3287 *networkStatus = dbHandle->columnInt(0);
3288 dbHandle->finalizeQuery();