+++ /dev/null
-<?php
-/**
- * StatusNet - the distributed open-source microblogging tool
- * Copyright (C) 2011, StatusNet, Inc.
- *
- * Data structure for blog entries
- *
- * PHP version 5
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- * @category Blog
- * @package StatusNet
- * @author Evan Prodromou <evan@status.net>
- * @copyright 2011 StatusNet, Inc.
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
- * @link http://status.net/
- */
-
-if (!defined('STATUSNET')) {
- // This check helps protect against security problems;
- // your code file can't be executed directly from the web.
- exit(1);
-}
-
-/**
- * Data structure for blog entries
- *
- * @category Blog
- * @package StatusNet
- * @author Evan Prodromou <evan@status.net>
- * @copyright 2011 StatusNet, Inc.
- * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
- * @link http://status.net/
- */
-
-class BlogEntry extends Managed_DataObject
-{
- public $__table = 'blog_entry';
-
- public $id; // UUID
- public $profile_id; // int
- public $title; // varchar(255)
- public $summary; // text
- public $content; // text
- public $uri; // text
- public $url; // text
- public $created; // datetime
- public $modified; // datetime
-
- const TYPE = 'http://activitystrea.ms/schema/1.0/blog-entry';
-
- function staticGet($k, $v=null)
- {
- return Managed_DataObject::staticGet('blog_entry', $k, $v);
- }
-
- static function schemaDef()
- {
- return array(
- 'description' => 'lite blog entry',
- 'fields' => array(
- 'id' => array('type' => 'char',
- 'length' => 36,
- 'not null' => true,
- 'description' => 'Unique ID (UUID)'),
- 'profile_id' => array('type' => 'int',
- 'not null' => true,
- 'description' => 'Author profile ID'),
- 'title' => array('type' => 'varchar',
- 'length' => 255,
- 'description' => 'title of the entry'),
- 'summary' => array('type' => 'text',
- 'description' => 'initial summary'),
- 'content' => array('type' => 'text',
- 'description' => 'HTML content of the entry'),
- 'uri' => array('type' => 'varchar',
- 'length' => 255,
- 'description' => 'URI (probably http://) for this entry'),
- 'url' => array('type' => 'varchar',
- 'length' => 255,
- 'description' => 'URL (probably http://) for this entry'),
- 'created' => array('type' => 'datetime',
- 'not null' => true,
- 'description' => 'date this record was created'),
- 'modified' => array('type' => 'datetime',
- 'not null' => true,
- 'description' => 'date this record was created'),
- ),
- 'primary key' => array('id'),
- 'foreign keys' => array(
- 'blog_entry_profile_id_fkey' => array('profile', array('profile_id' => 'id')),
- ),
- 'indexes' => array(
- 'blog_entry_created_idx' => array('created'),
- 'blog_entry_uri_idx' => array('uri'),
- ),
- );
- }
-
- static function saveNew($profile, $title, $content, $options=null)
- {
- if (is_null($options)) {
- $options = array();
- }
-
- $be = new BlogEntry();
- $be->id = (string) new UUID();
- $be->profile_id = $profile->id;
- $be->title = htmlspecialchars($title);
- $be->content = $content;
-
- if (array_key_exists('summary', $options)) {
- $be->summary = $options['summary'];
- } else {
- $be->summary = self::summarize($content);
- }
-
- $url = common_local_url('showblogentry', array('id' => $be->id));
-
- if (!array_key_exists('uri', $options)) {
- $options['uri'] = $url;
- }
-
- $be->uri = $options['uri'];
-
- if (!array_key_exists('url', $options)) {
- $options['url'] = $url;
- }
-
- $be->url = $options['url'];
-
- if (!array_key_exists('created', $options)) {
- $be->created = common_sql_now();
- }
-
- $be->created = $options['created'];
-
- $be->modified = common_sql_now();
-
- $be->insert();
-
- // Use user's preferences for short URLs, if possible
-
- try {
- $user = $profile->getUser();
- $shortUrl = File_redirection::makeShort($url,
- empty($user) ? null : $user);
- } catch (Exception $e) {
- // Don't let this stop us.
- $shortUrl = $url;
- }
-
- // XXX: this might be too long.
-
- $options['rendered'] = $be->summary . ' ' .
- XMLStringer::estring('a', array('href' => $shortUrl,
- 'class' => 'blog-entry'),
- _('More...'));
-
- $summaryText = html_entity_decode(strip_tags($summary), ENT_QUOTES, 'UTF-8');
-
- if (Notice::contentTooLong($summaryText)) {
- $summaryText = substr($summaryText, 0, Notice::maxContent() - mb_strlen($shortUrl) - 2) .
- '… ' . $shortUrl;
- }
-
- $content = $summaryText;
-
- // Override this no matter what.
-
- $options['object_type'] = self::TYPE;
-
- $source = array_key_exists('source', $options) ?
- $options['source'] : 'web';
-
- Notice::saveNew($profile->id, $content, $source, $options);
- }
-
- /**
- * Summarize the contents of a blog post
- *
- * We take the first div or paragraph of the blog post if there's a hit;
- * Otherwise we take the whole thing.
- *
- * @param string $html HTML of full content
- */
- static function summarize($html)
- {
- if (preg_match('#<p>.*?</p>#s', $html, $matches)) {
- return $matches[0];
- } else if (preg_match('#<div>.*?</div>#s', $html, $matches)) {
- return $matches[0];
- } else {
- return $html;
- }
- }
-
- static function fromNotice($notice)
- {
- return BlogEntry::staticGet('uri', $notice->uri);
- }
-
- function getNotice()
- {
- return Notice::staticGet('uri', $this->uri);
- }
-
- function asActivityObject()
- {
- $obj = new ActivityObject();
-
- $obj->id = $this->uri;
- $obj->type = self::TYPE;
- $obj->title = $this->title;
- $obj->summary = $this->summary;
- $obj->content = $this->content;
- $obj->link = $this->url;
-
- return $obj;
- }
-}
{
$schema = Schema::get();
- $schema->ensureTable('blog_entry', BlogEntry::schemaDef());
+ $schema->ensureTable('blog_entry', Blog_entry::schemaDef());
return true;
}
case 'BlogEntryListItem':
include_once $dir . '/'.strtolower($cls).'.php';
return false;
- case 'BlogEntry':
+ case 'Blog_entry':
include_once $dir . '/'.$cls.'.php';
return false;
default:
function types()
{
- return array(BlogEntry::TYPE);
+ return array(Blog_entry::TYPE);
}
function saveNoticeFromActivity($activity, $actor, $options=array())
$entryObj = $activity->objects[0];
- if ($entryObj->type != BlogEntry::TYPE) {
+ if ($entryObj->type != Blog_entry::TYPE) {
// TRANS: Exception thrown when blog plugin comes across a non-event type object.
throw new ClientException(_m('Wrong type for object.'));
}
switch ($activity->verb) {
case ActivityVerb::POST:
- $notice = BlogEntry::saveNew($actor,
+ $notice = Blog_entry::saveNew($actor,
$entryObj->title,
$entryObj->content,
$options);
function activityObjectFromNotice($notice)
{
- $entry = BlogEntry::fromNotice($notice);
+ $entry = Blog_entry::fromNotice($notice);
if (empty($entry)) {
throw new ClientException(sprintf(_('No blog entry for notice %s'),
function deleteRelated($notice)
{
- if ($notice->object_type == BlogEntry::TYPE) {
- $entry = BlogEntry::fromNotice($notice);
+ if ($notice->object_type == Blog_entry::TYPE) {
+ $entry = Blog_entry::fromNotice($notice);
if (exists($entry)) {
$entry->delete();
}
{
$notice = $nli->notice;
- if ($notice->object_type == BlogEntry::TYPE) {
+ if ($notice->object_type == Blog_entry::TYPE) {
return new BlogEntryListItem($nli);
}
--- /dev/null
+<?php
+/**
+ * StatusNet - the distributed open-source microblogging tool
+ * Copyright (C) 2011, StatusNet, Inc.
+ *
+ * Data structure for blog entries
+ *
+ * PHP version 5
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * @category Blog
+ * @package StatusNet
+ * @author Evan Prodromou <evan@status.net>
+ * @copyright 2011 StatusNet, Inc.
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
+ * @link http://status.net/
+ */
+
+if (!defined('STATUSNET')) {
+ // This check helps protect against security problems;
+ // your code file can't be executed directly from the web.
+ exit(1);
+}
+
+/**
+ * Data structure for blog entries
+ *
+ * @category Blog
+ * @package StatusNet
+ * @author Evan Prodromou <evan@status.net>
+ * @copyright 2011 StatusNet, Inc.
+ * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
+ * @link http://status.net/
+ */
+
+class Blog_entry extends Managed_DataObject
+{
+ public $__table = 'blog_entry';
+
+ public $id; // UUID
+ public $profile_id; // int
+ public $title; // varchar(255)
+ public $summary; // text
+ public $content; // text
+ public $uri; // text
+ public $url; // text
+ public $created; // datetime
+ public $modified; // datetime
+
+ const TYPE = 'http://activitystrea.ms/schema/1.0/blog-entry';
+
+ function staticGet($k, $v=null)
+ {
+ return Managed_DataObject::staticGet('blog_entry', $k, $v);
+ }
+
+ static function schemaDef()
+ {
+ return array(
+ 'description' => 'lite blog entry',
+ 'fields' => array(
+ 'id' => array('type' => 'char',
+ 'length' => 36,
+ 'not null' => true,
+ 'description' => 'Unique ID (UUID)'),
+ 'profile_id' => array('type' => 'int',
+ 'not null' => true,
+ 'description' => 'Author profile ID'),
+ 'title' => array('type' => 'varchar',
+ 'length' => 255,
+ 'description' => 'title of the entry'),
+ 'summary' => array('type' => 'text',
+ 'description' => 'initial summary'),
+ 'content' => array('type' => 'text',
+ 'description' => 'HTML content of the entry'),
+ 'uri' => array('type' => 'varchar',
+ 'length' => 255,
+ 'description' => 'URI (probably http://) for this entry'),
+ 'url' => array('type' => 'varchar',
+ 'length' => 255,
+ 'description' => 'URL (probably http://) for this entry'),
+ 'created' => array('type' => 'datetime',
+ 'not null' => true,
+ 'description' => 'date this record was created'),
+ 'modified' => array('type' => 'datetime',
+ 'not null' => true,
+ 'description' => 'date this record was created'),
+ ),
+ 'primary key' => array('id'),
+ 'foreign keys' => array(
+ 'blog_entry_profile_id_fkey' => array('profile', array('profile_id' => 'id')),
+ ),
+ 'indexes' => array(
+ 'blog_entry_created_idx' => array('created'),
+ 'blog_entry_uri_idx' => array('uri'),
+ ),
+ );
+ }
+
+ static function saveNew($profile, $title, $content, $options=null)
+ {
+ if (is_null($options)) {
+ $options = array();
+ }
+
+ $be = new Blog_entry();
+ $be->id = (string) new UUID();
+ $be->profile_id = $profile->id;
+ $be->title = htmlspecialchars($title);
+ $be->content = $content;
+
+ if (array_key_exists('summary', $options)) {
+ $be->summary = $options['summary'];
+ } else {
+ $be->summary = self::summarize($content);
+ }
+
+ $url = common_local_url('showblogentry', array('id' => $be->id));
+
+ if (!array_key_exists('uri', $options)) {
+ $options['uri'] = $url;
+ }
+
+ $be->uri = $options['uri'];
+
+ if (!array_key_exists('url', $options)) {
+ $options['url'] = $url;
+ }
+
+ $be->url = $options['url'];
+
+ if (!array_key_exists('created', $options)) {
+ $be->created = common_sql_now();
+ }
+
+ $be->created = $options['created'];
+
+ $be->modified = common_sql_now();
+
+ $be->insert();
+
+ // Use user's preferences for short URLs, if possible
+
+ try {
+ $user = $profile->getUser();
+ $shortUrl = File_redirection::makeShort($url,
+ empty($user) ? null : $user);
+ } catch (Exception $e) {
+ // Don't let this stop us.
+ $shortUrl = $url;
+ }
+
+ // XXX: this might be too long.
+
+ $options['rendered'] = $be->summary . ' ' .
+ XMLStringer::estring('a', array('href' => $shortUrl,
+ 'class' => 'blog-entry'),
+ _('More...'));
+
+ $summaryText = html_entity_decode(strip_tags($summary), ENT_QUOTES, 'UTF-8');
+
+ if (Notice::contentTooLong($summaryText)) {
+ $summaryText = substr($summaryText, 0, Notice::maxContent() - mb_strlen($shortUrl) - 2) .
+ '… ' . $shortUrl;
+ }
+
+ $content = $summaryText;
+
+ // Override this no matter what.
+
+ $options['object_type'] = self::TYPE;
+
+ $source = array_key_exists('source', $options) ?
+ $options['source'] : 'web';
+
+ Notice::saveNew($profile->id, $content, $source, $options);
+ }
+
+ /**
+ * Summarize the contents of a blog post
+ *
+ * We take the first div or paragraph of the blog post if there's a hit;
+ * Otherwise we take the whole thing.
+ *
+ * @param string $html HTML of full content
+ */
+ static function summarize($html)
+ {
+ if (preg_match('#<p>.*?</p>#s', $html, $matches)) {
+ return $matches[0];
+ } else if (preg_match('#<div>.*?</div>#s', $html, $matches)) {
+ return $matches[0];
+ } else {
+ return $html;
+ }
+ }
+
+ static function fromNotice($notice)
+ {
+ return Blog_entry::staticGet('uri', $notice->uri);
+ }
+
+ function getNotice()
+ {
+ return Notice::staticGet('uri', $this->uri);
+ }
+
+ function asActivityObject()
+ {
+ $obj = new ActivityObject();
+
+ $obj->id = $this->uri;
+ $obj->type = self::TYPE;
+ $obj->title = $this->title;
+ $obj->summary = $this->summary;
+ $obj->content = $this->content;
+ $obj->link = $this->url;
+
+ return $obj;
+ }
+}
$notice = $this->nli->notice;
$out = $this->nli->out;
- $entry = BlogEntry::fromNotice($notice);
+ $entry = Blog_entry::fromNotice($notice);
if (empty($entry)) {
throw new Exception('BlogEntryListItem used for non-blog notice.');
$profile = $this->user->getProfile();
- $saved = BlogEntry::saveNew($profile,
+ $saved = Blog_entry::saveNew($profile,
$this->title,
$this->content,
$options);
{
$this->id = $this->trimmed('id');
- $this->entry = BlogEntry::staticGet('id', $this->id);
+ $this->entry = Blog_entry::staticGet('id', $this->id);
if (empty($this->entry)) {
// TRANS: Client exception thrown when referring to a non-existing blog entry.