1 #include "../../include/freenet/messageinserter.h"
\r
3 MessageInserter::MessageInserter()
\r
8 MessageInserter::MessageInserter(FCPv2 *fcp):IIndexInserter(fcp)
\r
13 void MessageInserter::CheckForNeededInsert()
\r
15 // only do 1 insert at a time
\r
16 if(m_inserting.size()==0)
\r
18 SQLite3DB::Statement st=m_db->Prepare("SELECT MessageUUID FROM tblMessageInserts INNER JOIN tblLocalIdentity ON tblMessageInserts.LocalIdentityID=tblLocalIdentity.LocalIdentityID WHERE tblLocalIdentity.PrivateKey IS NOT NULL AND tblLocalIdentity.PrivateKey <> '' AND tblMessageInserts.Inserted='false';");
\r
21 if(st.RowReturned())
\r
23 std::string messageuuid;
\r
24 st.ResultText(0,messageuuid);
\r
25 StartInsert(messageuuid);
\r
30 const bool MessageInserter::HandlePutFailed(FCPMessage &message)
\r
33 int localidentityid;
\r
34 std::vector<std::string> idparts;
\r
35 StringFunctions::Split(message["Identifier"],"|",idparts);
\r
36 StringFunctions::Convert(idparts[2],localidentityid);
\r
37 StringFunctions::Convert(idparts[3],index);
\r
39 // fatal put - or data exists - insert bogus index into database so we'll try to insert this message again
\r
40 if(message["Fatal"]=="true" || message["Code"]=="9")
\r
42 SQLite3DB::Statement st=m_db->Prepare("INSERT INTO tblMessageInserts(LocalIdentityID,Day,InsertIndex,Inserted) VALUES(?,?,?,'true');");
\r
43 st.Bind(0,localidentityid);
\r
44 st.Bind(1,idparts[5]);
\r
49 RemoveFromInsertList(idparts[1]);
\r
54 const bool MessageInserter::HandlePutSuccessful(FCPMessage &message)
\r
57 std::vector<std::string> idparts;
\r
58 StringFunctions::Split(message["Identifier"],"|",idparts);
\r
59 StringFunctions::Convert(idparts[3],index);
\r
61 SQLite3DB::Statement st=m_db->Prepare("UPDATE tblMessageInserts SET Day=?, InsertIndex=?, Inserted='true' WHERE MessageUUID=?;");
\r
62 st.Bind(0,idparts[5]);
\r
64 st.Bind(2,idparts[1]);
\r
67 RemoveFromInsertList(idparts[1]);
\r
69 m_log->WriteLog(LogFile::LOGLEVEL_DEBUG,"MessageInserter::HandlePutSuccessful successfully inserted message "+message["Identifier"]);
\r
74 void MessageInserter::Initialize()
\r
76 m_fcpuniquename="MessageInserter";
\r
79 void MessageInserter::StartInsert(const std::string &messageuuid)
\r
83 SQLite3DB::Statement st=m_db->Prepare("SELECT MessageXML,PrivateKey,tblLocalIdentity.LocalIdentityID FROM tblMessageInserts INNER JOIN tblLocalIdentity ON tblMessageInserts.LocalIdentityID=tblLocalIdentity.LocalIdentityID WHERE MessageUUID=?;");
\r
84 st.Bind(0,messageuuid);
\r
87 if(st.RowReturned())
\r
89 int localidentityid;
\r
92 std::string xmlsizestr;
\r
93 std::string privatekey;
\r
95 std::string indexstr;
\r
98 st.ResultText(0,xml);
\r
99 st.ResultText(1,privatekey);
\r
100 st.ResultInt(2,localidentityid);
\r
101 StringFunctions::Convert(xml.size(),xmlsizestr);
\r
102 StringFunctions::Convert(localidentityid,idstr);
\r
104 st=m_db->Prepare("SELECT MAX(InsertIndex) FROM tblMessageInserts WHERE Day=? AND LocalIdentityID=?;");
\r
105 st.Bind(0,now.Format("%Y-%m-%d"));
\r
106 st.Bind(1,localidentityid);
\r
109 if(st.ResultNull(0)==false)
\r
111 st.ResultInt(0,index);
\r
114 StringFunctions::Convert(index,indexstr);
\r
116 message.SetName("ClientPut");
\r
117 message["URI"]=privatekey+m_messagebase+"|"+now.Format("%Y-%m-%d")+"|Message|"+indexstr+".xml";
\r
118 message["Identifier"]=m_fcpuniquename+"|"+messageuuid+"|"+idstr+"|"+indexstr+"|"+message["URI"];
\r
119 message["UploadFrom"]="direct";
\r
120 message["DataLength"]=xmlsizestr;
\r
121 m_fcp->SendMessage(message);
\r
122 m_fcp->SendRaw(xml.c_str(),xml.size());
\r
124 m_inserting.push_back(messageuuid);
\r
126 m_log->WriteLog(LogFile::LOGLEVEL_DEBUG,"MessageInserter::StartInsert started message insert "+message["URI"]);
\r