silverstripe-blog/code/extensions/BlogPostFilter.php

52 lines
1.4 KiB
PHP
Raw Normal View History

2015-11-21 19:17:29 +13: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
*/
class BlogPostFilter extends DataExtension
{
/**
* Augment queries so that we don't fetch unpublished articles.
*
* @param SQLQuery $query
*/
2016-06-01 17:28:59 +12:00
public function augmentSQL(SQLSelect $query, DataQuery $dataQuery = null)
2015-11-21 19:17:29 +13:00
{
2016-06-01 17:28:59 +12:00
$stage = Versioned::get_stage();
2015-11-21 19:17:29 +13:00
if (Controller::curr() instanceof LeftAndMain) {
return;
}
if ($stage == 'Live' || !Permission::check('VIEW_DRAFT_CONTENT')) {
2016-06-01 17:28:59 +12:00
$query->addWhere(sprintf(
'"PublishDate" < \'%s\'',
Convert::raw2sql(SS_Datetime::now())
));
2015-11-21 19:17:29 +13: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
*
* @param SQLQuery $query
* @param mixed $dataQuery
* @param mixed $parent
*/
2016-06-01 17:28:59 +12:00
public function augmentLoadLazyFields(
SQLSelect &$query,
DataQuery &$dataQuery = null,
$dataObject
) {
2015-11-21 19:17:29 +13:00
$dataQuery->innerJoin('BlogPost', '"SiteTree"."ID" = "BlogPost"."ID"');
}
}