plug_adminusers.php 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. <?php
  2. if (!class_exists("plug_adminusers")) {
  3. class plug_adminusers {
  4. function __construct($ns) {
  5. $this->title = __("adminusers", "dagsopt");
  6. $this->pluginname = $ns->pluginname;
  7. $this->file = $ns->file;
  8. $this->ns = $ns;
  9. }
  10. function start() {
  11. add_action('manage_users_custom_column', array(&$this, 'imel_custom_column_userfield'), 15, 3);
  12. add_filter('manage_users_columns', array(&$this, 'imel_column_userfield'), 15, 1);
  13. add_filter('manage_users_sortable_columns', array(&$this, 'user_sortable_columns'), 15, 1);
  14. if (is_admin()) {
  15. //prolly not necessary, but I do want to be sure this only runs within the admin
  16. add_action('pre_user_query', array(&$this, 'my_user_query'));
  17. }
  18. }
  19. function help() {
  20. ?>
  21. <?php echo (__("Adds adminusers functions", "dagsopt")) ?>
  22. <?php
  23. }
  24. function Option($pre) {
  25. // update_option($pre . '_support_splash', $_POST[$pre . '_support_splash']);
  26. }
  27. function admin_line($pre) {
  28. ?>
  29. <hr>
  30. <?php
  31. }
  32. function imel_column_userfield($defaults) {
  33. $defaults['lastlogin'] = __('Seneste Login', 'lastlogin-column');
  34. $defaults['lastview'] = __('Sidst set', 'lastlogin-column');
  35. $defaults['proselect'] = __('Pro/Select', 'user-column');
  36. $defaults['gruppe'] = __('Gruppe', 'id-column');
  37. $defaults['navn'] = __('Navn', 'navn-column');
  38. $defaults['session'] = __('Sessions', 'session-column');
  39. $defaults['id'] = __('id', 'id-column');
  40. return $defaults;
  41. }
  42. function imel_custom_column_userfield($value, $column_name, $id) {
  43. if ($column_name == 'lastlogin') {
  44. $ss = get_user_meta($id, 'last_login', true);
  45. if ($ss) {
  46. $the_login_date = human_time_diff($ss);
  47. return $the_login_date;
  48. } else {
  49. return " ";
  50. }
  51. }
  52. if ($column_name == 'lastview') {
  53. $ss = get_user_meta($id, 'last_view', true);
  54. if ($ss) {
  55. $the_login_date = human_time_diff($ss);
  56. return $the_login_date;
  57. } else {
  58. return " ";
  59. }
  60. }
  61. if ($column_name == 'proselect') {
  62. $s = get_user_meta($id, 'Proselect', true);
  63. return $s;
  64. }
  65. if ($column_name == 'gruppe') {
  66. $s = get_user_meta($id, 'Gruppe', true);
  67. return $s;
  68. }
  69. if ($column_name == 'id') {
  70. return $id;
  71. }
  72. if ($column_name == 'navn') {
  73. return get_user_meta($id, 'Navn', true);
  74. }
  75. if ($column_name == 'session2') {
  76. $ss = get_user_meta($id, 'session_tokens', true);
  77. if ($ss) {
  78. $s = "";
  79. foreach ($ss as $name => $obj) {
  80. // $s .= human_time_diff($obj['login']) . " " . $obj['ua'] . "\n";
  81. $s .= human_time_diff($obj['login']) . " <br> ";
  82. }
  83. return $s;
  84. } else {
  85. return "N";
  86. }
  87. }
  88. if ($column_name == 'session') {
  89. $ss = get_user_meta($id, 'session_tokens', true);
  90. if ($ss) {
  91. $s = "";
  92. $i = 0;
  93. foreach ($ss as $name => $obj) {
  94. if ($i < 2) {
  95. $s .= human_time_diff($obj['login']) . " ";
  96. }
  97. $i++;
  98. }
  99. return count($ss) . ' | ' . $s . '';
  100. } else {
  101. return "N";
  102. }
  103. }
  104. if ($column_name == 'imel-login2-userfield') {
  105. $ss = get_user_meta($id, 'session_tokens', true);
  106. if ($ss) {
  107. //$f = array_pop(array_keys($ss));
  108. //return human_time_diff($ss[$f]['login']);
  109. return "L";
  110. } else {
  111. return "N";
  112. }
  113. }
  114. }
  115. function user_sortable_columns($columns) {
  116. $columns['session'] = 'session';
  117. $columns['id'] = 'id';
  118. $columns['gruppe'] = 'gruppe';
  119. $columns['proselect'] = 'proselect';
  120. $columns['lastlogin'] = 'lastlogin';
  121. $columns['lastview'] = 'lastview';
  122. return $columns;
  123. }
  124. function my_user_query($userquery) {
  125. if ('session' == $userquery->query_vars['orderby']) {
  126. global $wpdb;
  127. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  128. $userquery->query_where .= " AND alias.meta_key = 'session_tokens' "; //which meta are we sorting with?
  129. $userquery->query_orderby = " ORDER BY length(alias.meta_value) " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  130. }
  131. if ('proselect' == $userquery->query_vars['orderby']) {
  132. global $wpdb;
  133. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  134. $userquery->query_where .= " AND alias.meta_key = 'Proselect' "; //which meta are we sorting with?
  135. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  136. }
  137. if ('gruppe' == $userquery->query_vars['orderby']) {
  138. global $wpdb;
  139. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  140. $userquery->query_where .= " AND alias.meta_key = 'Gruppe' "; //which meta are we sorting with?
  141. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  142. }
  143. if ('lastlogin' == $userquery->query_vars['orderby']) {
  144. global $wpdb;
  145. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  146. $userquery->query_where .= " AND alias.meta_key = 'last_login' "; //which meta are we sorting with?
  147. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  148. }
  149. if ('lastview' == $userquery->query_vars['orderby']) {
  150. global $wpdb;
  151. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  152. $userquery->query_where .= " AND alias.meta_key = 'last_view' "; //which meta are we sorting with?
  153. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  154. }
  155. if ('id' == $userquery->query_vars['orderby']) {
  156. global $wpdb;
  157. //$userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  158. //$userquery->query_where .= " AND alias.meta_key = 'session_tokens' "; //which meta are we sorting with?
  159. $userquery->query_orderby = " ORDER BY ID " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  160. }
  161. }
  162. }
  163. global $plug_adminusers;
  164. $plug_adminusers = new plug_adminusers($this);
  165. $this->dagsopt['plug_adminusers'] = $plug_adminusers;
  166. }