plug_adminusers.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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'] = __('Seneste Side', 'lastlogin-column');
  35. $defaults['imel-login-userfield'] = __('Ældste Session', 'login-column');
  36. $defaults['imel-login2-userfield'] = __('Nyeste Session', 'login2-column');
  37. $defaults['proselect'] = __('Pro/Select', 'user-column');
  38. $defaults['gruppe'] = __('Gruppe', 'id-column');
  39. $defaults['imel-navn-userfield'] = __('Navn', 'navn-column');
  40. $defaults['session'] = __('sessions', 'session-column');
  41. $defaults['id'] = __('id', 'id-column');
  42. return $defaults;
  43. }
  44. function user_sortable_columns($columns) {
  45. $columns['session'] = 'session';
  46. $columns['id'] = 'id';
  47. $columns['gruppe'] = 'gruppe';
  48. $columns['proselect'] = 'proselect';
  49. $columns['lastlogin'] = 'lastlogin';
  50. $columns['lastview'] = 'lastview';
  51. return $columns;
  52. }
  53. function my_user_query($userquery) {
  54. if ('session' == $userquery->query_vars['orderby']) {
  55. global $wpdb;
  56. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  57. $userquery->query_where .= " AND alias.meta_key = 'session_tokens' "; //which meta are we sorting with?
  58. $userquery->query_orderby = " ORDER BY length(alias.meta_value) " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  59. }
  60. if ('proselect' == $userquery->query_vars['orderby']) {
  61. global $wpdb;
  62. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  63. $userquery->query_where .= " AND alias.meta_key = 'Proselect' "; //which meta are we sorting with?
  64. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  65. }
  66. if ('gruppe' == $userquery->query_vars['orderby']) {
  67. global $wpdb;
  68. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  69. $userquery->query_where .= " AND alias.meta_key = 'Gruppe' "; //which meta are we sorting with?
  70. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  71. }
  72. if ('lastlogin' == $userquery->query_vars['orderby']) {
  73. global $wpdb;
  74. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  75. $userquery->query_where .= " AND alias.meta_key = 'last_login' "; //which meta are we sorting with?
  76. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  77. }
  78. if ('lastview' == $userquery->query_vars['orderby']) {
  79. global $wpdb;
  80. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  81. $userquery->query_where .= " AND alias.meta_key = 'last_view' "; //which meta are we sorting with?
  82. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  83. }
  84. if ('id' == $userquery->query_vars['orderby']) {
  85. global $wpdb;
  86. //$userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  87. //$userquery->query_where .= " AND alias.meta_key = 'session_tokens' "; //which meta are we sorting with?
  88. $userquery->query_orderby = " ORDER BY ID " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  89. }
  90. }
  91. function imel_custom_column_userfield($value, $column_name, $id) {
  92. if ($column_name == 'lastlogin') {
  93. $ss = get_user_meta($id, 'last_login', true);
  94. if ($ss) {
  95. $the_login_date = human_time_diff($ss);
  96. return $the_login_date;
  97. } else {
  98. return " ";
  99. }
  100. }
  101. if ($column_name == 'lastview') {
  102. $ss = get_user_meta($id, 'last_view', true);
  103. if ($ss) {
  104. $the_login_date = human_time_diff($ss);
  105. return $the_login_date;
  106. } else {
  107. return " ";
  108. }
  109. }
  110. if ($column_name == 'proselect') {
  111. $s = get_user_meta($id, 'Proselect', true);
  112. return $s;
  113. }
  114. if ($column_name == 'gruppe') {
  115. $s = get_user_meta($id, 'Gruppe', true);
  116. return $s;
  117. }
  118. if ($column_name == 'id') {
  119. return $id;
  120. }
  121. if ($column_name == 'imel-navn-userfield') {
  122. return get_user_meta($id, 'Navn', true);
  123. }
  124. if ($column_name == 'session2') {
  125. $ss = get_user_meta($id, 'session_tokens', true);
  126. if ($ss) {
  127. $s = "";
  128. foreach ($ss as $name => $obj) {
  129. // $s .= human_time_diff($obj['login']) . " " . $obj['ua'] . "\n";
  130. $s .= human_time_diff($obj['login']) . " <br> ";
  131. }
  132. return $s;
  133. } else {
  134. return "N";
  135. }
  136. }
  137. if ($column_name == 'session') {
  138. $ss = get_user_meta($id, 'session_tokens', true);
  139. if ($ss) {
  140. $s = "";
  141. $i = 0;
  142. foreach ($ss as $name => $obj) {
  143. if ($i < 2) {
  144. $s .= human_time_diff($obj['login']) . " ";
  145. }
  146. $i++;
  147. }
  148. return count($ss) . ' | ' . $s . '';
  149. } else {
  150. return "N";
  151. }
  152. }
  153. if ($column_name == 'imel-login2-userfield') {
  154. $ss = get_user_meta($id, 'session_tokens', true);
  155. if ($ss) {
  156. //$f = array_pop(array_keys($ss));
  157. //return human_time_diff($ss[$f]['login']);
  158. return "L";
  159. } else {
  160. return "N";
  161. }
  162. }
  163. }
  164. }
  165. global $plug_adminusers;
  166. $plug_adminusers = new plug_adminusers($this);
  167. $this->dagsopt['plug_adminusers'] = $plug_adminusers;
  168. }