2011-03-23 22:51:00 +13:00
|
|
|
<?php
|
2013-10-15 11:26:23 +13:00
|
|
|
|
2016-08-11 11:14:02 +12:00
|
|
|
namespace SilverStripe\Admin;
|
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Forms\LiteralField;
|
|
|
|
use SilverStripe\Forms\FileField;
|
|
|
|
use SilverStripe\Forms\FieldList;
|
|
|
|
use SilverStripe\Forms\FormAction;
|
|
|
|
use SilverStripe\Forms\RequiredFields;
|
|
|
|
use SilverStripe\Forms\Form;
|
2016-10-28 15:22:21 +13:00
|
|
|
use SilverStripe\ORM\FieldType\DBField;
|
2016-06-23 11:37:22 +12:00
|
|
|
use SilverStripe\Security\Group;
|
|
|
|
use SilverStripe\Security\GroupCsvBulkLoader;
|
|
|
|
|
2011-03-23 22:51:00 +13:00
|
|
|
/**
|
|
|
|
* Imports {@link Group} records by CSV upload, as defined in
|
|
|
|
* {@link GroupCsvBulkLoader}.
|
|
|
|
*/
|
2016-12-16 17:34:21 +13:00
|
|
|
class GroupImportForm extends Form
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var Group Optional group relation
|
|
|
|
*/
|
|
|
|
protected $group;
|
|
|
|
|
|
|
|
public function __construct($controller, $name, $fields = null, $actions = null, $validator = null)
|
|
|
|
{
|
|
|
|
if (!$fields) {
|
|
|
|
$helpHtml = _t(
|
|
|
|
'GroupImportForm.Help1',
|
|
|
|
'<p>Import one or more groups in <em>CSV</em> format (comma-separated values).'
|
|
|
|
. ' <small><a href="#" class="toggle-advanced">Show advanced usage</a></small></p>'
|
|
|
|
);
|
|
|
|
$helpHtml .= _t(
|
|
|
|
'GroupImportForm.Help2',
|
|
|
|
'<div class="advanced">'
|
|
|
|
. '<h4>Advanced usage</h4>'
|
|
|
|
. '<ul>'
|
|
|
|
. '<li>Allowed columns: <em>%s</em></li>'
|
|
|
|
. '<li>Existing groups are matched by their unique <em>Code</em> value, and updated with any new values from the '
|
|
|
|
. 'imported file</li>'
|
|
|
|
. '<li>Group hierarchies can be created by using a <em>ParentCode</em> column.</li>'
|
|
|
|
. '<li>Permission codes can be assigned by the <em>PermissionCode</em> column. Existing permission codes are not '
|
|
|
|
. 'cleared.</li>'
|
|
|
|
. '</ul>'
|
|
|
|
. '</div>'
|
|
|
|
);
|
|
|
|
|
|
|
|
$importer = new GroupCsvBulkLoader();
|
|
|
|
$importSpec = $importer->getImportSpec();
|
|
|
|
$helpHtml = sprintf($helpHtml, implode(', ', array_keys($importSpec['fields'])));
|
|
|
|
|
|
|
|
$fields = new FieldList(
|
|
|
|
new LiteralField('Help', $helpHtml),
|
|
|
|
$fileField = new FileField(
|
|
|
|
'CsvFile',
|
|
|
|
DBField::create_field('HTMLFragment', _t(
|
|
|
|
'SecurityAdmin_MemberImportForm.FileFieldLabel',
|
|
|
|
'CSV File <small>(Allowed extensions: *.csv)</small>'
|
|
|
|
))
|
|
|
|
)
|
|
|
|
);
|
|
|
|
$fileField->getValidator()->setAllowedExtensions(array('csv'));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$actions) {
|
|
|
|
$action = new FormAction('doImport', _t('SecurityAdmin_MemberImportForm.BtnImport', 'Import from CSV'));
|
2016-12-01 10:07:07 +13:00
|
|
|
$action->addExtraClass('btn btn-secondary-outline font-icon-upload');
|
2016-12-16 17:34:21 +13:00
|
|
|
$actions = new FieldList($action);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$validator) {
|
|
|
|
$validator = new RequiredFields('CsvFile');
|
|
|
|
}
|
|
|
|
|
|
|
|
parent::__construct($controller, $name, $fields, $actions, $validator);
|
|
|
|
|
|
|
|
$this->addExtraClass('cms');
|
|
|
|
$this->addExtraClass('import-form');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function doImport($data, $form)
|
|
|
|
{
|
|
|
|
$loader = new GroupCsvBulkLoader();
|
|
|
|
|
|
|
|
// load file
|
|
|
|
$result = $loader->load($data['CsvFile']['tmp_name']);
|
|
|
|
|
|
|
|
// result message
|
|
|
|
$msgArr = array();
|
|
|
|
if ($result->CreatedCount()) {
|
|
|
|
$msgArr[] = _t(
|
|
|
|
'GroupImportForm.ResultCreated',
|
|
|
|
'Created {count} groups',
|
|
|
|
array('count' => $result->CreatedCount())
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if ($result->UpdatedCount()) {
|
|
|
|
$msgArr[] = _t(
|
|
|
|
'GroupImportForm.ResultUpdated',
|
|
|
|
'Updated %d groups',
|
|
|
|
array('count' => $result->UpdatedCount())
|
|
|
|
);
|
|
|
|
}
|
|
|
|
if ($result->DeletedCount()) {
|
|
|
|
$msgArr[] = _t(
|
|
|
|
'GroupImportForm.ResultDeleted',
|
|
|
|
'Deleted %d groups',
|
|
|
|
array('count' => $result->DeletedCount())
|
|
|
|
);
|
|
|
|
}
|
|
|
|
$msg = ($msgArr) ? implode(',', $msgArr) : _t('MemberImportForm.ResultNone', 'No changes');
|
|
|
|
|
|
|
|
$this->sessionMessage($msg, 'good');
|
|
|
|
|
|
|
|
$this->controller->redirectBack();
|
|
|
|
}
|
2011-03-23 22:51:00 +13:00
|
|
|
}
|