silverstripe-blog/code/extensions/BlogPostFilter.php

36 lines
1.2 KiB
PHP
Raw Normal View History

2013-07-21 11:23:35 +01:00
<?php
/**
* This is responsible for filtering only published posts to users who do not have
* permission to view non-published posts.
*
* @package silverstripe
* @subpackage blog
*
* @author Michael Strong <github@michaelstrong.co.uk>
**/
2013-08-04 17:38:26 +01:00
class BlogPostFilter extends DataExtension {
2013-07-21 11:23:35 +01:00
/**
2013-08-04 17:38:26 +01:00
* Augment queries so that we don't fetch unpublished articles.
2013-07-21 11:23:35 +01:00
**/
2013-08-04 17:38:26 +01:00
public function augmentSQL(SQLQuery &$query) {
$stage = Versioned::current_stage();
if($stage == 'Live' || !Permission::check("VIEW_DRAFT_CONTENT")) {
2013-10-09 23:09:28 +01:00
$query->addWhere("PublishDate < '" . Convert::raw2sql(SS_Datetime::now()) . "'");
}
2013-07-21 11:23:35 +01:00
}
2013-08-23 16:22:13 +01:00
/**
* This is a fix so that when we try to fetch subclasses of BlogPost,
* lazy loading includes the BlogPost table in its query. Leaving this table out
* means the default sort order column PublishDate causes an error.
*
* @see https://github.com/silverstripe/silverstripe-framework/issues/1682
2013-08-23 16:22:13 +01:00
**/
public function augmentLoadLazyFields(SQLQuery &$query, &$dataQuery, $parent) {
// Ensures that we're joining the BlogPost table which holds required db fields.
$dataQuery->innerJoin("BlogPost", "`SiteTree`.`ID` = `BlogPost`.`ID`");
}
2013-07-21 11:23:35 +01:00
}