table_forum_announcement.php
2.95 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php
/**
* [Discuz!] (C)2001-2099 Comsenz Inc.
* This is NOT a freeware, use is subject to license terms
*
* $Id: table_forum_announcement.php 27829 2012-02-15 07:34:43Z chenmengshu $
*/
if(!defined('IN_DISCUZ')) {
exit('Access Denied');
}
class table_forum_announcement extends discuz_table
{
public function __construct() {
$this->_table = 'forum_announcement';
$this->_pk = 'id';
parent::__construct();
}
public function fetch_all_by_date($timestamp, $type = 2) {
return DB::fetch_all('SELECT * FROM %t WHERE type!=%d AND starttime<=%d AND (endtime=0 OR endtime>%d) ORDER BY displayorder, starttime DESC, id DESC', array($this->_table, $type, $timestamp, $timestamp), $this->_pk);
}
public function fetch_all_by_displayorder() {
return DB::fetch_all('SELECT * FROM %t ORDER BY displayorder, starttime DESC, id DESC', array($this->_table), $this->_pk);
}
public function fetch_by_displayorder($timestamp) {
return DB::fetch_first('SELECT * FROM %t WHERE type!=2 AND groups = \'\' AND starttime<=%d AND (endtime>=%d OR endtime=0) ORDER BY displayorder, starttime DESC, id DESC LIMIT 1', array($this->_table, $timestamp, $timestamp));
}
public function fetch_all_by_time($time, $type, $bannedids, $startrow, $items) {
$type = dintval($type, true);
$sql = ' AND '.DB::field('type', $type);
if($bannedids) {
$bannedids = dintval($bannedids, true);
$sql .= ' AND '.DB::field('id', $bannedids, 'notin');
}
return DB::fetch_all('SELECT * FROM %t WHERE starttime <= %d AND (endtime = \'\' || endtime >= %d) %i ORDER BY displayorder DESC LIMIT %d, %d', array($this->_table, $time, $time, $sql, $startrow, $items), $this->_pk);
}
public function fetch_by_id_username($id, $username, $adminid = 1) {
return DB::fetch_first('SELECT * FROM %t WHERE id=%d AND (%d=1 AND author=%s)', array($this->_table, $id, $adminid, $username));
}
public function delete_by_id_username($ids, $username, $adminid = 1) {
if(($ids = dintval((array)$ids, true))) {
DB::query('DELETE FROM %t WHERE id IN(%n) AND (%d=1 OR author=%s)', array($this->_table, $ids, $adminid, $username), false, true);
}
}
public function update_displayorder_by_id_username($id, $displayorder, $username, $adminid = 1) {
if(($id = dintval((array)$id, true))) {
DB::query('UPDATE %t SET displayorder=%d WHERE id IN(%n) AND (%d=1 OR author=%s)', array($this->_table, $displayorder, $id, $adminid, $username), false, true);
}
}
public function update_by_id_username($id, $data, $username, $adminid = 1) {
if(($id = dintval($id, true)) && $data && is_array($data)) {
$adminid = dintval($adminid);
DB::update($this->_table, $data, DB::field($this->_pk, $id)." AND ('{$adminid}'=1 OR ".DB::field('author', $username).')', true);
}
}
public function delete_all_by_endtime($timestamp) {
DB::query("DELETE FROM %t WHERE endtime<%d AND endtime<>'0'", array($this->_table, $timestamp));
}
}
?>