Context-detection API for Android developed as a university project
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

admin.php 6.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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_sample_edit($args) {
  33. $sql = 'SELECT wc_id, activity_id, log_id, wc_offset FROM windowclassifications';
  34. $res = mysql_query($sql);
  35. $acs = getActivityArray();
  36. while ($row = mysql_fetch_assoc($res)) {
  37. $name = 'value_' . $row['log_id'] . '_' . $row['wc_offset'];
  38. if (isset($args[$name])) {
  39. if ((int) $args[$name] == (int) $row['activity_id']) {
  40. unset($args[$name]);
  41. } else {
  42. mysql_query('UPDATE windowclassifications SET activity_id = ' . ((int) $args[$name]) . ' WHERE wc_id = ' . $row['wc_id']);
  43. }
  44. }
  45. }
  46. foreach ($args as $name => $val) {
  47. if ($acs[$val] == 'UNCLASSIFIED/PENDING') { continue; }
  48. list($value, $log, $offset) = explode('_', $name);
  49. mysql_query('INSERT INTO windowclassifications (activity_id, log_id, wc_offset) VALUES ('. ((int) $val) . ', ' . ((int) $log) . ', ' . ((int) $offset) . ')');
  50. }
  51. }
  52. if (isset($_POST['action'])) {
  53. $args = array();
  54. $action = str_replace('.', '_', $_POST['action']) . '_';
  55. foreach ($_POST as $k => $v) {
  56. if (substr($k, 0, strlen($action)) == $action) {
  57. $args[substr($k, strlen($action))] = $v;
  58. }
  59. }
  60. call_user_func('process_' . str_replace('.', '_', $_POST['action']), $args);
  61. header('Location: /android/admin.php');
  62. exit;
  63. }
  64. # ------------------- End of form handling ----------------------
  65. $acs = getActivityArray();
  66. ?>
  67. <h1>Activity management</h1>
  68. <h2>Add an activity</h2>
  69. <form action="admin.php" method="post">
  70. <input type="hidden" name="action" value="activity.add">
  71. <select name="activity.add.parent">
  72. <?PHP
  73. asort($acs);
  74. foreach ($acs as $id => $name) {
  75. echo ' <option value="', $id, '">', htmlentities($name), '</option>';
  76. }
  77. ?>
  78. </select> /
  79. <input type="text" name="activity.add.name">
  80. <input type="submit" value="Add">
  81. </form>
  82. <h1>Sample management</h1>
  83. <?PHP
  84. $sql = 'SELECT log_id, log_imei, log_version, log_time, log_activity, log_data FROM sensorlogger WHERE log_statuscode = 1';
  85. $res = mysql_query($sql);
  86. ?>
  87. <style type="text/css">
  88. .windowed { background: url('windowbg.png') repeat-y -256px 0px; }
  89. .windowboxes { margin: 0px; padding: 0px; border-right: 1px solid black; display: inline-block; }
  90. .windowboxes li { display: inline-block; width: 255px; text-align: center; border: 1px solid black; margin: 0px; padding: 0px; border-right: 0; }
  91. .windowboxes.odd { padding-left: 128px; }
  92. .windowboxes li select { width: 253px; }
  93. </style>
  94. <script type="text/javascript">
  95. function showWindow(id, offset) {
  96. document.getElementById('window_' + id).style.backgroundPosition = (offset * 2) + "px 0px";
  97. }
  98. function hideWindow(id) {
  99. showWindow(id, -128);
  100. }
  101. function classifyAll(select) {
  102. var tr = select.parentNode.parentNode;
  103. var selects = tr.getElementsByTagName('select');
  104. for (var i = 0; i < selects.length; i++) {
  105. selects[i].value = select.value;
  106. }
  107. }
  108. </script>
  109. <form action="admin.php" method="post">
  110. <input type="hidden" name="action" value="sample.edit">
  111. <?PHP
  112. echo '<table border="1">';
  113. while ($row = mysql_fetch_assoc($res)) {
  114. $sql2 = 'SELECT wc_offset, activity_id FROM windowclassifications WHERE log_id = ' . $row['log_id'];
  115. $res2 = mysql_query($sql2);
  116. $wcs = array();
  117. while ($row2 = mysql_fetch_assoc($res2)) {
  118. $wcs[(int) $row2['wc_offset']] = (int) $row2['activity_id'];
  119. }
  120. $points = 0;
  121. echo '<tr><td><table>';
  122. 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>'; }
  123. echo '</table>';
  124. echo '<select onChange="classifyAll(this)">';
  125. echo ' <option value="">Classify all as...</option>';
  126. foreach ($acs as $id => $name) {
  127. echo '<option value="', $id, '">', htmlentities($name), '</option>';
  128. }
  129. echo '</select>';
  130. echo '</td><td>';
  131. echo '<ol class="windowboxes even">';
  132. for ($i = 0; $i + 128 < $points; $i += 128) {
  133. echo '<li onMouseOver="showWindow(', $row['log_id'], ', ', $i, ')" onMouseOut="hideWindow(', $row['log_id'], ')">';
  134. echo '<select name="sample.edit.value_', $row['log_id'], '_', $i, '">';
  135. foreach ($acs as $id => $name) {
  136. echo '<option value="', $id, '"', (isset($wcs[$i]) && $wcs[$i] == $id) || (!isset($wcs[$i]) && $name == 'UNCLASSIFIED/PENDING') ? ' selected="selected"' : '','>', htmlentities($name), '</option>';
  137. }
  138. echo '</select>';
  139. echo '</li>';
  140. }
  141. echo '</ol>';
  142. echo '<div class="windowed" id="window_', $row['log_id'], '" styleb"background-color: orange;">';
  143. echo '<img src="data.php?graph=', $row['log_id'], '&amp;ds=1&amp;imei=', $row['log_imei'], '" height="330">';
  144. echo '<br><img src="data.php?graph=', $row['log_id'], '&amp;ds=2&amp;imei=', $row['log_imei'], '" height="330">';
  145. echo '</div>';
  146. echo '<ol class="windowboxes odd">';
  147. for ($i = 64; $i + 128 < $points; $i += 128) {
  148. echo '<li onMouseOver="showWindow(', $row['log_id'], ', ', $i, ')" onMouseOut="hideWindow(', $row['log_id'], ')">';
  149. echo '<select name="sample.edit.value_', $row['log_id'], '_', $i, '">';
  150. foreach ($acs as $id => $name) {
  151. echo '<option value="', $id, '"', (isset($wcs[$i]) && $wcs[$i] == $id) || (!isset($wcs[$i]) && $name == 'UNCLASSIFIED/PENDING') ? ' selected="selected"' : '','>', htmlentities($name), '</option>';
  152. }
  153. echo '</select>';
  154. echo '</li>';
  155. }
  156. echo '</ol>';
  157. echo '</td>';
  158. echo '</tr>';
  159. }
  160. echo '</table>';
  161. ?>
  162. <input type="submit" value="SUBMIT ALL MODIFICATIONS">
  163. </form>