X-Git-Url: https://git.pterodactylus.net/?p=fms.git;a=blobdiff_plain;f=src%2Fhttp%2Fpages%2Fpeertrustpage.cpp;h=38bddbf116b605bb160ab7df4cafd9a4d066547a;hp=a9ac96f60feede26466a5ba8f46d5406f61e2758;hb=f60495a029c54358f82956482fe203fe2b7b5b23;hpb=f208e33c29132aacaec448e74341edea1b925a2a diff --git a/src/http/pages/peertrustpage.cpp b/src/http/pages/peertrustpage.cpp index a9ac96f..38bddbf 100644 --- a/src/http/pages/peertrustpage.cpp +++ b/src/http/pages/peertrustpage.cpp @@ -10,6 +10,15 @@ const std::string PeerTrustPage::GeneratePage(const std::string &method, const s int count=0; std::string countstr; std::string content=""; + int identitycount=0; // total number of ids we know + int rowsperpage=25; // how many ids to show per page + std::string rowsperpagestr; + int startrow=0; + std::string startrowstr="0"; + std::string namesearch=""; + std::string sql; + + StringFunctions::Convert(rowsperpage,rowsperpagestr); if(queryvars.find("formaction")!=queryvars.end() && (*queryvars.find("formaction")).second=="update") { @@ -48,14 +57,66 @@ const std::string PeerTrustPage::GeneratePage(const std::string &method, const s } + // if startrow is specified + if(queryvars.find("startrow")!=queryvars.end()) + { + startrowstr=(*queryvars.find("startrow")).second; + // convert back and forth, just in case a number wasn't passed in startrow + StringFunctions::Convert(startrowstr,startrow); + if(startrow<0) + { + startrow=0; + } + StringFunctions::Convert(startrow,startrowstr); + } + + // if we are searching by name + if(queryvars.find("namesearch")!=queryvars.end()) + { + namesearch=(*queryvars.find("namesearch")).second; + } + content+="

Peer Trust

"; content+="Message Trust is how much you trust the identity to post good messages. Trust List Trust is how much weight you want the trust list of that identity to have when calculating the total. The local trust levels are set by you, and the peer trust levels are calculated by a weighted average using other identities trust lists."; + content+="
"; + content+="
"; + content+=""; + content+=""; + content+="
"; + content+="
"; content+="
"; content+=""; + content+=""; content+=""; content+=""; - SQLite3DB::Statement st=m_db->Prepare("SELECT IdentityID,Name,LocalMessageTrust,PeerMessageTrust,LocalTrustListTrust,PeerTrustListTrust,PublicKey FROM tblIdentity ORDER BY Name;"); + // get count of identities we are showing + sql="SELECT COUNT(*) FROM tblIdentity"; + if(namesearch!="") + { + sql+=" WHERE Name LIKE '%' || ? || '%'"; + } + sql+=";"; + SQLite3DB::Statement st=m_db->Prepare(sql); + if(namesearch!="") + { + st.Bind(0,namesearch); + } + st.Step(); + st.ResultInt(0,identitycount); + st.Finalize(); + + sql="SELECT IdentityID,Name,LocalMessageTrust,PeerMessageTrust,LocalTrustListTrust,PeerTrustListTrust,PublicKey FROM tblIdentity"; + if(namesearch!="") + { + sql+=" WHERE Name LIKE '%' || ? || '%'"; + } + sql+=" ORDER BY Name COLLATE NOCASE LIMIT "+startrowstr+","+rowsperpagestr+";"; + st=m_db->Prepare(sql); + if(namesearch!="") + { + st.Bind(0,namesearch); + } st.Step(); while(st.RowReturned()) @@ -67,6 +128,7 @@ const std::string PeerTrustPage::GeneratePage(const std::string &method, const s std::string localtrustlisttrust; std::string peertrustlisttrust; std::string publickey; + std::string keypart=""; StringFunctions::Convert(count,countstr); @@ -78,30 +140,64 @@ const std::string PeerTrustPage::GeneratePage(const std::string &method, const s st.ResultText(5,peertrustlisttrust); st.ResultText(6,publickey); + if(publickey.size()>8) + { + keypart=publickey.substr(3,5); + } + content+=""; content+=""; - content+=""; - content+=""; - content+=""; + content+=""; - content+=""; + content+=""; content+=""; st.Step(); count++; } + + if(startrow>0 || startrow+rowsperpage0) + { + StringFunctions::Convert(startrow-rowsperpage,tempstr); + content+=""; + cols+=2; + } + if(startrow+rowsperpageNext Page -->"; + } + content+=""; + } content+=""; content+="
NameLocal Message TrustPeer Message TrustLocal Trust List TrustPeer Trust List Trust
"; content+=""; + content+=""; if(name!="") { - content+=name; + content+=SanitizeOutput(name+keypart)+"..."; } else { content+="[Unknown Name]"; } + content+=""; content+=""; + content+=""; content+=""; content+=""+peermessagetrust+""; + content+=""; + content+=peermessagetrust+""; content+=""; content+=""+peertrustlisttrust+""; + content+=peertrustlisttrust+"
<-- Previous Page
"; @@ -110,6 +206,25 @@ const std::string PeerTrustPage::GeneratePage(const std::string &method, const s return "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n"+StringFunctions::Replace(m_template,"[CONTENT]",content); } +const std::string PeerTrustPage::GetClassString(const std::string &trustlevel) +{ + int tempint=0; + std::string tempstr; + + StringFunctions::Convert(trustlevel,tempint); + tempint/=10; + StringFunctions::Convert(tempint,tempstr); + + if(trustlevel!="") + { + return "class=\"trust"+tempstr+"\""; + } + else + { + return ""; + } +} + const bool PeerTrustPage::WillHandleURI(const std::string &uri) { if(uri.find("peertrust.")!=std::string::npos)