--- smsdaemon/SmsPdu.cpp 2008/06/13 10:10:06 75 +++ smsdaemon/SmsPdu.cpp 2008/12/18 06:53:29 196 @@ -8,10 +8,15 @@ #include #include -#include +#include -#include "common.h" -#include "util.h" +#include "Logger.h" +#include "Util.h" + +#include "Exceptions.h" +#include +#include +#include using namespace std; @@ -24,7 +29,7 @@ string SwitchChars(string input) { for (unsigned int i=1; i 800) { - Common::instance()->logMessage("Trying to send multipart sms > 800 bytes !!!"); + Logger::logMessage("Trying to send multipart sms > 800 bytes !!!"); message = message.substr(0,800); } @@ -184,14 +188,14 @@ pdu.insert( pdu.end(), phone.begin(), phone.end()); pdu.push_back(0x00); // Protocol identifier - pdu.push_back(0x00); // Data coding scheme + pdu.push_back(0x00); // Data coding scheme int shift_start = 0; string message_part; if (multipart) { message_part = message.substr(0, PDU_LEN); - message.erase(0, PDU_LEN); + message.erase(0, PDU_LEN-1); pdu.push_back( message_part.length()+ 7 ); //UserDataLength pdu.push_back( 0x06 ); // UDH Len @@ -208,7 +212,7 @@ if (message.length() > 160) { message_part = message.substr(0,160); //truncate to 160 - Common::instance()->logMessage("Truncated message"); + Logger::logMessage("Truncated message"); } else { @@ -275,9 +279,88 @@ } + std::list partlist; + typedef std::list::iterator iterator; + + SMS ConcatenateParts(SmsPart& part) + { + SMS sms; + if (part.group == -1) + { + sms.SetMessage(part.message); + sms.SetSender(part.sender); + } + else + { + partlist.push_back(part); + + vector vec; + for (iterator it=partlist.begin(); it!=partlist.end(); ++it) + { + SmsPart& current = *it; + if (current.sender == part.sender && current.group == part.group) + vec.push_back(current); + } + + if (vec.size() == (unsigned)part.count) //we have all parts + { + sort(vec.begin(), vec.end()); + string message; + for (unsigned i=0; i& udh, SmsPart& part) + { + if (udh.size() == 0) + { + Logger::logMessage("ParseUdh(): empty udh"); + return; + } + + if (udh[0] != 0) + { + Logger::logMessage("unknown UDH type"); + return; + } + + if (udh.size() < 5) + { + Logger::logMessage("UDH to short to be multipart"); + return; + } + + part.group = udh[2]; + part.count = udh[3]; + part.id = udh[4]; + } + + + SmsPart ParseSmsPduWorker(std::string pdu_str) + { vector pdu = HexDecodeString(pdu_str); @@ -295,23 +378,35 @@ ++it; //ignore Type-Of-Address - result.sender = DecodeRawPhonenr( it, it+(sender_len/2) ); + string sender = DecodeRawPhonenr( it, it+(sender_len/2) ); it += (sender_len/2); ++it; //protocol identifier ++it; //Data encoding - result.timestamp = DecodeTimestamp(it, it+7); + string timestamp = DecodeTimestamp(it, it+7); it += 7; unsigned char data_len = (*it++); + + SmsPart part; + part.group = -1; + int shift_start = 0; + if (UDHI) { - int udh_len = (*it++); - it += udh_len; //just ignore the User Data Header + int udh_len = (*it++); + + vector udh; + for (int i=0; i user_data; user_data.insert(user_data.end(), it, it+data_len); - - result.message = Decode8to7bit(user_data, shift_start); - - return result; + string message = Decode8to7bit(user_data, shift_start).substr(0,data_len); + + message = Util::str_trim(message); + + + part.message = message; + part.sender = sender; + + return part; } }