API CHANGE: Introduced new API for SS_Report (from r98215)

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@105808 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Ingo Schommer 2010-05-28 01:35:53 +00:00
parent 97031196fa
commit ce675197bb
2 changed files with 34 additions and 105 deletions

View File

@ -35,37 +35,6 @@ class ReportAdmin extends LeftAndMain {
Requirements::javascript(CMS_DIR . '/javascript/ReportAdmin.Tree.js'); Requirements::javascript(CMS_DIR . '/javascript/ReportAdmin.Tree.js');
} }
/**
* Returns an array of all the reports classnames that could be shown on this site
* to any user. Base class is not included in the response.
* It does not perform filtering based on canView().
*
* @return An array of report class-names, i.e.:
* array("AllOrdersReport","CurrentOrdersReport","UnprintedOrderReport")
*/
public function getReportClassNames() {
$baseClass = 'SS_Report';
$response = array();
// get all sub-classnames (incl. base classname).
$classNames = ClassInfo::subclassesFor( $baseClass );
// drop base className
$classNames = array_diff($classNames, array($baseClass));
// drop report classes, which are not initiatable.
foreach($classNames as $className) {
// Remove abstract classes
$classReflection = new ReflectionClass($className);
if($classReflection->isInstantiable() ) {
$response[] = $className;
}
}
return $response;
}
/** /**
* Does the parent permission checks, but also * Does the parent permission checks, but also
* makes sure that instantiatable subclasses of * makes sure that instantiatable subclasses of
@ -76,23 +45,16 @@ class ReportAdmin extends LeftAndMain {
* @return boolean * @return boolean
*/ */
function canView($member = null) { function canView($member = null) {
if(!$member && $member !== FALSE) { if(!$member && $member !== FALSE) $member = Member::currentUser();
$member = Member::currentUser();
}
if(!parent::canView($member)) return false; if(!parent::canView($member)) return false;
$hasViewableSubclasses = false; $hasViewableSubclasses = false;
$subClasses = array_values( $this->getReportClassNames() ); foreach($this->Reports() as $report) {
if($report->canView($member)) return true;
foreach($subClasses as $subclass) {
if(singleton($subclass)->canView()) {
$hasViewableSubclasses = true;
}
} }
return $hasViewableSubclasses;
return false;
} }
/** /**
@ -102,36 +64,7 @@ class ReportAdmin extends LeftAndMain {
* @return DataObjectSet * @return DataObjectSet
*/ */
public function Reports() { public function Reports() {
$processedReports = array(); return new DataObjectSet(SS_Report::get_reports('ReportAdmin'));
$subClasses = $this->getReportClassNames();
if($subClasses) {
foreach($subClasses as $subClass) {
$processedReports[] = new $subClass();
}
}
$reports = new DataObjectSet($processedReports);
return $reports;
}
/**
* Get EditForm for the class specified in request or in session variable
*
* @param HTTPRequest
* @return Form
*/
public function EditForm($request = null) {
$className = Session::get('currentPage');
$requestId = $this->getRequest()->requestVar('ID');
if(!$requestId) $requestId = $this->getRequest()->latestParam('ID');
if ( $requestId )
return $this->getEditForm($requestId);
// $className can be null
return $this->getEditForm($className);
} }
/** /**
@ -146,24 +79,35 @@ class ReportAdmin extends LeftAndMain {
return $form = $this->EmptyForm(); return $form = $this->EmptyForm();
} }
if (!class_exists($className)) { Session::set('currentPage', $className);
die("$className does not exist");
$fields = new FieldSet();
$actions = new FieldSet();
$reports = SS_Report::get_reports('ReportAdmin');
if(!isset($reports[$className])) return false;
$report = $reports[$className];
if(!$report || !$report->canView()) return Security::permissionFailure($this);
$fields = $report->getCMSFields();
$actions = $report->getCMSActions();
$idField = new HiddenField('ID');
$idField->setValue($id);
$fields->push($idField);
$form = new Form($this, 'EditForm', $fields, $actions);
// Include search criteria in the form action so that pagination works
$filteredCriteria = array_merge($_GET, $_POST);
foreach(array('ID','url','ajax','ctf','update','action_updatereport','SecurityID') as $notAParam) {
unset($filteredCriteria[$notAParam]);
} }
Session::set('currentPage', $className); $formLink = $this->Link() . '/EditForm';
if($filteredCriteria) $formLink .= '?' . http_build_query($filteredCriteria);
$obj = new $className(); $form->setFormAction($formLink);
if(!$obj->canView()) return Security::permissionFailure($this);
$fields = $obj->getCMSFields();
$idField = new HiddenField('ID');
$idField->setValue($className);
$fields->push($idField);
$actions = $obj->getCMSActions();
$form = new Form($this, 'EditForm', $fields, $actions);
$form->setTemplate('ReportAdminForm'); $form->setTemplate('ReportAdminForm');
$form->loadDataFrom($this->request->requestVars()); $form->loadDataFrom($this->request->requestVars());
@ -182,13 +126,7 @@ class ReportAdmin extends LeftAndMain {
* @return boolean * @return boolean
*/ */
public static function has_reports() { public static function has_reports() {
$subClasses = $this->getReportClassNames(); return sizeof(SS_Report::get_reports('ReportAdmin')) > 0;
if($subClasses) {
foreach($subClasses as $subClass) {
return true;
}
}
return false;
} }
} }

View File

@ -1,9 +0,0 @@
<% if EditForm %>
$EditForm
<% else %>
<form id="Form_EditForm" action="admin/reports/EditForm" method="post" enctype="multipart/form-data">
<p><% _t('WELCOME1','Welcome to the',50,'Followed by application name') %> $ApplicationName <% _t('WELCOME2','reporting section. Please choose a specific report from the left.',50) %></p>
</form>
<% end_if %>
<div class="notice-wrap"></div>