fields['mesgs'] = array( "guid", "author", "mesg", "attachment", ); parent::__construct($guid); try { $this->expectType("log"); } catch (Exception $e) { $this->expectType("mesg"); } } /* * Initialize a new regular message. */ public static function initNew(string $message, user $author, object $parent) : mesg { $mesg = new mesg(); $mesg->setOwner($author); $mesg->setParent($parent); $mesg->name = "message " . $mesg->guid; $mesg->objtype = "mesg"; $mesg->setAuthor($author); $mesg->mesg = $message; $mesg->saveObj(); return $mesg; } /* * Initialize a new pad discussion thread. */ public static function initNewDiscussion(string $name, string $message, user $author, pad $parent) : mesg { $mesg = new mesg(); $mesg->setOwner($author); $mesg->setParent($parent); $mesg->name = $name; $mesg->objtype = "mesg"; $mesg->setAuthor($author); $mesg->mesg = $message; $mesg->saveObj(); return $mesg; } /* * Initialize a new private message (user-to-user). */ public static function initNewPM(string $name, string $message, user $author, user $rcpt) : mesg { $mesg = new mesg(); $mesg->setOwner($rcpt); $mesg->setParent($rcpt); $mesg->name = $name; $mesg->objtype = "mesg"; $mesg->setAuthor($author); $mesg->mesg = $message; $mesg->saveObj(); return $mesg; } /* * Initialize a new log message. */ public static function initNewLog(string $message, user $author, object $parent) : mesg { $owner = $parent->getOwner(); if (!$owner) $owner = $parent; $mesg = new mesg(); $mesg->setOwner($owner); $mesg->setParent($parent); $mesg->name = "log " . $mesg->guid; $mesg->objtype = "log"; $mesg->setAuthor($author); $mesg->mesg = $message; $mesg->saveObj(); return $mesg; } /* * Initialize a new admin log message. */ public static function initNewAdminLog(string $message, user $author) : mesg { $mesg = new mesg(); $mesg->saveObj(); // need to get a guid $mesg->name = "admin log " . $mesg->guid; $mesg->objtype = "log"; $mesg->setAuthor($author); $mesg->mesg = $message; $mesg->saveObj(); return $mesg; } /* * Get an array of messages in the admin log, between two timestamps. * With no arguments, the entire log is returned. Results are sorted * in reverse chronological order. */ public static function getAdminLog_ordByDatetime(?string $after = NULL, ?string $before = NULL) : array { $query = "SELECT guid FROM objects WHERE objtype = 'log' AND " . "parent = '' "; if ($after) $query += "AND created >= '" . database::esc($after) . "' "; if ($before) $query += "AND created < '" . database::esc($before) . "' "; $query += "ORDER BY created DESC"; $res = database::query($query); $log = array(); foreach ($res as $l) $log[] = new mesg($l['guid']); return $log; } /* * Get the author of this message. This user either actually wrote * this message, or caused it to be generated. */ public function getAuthor() : user { if (!isset($this->author) || $this->author == "") return NULL; return new user($this->author); } /* * Set the author of this message. This should usually only be done * while constructing a new message or to clear out references to * a user that got removed. */ public function setAuthor(user $author) : void { $this->author = $author->guid; $this->saveObj(); } /* * Check whether this message has been seen by the given user */ public function seenBy(user $viewer) : bool { $query = "SELECT * FROM views WHERE guid = '" . database::esc($this->guid) . "' " . "AND viewer = '" . database::esc($viewer->guid) . "'"; $res = database::query($query); return count($res) > 0; } /* * Mark this message as seen by the given user */ public function markSeen(user $viewer) : void { if (!$this->seenBy($viewer)) { $query = "INSERT INTO views (guid, viewer) VALUES ('" . database::esc($this->guid) . "', '" . database::esc($viewer->guid) . "')"; database::query($query); } } /* * Format message (if auto generated), and insert HTML linebreaks (
) * at message newlines. */ public function renderMesg() : string { if ($this->objtype == "log") $mesg = sprintf($this->mesg, $this->getAuthor()->getDisplayName()); else $mesg = $this->mesg; return nl2br($mesg); } /* * Get the URL to this message's attachment. If no file is attached, * NULL is returned. */ public function getAttachment() : ?string { if (!is_file("dynmic/attach/" . $this->guid)) return NULL; return ar() . "/df.php?d=attach&f=" . $this->guid; } /* * Set the attached file for this message. Should typically be done * during new message creation and not changed afterward. Returns * false if there is a problem saving the attachment. */ public function setAttachment(array $file) : bool { $path = "dynmic/attach/" . $this->guid; return saveFile($file, $path, self::ATTACH_MAXSIZE); } } ?>