silverstripe-blog/code/model/Blog.php

901 lines
22 KiB
PHP
Raw Normal View History

2013-07-21 12:23:35 +02:00
<?php
/**
* Blog Holder
*
* @package silverstripe
* @subpackage blog
2015-04-21 06:47:46 +02:00
*
* @method HasManyList Tags() List of tags in this blog
* @method HasManyList Categories() List of categories in this blog
* @method ManyManyList Editors() List of editors
* @method ManyManyList Writers() List of writers
* @method ManyManyList Contributors() List of contributors
2013-07-21 12:23:35 +02:00
*
2014-02-20 17:37:55 +01:00
* @author Michael Strong <github@michaelstrong.co.uk>
2015-04-21 06:47:46 +02:00
**/
class Blog extends Page implements PermissionProvider {
/**
* Permission for user management
*
* @var string
*/
const MANAGE_USERS = 'BLOG_MANAGE_USERS';
/**
* If true, users assigned as editor, writer, or contributor will be automatically
* granted CMS_ACCESS_CMSMain permission. If false, only users with this permission
* already may be assigned.
*
* @var boolean
* @config
*/
private static $grant_user_access = true;
/**
* Permission to either require, or grant to users assigned to work on this blog
*
* @var string
* @config
*/
private static $grant_user_permission = 'CMS_ACCESS_CMSMain';
/**
* Group code to assign newly granted users toh
*
* @var string
* @config
*/
private static $grant_user_group = 'blog-users';
2013-07-21 12:23:35 +02:00
2013-08-04 18:38:26 +02:00
private static $db = array(
"PostsPerPage" => "Int",
);
2013-07-21 12:23:35 +02:00
private static $has_many = array(
"Tags" => "BlogTag",
2013-08-04 18:38:26 +02:00
"Categories" => "BlogCategory",
2013-07-21 12:23:35 +02:00
);
private static $many_many = array(
'Editors' => 'Member',
'Writers' => 'Member',
'Contributors' => 'Member',
);
2015-04-21 06:47:46 +02:00
2013-07-21 12:23:35 +02:00
private static $allowed_children = array(
2013-08-04 18:38:26 +02:00
"BlogPost",
2013-07-21 12:23:35 +02:00
);
2013-08-04 18:38:26 +02:00
private static $extensions = array(
"BlogFilter",
);
2013-07-21 12:23:35 +02:00
private static $defaults = array(
"ProvideComments" => false,
);
2013-07-21 12:23:35 +02:00
private static $description = 'Adds a blog to your website.';
2013-07-21 12:23:35 +02:00
public function getCMSFields() {
2015-04-09 03:03:16 +02:00
Requirements::css(BLOGGER_DIR . '/css/cms.css');
2015-04-23 04:27:30 +02:00
Requirements::javascript(BLOGGER_DIR . '/js/cms.js');
2015-04-09 03:03:16 +02:00
$self =& $this;
2015-04-21 06:47:46 +02:00
$this->beforeUpdateCMSFields(function ($fields) use ($self) {
if(!$self->canEdit()) {
return;
}
2013-08-04 18:38:26 +02:00
$categories = GridField::create(
"Categories",
_t("Blog.Categories", "Categories"),
$self->Categories(),
2015-04-21 06:47:46 +02:00
GridFieldCategorisationConfig::create(15, $self->Categories(), 'BlogCategory', 'Categories', 'BlogPosts')
);
2013-08-04 18:38:26 +02:00
$tags = GridField::create(
"Tags",
_t("Blog.Tags", "Tags"),
$self->Tags(),
2015-04-21 09:17:27 +02:00
GridFieldCategorisationConfig::create(15, $self->Tags(), 'BlogTag', 'Tags', 'BlogPosts')
);
2013-08-04 18:38:26 +02:00
2015-04-21 06:47:46 +02:00
$fields->addFieldsToTab("Root.Categorisation", array(
$categories,
$tags
));
2015-04-23 06:06:56 +02:00
$fields->findOrMakeTab("Root.Categorisation")->addExtraClass('blog-cms-categorisation');
});
2015-04-21 06:47:46 +02:00
$fields = parent::getCMSFields();
2015-04-21 06:47:46 +02:00
2013-08-04 18:38:26 +02:00
return $fields;
}
/**
* Check if this member is an editor of the blog
*
* @param Member $member
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
public function isEditor($member) {
$isEditor = $this->isMemberOf($member, $this->Editors());
$this->extend('updateIsEditor', $isEditor, $member);
return $isEditor;
}
/**
* Check if this member is a writer of the blog
*
* @param Member $member
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
public function isWriter($member) {
$isWriter = $this->isMemberOf($member, $this->Writers());
$this->extend('updateIsWriter', $isWriter, $member);
return $isWriter;
}
/**
* Check if this member is a contributor of the blog
*
* @param Member $member
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
public function isContributor($member) {
$isContributor = $this->isMemberOf($member, $this->Contributors());
$this->extend('updateIsContributor', $isContributor, $member);
return $isContributor;
}
2015-04-09 05:45:12 +02:00
/**
* Determine the role of the given member
* Call be called via template to determine the current user
*
* E.g. `Hello $RoleOf($CurrentMember.ID)`
*
* @param Member|integer $member
2015-04-21 06:47:46 +02:00
*
2015-04-09 05:45:12 +02:00
* @return string|null Author, Editor, Writer, Contributor, or null if no role
*/
public function RoleOf($member) {
if(is_numeric($member)) $member = DataObject::get_by_id('Member', $member);
if(!$member) return null;
// Check each role
if($this->isEditor($member)) return _t('Blog.EDITOR', 'Editor');
if($this->isWriter($member)) return _t('Blog.WRITER', 'Writer');
if($this->isContributor($member)) return _t('Blog.CONTRIBUTOR', 'Contributor');
}
/**
* Determine if the given member belongs to the given subrelation
*
* @param Member $member
* @param DataList $list Relation to check
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
protected function isMemberOf($member, $list) {
if(!$member || !$member->exists()) return false;
if($list instanceof UnsavedRelationList) {
return in_array($member->ID, $list->getIDList());
}
return $list->byID($member->ID) !== null;
}
public function canEdit($member = null) {
$member = $member ?: Member::currentUser();
if(is_numeric($member)) $member = Member::get()->byID($member);
2015-04-21 06:47:46 +02:00
// Allow editors to edit this page
if($this->isEditor($member)) return true;
return parent::canEdit($member);
}
/**
* Determine if this user can edit the editors list
*
* @param Member $member
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
public function canEditEditors($member = null) {
$member = $member ?: Member::currentUser();
$extended = $this->extendedCan('canEditEditors', $member);
if($extended !== null) return $extended;
// Check permission
return Permission::checkMember($member, self::MANAGE_USERS);
}
/**
* Determine if this user can edit writers list
*
* @param Member $member
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
public function canEditWriters($member = null) {
$member = $member ?: Member::currentUser();
if(is_numeric($member)) $member = Member::get()->byID($member);
$extended = $this->extendedCan('canEditWriters', $member);
if($extended !== null) return $extended;
// Editors can edit writers
if($this->isEditor($member)) return true;
// Check permission
return Permission::checkMember($member, self::MANAGE_USERS);
}
/**
* Determines if this user can edit the contributors list
*
* @param type $member
2015-04-21 06:47:46 +02:00
*
* @return boolean
*/
public function canEditContributors($member = null) {
$member = $member ?: Member::currentUser();
if(is_numeric($member)) $member = Member::get()->byID($member);
2015-04-21 06:47:46 +02:00
$extended = $this->extendedCan('canEditContributors', $member);
if($extended !== null) return $extended;
// Editors can edit writers
if($this->isEditor($member)) return true;
// Check permission
return Permission::checkMember($member, self::MANAGE_USERS);
}
public function canAddChildren($member = null) {
$member = $member ?: Member::currentUser();
if(is_numeric($member)) $member = Member::get()->byID($member);
// Editors, Writers and Contributors can add children
if($this->isEditor($member) || $this->isWriter($member) || $this->isContributor($member)) {
return true;
}
return parent::canAddChildren($member);
}
2013-08-04 18:38:26 +02:00
2013-08-04 18:38:26 +02:00
public function getSettingsFields() {
$fields = parent::getSettingsFields();
2015-04-21 06:47:46 +02:00
$fields->addFieldToTab("Root.Settings",
NumericField::create("PostsPerPage", _t("Blog.PostsPerPage", "Posts Per Page"))
);
// Roles and Permissions
$members = $this->getCandidateUsers()->map()->toArray();
// Editors
$editorField = ListboxField::create('Editors', 'Editors', $members)
->setMultiple(true)
2015-04-09 03:03:16 +02:00
->setRightTitle('<a class="toggle-description">help</a>')
->setDescription('
2015-04-13 01:45:57 +02:00
An editor has control over specific Blogs, and all posts included within it. Short of being able to assign other editors to a blog, they are able to handle most changes to their assigned blog.<br />
2015-04-09 03:03:16 +02:00
<br />
Editors have these permissions:<br />
<br />
Update or publish any BlogPost in their Blog<br />
Update or publish their Blog<br />
Assign/unassign writers to their Blog<br />
Assign/unassign contributors to their Blog<br />
Assign/unassign any member as an author of a particular BlogPost
');
if(!$this->canEditEditors()) {
$editorField = $editorField->performDisabledTransformation();
}
// Writers
$writerField = ListboxField::create('Writers', 'Writers', $members)
->setMultiple(true)
2015-04-09 03:03:16 +02:00
->setRightTitle('<a class="toggle-description">help</a>')
->setDescription('
2015-04-13 01:45:57 +02:00
A writer has full control over creating, editing and publishing BlogPosts they have authored or have been assigned to. Writers are unable to edit BlogPosts to which they are not assigned.<br />
2015-04-09 03:03:16 +02:00
<br />
Writers have these permissions:<br />
<br />
2015-04-13 01:45:57 +02:00
Update or publish any BlogPost they have authored or have been assigned to<br />
Assign/unassign any member as an author of a particular BlogPost they have authored or have been assigned to
2015-04-09 03:03:16 +02:00
');
if(!$this->canEditWriters()) {
$writerField = $writerField->performDisabledTransformation();
}
// Contributors
$contributorField = ListboxField::create('Contributors', 'Contributors', $members)
->setMultiple(true)
2015-04-09 03:03:16 +02:00
->setRightTitle('<a class="toggle-description">help</a>')
->setDescription('
2015-04-13 01:45:57 +02:00
Contributors have the ability to create or edit BlogPosts, but are unable to publish without authorisation of an editor. They are also unable to assign other contributing authors to any of their BlogPosts.<br />
2015-04-09 03:03:16 +02:00
<br />
Contributors have these permissions:<br />
<br />
2015-04-13 01:45:57 +02:00
Update any BlogPost they have authored or have been assigned to
2015-04-09 03:03:16 +02:00
');
2015-04-21 06:47:46 +02:00
if(!$this->canEditContributors()) {
$contributorField = $contributorField->performDisabledTransformation();
}
2015-04-21 06:47:46 +02:00
$fields->addFieldsToTab('Root.Users', array(
$editorField,
$writerField,
$contributorField
));
2013-07-21 12:23:35 +02:00
return $fields;
}
/**
* Return blog posts
2013-07-21 12:23:35 +02:00
*
* @return DataList of BlogPost objects
2015-04-21 06:47:46 +02:00
**/
2013-07-21 12:23:35 +02:00
public function getBlogPosts() {
$blogPosts = BlogPost::get()->filter("ParentID", $this->ID);
//Allow decorators to manipulate list
$this->extend('updateGetBlogPosts', $blogPosts);
return $blogPosts;
2013-07-21 12:23:35 +02:00
}
2013-10-10 00:09:28 +02:00
/**
* Returns blogs posts for a given date period.
*
* @param $year int
* @param $month int
* @param $day int
2013-10-10 00:09:28 +02:00
*
* @return DataList
2015-04-21 06:47:46 +02:00
**/
2013-10-10 00:09:28 +02:00
public function getArchivedBlogPosts($year, $month = null, $day = null) {
$query = $this->getBlogPosts()->dataQuery();
$stage = $query->getQueryParam("Versioned.stage");
if($stage) $stage = '_' . Convert::raw2sql($stage);
$query->innerJoin("BlogPost", "`SiteTree" . $stage . "`.`ID` = `BlogPost" . $stage . "`.`ID`");
$query->where("YEAR(PublishDate) = '" . Convert::raw2sql($year) . "'");
if($month) {
$query->where("MONTH(PublishDate) = '" . Convert::raw2sql($month) . "'");
if($day) {
$query->where("DAY(PublishDate) = '" . Convert::raw2sql($day) . "'");
}
}
return $this->getBlogPosts()->setDataQuery($query);
}
2015-03-22 23:18:02 +01:00
/**
* Get a link to a Member profile.
2015-04-21 06:47:46 +02:00
*
2015-03-22 23:18:02 +01:00
* @param urlSegment
2015-04-21 06:47:46 +02:00
*
2015-03-22 23:18:02 +01:00
* @return String
*/
public function ProfileLink($urlSegment) {
return Controller::join_links($this->Link(), 'profile', $urlSegment);
}
/**
* This sets the title for our gridfield
*
* @return string
*/
public function getLumberjackTitle() {
return _t('Blog.LumberjackTitle', 'Blog Posts');
}
/**
* This overwrites lumberjacks default gridfield config.
*
* @return GridFieldConfig
*/
public function getLumberjackGridFieldConfig() {
2015-02-07 00:52:45 +01:00
return GridFieldConfig_BlogPost::create();
}
public function providePermissions() {
return array(
Blog::MANAGE_USERS => array(
'name' => _t(
'Blog.PERMISSION_MANAGE_USERS_DESCRIPTION',
'Manage users for individual blogs'
),
'help' => _t(
'Blog.PERMISSION_MANAGE_USERS_HELP',
'Allow assignment of Editors, Writers, or Contributors to blogs'
),
'category' => _t('Blog.PERMISSIONS_CATEGORY', 'Blog permissions'),
'sort' => 100
)
);
}
/**
* Gets the list of user candidates to be assigned to assist with this blog
*
* @return SS_List
*/
protected function getCandidateUsers() {
if($this->config()->grant_user_access) {
// If we are allowed to grant CMS access, all users are candidates
return Member::get();
} else {
// If access cannot be granted, limit users to those who can access the CMS
// This is useful for more secure sites
$permission = $this->config()->grant_user_permission;
return Permission::get_members_by_permission($permission);
}
}
/**
* Gets or creates the group used to assign CMS access
*
* @return Group
*/
protected function getUserGroup() {
$code = $this->config()->grant_user_group;
$group = Group::get()->filter('Code', $code)->first();
if($group) return $group;
// Create new group
$group = new Group();
$group->Title = 'Blog users';
$group->Code = $code;
$group->write();
// Add permission
$permission = new Permission();
$permission->Code = $this->config()->grant_user_permission;
$group->Permissions()->add($permission);
return $group;
}
protected function onBeforeWrite() {
parent::onBeforeWrite();
$this->assignGroup();
}
/**
* Assign users as necessary to the blog group
*/
protected function assignGroup() {
// Ensure that any user granted editor, writer, or contributor have CMS_ACCESS_CMSMain access
if(!$this->config()->grant_user_access) return;
// Generate or retrieve the group
$group = $this->getUserGroup();
foreach(array($this->Editors(), $this->Writers(), $this->Contributors()) as $userlist) {
foreach($userlist as $user) {
// Ensure user exists in the group
if(!$user->inGroup($group)) $user->Groups()->add($group);
}
}
}
2013-07-21 12:23:35 +02:00
}
/**
* Blog Controller
*
* @package silverstripe
* @subpackage blog
*
* @author Michael Strong <github@michaelstrong.co.uk>
2015-04-21 06:47:46 +02:00
**/
2013-07-21 12:23:35 +02:00
class Blog_Controller extends Page_Controller {
private static $allowed_actions = array(
'archive',
'tag',
'category',
'rss',
2015-03-22 23:18:02 +01:00
'profile'
2013-07-21 12:23:35 +02:00
);
private static $url_handlers = array(
2013-08-04 18:38:26 +02:00
'tag/$Tag!' => 'tag',
'category/$Category!' => 'category',
'archive/$Year!/$Month/$Day' => 'archive',
2015-03-22 23:18:02 +01:00
'profile/$URLSegment!' => 'profile'
2013-07-21 12:23:35 +02:00
);
private static $casting = array(
'MetaTitle' => 'Text',
'FilterDescription' => 'Text'
);
2013-08-04 18:38:26 +02:00
2015-04-21 06:47:46 +02:00
/**
2013-08-04 18:38:26 +02:00
* The current Blog Post DataList query.
*
* @var DataList
2015-04-21 06:47:46 +02:00
**/
2013-07-21 12:23:35 +02:00
protected $blogPosts;
2013-08-04 18:38:26 +02:00
2013-07-21 12:23:35 +02:00
public function index() {
2013-08-04 18:38:26 +02:00
$this->blogPosts = $this->getBlogPosts();
2013-07-21 12:23:35 +02:00
return $this->render();
}
2015-03-22 23:18:02 +01:00
/**
* Renders a Blog Member's profile.
*
* @return SS_HTTPResponse
2015-04-21 06:47:46 +02:00
**/
2015-03-22 23:18:02 +01:00
public function profile() {
$profile = $this->getCurrentProfile();
if(!$profile) {
return $this->httpError(404, 'Not Found');
}
$this->blogPosts = $this->getCurrentProfilePosts();
return $this->render();
}
2013-07-21 12:23:35 +02:00
2015-03-22 23:18:02 +01:00
/**
* Get the Member associated with the current URL segment.
2015-04-21 06:47:46 +02:00
*
2015-03-22 23:18:02 +01:00
* @return Member|null
2015-04-21 06:47:46 +02:00
**/
2015-03-22 23:18:02 +01:00
public function getCurrentProfile() {
$urlSegment = $this->request->param('URLSegment');
if($urlSegment) {
return Member::get()
->filter('URLSegment', $urlSegment)
->first();
}
return null;
}
/**
* Get posts related to the current Member profile
2015-04-21 06:47:46 +02:00
*
2015-03-22 23:18:02 +01:00
* @return DataList|null
2015-04-21 06:47:46 +02:00
**/
2015-03-22 23:18:02 +01:00
public function getCurrentProfilePosts() {
$profile = $this->getCurrentProfile();
if($profile) {
return $profile->AuthoredPosts()->filter('ParentID', $this->ID);
}
return null;
}
2013-08-04 18:38:26 +02:00
/**
* Renders an archive for a specificed date. This can be by year or year/month
*
* @return SS_HTTPResponse
2015-04-21 06:47:46 +02:00
**/
2013-07-21 12:23:35 +02:00
public function archive() {
2013-08-04 18:38:26 +02:00
$year = $this->getArchiveYear();
$month = $this->getArchiveMonth();
$day = $this->getArchiveDay();
2013-08-04 18:38:26 +02:00
// If an invalid month has been passed, we can return a 404.
if($this->request->param("Month") && !$month) {
return $this->httpError(404, "Not Found");
}
2013-08-04 18:38:26 +02:00
// Check for valid day
if($month && $this->request->param("Day") && !$day) {
return $this->httpError(404, "Not Found");
}
2013-08-04 18:38:26 +02:00
if($year) {
2013-10-10 00:09:28 +02:00
$this->blogPosts = $this->getArchivedBlogPosts($year, $month, $day);
2013-08-04 18:38:26 +02:00
return $this->render();
}
return $this->httpError(404, "Not Found");
2013-07-21 12:23:35 +02:00
}
2013-08-04 18:38:26 +02:00
/**
* Renders the blog posts for a given tag.
*
* @return SS_HTTPResponse
2015-04-21 06:47:46 +02:00
**/
2013-07-21 12:23:35 +02:00
public function tag() {
2013-08-04 18:38:26 +02:00
$tag = $this->getCurrentTag();
2013-07-21 12:23:35 +02:00
if($tag) {
2013-08-04 18:38:26 +02:00
$this->blogPosts = $tag->BlogPosts();
return $this->render();
2013-07-21 12:23:35 +02:00
}
return $this->httpError(404, "Not Found");
}
2013-08-04 18:38:26 +02:00
/**
* Renders the blog posts for a given category
*
* @return SS_HTTPResponse
2015-04-21 06:47:46 +02:00
**/
2013-07-21 12:23:35 +02:00
public function category() {
2013-08-04 18:38:26 +02:00
$category = $this->getCurrentCategory();
2013-07-21 12:23:35 +02:00
if($category) {
2013-08-04 18:38:26 +02:00
$this->blogPosts = $category->BlogPosts();
return $this->render();
2013-07-21 12:23:35 +02:00
}
return $this->httpError(404, "Not Found");
}
/**
* Get the meta title for the current action
*
* @return string
*/
public function getMetaTitle() {
$title = $this->data()->getTitle();
$filter = $this->getFilterDescription();
if($filter) {
$title = "{$title} - {$filter}";
}
2015-04-21 06:47:46 +02:00
$this->extend('updateMetaTitle', $title);
return $title;
}
/**
* Returns a description of the current filter
*
* @return string
*/
public function getFilterDescription() {
$items = array();
// Check current page
$list = $this->PaginatedList();
$currentPage = $list->CurrentPage();
// Build title
if($currentPage > 1) {
$items[] = _t(
'Blog.FILTERDESCRIPTION_PAGE',
"Page {page}",
null,
array('page' => $currentPage)
);
}
// Check author
if($author = $this->getCurrentProfile()) {
$items[] = _t(
'Blog.FILTERDESCRIPTION_AUTHOR',
"By {author}",
null,
array('author' => $author->Title)
);
}
// Check tag
if($tag = $this->getCurrentTag()) {
$items[] = _t(
'Blog.FILTERDESCRIPTION_TAG',
"Tagged with {tag}",
null,
array('tag' => $tag->Title)
);
}
// Check category
if($category = $this->getCurrentCategory()) {
$items[] = _t(
'Blog.FILTERDESCRIPTION_CATEGORY',
"In category {category}",
null,
array('category' => $category->Title)
);
}
// Check archive
if($this->owner->getArchiveYear()) {
if($this->owner->getArchiveDay()) {
$date = $this->owner->getArchiveDate()->Nice();
2015-04-21 06:47:46 +02:00
} elseif($this->owner->getArchiveMonth()) {
$date = $this->owner->getArchiveDate()->format("F, Y");
} else {
$date = $this->owner->getArchiveDate()->format("Y");
}
$items[] = _t(
'Blog.FILTERDESCRIPTION_DATE',
"In {date}",
null,
array('date' => $date)
);
}
$result = '';
if($items) $result = implode(', ', $items);
// Allow extension
$this->extend('updateFilterDescription', $result);
return $result;
}
2013-08-04 18:38:26 +02:00
/**
* Displays an RSS feed of blog posts
*
* @return string HTML
2015-04-21 06:47:46 +02:00
**/
public function rss() {
$rss = new RSSFeed($this->getBlogPosts(), $this->Link(), $this->MetaTitle, $this->MetaDescription);
$this->extend('updateRss', $rss);
return $rss->outputToBrowser();
}
2013-08-04 18:38:26 +02:00
/**
* Returns a list of paginated blog posts based on the blogPost dataList
*
* @return PaginatedList
2015-04-21 06:47:46 +02:00
**/
2013-08-04 18:38:26 +02:00
public function PaginatedList() {
$posts = new PaginatedList($this->blogPosts);
// If pagination is set to '0' then no pagination will be shown.
2015-03-04 23:20:47 +01:00
if($this->PostsPerPage > 0) {
$posts->setPageLength($this->PostsPerPage);
} else {
$pageSize = $this->getBlogPosts()->count() ?: 99999;
$posts->setPageLength($pageSize);
}
2013-08-04 18:38:26 +02:00
$start = $this->request->getVar($posts->getPaginationGetVar());
$posts->setPageStart($start);
return $posts;
}
/**
* Tag Getter for use in templates.
*
* @return BlogTag|null
2015-04-21 06:47:46 +02:00
**/
2013-08-04 18:38:26 +02:00
public function getCurrentTag() {
$tag = $this->request->param("Tag");
if($tag) {
return $this->dataRecord->Tags()
->filter("URLSegment", $tag)
->first();
}
return null;
}
/**
* Category Getter for use in templates.
*
* @return BlogCategory|null
2015-04-21 06:47:46 +02:00
**/
2013-08-04 18:38:26 +02:00
public function getCurrentCategory() {
$category = $this->request->param("Category");
if($category) {
return $this->dataRecord->Categories()
->filter("URLSegment", $category)
->first();
}
return null;
}
/**
* Fetches the archive year from the url
*
* @return int|null
2015-04-21 06:47:46 +02:00
**/
2013-08-04 18:38:26 +02:00
public function getArchiveYear() {
$year = $this->request->param("Year");
if(preg_match("/^[0-9]{4}$/", $year)) {
return (int) $year;
2013-08-04 18:38:26 +02:00
}
return null;
2013-07-21 12:23:35 +02:00
}
2013-08-04 18:38:26 +02:00
/**
* Fetches the archive money from the url.
*
* @return int|null
2015-04-21 06:47:46 +02:00
**/
2013-08-04 18:38:26 +02:00
public function getArchiveMonth() {
$month = $this->request->param("Month");
if(preg_match("/^[0-9]{1,2}$/", $month)) {
if($month > 0 && $month < 13) {
// Check that we have a valid date.
if(checkdate($month, 01, $this->getArchiveYear())) {
return (int) $month;
}
}
}
return null;
}
/**
* Fetches the archive day from the url
*
* @return int|null
2015-04-21 06:47:46 +02:00
**/
public function getArchiveDay() {
$day = $this->request->param("Day");
if(preg_match("/^[0-9]{1,2}$/", $day)) {
// Check that we have a valid date
if(checkdate($this->getArchiveMonth(), $day, $this->getArchiveYear())) {
return (int) $day;
}
2013-08-04 18:38:26 +02:00
}
return null;
}
/**
* Returns the current archive date.
*
* @return Date
2015-04-21 06:47:46 +02:00
**/
2013-08-04 18:38:26 +02:00
public function getArchiveDate() {
$year = $this->getArchiveYear();
$month = $this->getArchiveMonth();
$day = $this->getArchiveDay();
2013-08-04 18:38:26 +02:00
if($year) {
if($month) {
$date = $year . '-' . $month . '-01';
if($day) {
$date = $year . '-' . $month . '-' . $day;
}
2013-08-04 18:38:26 +02:00
} else {
$date = $year . '-01-01';
2013-08-04 18:38:26 +02:00
}
return DBField::create_field("Date", $date);
2013-08-04 18:38:26 +02:00
}
}
/**
* Returns a link to the RSS feed.
*
* @return string URL
2015-04-21 06:47:46 +02:00
**/
public function getRSSLink() {
return $this->Link("rss");
}
}