. require_once("../inc/boinc_db.inc"); class BoincCategory { static function lookup_id($id) { $db = BoincDb::get(); return $db->lookup_id($id, 'category', 'BoincCategory'); } static function lookup($clause) { $db = BoincDb::get(); return $db->lookup('category', 'BoincCategory', $clause); } static function enum($clause=null) { $db = BoincDb::get(); return $db->enum('category', 'BoincCategory', $clause); } } class BoincForum { static function insert($clause) { $db = BoincDb::get(); $ret = $db->insert('forum', $clause); if (!$ret) return null; return $db->insert_id(); } static function lookup_id($id) { $db = BoincDb::get(); return $db->lookup_id($id, 'forum', 'BoincForum'); } static function lookup($clause) { $db = BoincDb::get(); return $db->lookup('forum', 'BoincForum', $clause); } static function enum($clause) { $db = BoincDb::get(); return $db->enum('forum', 'BoincForum', $clause); } function update($clause) { $db = BoincDb::get(); return $db->update($this, 'forum', $clause); } function delete() { $db = BoincDb::get(); return $db->delete($this, 'forum'); } } class BoincThread { static function insert($clause) { $db = BoincDb::get(); $ret = $db->insert('thread', $clause); if (!$ret) return null; return $db->insert_id(); } static function lookup_id($id) { $db = BoincDb::get(); return $db->lookup_id($id, 'thread', 'BoincThread'); } function update($clause) { $db = BoincDb::get(); return $db->update($this, 'thread', $clause); } static function enum($clause="") { $db = BoincDb::get(); return $db->enum('thread', 'BoincThread', $clause); } function rating() { return $this->score*$this->votes; } function delete() { $db = BoincDb::get(); return $db->delete($this, 'thread'); } } class BoincPost { static function insert($clause) { $db = BoincDb::get(); $ret = $db->insert('post', $clause); if (!$ret) return null; return $db->insert_id(); } static function lookup_id($id) { $db = BoincDb::get(); return $db->lookup_id($id, 'post', 'BoincPost'); } static function count($clause) { $db = BoincDb::get(); return $db->count('post', $clause); } function update($clause) { $db = BoincDb::get(); return $db->update($this, 'post', $clause); } static function enum($clause) { $db = BoincDb::get(); return $db->enum('post', 'BoincPost', $clause); } static function enum_general($query) { $db = BoincDb::get(); return $db->enum_general('BoincPost', $query); } function rating() { return $this->score*$this->votes; } function delete() { $db = BoincDb::get(); return $db->delete($this, 'post'); } static function delete_aux($clause) { $db = BoincDb::get(); return $db->delete_aux('post', $clause); } } class BoincForumPrefs { static $cache; static function lookup_userid($id) { $db = BoincDb::get(); return $db->lookup('forum_preferences', 'BoincForumPrefs', "userid=$id"); } static function insert($clause) { $db = BoincDb::get(); $ret = $db->insert('forum_preferences', $clause); } static function lookup(&$user, $nocache=false) { if (!$user) return; if (isset($user->prefs)) return; if (!$nocache && isset(self::$cache[$user->id])) { $prefs = self::$cache[$user->id]; } else { $prefs = self::lookup_userid($user->id); if (!$prefs) { $db = BoincDb::get(); if ($db->readonly) { return; } self::insert("(userid, last_post, forum_sorting, thread_sorting, rated_posts, ignorelist, pm_notification) values ($user->id, 0, 0, 8, '', '', 0)"); $prefs = self::lookup_userid($user->id); $prefs->userid = $user->id; $prefs->thread_sorting = 6; } self::$cache[$user->id] = $prefs; } $user->prefs = $prefs; } function privilege($specialbit) { return (substr($this->special_user, $specialbit,1)==1); } function update($clause) { $db = BoincDb::get(); $clause = "$clause where userid=$this->userid"; return $db->update_aux('forum_preferences', $clause); } function delete() { $db = BoincDb::get(); return $db->delete_aux('forum_preferences', "userid=$this->userid"); } static function enum($clause=null) { $db = BoincDb::get(); return $db->enum('forum_preferences', 'BoincForumPrefs', $clause); } } class BoincForumLogging { static $cache; static function replace($userid, $threadid, $timestamp) { $db = BoincDb::get(); return $db->replace('forum_logging', "userid=$userid, threadid=$threadid, timestamp=$timestamp"); } static function lookup($userid, $threadid) { $db = BoincDb::get(); return $db->lookup('forum_logging', 'BoincForumLogging', "userid=$userid and threadid=$threadid"); } static function lookup_cached($userid, $threadid) { if (isset(self::$cache[$threadid])) { return self::$cache[$threadid]; } $x = self::lookup($userid, $threadid); if (!$x) { $x = new BoincForumLogging(); $x->timestamp = 0; } self::$cache[$threadid] = $x; } static function delete_aux($clause) { $db = BoincDb::get(); return $db->delete_aux('forum_logging', $clause); } static function cleanup() { // Every 28 days, delete records older than 28 days. // Keep track of the last time we did this in a special record // with userid = threadid = 0. // This gets called from forum_index.php // (i.e. each time the forum main page is loaded). // $fl = BoincForumLogging::lookup(0, 0); if ($fl) { if ($fl->timestamplookup('subscriptions', 'BoincSubscription', "userid=$userid and threadid=$threadid"); } static function delete($userid, $threadid) { $db = BoincDb::get(); return $db->delete_aux('subscriptions', "userid=$userid and threadid=$threadid"); } static function enum($clause) { $db = BoincDb::get(); return $db->enum('subscriptions', 'BoincSubscription', $clause); } static function replace($userid, $threadid) { $db = BoincDb::get(); return $db->replace('subscriptions', "userid=$userid, threadid=$threadid"); } } class BoincPostRating { static function lookup($userid, $postid) { $db = BoincDb::get(); return $db->lookup('post_ratings', 'BoincPostRating', "user=$userid and post=$postid"); } static function replace($userid, $postid, $rating) { $db = BoincDb::get(); return $db->replace('post_ratings', "user=$userid, post=$postid, rating=$rating"); } } class BoincFriend { static function insert($clause) { $db = BoincDb::get(); return $db->insert('friend', $clause); } static function lookup($uid1, $uid2) { $db = BoincDb::get(); return $db->lookup('friend', 'BoincFriend', "user_src=$uid1 and user_dest=$uid2"); } function update($clause) { $db = BoincDb::get(); return $db->update_aux('friend', "$clause where user_src=$this->user_src and user_dest=$this->user_dest"); } static function enum($clause) { $db = BoincDb::get(); return $db->enum('friend', 'BoincFriend', $clause); } static function delete_aux($clause) { $db = BoincDb::get(); return $db->delete_aux('friend', $clause); } static function delete($id1, $id2) { $db = BoincDb::get(); $db->delete_aux('friend', "user_src=$id1 and user_dest=$id2"); $db->delete_aux('friend', "user_src=$id2 and user_dest=$id1"); } static function replace($clause) { $db = BoincDb::get(); return $db->replace('friend', $clause); } } class BoincNotify { static function insert($clause) { $db = BoincDb::get(); $ret = $db->insert('notify', $clause); if (!$ret) return null; return $db->insert_id(); } static function replace($clause) { $db = BoincDb::get(); return $db->replace('notify', $clause); } static function enum($clause) { $db = BoincDb::get(); return $db->enum('notify', 'BoincNotify', $clause); } static function lookup($userid, $type, $opaque) { $db = BoincDb::get(); return $db->lookup('notify', 'BoincNotify', "userid=$userid and type=$type and opaque=$opaque"); } function delete() { $db = BoincDb::get(); return $db->delete($this, 'notify'); } static function delete_aux($clause) { $db = BoincDb::get(); $db->delete_aux('notify', $clause); } static function enum_general($query) { $db = BoincDb::get(); return $db->enum_general('BoincNotify', $query); } } define ('NOTIFY_FRIEND_REQ', 1); define ('NOTIFY_FRIEND_ACCEPT', 2); define ('NOTIFY_PM', 3); define ('NOTIFY_SUBSCRIBED_POST', 4); ?>