silverstripe-blog/code/extensions/BlogPostFilter.php

39 lines
1.2 KiB
PHP
Raw Normal View History

2013-07-21 11:23:35 +01:00
<?php
/**
2015-05-10 02:33:12 +12:00
* This is responsible for filtering only published posts to users who do not have permission to
* view non-published posts.
*
* @package silverstripe
* @subpackage blog
2015-05-10 02:33:12 +12:00
*/
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.
2015-05-10 02:33:12 +12:00
*
* @param SQLQuery $query
*/
2013-08-04 17:38:26 +01:00
public function augmentSQL(SQLQuery &$query) {
$stage = Versioned::current_stage();
2015-05-10 02:33:12 +12:00
if($stage == 'Live' || !Permission::check('VIEW_DRAFT_CONTENT')) {
2015-05-14 11:11:50 +12:00
$query->addWhere(sprintf('"PublishDate" < \'%s\'', Convert::raw2sql(SS_Datetime::now())));
}
2013-07-21 11:23:35 +01:00
}
2013-08-23 16:22:13 +01:00
/**
2015-05-10 02:33:12 +12: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
2015-05-10 02:33:12 +12:00
*
* @param SQLQuery $query
* @param mixed $dataQuery
* @param mixed $parent
*/
2013-08-23 16:22:13 +01:00
public function augmentLoadLazyFields(SQLQuery &$query, &$dataQuery, $parent) {
2015-05-14 11:11:50 +12:00
$dataQuery->innerJoin('BlogPost', '"SiteTree"."ID" = "BlogPost"."ID"');
2013-08-23 16:22:13 +01:00
}
2015-05-10 02:33:12 +12:00
}