version 0.3.27
[fms.git] / src / freenet / unknownidentityrequester.cpp
diff --git a/src/freenet/unknownidentityrequester.cpp b/src/freenet/unknownidentityrequester.cpp
new file mode 100644 (file)
index 0000000..765eb3f
--- /dev/null
@@ -0,0 +1,53 @@
+#include "../../include/freenet/unknownidentityrequester.h"\r
+#include "../../include/option.h"\r
+\r
+#ifdef XMEM\r
+       #include <xmem.h>\r
+#endif\r
+\r
+UnknownIdentityRequester::UnknownIdentityRequester()\r
+{\r
+       Initialize();\r
+}\r
+\r
+UnknownIdentityRequester::UnknownIdentityRequester(FCPv2 *fcp):IdentityRequester(fcp)\r
+{\r
+       Initialize();\r
+}\r
+\r
+void UnknownIdentityRequester::Initialize()\r
+{\r
+       m_fcpuniquename="UnknownIdentityRequester";\r
+       Option::Instance()->GetInt("MaxIdentityRequests",m_maxrequests);\r
+\r
+       // unknown identities get 1/5 of the max requests option - known identities get 4/5 + any remaining if not evenly divisible\r
+       m_maxrequests=(m_maxrequests/5);\r
+\r
+       if(m_maxrequests<1)\r
+       {\r
+               m_maxrequests=1;\r
+               m_log->error("Option MaxIdentityRequests is currently set at less than 1.  It must be 1 or greater.");\r
+       }\r
+       if(m_maxrequests>100)\r
+       {\r
+               m_log->warning("Option MaxIdentityRequests is currently set at more than 100.  This value might be incorrectly configured.");\r
+       }\r
+}\r
+\r
+void UnknownIdentityRequester::PopulateIDList()\r
+{\r
+       int id;\r
+\r
+       // select identities we want to query (haven't seen at all) - sort by their trust level (descending)\r
+       SQLite3DB::Statement st=m_db->Prepare("SELECT IdentityID FROM tblIdentity WHERE PublicKey IS NOT NULL AND PublicKey <> '' AND LastSeen IS NULL ORDER BY LocalMessageTrust+LocalTrustListTrust DESC;");\r
+       st.Step();\r
+\r
+       m_ids.clear();\r
+\r
+       while(st.RowReturned())\r
+       {\r
+               st.ResultInt(0,id);\r
+               m_ids[id]=false;\r
+               st.Step();\r
+       }\r
+}\r