Context-detection API for Android developed as a university project
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

admin.php 8.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. <?PHP
  2. session_start();
  3. $allowedIDs = array(
  4. 'https://www.google.com/accounts/o8/id?id=AItOawk9b32oBoVvjzwEhvC2GOhsxj0MN2mWoc8', // Me
  5. 'https://www.google.com/accounts/o8/id?id=AItOawk8LzSeazeZxqMCTVKm-OkUu0mLDLOqBBs', // Simon
  6. );
  7. if (isset($_SESSION['openid']['error'])) {
  8. // Failed OpenID login attempt
  9. echo 'ERROR: ', htmlentities($_SESSION['openid']['error']);
  10. unset($_SESSION['openid']['error']);
  11. exit;
  12. } else if (isset($_SESSION['openid']['validated']) && $_SESSION['openid']['validated']) {
  13. if (!in_array($_SESSION['openid']['identity'], $allowedIDs)) {
  14. echo 'ERROR: ', htmlentities($_SESSION['openid']['identity']), ' not permitted';
  15. exit;
  16. }
  17. } else {
  18. if (!isset($_REQUEST['openid_mode'])) {
  19. $_POST['openid_url'] = 'https://www.google.com/accounts/o8/id';
  20. }
  21. require('openid/processor.php');
  22. exit;
  23. }
  24. # -------------- End of authentication code --------------------------
  25. require('common.php');
  26. # -------------- Form handling -----------------
  27. function process_activity_add($args) {
  28. $sql = 'INSERT INTO activities (activity_name, activity_parent) VALUES (\'';
  29. $sql .= m($args['name']) . '\', ' . ((int) $args['parent']) . ')';
  30. mysql_query($sql);
  31. }
  32. function process_activity_delete($args) {
  33. $sql = 'DELETE FROM windowclassifications WHERE activity_id = ' . ((int) $args['id']);
  34. mysql_query($sql);
  35. $sql = 'SELECT activity_id FROM activities WHERE activity_parent = ' . ((int) $args['id']);
  36. $res = mysql_query($sql);
  37. while ($row = mysql_fetch_assoc($res)) {
  38. process_activity_delete(array('id' => $row['activity_id']));
  39. }
  40. $sql = 'DELETE FROM activities WHERE activity_id = ' . ((int) $args['id']);
  41. mysql_query($sql);
  42. }
  43. function process_sample_edit($args) {
  44. $sql = 'SELECT wc_id, activity_id, log_id, wc_offset FROM windowclassifications';
  45. $res = mysql_query($sql);
  46. $acs = getActivityArray();
  47. while ($row = mysql_fetch_assoc($res)) {
  48. $name = 'value_' . $row['log_id'] . '_' . $row['wc_offset'];
  49. if (isset($args[$name])) {
  50. if ((int) $args[$name] == (int) $row['activity_id']) {
  51. unset($args[$name]);
  52. } else {
  53. mysql_query('UPDATE windowclassifications SET activity_id = ' . ((int) $args[$name]) . ' WHERE wc_id = ' . $row['wc_id']);
  54. }
  55. }
  56. }
  57. foreach ($args as $name => $val) {
  58. if ($acs[$val] == 'UNCLASSIFIED/PENDING') { continue; }
  59. list($value, $log, $offset) = explode('_', $name);
  60. mysql_query('INSERT INTO windowclassifications (activity_id, log_id, wc_offset) VALUES ('. ((int) $val) . ', ' . ((int) $log) . ', ' . ((int) $offset) . ')');
  61. }
  62. }
  63. function process_export($args) {
  64. $acs = getActivityArray();
  65. $sql = 'SELECT wc_offset, activity_id, log_data FROM activities NATURAL JOIN windowclassifications NATURAL JOIN sensorlogger WHERE log_statuscode = 1 AND (0';
  66. foreach ($acs as $id => $name) {
  67. if (substr($name, 0, 10) == 'CLASSIFIED') {
  68. $sql .= ' OR activity_id = ' . $id;
  69. }
  70. }
  71. $sql .= ')';
  72. $res = mysql_query($sql);
  73. header('Content-type: text/plain');
  74. while ($row = mysql_fetch_assoc($res)) {
  75. echo 'Activity: ', $acs[$row['activity_id']], "\n";
  76. $data = array_slice(explode("\n", $row['log_data']), $row['wc_offset'], 128);
  77. echo implode("\n", $data);
  78. echo "\n";
  79. }
  80. exit;
  81. }
  82. if (isset($_POST['action'])) {
  83. $args = array();
  84. $action = str_replace('.', '_', $_POST['action']) . '_';
  85. foreach ($_POST as $k => $v) {
  86. if (substr($k, 0, strlen($action)) == $action) {
  87. $args[substr($k, strlen($action))] = $v;
  88. }
  89. }
  90. call_user_func('process_' . str_replace('.', '_', $_POST['action']), $args);
  91. header('Location: /android/admin.php');
  92. exit;
  93. }
  94. # ------------------- End of form handling ----------------------
  95. $acs = getActivityArray();
  96. ?>
  97. <h1>Activity management</h1>
  98. <h2>Add an activity</h2>
  99. <form action="admin.php" method="post">
  100. <input type="hidden" name="action" value="activity.add">
  101. <select name="activity.add.parent">
  102. <?PHP
  103. asort($acs);
  104. foreach ($acs as $id => $name) {
  105. echo ' <option value="', $id, '">', htmlentities($name), '</option>';
  106. }
  107. ?>
  108. </select> /
  109. <input type="text" name="activity.add.name">
  110. <input type="submit" value="Add">
  111. </form>
  112. <h2>Delete an activity</h2>
  113. <form action="admin.php" method="post">
  114. <input type="hidden" name="action" value="activity.delete">
  115. <select name="activity.delete.id">
  116. <?PHP
  117. asort($acs);
  118. foreach ($acs as $id => $name) {
  119. echo ' <option value="', $id, '">', htmlentities($name), '</option>';
  120. }
  121. ?>
  122. <input type="submit" value="Delete">
  123. </form>
  124. <h1>Export</h1>
  125. <form action="admin.php" method="post">
  126. <input type="hidden" name="action" value="export">
  127. <input type="submit" value="Export classified windows">
  128. </form>
  129. <h1>Sample management</h1>
  130. <?PHP
  131. $sql = 'SELECT log_id, log_imei, log_version, log_time, log_activity, log_data FROM sensorlogger WHERE log_statuscode = 1';
  132. $res = mysql_query($sql);
  133. ?>
  134. <style type="text/css">
  135. .windowed { background: url('windowbg.png') repeat-y -256px 0px; }
  136. .windowboxes { margin: 0px; padding: 0px; border-right: 1px solid black; display: inline-block; }
  137. .windowboxes li { display: inline-block; width: 255px; text-align: center; border: 1px solid black; margin: 0px; padding: 0px; border-right: 0; }
  138. .windowboxes.odd { padding-left: 128px; }
  139. .windowboxes li select { width: 253px; }
  140. </style>
  141. <script type="text/javascript">
  142. function showWindow(id, offset) {
  143. document.getElementById('window_' + id).style.backgroundPosition = (offset * 2) + "px 0px";
  144. }
  145. function hideWindow(id) {
  146. showWindow(id, -128);
  147. }
  148. function classifyAll(select) {
  149. var tr = select.parentNode.parentNode;
  150. var selects = tr.getElementsByTagName('select');
  151. for (var i = 0; i < selects.length; i++) {
  152. selects[i].value = select.value;
  153. }
  154. }
  155. </script>
  156. <form action="admin.php" method="post">
  157. <input type="hidden" name="action" value="sample.edit">
  158. <?PHP
  159. echo '<table border="1">';
  160. while ($row = mysql_fetch_assoc($res)) {
  161. $sql2 = 'SELECT wc_offset, activity_id FROM windowclassifications WHERE log_id = ' . $row['log_id'];
  162. $res2 = mysql_query($sql2);
  163. $wcs = array();
  164. while ($row2 = mysql_fetch_assoc($res2)) {
  165. $wcs[(int) $row2['wc_offset']] = (int) $row2['activity_id'];
  166. }
  167. $points = 0;
  168. echo '<tr><td><table>';
  169. foreach ($row as $k => $v) { echo '<tr><th>', $k, '</th><td>', $k == 'log_data' ? ($points = count(explode("\n", $v))) . ' line(s)' : nl2br(htmlentities($v)), '</td></tr>'; }
  170. echo '</table>';
  171. echo '<select onChange="classifyAll(this)">';
  172. echo ' <option value="">Classify all as...</option>';
  173. foreach ($acs as $id => $name) {
  174. echo '<option value="', $id, '">', htmlentities($name), '</option>';
  175. }
  176. echo '</select>';
  177. echo '</td><td>';
  178. echo '<ol class="windowboxes even">';
  179. for ($i = 0; $i + 128 < $points; $i += 128) {
  180. echo '<li onMouseOver="showWindow(', $row['log_id'], ', ', $i, ')" onMouseOut="hideWindow(', $row['log_id'], ')">';
  181. echo '<select name="sample.edit.value_', $row['log_id'], '_', $i, '">';
  182. foreach ($acs as $id => $name) {
  183. echo '<option value="', $id, '"', (isset($wcs[$i]) && $wcs[$i] == $id) || (!isset($wcs[$i]) && $name == 'UNCLASSIFIED/PENDING') ? ' selected="selected"' : '','>', htmlentities($name), '</option>';
  184. }
  185. echo '</select>';
  186. echo '</li>';
  187. }
  188. echo '</ol>';
  189. echo '<div class="windowed" id="window_', $row['log_id'], '" styleb"background-color: orange;">';
  190. echo '<img src="data.php?graph=', $row['log_id'], '&amp;ds=1&amp;imei=', $row['log_imei'], '" height="330">';
  191. echo '<br><img src="data.php?graph=', $row['log_id'], '&amp;ds=2&amp;imei=', $row['log_imei'], '" height="330">';
  192. echo '</div>';
  193. echo '<ol class="windowboxes odd">';
  194. for ($i = 64; $i + 128 < $points; $i += 128) {
  195. echo '<li onMouseOver="showWindow(', $row['log_id'], ', ', $i, ')" onMouseOut="hideWindow(', $row['log_id'], ')">';
  196. echo '<select name="sample.edit.value_', $row['log_id'], '_', $i, '">';
  197. foreach ($acs as $id => $name) {
  198. echo '<option value="', $id, '"', (isset($wcs[$i]) && $wcs[$i] == $id) || (!isset($wcs[$i]) && $name == 'UNCLASSIFIED/PENDING') ? ' selected="selected"' : '','>', htmlentities($name), '</option>';
  199. }
  200. echo '</select>';
  201. echo '</li>';
  202. }
  203. echo '</ol>';
  204. echo '</td>';
  205. echo '</tr>';
  206. }
  207. echo '</table>';
  208. ?>
  209. <input type="submit" value="SUBMIT ALL MODIFICATIONS">
  210. </form>