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