--- smsdaemon/GsmModem.h 2008/06/17 17:47:37 105 +++ smsdaemon/ModemTransceiver.h 2008/12/18 06:53:29 196 @@ -1,10 +1,9 @@ -#ifndef __GSMMODEM_H__ -#define __GSMMODEM_H__ +#ifndef __MODEMTRANSCEIVER_H__ +#define __MODEMTRANSCEIVER_H__ -/* using http://sourceforge.net/projects/libserial/ - */ -#include "IGsmModem.h" + +#include "ISmsTransceiver.h" #include #include @@ -14,24 +13,29 @@ class SerialPort; -class GsmModem : public IGsmModem +class ModemTransceiver : public ISmsTransceiver { public: - GsmModem(SerialPort& serialport); - virtual ~GsmModem() {} + ModemTransceiver(SerialPort& serialport); + virtual ~ModemTransceiver() {} void Init(); virtual void SendSms(std::string to, std::string message, bool allowMultipart); - void SendSmsPdu(std::string pdu, int len); + void SendSmsPdu(std::string pdu, int len); + + virtual std::vector ReadSms(bool readAll=false); - std::vector ReadSms(bool readAll=false); - void DeleteSms(std::string smsIndex); - int DeleteAllSms(); + virtual void DeleteSms(std::string smsIndex); + virtual int DeleteAllSms(); private: std::string GetResponse(); std::string Command(std::string command, std::string term = "OK\r\n"); + //decode an CMGF=1 text string + SMS FromRawString(const std::string& input); + SMS FromPduString(const std::string& input); + void HandlePincode(); void WaitForSimcard(); @@ -39,23 +43,5 @@ SerialPort& m_port; }; -class DebugGsmModem : public IGsmModem -{ -public: - DebugGsmModem() : _print(false) {} - DebugGsmModem(bool print) : _print(print) {} - - - virtual void SendSms(std::string to, std::string message, bool allowMultipart); - - std::string GetTo() {return _to;} - std::string GetMessage() {return _message;} - bool GetMultipart() {return _multipart;} -private: - std::string _to; - std::string _message; - bool _multipart; - bool _print; -}; -#endif // __GSMMODEM_H__ +#endif // __MODEMTRANSCEIVER_H__