silverstripe-framework/admin/code/MemberImportForm.php

129 lines
3.6 KiB
PHP
Raw Normal View History

<?php
2013-10-15 11:26:23 +13:00
2016-08-11 11:14:02 +12:00
namespace SilverStripe\Admin;
2016-06-23 11:37:22 +12:00
use SilverStripe\Security\MemberCsvBulkLoader;
2016-08-11 11:14:02 +12:00
use Form;
use FieldList;
use LiteralField;
use FileField;
use FormAction;
use RequiredFields;
use Requirements;
2016-06-23 11:37:22 +12:00
/**
* Imports {@link Member} records by CSV upload, as defined in
* {@link MemberCsvBulkLoader}.
2014-08-15 18:53:05 +12:00
*
2013-10-15 11:26:23 +13:00
* @package framework
* @subpackage admin
*/
class MemberImportForm extends Form {
2014-08-15 18:53:05 +12:00
/**
* @var Group Optional group relation
*/
protected $group;
2014-08-15 18:53:05 +12:00
public function __construct($controller, $name, $fields = null, $actions = null, $validator = null) {
if(!$fields) {
$helpHtml = _t(
2014-08-15 18:53:05 +12:00
'MemberImportForm.Help1',
'<p>Import users in <em>CSV format</em> (comma-separated values).'
. ' <small><a href="#" class="toggle-advanced">Show advanced usage</a></small></p>'
);
$helpHtml .= _t(
2014-08-15 18:53:05 +12:00
'MemberImportForm.Help2',
2015-08-24 16:29:40 +12:00
'<div class="advanced">'
. '<h4>Advanced usage</h4>'
. '<ul>'
. '<li>Allowed columns: <em>%s</em></li>'
. '<li>Existing users are matched by their unique <em>Code</em> property, and updated with any new values from '
. 'the imported file.</li>'
. '<li>Groups can be assigned by the <em>Groups</em> column. Groups are identified by their <em>Code</em> property, '
. 'multiple groups can be separated by comma. Existing group memberships are not cleared.</li>'
. '</ul>'
. '</div>'
);
2014-08-15 18:53:05 +12:00
$importer = new MemberCsvBulkLoader();
$importSpec = $importer->getImportSpec();
$helpHtml = sprintf($helpHtml, implode(', ', array_keys($importSpec['fields'])));
2014-08-15 18:53:05 +12:00
$fields = new FieldList(
new LiteralField('Help', $helpHtml),
$fileField = new FileField(
2014-08-15 18:53:05 +12:00
'CsvFile',
_t(
2014-08-15 18:53:05 +12:00
'SecurityAdmin_MemberImportForm.FileFieldLabel',
'CSV File <small>(Allowed extensions: *.csv)</small>'
)
)
);
$fileField->getValidator()->setAllowedExtensions(array('csv'));
}
2014-08-15 18:53:05 +12:00
if(!$actions) {
$action = new FormAction('doImport', _t('SecurityAdmin_MemberImportForm.BtnImport', 'Import from CSV'));
2016-07-01 13:37:29 +12:00
$action->addExtraClass('btn btn-secondary-outline ss-ui-button');
$actions = new FieldList($action);
}
if(!$validator) $validator = new RequiredFields('CsvFile');
2014-08-15 18:53:05 +12:00
parent::__construct($controller, $name, $fields, $actions, $validator);
Requirements::javascript(FRAMEWORK_DIR . '/thirdparty/jquery-entwine/dist/jquery.entwine-dist.js');
Requirements::javascript(FRAMEWORK_ADMIN_DIR . '/client/dist/js/MemberImportForm.js');
$this->addExtraClass('cms');
$this->addExtraClass('import-form');
}
2014-08-15 18:53:05 +12:00
public function doImport($data, $form) {
$loader = new MemberCsvBulkLoader();
2014-08-15 18:53:05 +12:00
// optionally set group relation
if($this->group) $loader->setGroups(array($this->group));
2014-08-15 18:53:05 +12:00
// load file
$result = $loader->load($data['CsvFile']['tmp_name']);
2014-08-15 18:53:05 +12:00
// result message
$msgArr = array();
if($result->CreatedCount()) $msgArr[] = _t(
'MemberImportForm.ResultCreated', 'Created {count} members',
array('count' => $result->CreatedCount())
);
if($result->UpdatedCount()) $msgArr[] = _t(
'MemberImportForm.ResultUpdated', 'Updated {count} members',
array('count' => $result->UpdatedCount())
);
if($result->DeletedCount()) $msgArr[] = _t(
'MemberImportForm.ResultDeleted', 'Deleted %d members',
array('count' => $result->DeletedCount())
);
$msg = ($msgArr) ? implode(',', $msgArr) : _t('MemberImportForm.ResultNone', 'No changes');
2014-08-15 18:53:05 +12:00
$this->sessionMessage($msg, 'good');
2014-08-15 18:53:05 +12:00
$this->controller->redirectBack();
}
2014-08-15 18:53:05 +12:00
/**
* @param $group Group
*/
public function setGroup($group) {
$this->group = $group;
}
2014-08-15 18:53:05 +12:00
/**
* @return Group
*/
public function getGroup($group) {
return $this->group;
}
}