X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=classes%2FConversation.php;h=033b99384b0470f10c7e46d72bd37331eab79b5a;hb=27ed6b7db05bd2879841d6d95d9d8e273d7454b5;hp=4bad474c7334207ef2ab6e8d8040050c7b093b31;hpb=8c710ad2c1b80544acccb515f7b601aadff2de16;p=quix0rs-gnu-social.git diff --git a/classes/Conversation.php b/classes/Conversation.php index 4bad474c73..033b99384b 100755 --- a/classes/Conversation.php +++ b/classes/Conversation.php @@ -22,36 +22,29 @@ * @category Data * @package StatusNet * @author Zach Copley + * @author Mikael Nordfeldth * @copyright 2010 StatusNet Inc. + * @copyright 2009-2014 Free Software Foundation, Inc http://www.fsf.org * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 * @link http://status.net/ */ -require_once INSTALLDIR . '/classes/Memcached_DataObject.php'; +if (!defined('GNUSOCIAL')) { exit(1); } class Conversation extends Managed_DataObject { - ###START_AUTOCODE - /* the code below is auto generated do not remove the above tag */ - - public $__table = 'conversation'; // table name + public $__table = 'conversation'; // table name public $id; // int(4) primary_key not_null - public $uri; // varchar(225) unique_key + public $uri; // varchar(255) unique_key public $created; // datetime not_null public $modified; // timestamp not_null default_CURRENT_TIMESTAMP - /* Static get */ - function staticGet($k,$v=NULL) { return Memcached_DataObject::staticGet('conversation',$k,$v); } - - /* the code above is auto generated do not remove the tag below */ - ###END_AUTOCODE - public static function schemaDef() { return array( 'fields' => array( - 'id' => array('type' => 'serial', 'not null' => true, 'description' => 'unique identifier'), - 'uri' => array('type' => 'varchar', 'length' => 225, 'description' => 'URI of the conversation'), + 'id' => array('type' => 'int', 'not null' => true, 'description' => 'should be set from root notice id (since 2014-03-01 commit)'), + 'uri' => array('type' => 'varchar', 'length' => 255, 'description' => 'URI of the conversation'), 'created' => array('type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'), 'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'), ), @@ -67,25 +60,20 @@ class Conversation extends Managed_DataObject * * @return Conversation the new conversation DO */ - static function create() + static function create(Notice $notice) { + if (empty($notice->id)) { + throw new ServerException(_('Tried to create conversation for not yet inserted notice')); + } $conv = new Conversation(); $conv->created = common_sql_now(); - $id = $conv->insert(); + $conv->id = $notice->id; + $conv->uri = common_local_url('conversation', array('id' => $notice->id), null, null, false); + $result = $conv->insert(); - if (empty($id)) { + if ($result === false) { common_log_db_error($conv, 'INSERT', __FILE__); - return null; - } - - $orig = clone($conv); - $orig->uri = common_local_url('conversation', array('id' => $id), - null, null, false); - $result = $orig->update($conv); - - if (empty($result)) { - common_log_db_error($conv, 'UPDATE', __FILE__); - return null; + throw new ServerException(_('Failed to create conversation for notice')); } return $conv; @@ -109,4 +97,22 @@ class Conversation extends Managed_DataObject return $cnt; } + + static public function getUrlFromNotice(Notice $notice, $anchor=true) + { + $conv = self::getKV('id', $notice->conversation); + return $conv->getUrl($anchor ? $notice->id : null); + } + + public function getUri() + { + return $this->uri; + } + + public function getUrl($noticeId=null) + { + // FIXME: the URL router should take notice-id as an argument... + return common_local_url('conversation', array('id' => $this->id)) . + ($noticeId===null ? '' : "#notice-{$noticeId}"); + } }