Mercurial > hg > fapweb
annotate admin.inc.php @ 5:76c3b89d7b11
Improve voting, clean up the code, etc.
author | Matti Hamalainen <ccr@tnsp.org> |
---|---|
date | Wed, 05 Dec 2012 08:08:58 +0200 |
parents | 8019b357cc03 |
children | d76020022881 |
rev | line source |
---|---|
0 | 1 <? |
2 // Check if sessions are enabled | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
3 if (!stChkSetting("admPassword")) |
0 | 4 { |
5 echo "<h1>Oh noes, admin configuration not done!</h1>\n". | |
6 "<p>Better go and prod that, so you get to use the fine admin interface.</p>\n"; | |
7 $authState = "error"; | |
8 } | |
9 else | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
10 if (stAdmSessionAuth()) |
0 | 11 { |
12 $authState = "ok"; | |
13 } | |
14 else | |
15 { | |
16 // Perform authentication if we are not in session already | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
17 echo |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
18 "<h1>Party admin login</h1>\n". |
0 | 19 "<p>Please use illegal telepathy over HTTP to provide a password to enter the party administration systembolaget.</p>\n". |
20 "<form name=\"admlogin\" action=\"login.php\" method=\"post\">\n". | |
21 stGetFormHiddenInput("mode", "check")."\n". | |
22 stGetFormHiddenInput("goto", $_SERVER["SERVER_NAME"].$_SERVER["REQUEST_URI"])."\n". | |
23 stGetFormPasswordInput("admpass", "pass", "")."\n". | |
24 " <input type=\"submit\" value=\" Login \" />\n". | |
25 "</form>\n"; | |
26 | |
27 $authState = "login"; | |
28 } | |
29 | |
30 if ($authState == "ok") | |
31 { | |
32 ?> | |
33 <script type="text/javascript"> | |
34 function statusMsg(msg) | |
35 { | |
36 document.getElementById("nstatus").innerHTML = msg; | |
37 } | |
38 | |
39 | |
40 function strtrim(str) | |
41 { | |
42 if (!str || str == null) | |
43 return ""; | |
44 return str.replace(/^\s+|\s+$/g,'') | |
45 } | |
46 | |
47 | |
48 function strencode(str) | |
49 { | |
50 return encodeURIComponent(escape(str)); | |
51 } | |
52 | |
53 | |
54 function createXMLRequest() | |
55 { | |
56 var req; | |
57 if (window.XMLHttpRequest) | |
58 { | |
59 // Modern browsers | |
60 req = new XMLHttpRequest(); | |
61 } | |
62 else | |
63 { | |
64 // Old IE versions | |
65 req = new ActiveXObject("Microsoft.XMLHTTP"); | |
66 } | |
67 return req; | |
68 } | |
69 | |
70 | |
71 function sendPOSTRequest(params, success, failure) | |
72 { | |
73 var req = createXMLRequest(); | |
74 req.open("POST", "ajax.php", true); | |
75 req.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); | |
76 req.setRequestHeader("Content-length", params.length); | |
77 req.setRequestHeader("Connection", "close"); | |
78 | |
79 req.onreadystatechange = function() | |
80 { | |
81 if (req.readyState == 4) | |
82 { | |
83 if (req.status == 404) | |
84 { | |
85 window.location = "logout"; | |
86 } | |
87 else | |
88 if (req.status == 200) | |
89 { | |
90 success(req.responseText); | |
91 statusMsg(req.statusText); | |
92 } | |
93 else | |
94 { | |
95 if (failure) | |
96 { | |
97 failure(req.status, req.statusText, req.responseText); | |
98 } | |
99 else | |
100 { | |
101 statusMsg("["+req.status+" - "+req.statusText+"] "+ req.responseText); | |
102 } | |
103 } | |
104 } | |
105 } | |
106 req.send(params); | |
107 } | |
108 | |
109 | |
110 function makePostArgs(fields, fprefix, fsuffix) | |
111 { | |
112 var res = []; | |
113 for (var id in fields) | |
114 { | |
115 var elem = document.getElementById(fprefix + id + fsuffix); | |
116 if (!elem) | |
117 { | |
118 alert("No such DOM element '"+ id +"'."); | |
119 return ""; | |
120 } | |
121 | |
122 switch (fields[id]) | |
123 { | |
124 case 0: | |
125 case 1: | |
126 { | |
127 var str = strtrim(elem.value); | |
128 if (fields[id] == 1 && str == "") | |
129 { | |
130 alert("One or more of the fields are empty."); | |
131 return ""; | |
132 } | |
133 res.push(id+"="+strencode(str)); | |
134 } | |
135 break; | |
136 | |
137 case 2: | |
138 res.push(id+"="+parseInt(elem.value)); | |
139 break; | |
140 | |
141 case 3: | |
142 res.push(id+"="+(elem.checked ? "1" : "0")); | |
143 break; | |
144 | |
145 } | |
146 } | |
147 return res.join("&"); | |
148 } | |
149 | |
150 | |
151 function refreshItems(id,name,msgname) | |
152 { | |
153 var msuccess = function(txt) | |
154 { | |
155 var nitem = document.getElementById(id); | |
156 nitem.innerHTML = txt; | |
157 } | |
158 | |
159 sendPOSTRequest("action=get&type="+name, msuccess); | |
160 } | |
161 | |
162 | |
163 function deleteItem(id,prefix,type,func,dsc) | |
164 { | |
165 var msuccess = function(txt) | |
166 { | |
167 var item = document.getElementById(prefix+id); | |
168 item.style.display = "none"; | |
169 setTimeout(func, 550); | |
170 } | |
171 | |
172 if (confirm("Are you sure you want to delete "+dsc+" #"+id+"?")) | |
173 { | |
174 sendPOSTRequest("action=delete&type="+type+"&id="+id, msuccess); | |
175 } | |
176 } | |
177 | |
178 | |
179 function refreshNews() | |
180 { | |
181 refreshItems("nnews", "news", "News list"); | |
182 } | |
183 | |
184 | |
185 function refreshAttendees() | |
186 { | |
187 refreshItems("nattendees", "attendees", "Attendees list"); | |
188 } | |
189 | |
190 | |
191 function refreshDump() | |
192 { | |
193 var msuccess = function(txt) | |
194 { | |
195 var nitem = document.getElementById("ndump"); | |
196 nitem.innerHTML = txt; | |
197 } | |
198 | |
199 sendPOSTRequest("action=dump&type=attendees", msuccess); | |
200 } | |
201 | |
202 | |
203 function refreshCompos() | |
204 { | |
205 refreshItems("ncompos", "compos", "Compo list"); | |
206 } | |
207 | |
208 | |
209 function refreshEntries() | |
210 { | |
211 refreshItems("nentries", "entries", "Entry list"); | |
212 } | |
213 | |
214 | |
215 function refreshVoters() | |
216 { | |
217 refreshItems("nvoters", "voters", "Voters list"); | |
218 } | |
219 | |
220 | |
221 function addNews() | |
222 { | |
223 var args = makePostArgs({"title":1,"text":1,"author":1}, "nn", ""); | |
224 | |
225 var msuccess = function(txt) | |
226 { | |
227 setTimeout("refreshNews();", 550); | |
228 } | |
229 | |
230 sendPOSTRequest( | |
231 "action=add&type=news&"+args, | |
232 msuccess); | |
233 return false; | |
234 } | |
235 | |
236 | |
237 function deleteNews(id) | |
238 { | |
239 deleteItem(id, "news", "news", "refreshNews();", "news item"); | |
240 } | |
241 | |
242 | |
243 function deleteAttendee(id) | |
244 { | |
245 deleteItem(id, "attendee", "attendees", "refreshAttendees();", "attendee"); | |
246 } | |
247 | |
248 | |
249 function updateAttendee(id) | |
250 { | |
251 var args = makePostArgs({"oneliner":0,"email":0}, "at", id); | |
252 | |
253 sendPOSTRequest("action=update&type=attendees&id="+id+"&"+args); | |
254 } | |
255 | |
256 | |
257 function addCompo() | |
258 { | |
259 var args = makePostArgs({"name":1, "description":1}, "nc", ""); | |
260 | |
261 var msuccess = function(txt) | |
262 { | |
263 setTimeout("refreshCompos();", 550); | |
264 } | |
265 | |
266 sendPOSTRequest("action=add&type=compo&"+args, msuccess); | |
267 return false; | |
268 } | |
269 | |
270 | |
271 function updateCompo(id) | |
272 { | |
273 var args = makePostArgs({"name":1, "description":1, "enabled":3}, "co", id); | |
274 | |
275 sendPOSTRequest("action=update&type=compo&id="+id+"&"+args); | |
276 } | |
277 | |
278 | |
279 function addEntry(id) | |
280 { | |
281 var args = makePostArgs({"name":1, "author":1}, "ne", id); | |
282 | |
283 var msuccess = function(txt) | |
284 { | |
285 setTimeout("refreshEntries();", 550); | |
286 } | |
287 | |
288 sendPOSTRequest("action=add&type=entry&compo_id="+id+"&"+args, msuccess); | |
289 return false; | |
290 } | |
291 | |
292 | |
293 function updateEntry(id) | |
294 { | |
295 var args = makePostArgs({"name":1, "author":1}, "en", id); | |
296 | |
297 sendPOSTRequest( | |
298 "action=update&type=entry&id="+id+"&"+args); | |
299 } | |
300 | |
301 | |
302 function deleteEntry(id) | |
303 { | |
304 deleteItem(id, "entry", "entries", "refreshEntries();", "entry"); | |
305 } | |
306 | |
307 | |
308 function updateVoter(id) | |
309 { | |
310 var args = makePostArgs({"enabled":3, "name":0}, "vo", id); | |
311 | |
312 sendPOSTRequest("action=update&type=voter&id="+id+"&"+args); | |
313 } | |
314 | |
315 | |
316 var registeredTabs = Object(); | |
317 | |
318 | |
319 function updateTabList() | |
320 { | |
321 var item = document.getElementById("pageTabs"); | |
322 var str = ""; | |
323 for (var id in registeredTabs) | |
324 { | |
325 str += "<a href=\"#\" onClick=\"switchActiveTab('"+ | |
326 id+"')\">"+registeredTabs[id]+"</a>"; | |
327 } | |
328 | |
329 str += "<a class=\"admin\" href=\"logout\">Logout</a>"; | |
330 | |
331 item.innerHTML = str; | |
332 } | |
333 | |
334 | |
335 function registerTab(id, name) | |
336 { | |
337 registeredTabs[id] = name; | |
338 } | |
339 | |
340 | |
341 function refreshTabs() | |
342 { | |
343 for (var id in registeredTabs) | |
344 { | |
345 setTimeout("refresh"+ registeredTabs[id] +"();", 10); | |
346 } | |
347 } | |
348 | |
349 | |
350 function switchActiveTab(tab) | |
351 { | |
352 for (var id in registeredTabs) | |
353 { | |
354 var ob = document.getElementById(id); | |
355 if (ob) | |
356 { | |
357 ob.style.display = (tab == id) ? "block" : "none"; | |
358 if (tab == id) | |
359 { | |
360 setTimeout("refresh"+ registeredTabs[id] +"();", 10); | |
361 } | |
362 } | |
363 } | |
364 } | |
365 </script> | |
366 | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
367 <!-- ========================== --> |
0 | 368 |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
369 <div id="nstatus">-</div> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
370 |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
371 <div id="pageTabs"></div> |
0 | 372 |
373 <!-- ========================== --> | |
374 | |
375 <div id="ntab0"> | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
376 <form method="post" action="" onsubmit="return addNews()"> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
377 <input id="nntitle" type="text" size="40" /><br /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
378 <textarea id="nntext" rows="5" cols="60"></textarea><br /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
379 <input id="nnauthor" type="text" value="orgaz" /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
380 <input id="nnadd" type="submit" value=" Add post " /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
381 <input type="button" value=" Clear " onClick="this.form.reset()" /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
382 </form> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
383 <hr /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
384 <div id="nnews"></div> |
0 | 385 </div> |
386 | |
387 <!-- ========================== --> | |
388 | |
389 <div id="ntab1"> | |
390 <div id="nattendees"> | |
391 </div> | |
392 </div> | |
393 | |
394 <!-- ========================== --> | |
395 | |
396 <div id="ntab2"> | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
397 <div id="ndump"></div> |
0 | 398 </div> |
399 | |
400 <!-- ========================== --> | |
401 | |
402 <div id="ntab3"> | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
403 <form method="post" action="" onsubmit="return addCompo()"> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
404 <input id="ncname" type="text" size="64" /><br /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
405 <textarea id="ncdescription" rows="5" cols="60"></textarea><br /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
406 <input id="nccompo" type="submit" value=" Add compo " /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
407 <input type="button" value=" Clear " onClick="this.form.reset()" /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
408 </form> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
409 <hr /> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
410 <div id="ncompos"></div> |
0 | 411 </div> |
412 | |
413 <!-- ========================== --> | |
414 | |
415 <div id="ntab4"> | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
416 <div id="nentries"></div> |
0 | 417 </div> |
418 | |
419 <!-- ========================== --> | |
420 | |
421 <div id="ntab5"> | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
422 <p> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
423 Key entries can only be generated via the shell-utility 'keygen'. |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
424 </p> |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
425 <div id="nvoters"></div> |
0 | 426 </div> |
427 | |
428 <!-- ========================== --> | |
429 | |
430 <script type="text/javascript"> | |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
431 registerTab("ntab0", "News"); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
432 registerTab("ntab1", "Attendees"); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
433 registerTab("ntab2", "Dump"); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
434 registerTab("ntab3", "Compos"); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
435 registerTab("ntab4", "Entries"); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
436 registerTab("ntab5", "Voters"); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
437 updateTabList(); |
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
438 switchActiveTab("ntab0"); |
0 | 439 </script> |
5
76c3b89d7b11
Improve voting, clean up the code, etc.
Matti Hamalainen <ccr@tnsp.org>
parents:
0
diff
changeset
|
440 <? } ?> |