table_common_member_validate.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <?php
  2. /**
  3. * [Discuz!] (C)2001-2099 Comsenz Inc.
  4. * This is NOT a freeware, use is subject to license terms
  5. *
  6. * $Id: table_common_member_validate.php 27848 2012-02-15 09:07:27Z zhangguosheng $
  7. */
  8. if(!defined('IN_DISCUZ')) {
  9. exit('Access Denied');
  10. }
  11. class table_common_member_validate extends discuz_table
  12. {
  13. public function __construct() {
  14. $this->_table = 'common_member_validate';
  15. $this->_pk = 'uid';
  16. parent::__construct();
  17. }
  18. public function fetch_all_validate_uid($submittimes = '', $regdate = '', $moddate = '', $regip = '') {
  19. $sql = 'm.groupid=8';
  20. $sql .= $submittimes ? ' AND v.submittimes>'.intval($submittimes) : '';
  21. $sql .= $regdate ? ' AND m.regdate<'.(TIMESTAMP - intval($regdate) * 86400) : '';
  22. $sql .= $moddate ? ' AND v.moddate<'.(TIMESTAMP - intval($moddate) * 86400) : '';
  23. $sql .= ($regip = stripsearchkey(addslashes((string)$regip))) ? " AND m.regip LIKE '".$regip."%'" : '';
  24. return DB::fetch_all("SELECT v.uid FROM ".DB::table('common_member_validate')." v, ".DB::table('common_member')." m
  25. WHERE $sql AND m.uid=v.uid", null, 'uid');
  26. }
  27. public function fetch_all_invalidate($start, $limit) {
  28. return DB::fetch_all('SELECT mvi.field, v.message, v.submittimes, v.submitdate, v.moddate, v.admin, v.remark, v.uid as vuid
  29. FROM '.DB::table('common_member_validate').' v
  30. LEFT JOIN '.DB::table('common_member_verify_info').' mvi ON mvi.uid=v.uid AND mvi.verifytype=0
  31. WHERE v.status=0 ORDER BY v.submitdate DESC '.DB::limit($start, $limit), '', 'vuid');
  32. }
  33. public function count_by_status($status) {
  34. return DB::result_first('SELECT COUNT(*) FROM %t WHERE status=%d', array($this->_table, $status));
  35. }
  36. public function fetch_all_status_by_count() {
  37. $count = array();
  38. $query = DB::query("SELECT status, COUNT(*) AS count FROM ".DB::table('common_member_validate')." GROUP BY status");
  39. while($num = DB::fetch($query)) {
  40. $count[$num['status']] = $num['count'];
  41. }
  42. return $count;
  43. }
  44. public function fetch_all_by_status($status, $start = 0, $limit = 0) {
  45. return DB::fetch_all('SELECT * FROM %t WHERE status=%d ORDER BY submitdate DESC'.DB::limit($start, $limit), array($this->_table, $status), $this->_pk);
  46. }
  47. }
  48. ?>