/[projects]/smsdaemon/SmsToolTransceiver.cpp
ViewVC logotype

Contents of /smsdaemon/SmsToolTransceiver.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 196 - (show annotations) (download)
Thu Dec 18 06:53:29 2008 UTC (15 years, 5 months ago) by torben
File size: 4052 byte(s)
Make pretty

astyle -t -b -N

1 #include "SmsToolTransceiver.h"
2
3 #include "Logger.h"
4 #include "Util.h"
5 #include "Common.h"
6 #include "ConfigFile.h"
7
8 #include <stdexcept>
9 #include <iostream>
10 #include <fstream>
11 #include <sstream>
12 #include <iomanip>
13
14 #include <cstring>
15 #include <errno.h>
16 #include <time.h>
17 #include <stdlib.h>
18 #include <sys/types.h>
19 #include <dirent.h>
20
21 using namespace std;
22
23 string appendSlash(string& str)
24 {
25 if (str.at(str.length()-1) != '/');
26 str += "/";
27 return str;
28 }
29
30 SmsToolTransceiver::SmsToolTransceiver()
31 {
32 Common* cmn = Common::instance();
33
34 try
35 {
36 inboxdir = cmn->GetConfigfile()->GetValue("smstools","inboxdir").StringValue();
37 }
38 catch (...)
39 {
40 Logger::logMessage("Config error> smstools::inboxdir not specified");
41 exit(1);
42 }
43 try
44 {
45 outgoingdir = cmn->GetConfigfile()->GetValue("smstools","outgoingdir").StringValue();
46 }
47 catch (...)
48 {
49 Logger::logMessage("Config error> smstools::outgoingdir not specified");
50 exit(1);
51 }
52
53 inboxdir = appendSlash(inboxdir);
54 outgoingdir = appendSlash(outgoingdir);
55
56 }
57
58
59 void SmsToolTransceiver::SendSms(std::string to, std::string message, bool allowMultipart)
60 {
61 std::string filename = CreateFilename();
62 Logger::logMessage( std::string("Sending sms to: ") + to);
63
64 string tempfile = outgoingdir + filename + ".LOCK";
65
66 string destfile = outgoingdir + filename;
67
68 ofstream out( tempfile.c_str() );
69 if (!out )
70 {
71 Logger::logMessage("SmsToolTransceiver:: could not create temp file");
72 return;
73 }
74 out << "To: " << to << "\n\n" << message ;
75 out.close();
76
77 Common::instance()->smsCounter.outgoing++;
78
79 int result = rename(tempfile.c_str(), destfile.c_str());
80
81 if (result)
82 Logger::logMessage( string("SmsToolTransceiver could not spool file: ") + strerror(errno) );
83 }
84
85 std::string SmsToolTransceiver::CreateFilename()
86 {
87 std::stringstream ss;
88 ss << "smsdaemon_";
89 ss << std::setw(8) << std::setfill('0') << std::uppercase << std::hex << time(0) << "_";
90 ss << std::setw(8) << std::setfill('0') << std::uppercase << std::hex << rand();
91 ss << std::setw(8) << std::setfill('0') << std::uppercase << std::hex << rand();
92 return ss.str();
93 }
94
95 std::vector<SMS> SmsToolTransceiver::ReadSms(bool readAll)
96 {
97 std::vector<SMS> vec;
98 DIR* dir = opendir( inboxdir.c_str() );
99
100 if (dir != 0)
101 {
102 dirent* entry;
103 while ( (entry = readdir(dir)) != 0)
104 {
105 if (entry->d_name[0] == '.')
106 continue;
107 Logger::logMessage( string("SmsTool::ReadSms >") +entry->d_name);
108
109 try
110 {
111 SMS sms = ParseFile( inboxdir + entry->d_name);
112 vec.push_back(sms);
113 }
114 catch (std::exception& e)
115 {
116 Logger::logMessage(e.what());
117 }
118
119 if (!readAll)
120 break;
121 }
122 }
123 else
124 {
125 Logger::logMessage( string("SmsToolTransceiver could open inbox dir ") + strerror(errno) );
126 }
127 closedir(dir);
128
129 return vec;
130 }
131
132
133 SMS SmsToolTransceiver::ParseFile(std::string path)
134 {
135 SMS sms;
136
137 string file = Util::readfile(path);
138 int result = ::unlink(path.c_str());
139 if (result)
140 {
141 string message = "SmsTool> unlink ";
142 message += path;
143 message += " failed: ";
144 message += strerror(errno);
145 throw std::runtime_error( message );
146 }
147
148
149 unsigned int pos = file.find("\n\n");
150
151 if (pos != string::npos)
152 {
153 string header = file.substr(0,pos);
154 string body = file.substr(pos+2,1024);
155
156 sms.SetIndex(path);
157 sms.SetMessage(body);
158
159 ParseHeaders(header, sms);
160
161 }
162 else
163 {
164 throw std::runtime_error("SmsTool: invalid incomming file");
165 }
166
167 return sms;
168 }
169
170 void SmsToolTransceiver::ParseHeaders(std::string& headerstring, SMS& sms)
171 {
172 std::vector<std::string> headers = Util::str_split(headerstring, "\n");
173
174 for (unsigned int i=0; i<headers.size(); i++)
175 {
176 unsigned int pos = headers[i].find(":");
177 if (pos != string::npos)
178 {
179 string key = Util::str_trim( headers[i].substr(0,pos) );
180 string val = Util::str_trim( headers[i].substr(pos+1) );
181
182 if (key == "From")
183 sms.SetSender(val);
184
185 if (key == "Received")
186 sms.SetTimestamp(val);
187 }
188 else
189 {
190 Logger::logMessage(string("SmsTool: Invalid sms file header> ") + headers[i]);
191 }
192 }
193
194 }
195
196 int SmsToolTransceiver::DeleteAllSms()
197 {
198 return 0;
199 }

  ViewVC Help
Powered by ViewVC 1.1.20