silverstripe-blog/src/Model/BlogPostFilter.php

71 lines
2.1 KiB
PHP
Raw Permalink Normal View History

2015-11-21 07:17:29 +01:00
<?php
namespace SilverStripe\Blog\Model;
use SilverStripe\Admin\LeftAndMain;
use SilverStripe\Control\Controller;
use SilverStripe\Core\Convert;
use SilverStripe\ORM\DataExtension;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\DataQuery;
use SilverStripe\ORM\FieldType\DBDatetime;
use SilverStripe\ORM\Queries\SQLSelect;
use SilverStripe\Security\Permission;
2018-01-29 04:13:19 +01:00
use SilverStripe\Versioned\Versioned;
2015-11-21 07:17:29 +01:00
/**
* This is responsible for filtering only published posts to users who do not have permission to
* view non-published posts.
*
*/
class BlogPostFilter extends DataExtension
{
/**
* Augment queries so that we don't fetch unpublished articles.
*
* @param SQLSelect $query
* @param DataQuery $query
2015-11-21 07:17:29 +01:00
*/
2016-06-01 07:28:59 +02:00
public function augmentSQL(SQLSelect $query, DataQuery $dataQuery = null)
2015-11-21 07:17:29 +01:00
{
2017-07-05 15:49:34 +02:00
if (Controller::has_curr() && Controller::curr() instanceof LeftAndMain) {
2015-11-21 07:17:29 +01:00
return;
}
if (Versioned::get_stage() === Versioned::LIVE ||
(
Versioned::get_draft_site_secured() &&
!Permission::check('VIEW_DRAFT_CONTENT')
)
) {
2016-06-01 07:28:59 +02:00
$query->addWhere(sprintf(
'"PublishDate" < \'%s\'',
Convert::raw2sql(DBDatetime::now())
2016-06-01 07:28:59 +02:00
));
2015-11-21 07:17:29 +01:00
}
}
/**
* {@inheritDoc}
*
2015-11-21 07:17:29 +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
*
* @param SQLSelect $query
* @param DataQuery $dataQuery
* @param DataObject $dataObject
2015-11-21 07:17:29 +01:00
*/
public function augmentLoadLazyFields(SQLSelect &$query, DataQuery &$dataQuery = null, $dataObject)
{
$blogPostTable = DataObject::getSchema()->tableName(BlogPost::class);
$dataQuery->innerJoin(
$blogPostTable,
'"SiteTree"."ID" = "' . $blogPostTable . '"."ID"'
);
2015-11-21 07:17:29 +01:00
}
}