2011-03-23 12:25:02 +13:00
|
|
|
<?php
|
2013-06-21 10:45:33 +12:00
|
|
|
|
2016-07-22 11:32:32 +12:00
|
|
|
namespace SilverStripe\CMS\Model;
|
|
|
|
|
2016-08-23 14:36:06 +12:00
|
|
|
use SilverStripe\Core\ClassInfo;
|
2016-06-16 16:57:19 +12:00
|
|
|
use SilverStripe\ORM\DB;
|
|
|
|
use SilverStripe\ORM\DataQuery;
|
|
|
|
use SilverStripe\ORM\DataList;
|
|
|
|
use SilverStripe\ORM\DataExtension;
|
|
|
|
|
2013-06-21 10:45:33 +12:00
|
|
|
/**
|
|
|
|
* @todo Cleanup, refactor, test this class
|
|
|
|
*/
|
2011-04-15 19:37:15 +10:00
|
|
|
class SiteTreeFolderExtension extends DataExtension {
|
2012-03-27 17:05:11 +13:00
|
|
|
|
2011-03-23 12:25:02 +13:00
|
|
|
/**
|
2013-06-21 10:45:33 +12:00
|
|
|
* Looks for files used in system and create where clause which contains all ID's of files.
|
2016-01-06 12:42:07 +13:00
|
|
|
*
|
2013-06-21 10:45:33 +12:00
|
|
|
* @returns String where clause which will work as filter.
|
|
|
|
*/
|
2011-03-23 12:25:02 +13:00
|
|
|
public function getUnusedFilesListFilter() {
|
|
|
|
$result = DB::query("SELECT DISTINCT \"FileID\" FROM \"SiteTree_ImageTracking\"");
|
|
|
|
$usedFiles = array();
|
|
|
|
$where = '';
|
2016-07-22 11:32:32 +12:00
|
|
|
$classes = ClassInfo::subclassesFor('SilverStripe\\CMS\\Model\\SiteTree');
|
2016-03-09 09:50:55 +13:00
|
|
|
|
2011-03-23 12:25:02 +13:00
|
|
|
if($result->numRecords() > 0) {
|
|
|
|
while($nextResult = $result->next()) {
|
2016-01-06 12:42:07 +13:00
|
|
|
$where .= $nextResult['FileID'] . ',';
|
2011-03-23 12:25:02 +13:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach($classes as $className) {
|
2013-01-24 08:38:19 +13:00
|
|
|
$query = new DataQuery($className);
|
2011-03-23 12:25:02 +13:00
|
|
|
$ids = $query->execute()->column();
|
|
|
|
if(!count($ids)) continue;
|
2016-03-09 09:50:55 +13:00
|
|
|
|
2015-03-31 19:54:43 +13:00
|
|
|
foreach(singleton($className)->hasOne() as $relName => $joinClass) {
|
2016-08-23 14:36:06 +12:00
|
|
|
if($joinClass == 'SilverStripe\\Assets\\Image' || $joinClass == 'SilverStripe\\Assets\\File') {
|
2011-03-23 12:25:02 +13:00
|
|
|
$fieldName = $relName .'ID';
|
2013-01-24 08:38:19 +13:00
|
|
|
$query = DataList::create($className)->where("$fieldName > 0");
|
2011-03-23 12:25:02 +13:00
|
|
|
$query->distinct = true;
|
2012-05-01 17:58:14 +02:00
|
|
|
$query->select(array($fieldName));
|
2011-03-23 12:25:02 +13:00
|
|
|
$usedFiles = array_merge($usedFiles, $query->execute()->column());
|
|
|
|
|
2016-08-23 14:36:06 +12:00
|
|
|
} elseif($joinClass == 'SilverStripe\\Assets\\Folder') {
|
2011-03-23 12:25:02 +13:00
|
|
|
// @todo
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-03-09 09:50:55 +13:00
|
|
|
|
2011-03-23 12:25:02 +13:00
|
|
|
if($usedFiles) {
|
|
|
|
return "\"File\".\"ID\" NOT IN (" . implode(', ', $usedFiles) . ") AND (\"ClassName\" = 'File' OR \"ClassName\" = 'Image')";
|
|
|
|
|
|
|
|
} else {
|
|
|
|
return "(\"ClassName\" = 'File' OR \"ClassName\" = 'Image')";
|
|
|
|
}
|
2013-06-21 10:45:33 +12:00
|
|
|
return $where; // @todo - How?
|
2011-03-23 12:25:02 +13:00
|
|
|
}
|
2012-03-27 17:05:11 +13:00
|
|
|
}
|