version 0.2.14
[fms.git] / src / http / pages / localidentitiespage.cpp
1 #include "../../../include/http/pages/localidentitiespage.h"\r
2 #include "../../../include/stringfunctions.h"\r
3 #include "../../../include/http/identityexportxml.h"\r
4 #include "../../../include/global.h"\r
5 \r
6 #ifdef XMEM\r
7         #include <xmem.h>\r
8 #endif\r
9 \r
10 const std::string LocalIdentitiesPage::GeneratePage(const std::string &method, const std::map<std::string,std::string> &queryvars)\r
11 {\r
12         int count;\r
13         std::string countstr;\r
14         std::string content="";\r
15 \r
16         if(queryvars.find("formaction")!=queryvars.end())\r
17         {\r
18                 int id;\r
19                 std::vector<std::string> ids;\r
20                 std::vector<std::string> singleuse;\r
21                 std::vector<std::string> publishtrustlist;\r
22                 std::vector<std::string> publishboardlist;\r
23                 std::vector<std::string> publishfreesite;\r
24 \r
25                 CreateArgArray(queryvars,"chkidentityid",ids);\r
26                 CreateArgArray(queryvars,"singleuse",singleuse);\r
27                 CreateArgArray(queryvars,"publishtrustlist",publishtrustlist);\r
28                 CreateArgArray(queryvars,"publishboardlist",publishboardlist);\r
29                 CreateArgArray(queryvars,"publishfreesite",publishfreesite);\r
30 \r
31                 if((*queryvars.find("formaction")).second=="update")\r
32                 {\r
33                         SQLite3DB::Statement update=m_db->Prepare("UPDATE tblLocalIdentity SET SingleUse=?, PublishTrustList=?, PublishBoardList=?, PublishFreesite=? WHERE LocalIdentityID=?;");\r
34                         for(int i=0; i<ids.size(); i++)\r
35                         {\r
36                                 if(ids[i]!="")\r
37                                 {\r
38                                         StringFunctions::Convert(ids[i],id);\r
39                                         update.Bind(0,singleuse[i]);\r
40                                         update.Bind(1,publishtrustlist[i]);\r
41                                         update.Bind(2,publishboardlist[i]);\r
42                                         update.Bind(3,publishfreesite[i]);\r
43                                         update.Bind(4,id);\r
44                                         update.Step();\r
45                                         update.Reset();\r
46                                 }\r
47                         }\r
48                 }\r
49                 if((*queryvars.find("formaction")).second=="delete")\r
50                 {\r
51                         SQLite3DB::Statement del=m_db->Prepare("DELETE FROM tblLocalIdentity WHERE LocalIdentityID=?;");\r
52                         for(int i=0; i<ids.size(); i++)\r
53                         {\r
54                                 if(ids[i]!="")\r
55                                 {\r
56                                         StringFunctions::Convert(ids[i],id);\r
57                                         del.Bind(0,id);\r
58                                         del.Step();\r
59                                         del.Reset();\r
60                                 }\r
61                         }\r
62                 }\r
63                 if((*queryvars.find("formaction")).second=="export")\r
64                 {\r
65                         IdentityExportXML xml;\r
66                         SQLite3DB::Statement exp=m_db->Prepare("SELECT Name,PublicKey,PrivateKey,SingleUse,PublishTrustList,PublishBoardList,PublishFreesite FROM tblLocalIdentity WHERE PublicKey IS NOT NULL AND PrivateKey IS NOT NULL;");\r
67                         exp.Step();\r
68                         while(exp.RowReturned())\r
69                         {\r
70                                 std::string name="";\r
71                                 std::string publickey="";\r
72                                 std::string privatekey="";\r
73                                 std::string tempval="";\r
74                                 bool singleuse=false;\r
75                                 bool publishtrustlist=false;\r
76                                 bool publishboardlist=false;\r
77                                 bool publishfreesite=false;\r
78 \r
79                                 exp.ResultText(0,name);\r
80                                 exp.ResultText(1,publickey);\r
81                                 exp.ResultText(2,privatekey);\r
82                                 exp.ResultText(3,tempval);\r
83                                 if(tempval=="true")\r
84                                 {\r
85                                         singleuse=true;\r
86                                 }\r
87                                 exp.ResultText(4,tempval);\r
88                                 if(tempval=="true")\r
89                                 {\r
90                                         publishtrustlist=true;\r
91                                 }\r
92                                 exp.ResultText(5,tempval);\r
93                                 if(tempval=="true")\r
94                                 {\r
95                                         publishboardlist=true;\r
96                                 }\r
97                                 exp.ResultText(6,tempval);\r
98                                 if(tempval=="true")\r
99                                 {\r
100                                         publishfreesite=true;\r
101                                 }\r
102 \r
103                                 xml.AddIdentity(name,publickey,privatekey,singleuse,publishtrustlist,publishboardlist,publishfreesite);\r
104 \r
105                                 exp.Step();\r
106                         }\r
107                         return "HTTP/1.1 200 OK\r\nContent-Type: text/xml\r\nContent-Disposition: attachment; filename=identities.xml\r\n\r\n"+xml.GetXML();\r
108                 }\r
109                 if((*queryvars.find("formaction")).second=="import")\r
110                 {\r
111                         if(queryvars.find("file")!=queryvars.end())\r
112                         {\r
113                                 IdentityExportXML xml;\r
114                                 if(xml.ParseXML((*queryvars.find("file")).second))\r
115                                 {\r
116                                         SQLite3DB::Statement imp=m_db->Prepare("INSERT INTO tblLocalIdentity(Name,PublicKey,PrivateKey,SingleUse,PublishTrustList,PublishBoardList,PublishFreesite) VALUES(?,?,?,?,?,?,?);");\r
117                                         for(int i=0; i<xml.GetCount(); i++)\r
118                                         {\r
119                                                 std::string tempval="false";\r
120                                                 imp.Bind(0,xml.GetName(i));\r
121                                                 imp.Bind(1,xml.GetPublicKey(i));\r
122                                                 imp.Bind(2,xml.GetPrivateKey(i));\r
123                                                 if(xml.GetSingleUse(i))\r
124                                                 {\r
125                                                         tempval="true";\r
126                                                 }\r
127                                                 else\r
128                                                 {\r
129                                                         tempval="false";\r
130                                                 }\r
131                                                 imp.Bind(3,tempval);\r
132                                                 if(xml.GetPublishTrustList(i))\r
133                                                 {\r
134                                                         tempval="true";\r
135                                                 }\r
136                                                 else\r
137                                                 {\r
138                                                         tempval="false";\r
139                                                 }\r
140                                                 imp.Bind(4,tempval);\r
141                                                 if(xml.GetPublishBoardList(i))\r
142                                                 {\r
143                                                         tempval="true";\r
144                                                 }\r
145                                                 else\r
146                                                 {\r
147                                                         tempval="false";\r
148                                                 }\r
149                                                 imp.Bind(5,tempval);\r
150                                                 if(xml.GetPublishFreesite(i))\r
151                                                 {\r
152                                                         tempval="true";\r
153                                                 }\r
154                                                 else\r
155                                                 {\r
156                                                         tempval="false";\r
157                                                 }\r
158                                                 imp.Bind(6,tempval);\r
159                                                 imp.Step();\r
160                                                 imp.Reset();\r
161                                         }\r
162                                 }\r
163                         }\r
164                 }\r
165         }\r
166 \r
167         content+="<h2>Local Identities</h2>";\r
168 \r
169         content+="<table><tr><th>Export Identities</th><th>Import Identities</th></tr>";\r
170         content+="<tr><td>";\r
171         content+="<form name=\"frmexport\" method=\"POST\">";\r
172         content+="<input type=\"hidden\" name=\"formaction\" value=\"export\">";\r
173         content+="<input type=\"submit\" value=\"Export Identities\">";\r
174         content+="</form>";\r
175         content+="</td><td>";\r
176         content+="<form name=\"frmimport\" method=\"POST\" enctype=\"multipart/form-data\">";\r
177         content+="<input type=\"hidden\" name=\"formaction\" value=\"import\">";\r
178         content+="<input type=\"file\" name=\"file\">";\r
179         content+="<input type=\"submit\" value=\"Import Identities\">";\r
180         content+="</form>";\r
181         content+="</td></tr></table>";\r
182 \r
183         content+="<hr>";\r
184 \r
185 //      content+="<form name=\"frmlocalidentity\" method=\"POST\">";\r
186 //      content+="<input type=\"hidden\" name=\"formaction\" value=\"update\">";\r
187         content+="<table><tr><th>Name</th><th>Single Use</th><th>Publish Trust List</th><th>Publish Board List</th><th>Publish Freesite</th><th>Announced? *</th></tr>";\r
188 \r
189         SQLite3DB::Statement st=m_db->Prepare("SELECT LocalIdentityID,tblLocalIdentity.Name,tblLocalIdentity.PublicKey,tbLLocalIdentity.PublishTrustList,tblLocalIdentity.SingleUse,tblLocalIdentity.PublishBoardList,tblIdentity.IdentityID,tblLocalIdentity.PublishFreesite FROM tblLocalIdentity LEFT JOIN tblIdentity ON tblLocalIdentity.PublicKey=tblIdentity.PublicKey ORDER BY tblLocalIdentity.Name;");\r
190         st.Step();\r
191 \r
192         SQLite3DB::Statement trustst=m_db->Prepare("SELECT COUNT(*) FROM tblPeerTrust LEFT JOIN tblIdentity ON tblPeerTrust.TargetIdentityID=tblIdentity.IdentityID WHERE tblIdentity.PublicKey=? GROUP BY tblPeerTrust.TargetIdentityID;");\r
193 \r
194         count=0;\r
195         while(st.RowReturned())\r
196         {\r
197                 StringFunctions::Convert(count,countstr);\r
198                 std::string id="";\r
199                 std::string name="";\r
200                 std::string publickey="";\r
201                 std::string publishtrustlist="";\r
202                 std::string singleuse="";\r
203                 std::string publishboardlist="";\r
204                 std::string publishfreesite="";\r
205 \r
206                 st.ResultText(0,id);\r
207                 st.ResultText(1,name);\r
208                 st.ResultText(2,publickey);\r
209                 st.ResultText(3,publishtrustlist);\r
210                 st.ResultText(4,singleuse);\r
211                 st.ResultText(5,publishboardlist);\r
212                 st.ResultText(7,publishfreesite);\r
213 \r
214                 content+="<tr>";\r
215 //              content+="<td><input type=\"checkbox\" name=\"chkidentityid["+countstr+"]\" value=\""+id+"\"></td>";\r
216                 content+="<td title=\""+publickey+"\"><form name=\"frmupdate\""+countstr+"\" method=\"POST\"><input type=\"hidden\" name=\"formaction\" value=\"update\"><input type=\"hidden\" name=\"chkidentityid["+countstr+"]\" value=\""+id+"\">"+SanitizeOutput(CreateShortIdentityName(name,publickey))+"</td>";\r
217                 content+="<td>"+CreateTrueFalseDropDown("singleuse["+countstr+"]",singleuse)+"</td>";\r
218                 content+="<td>"+CreateTrueFalseDropDown("publishtrustlist["+countstr+"]",publishtrustlist)+"</td>";\r
219                 content+="<td>"+CreateTrueFalseDropDown("publishboardlist["+countstr+"]",publishboardlist)+"</td>";\r
220                 content+="<td>"+CreateTrueFalseDropDown("publishfreesite["+countstr+"]",publishfreesite)+"</td>";\r
221                 \r
222                 trustst.Bind(0,publickey);\r
223                 trustst.Step();\r
224                 if(trustst.RowReturned())\r
225                 {\r
226                         std::string numlists="";\r
227                         trustst.ResultText(0,numlists);\r
228                         content+="<td>Yes ("+numlists+")</td>";\r
229                 }\r
230                 else\r
231                 {\r
232                         content+="<td>No</td>";\r
233                 }\r
234                 trustst.Reset();\r
235 \r
236 /*\r
237                 if(st.ResultNull(6))\r
238                 {\r
239                         content+="<td>No</td>";\r
240                 }\r
241                 else\r
242                 {\r
243                         content+="<td>Yes</td>";\r
244                 }\r
245 */\r
246 \r
247                 content+="<td><input type=\"submit\" value=\"Update\"></form></td>";\r
248                 content+="<td><form name=\"frmdel\""+countstr+"\" method=\"POST\"><input type=\"hidden\" name=\"formaction\" value=\"delete\"><input type=\"hidden\" name=\"chkidentityid["+countstr+"]\" value=\""+id+"\"><input type=\"submit\" value=\"Delete\"></form></td>";\r
249                 content+="</tr>";\r
250                 st.Step();\r
251                 count++;\r
252         }\r
253 \r
254 //      content+="<tr><td colspan=\"5\"><center><input type=\"submit\" value=\"Update Selected\"> <input type=\"submit\" value=\"Delete Selected\" onClick=\"if(confirm('Delete Selected Identities?')){frmlocalidentity.formaction.value='delete';}else{return false;}\"></td></tr>";\r
255         content+="</table>";\r
256         content+="<p class=\"paragraph\">* An identity is considered successfully announced when you have downloaded a trust list from someone that contains the identity.  The number in parenthesis is how many trust lists that identity appears in.</p>";\r
257         content+="<p class=\"paragraph\">Single Use Identities will automatically be deleted 7 days after creation.</p>";\r
258 \r
259         return "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n"+StringFunctions::Replace(m_template,"[CONTENT]",content);\r
260 }\r
261 \r
262 const bool LocalIdentitiesPage::WillHandleURI(const std::string &uri)\r
263 {\r
264         if(uri.find("localidentities.")!=std::string::npos)\r
265         {\r
266                 return true;\r
267         }\r
268         else\r
269         {\r
270                 return false;\r
271         }\r
272 }\r