responsive
This commit is contained in:
parent
2bc62a34cf
commit
7add41b48e
|
@ -1548,7 +1548,7 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
* @return htmlElement HTML meta data
|
* @return htmlElement HTML meta data
|
||||||
*/
|
*/
|
||||||
function display_html_attributes() {
|
function display_html_attributes() {
|
||||||
$return = new htmlTable();
|
$return = new htmlResponsiveRow();
|
||||||
$this->checkForInvalidConfiguration($return);
|
$this->checkForInvalidConfiguration($return);
|
||||||
$modules = $this->getAccountContainer()->get_type()->getModules();
|
$modules = $this->getAccountContainer()->get_type()->getModules();
|
||||||
$typeId = $this->getAccountContainer()->get_type()->getId();
|
$typeId = $this->getAccountContainer()->get_type()->getId();
|
||||||
|
@ -1560,7 +1560,7 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$groups[$groupList[$i][1]] = $groupList[$i][0];
|
$groups[$groupList[$i][1]] = $groupList[$i][0];
|
||||||
}
|
}
|
||||||
if (count($groups)==0) {
|
if (count($groups)==0) {
|
||||||
$return->addElement(new htmlStatusMessage("ERROR", _('No Unix groups found in LDAP! Please create one first.')));
|
$return->add(new htmlStatusMessage("ERROR", _('No Unix groups found in LDAP! Please create one first.')), 12);
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
$shelllist = $this->getShells(); // list of all valid shells
|
$shelllist = $this->getShells(); // list of all valid shells
|
||||||
|
@ -1580,8 +1580,7 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$msg = new htmlStatusMessage($this->messages['uid'][5][0],
|
$msg = new htmlStatusMessage($this->messages['uid'][5][0],
|
||||||
$this->messages['uid'][5][1], $this->messages['uid'][5][2],
|
$this->messages['uid'][5][1], $this->messages['uid'][5][2],
|
||||||
array(htmlspecialchars($users[$firstSuggestion])));
|
array(htmlspecialchars($users[$firstSuggestion])));
|
||||||
$msg->colspan = 10;
|
$return->add($msg, 12);
|
||||||
$return->addElement($msg, true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif ($this->getAccountContainer()->getAccountModule('windowsUser') != null) {
|
elseif ($this->getAccountContainer()->getAccountModule('windowsUser') != null) {
|
||||||
|
@ -1621,87 +1620,100 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
}
|
}
|
||||||
|
|
||||||
$userName = '';
|
$userName = '';
|
||||||
if (isset($this->attributes['uid'][0])) $userName = $this->attributes['uid'][0];
|
if (isset($this->attributes['uid'][0])) {
|
||||||
|
$userName = $this->attributes['uid'][0];
|
||||||
|
}
|
||||||
$uidLabel = _("User name");
|
$uidLabel = _("User name");
|
||||||
if ($this->get_scope() == 'host') {
|
if ($this->get_scope() == 'host') {
|
||||||
$uidLabel = _("Host name");
|
$uidLabel = _("Host name");
|
||||||
}
|
}
|
||||||
$uidInput = new htmlTableExtendedInputField($uidLabel, 'uid', $userName, 'uid');
|
$uidInput = new htmlResponsiveInputField($uidLabel, 'uid', $userName, 'uid');
|
||||||
$uidInput->setRequired(true);
|
$uidInput->setRequired(true);
|
||||||
$uidInput->setFieldMaxLength(100);
|
$uidInput->setFieldMaxLength(100);
|
||||||
$return->addElement($uidInput, true);
|
$return->add($uidInput, 12);
|
||||||
if ($this->manageCn($modules)) {
|
if ($this->manageCn($modules)) {
|
||||||
$this->addMultiValueInputTextField($return, 'cn', _("Common name"));
|
$this->addMultiValueInputTextField($return, 'cn', _("Common name"));
|
||||||
}
|
}
|
||||||
$uidNumber = '';
|
$uidNumber = '';
|
||||||
if (isset($this->attributes['uidNumber'][0])) $uidNumber = $this->attributes['uidNumber'][0];
|
if (isset($this->attributes['uidNumber'][0])) {
|
||||||
$uidNumberInput = new htmlTableExtendedInputField(_('UID number'), 'uidNumber', $uidNumber, 'uidNumber');
|
$uidNumber = $this->attributes['uidNumber'][0];
|
||||||
|
}
|
||||||
|
$uidNumberInput = new htmlResponsiveInputField(_('UID number'), 'uidNumber', $uidNumber, 'uidNumber');
|
||||||
$uidNumberInput->setFieldMaxLength(20);
|
$uidNumberInput->setFieldMaxLength(20);
|
||||||
$uidNumberInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
$uidNumberInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
||||||
$return->addElement($uidNumberInput, true);
|
$return->add($uidNumberInput, 12);
|
||||||
if (!$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hidegecos')) {
|
if (!$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hidegecos')) {
|
||||||
$gecos = '';
|
$gecos = '';
|
||||||
if (isset($this->attributes['gecos'][0])) $gecos = $this->attributes['gecos'][0];
|
if (isset($this->attributes['gecos'][0])) {
|
||||||
$return->addElement(new htmlTableExtendedInputField(_('Gecos'), 'gecos', $gecos, 'gecos'), true);
|
$gecos = $this->attributes['gecos'][0];
|
||||||
|
}
|
||||||
|
$return->add(new htmlResponsiveInputField(_('Gecos'), 'gecos', $gecos, 'gecos'), 12);
|
||||||
}
|
}
|
||||||
$primaryGroup = array();
|
$primaryGroup = array();
|
||||||
if (isset($this->attributes['gidNumber'][0])) {
|
if (isset($this->attributes['gidNumber'][0])) {
|
||||||
$primaryGroup[] = $this->attributes['gidNumber'][0];
|
$primaryGroup[] = $this->attributes['gidNumber'][0];
|
||||||
}
|
}
|
||||||
$gidNumberSelect = new htmlTableExtendedSelect('gidNumber', $groups, $primaryGroup, _('Primary group'), 'gidNumber');
|
$gidNumberSelect = new htmlResponsiveSelect('gidNumber', $groups, $primaryGroup, _('Primary group'), 'gidNumber');
|
||||||
$gidNumberSelect->setHasDescriptiveElements(true);
|
$gidNumberSelect->setHasDescriptiveElements(true);
|
||||||
$return->addElement($gidNumberSelect, true);
|
$return->add($gidNumberSelect, 12);
|
||||||
|
|
||||||
if ($this->get_scope()=='user') {
|
if ($this->get_scope()=='user') {
|
||||||
// additional groups
|
// additional groups
|
||||||
if (!$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hidegon') || !$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hideposixGroups')) {
|
if (!$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hidegon') || !$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hideposixGroups')) {
|
||||||
$return->addElement(new htmlOutputText(_('Additional groups')));
|
$return->addLabel(new htmlOutputText(_('Additional groups')));
|
||||||
$return->addElement(new htmlAccountPageButton(get_class($this), 'group', 'open', _('Edit groups')));
|
$additionalGroups = new htmlGroup();
|
||||||
$return->addElement(new htmlHelpLink('addgroup'), true);
|
$additionalGroups->addElement(new htmlAccountPageButton(get_class($this), 'group', 'open', _('Edit groups')));
|
||||||
|
$additionalGroups->addElement(new htmlHelpLink('addgroup'));
|
||||||
|
$return->addField($additionalGroups);
|
||||||
}
|
}
|
||||||
// home directory
|
// home directory
|
||||||
$homeDir = isset($this->attributes[$homeDirAttr][0]) ? $this->attributes[$homeDirAttr][0] : '';
|
$homeDir = isset($this->attributes[$homeDirAttr][0]) ? $this->attributes[$homeDirAttr][0] : '';
|
||||||
$homedirInput = new htmlTableExtendedInputField(_('Home directory'), 'homeDirectory', $homeDir, 'homeDirectory');
|
$homedirInput = new htmlResponsiveInputField(_('Home directory'), 'homeDirectory', $homeDir, 'homeDirectory');
|
||||||
$homedirInput->setRequired(true);
|
$homedirInput->setRequired(true);
|
||||||
$return->addElement($homedirInput, true);
|
$return->add($homedirInput, 12);
|
||||||
if (($_SESSION['config']->get_scriptPath() != null) && ($_SESSION['config']->get_scriptPath() != '')) {
|
if (($_SESSION['config']->get_scriptPath() != null) && ($_SESSION['config']->get_scriptPath() != '')) {
|
||||||
if ($this->getAccountContainer()->isNewAccount) {
|
if ($this->getAccountContainer()->isNewAccount) {
|
||||||
// get list of lamdaemon servers
|
// get list of lamdaemon servers
|
||||||
$lamdaemonServers = explode(";", $_SESSION['config']->get_scriptServers());
|
$lamdaemonServers = explode(";", $_SESSION['config']->get_scriptServers());
|
||||||
for ($i = 0; $i < sizeof($lamdaemonServers); $i++) {
|
for ($i = 0; $i < sizeof($lamdaemonServers); $i++) {
|
||||||
$temp = explode(":", $lamdaemonServers[$i]);
|
$temp = explode(":", $lamdaemonServers[$i]);
|
||||||
if (isset($temp[1])) $lamdaemonServers[$i] = $temp[1];
|
if (isset($temp[1])) {
|
||||||
else $lamdaemonServers[$i] = $temp[0];
|
$lamdaemonServers[$i] = $temp[1];
|
||||||
}
|
|
||||||
$homeDirLabel = new htmlOutputText(_('Create home directory'));
|
|
||||||
$homeDirLabel->alignment = htmlElement::ALIGN_TOP;
|
|
||||||
$return->addElement($homeDirLabel);
|
|
||||||
$homeServerContainer = new htmlTable();
|
|
||||||
for ($h = 0; $h < sizeof($lamdaemonServers); $h++) {
|
|
||||||
$homeServerContainer->addElement(new htmlTableExtendedInputCheckbox('createhomedir_' . $h, in_array($lamdaemonServers[$h], $this->lamdaemonServers), $lamdaemonServers[$h], null, false), true);
|
|
||||||
}
|
|
||||||
$return->addElement($homeServerContainer);
|
|
||||||
$homeDirHelp = new htmlHelpLink('createhomedir');
|
|
||||||
$homeDirHelp->alignment = htmlElement::ALIGN_TOP;
|
|
||||||
$return->addElement($homeDirHelp, true);
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$return->addElement(new htmlOutputText(''));
|
$lamdaemonServers[$i] = $temp[0];
|
||||||
$return->addElement(new htmlAccountPageButton(get_class($this), 'homedir', 'open', _('Check home directories')), true);
|
}
|
||||||
|
}
|
||||||
|
$homeDirLabel = new htmlOutputText(_('Create home directory'));
|
||||||
|
$return->addLabel($homeDirLabel);
|
||||||
|
$homeServerContainer = new htmlTable();
|
||||||
|
for ($h = 0; $h < sizeof($lamdaemonServers); $h++) {
|
||||||
|
$homeServerContainer->addElement(new htmlTableExtendedInputCheckbox('createhomedir_' . $h, in_array($lamdaemonServers[$h], $this->lamdaemonServers), $lamdaemonServers[$h], null, false));
|
||||||
|
if ($h === 0) {
|
||||||
|
$homeDirHelp = new htmlHelpLink('createhomedir');
|
||||||
|
$homeServerContainer->addElement($homeDirHelp);
|
||||||
|
}
|
||||||
|
$homeServerContainer->addNewLine();
|
||||||
|
}
|
||||||
|
$return->addField($homeServerContainer);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$return->addLabel(new htmlOutputText(' ', false));
|
||||||
|
$return->addField(new htmlAccountPageButton(get_class($this), 'homedir', 'open', _('Check home directories')));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$selectedShell = array();
|
$selectedShell = array();
|
||||||
if (isset($this->attributes['loginShell'][0])) {
|
if (isset($this->attributes['loginShell'][0])) {
|
||||||
$selectedShell = array($this->attributes['loginShell'][0]);
|
$selectedShell = array($this->attributes['loginShell'][0]);
|
||||||
}
|
}
|
||||||
$return->addElement(new htmlTableExtendedSelect('loginShell', $shelllist, $selectedShell, _('Login shell'), 'loginShell'), true);
|
$return->add(new htmlResponsiveSelect('loginShell', $shelllist, $selectedShell, _('Login shell'), 'loginShell'), 12);
|
||||||
}
|
}
|
||||||
// password buttons
|
// password buttons
|
||||||
if (checkIfWriteAccessIsAllowed($this->get_scope())
|
if (checkIfWriteAccessIsAllowed($this->get_scope())
|
||||||
&& isset($this->attributes[$this->getPasswordAttrName($modules)][0])
|
&& isset($this->attributes[$this->getPasswordAttrName($modules)][0])
|
||||||
&& $this->isPasswordManaged()) {
|
&& $this->isPasswordManaged()) {
|
||||||
$return->addElement(new htmlOutputText(_('Password')));
|
$return->addLabel(new htmlOutputText(_('Password')));
|
||||||
$pwdContainer = new htmlTable();
|
$pwdContainer = new htmlGroup();
|
||||||
if (pwd_is_enabled($this->attributes[$this->getPasswordAttrName($modules)][0])) {
|
if (pwd_is_enabled($this->attributes[$this->getPasswordAttrName($modules)][0])) {
|
||||||
$pwdContainer->addElement(new htmlButton('lockPassword', _('Lock password')));
|
$pwdContainer->addElement(new htmlButton('lockPassword', _('Lock password')));
|
||||||
}
|
}
|
||||||
|
@ -1709,20 +1721,18 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$pwdContainer->addElement(new htmlButton('unlockPassword', _('Unlock password')));
|
$pwdContainer->addElement(new htmlButton('unlockPassword', _('Unlock password')));
|
||||||
}
|
}
|
||||||
$pwdContainer->addElement(new htmlButton('removePassword', _('Remove password')));
|
$pwdContainer->addElement(new htmlButton('removePassword', _('Remove password')));
|
||||||
$pwdContainer->colspan = 2;
|
$return->addField($pwdContainer);
|
||||||
$return->addElement($pwdContainer, true);
|
|
||||||
}
|
}
|
||||||
// remove button
|
// remove button
|
||||||
if ($this->isOptional($modules) && !$this->skipObjectClass()) {
|
if ($this->isOptional($modules) && !$this->skipObjectClass()) {
|
||||||
$return->addElement(new htmlSpacer(null, '20px'), true);
|
$return->addVerticalSpacer('2rem');
|
||||||
$remButton = new htmlButton('remObjectClass', _('Remove Unix extension'));
|
$remButton = new htmlButton('remObjectClass', _('Remove Unix extension'));
|
||||||
$remButton->colspan = 5;
|
$return->add($remButton, 12, 12, 12, 'text-center');
|
||||||
$return->addElement($remButton, true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// add button
|
// add button
|
||||||
$return->addElement(new htmlButton('addObjectClass', _('Add Unix extension')));
|
$return->add(new htmlButton('addObjectClass', _('Add Unix extension')), 12);
|
||||||
}
|
}
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
@ -1730,9 +1740,9 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
/**
|
/**
|
||||||
* Checks if the configuration is valid and prints an error if not.
|
* Checks if the configuration is valid and prints an error if not.
|
||||||
*
|
*
|
||||||
* @param htmlTable $content content area
|
* @param htmlResponsiveRow $content content area
|
||||||
*/
|
*/
|
||||||
private function checkForInvalidConfiguration(htmlTable $content) {
|
private function checkForInvalidConfiguration(htmlResponsiveRow $content) {
|
||||||
$typeId = $this->getAccountContainer()->get_type()->getId();
|
$typeId = $this->getAccountContainer()->get_type()->getId();
|
||||||
if ($this->get_scope() == 'user') {
|
if ($this->get_scope() == 'user') {
|
||||||
$generatorOption = 'posixAccount_' . $typeId . '_uidGeneratorUsers';
|
$generatorOption = 'posixAccount_' . $typeId . '_uidGeneratorUsers';
|
||||||
|
@ -1742,8 +1752,7 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
}
|
}
|
||||||
if (empty($this->moduleSettings[$generatorOption])) {
|
if (empty($this->moduleSettings[$generatorOption])) {
|
||||||
$message = new htmlStatusMessage('ERROR', _('Invalid configuration detected. Please edit your server profile (module settings) and fill all required fields.'));
|
$message = new htmlStatusMessage('ERROR', _('Invalid configuration detected. Please edit your server profile (module settings) and fill all required fields.'));
|
||||||
$message->colspan = 5;
|
$content->add($message, 12);
|
||||||
$content->addElement($message, true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1771,7 +1780,7 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
* @return htmlElement meta HTML code
|
* @return htmlElement meta HTML code
|
||||||
*/
|
*/
|
||||||
function display_html_group() {
|
function display_html_group() {
|
||||||
$return = new htmlTable();
|
$return = new htmlResponsiveRow();
|
||||||
$modules = $this->getAccountContainer()->get_type()->getModules();
|
$modules = $this->getAccountContainer()->get_type()->getModules();
|
||||||
$typeId = $this->getAccountContainer()->get_type()->getId();
|
$typeId = $this->getAccountContainer()->get_type()->getId();
|
||||||
$showUnix = !$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hideposixGroups');
|
$showUnix = !$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hideposixGroups');
|
||||||
|
@ -1820,8 +1829,8 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$unixContainer->addElement($addSelect, true);
|
$unixContainer->addElement($addSelect, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$return->addElement($unixContainer, true);
|
$return->add($unixContainer, 12);
|
||||||
$return->addVerticalSpace('3rem');
|
$return->addVerticalSpacer('3rem');
|
||||||
}
|
}
|
||||||
|
|
||||||
$showGon = self::areGroupOfNamesActive() && !$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hidegon');
|
$showGon = self::areGroupOfNamesActive() && !$this->isBooleanConfigOptionSet('posixAccount_' . $typeId . '_hidegon');
|
||||||
|
@ -1871,8 +1880,8 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$addGonSelect->setRightToLeftTextDirection(true);
|
$addGonSelect->setRightToLeftTextDirection(true);
|
||||||
$gonContainer->addElement($addGonSelect);
|
$gonContainer->addElement($addGonSelect);
|
||||||
$gonContainer->addNewLine();
|
$gonContainer->addNewLine();
|
||||||
$return->addElement($gonContainer, true);
|
$return->add($gonContainer, 12);
|
||||||
$return->addVerticalSpace('3rem');
|
$return->addVerticalSpacer('3rem');
|
||||||
}
|
}
|
||||||
|
|
||||||
$showGonSync = $showGon && !$autoSyncGon;
|
$showGonSync = $showGon && !$autoSyncGon;
|
||||||
|
@ -1880,11 +1889,9 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$moduleList = $this->getAccountContainer()->get_type()->getModules();
|
$moduleList = $this->getAccountContainer()->get_type()->getModules();
|
||||||
$showWindowsSync = $this->isWindows($moduleList);
|
$showWindowsSync = $this->isWindows($moduleList);
|
||||||
if ($showUnixSync && ($showGonSync || $showWindowsSync)) {
|
if ($showUnixSync && ($showGonSync || $showWindowsSync)) {
|
||||||
$return->addElement(new htmlSubTitle(_('Sync groups')), true);
|
$return->add(new htmlSubTitle(_('Sync groups')), 12);
|
||||||
$syncOptionTable = new htmlTable();
|
$return->add(new htmlResponsiveInputCheckbox('syncDeleteGroups', true, _('Delete non-matching entries')), 12);
|
||||||
$syncOptionTable->addElement(new htmlTableExtendedInputCheckbox('syncDeleteGroups', true, _('Delete non-matching entries')), true);
|
$return->addVerticalSpacer('1rem');
|
||||||
$return->addElement($syncOptionTable, true);
|
|
||||||
$return->addVerticalSpace('1rem');
|
|
||||||
if ($showGonSync) {
|
if ($showGonSync) {
|
||||||
$syncButtons = new htmlGroup();
|
$syncButtons = new htmlGroup();
|
||||||
$u2gonButton = new htmlAccountPageButton(get_class($this), 'group', 'syncU2GON', _('Sync Unix to group of names'));
|
$u2gonButton = new htmlAccountPageButton(get_class($this), 'group', 'syncU2GON', _('Sync Unix to group of names'));
|
||||||
|
@ -1894,7 +1901,7 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$gon2uButton = new htmlAccountPageButton(get_class($this), 'group', 'syncGON2U', _('Sync group of names to Unix'));
|
$gon2uButton = new htmlAccountPageButton(get_class($this), 'group', 'syncGON2U', _('Sync group of names to Unix'));
|
||||||
$gon2uButton->setIconClass('groupButton');
|
$gon2uButton->setIconClass('groupButton');
|
||||||
$syncButtons->addElement($gon2uButton);
|
$syncButtons->addElement($gon2uButton);
|
||||||
$return->addElement($syncButtons);
|
$return->add($syncButtons, 12, 12, 12, 'text-center');
|
||||||
if ($showWindowsSync) {
|
if ($showWindowsSync) {
|
||||||
$syncButtons->addElement(new htmlSpacer('2rem', null));
|
$syncButtons->addElement(new htmlSpacer('2rem', null));
|
||||||
}
|
}
|
||||||
|
@ -1904,14 +1911,13 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
$gon2uButton = new htmlAccountPageButton(get_class($this), 'group', 'syncWin2U', _('Sync Windows to Unix'));
|
$gon2uButton = new htmlAccountPageButton(get_class($this), 'group', 'syncWin2U', _('Sync Windows to Unix'));
|
||||||
$gon2uButton->setIconClass('sambaButton');
|
$gon2uButton->setIconClass('sambaButton');
|
||||||
$syncButtons->addElement($gon2uButton);
|
$syncButtons->addElement($gon2uButton);
|
||||||
$return->addElement($syncButtons);
|
$return->add($syncButtons, 12, 12, 12, 'text-center');
|
||||||
}
|
}
|
||||||
$return->addNewLine();
|
|
||||||
$return->addVerticalSpace('3rem');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$return->addVerticalSpacer('2rem');
|
||||||
$backButton = new htmlAccountPageButton(get_class($this), 'attributes', 'back', _('Back'));
|
$backButton = new htmlAccountPageButton(get_class($this), 'attributes', 'back', _('Back'));
|
||||||
$return->addElement($backButton);
|
$return->add($backButton, 12);
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1923,13 +1929,10 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
function display_html_homedir() {
|
function display_html_homedir() {
|
||||||
$modules = $this->getAccountContainer()->get_type()->getModules();
|
$modules = $this->getAccountContainer()->get_type()->getModules();
|
||||||
$homeDirAttr = $this->getHomedirAttrName($modules);
|
$homeDirAttr = $this->getHomedirAttrName($modules);
|
||||||
$return = new htmlTable();
|
$return = new htmlResponsiveRow();
|
||||||
$return->addElement(new htmlOutputText(_('Home directory')));
|
$return->addLabel(new htmlOutputText(_('Home directory')));
|
||||||
$return->addElement(new htmlSpacer('5px', null));
|
$return->addField(new htmlOutputText($this->attributes[$homeDirAttr][0]));
|
||||||
$return->addElement(new htmlOutputText($this->attributes[$homeDirAttr][0]), true);
|
$return->addVerticalSpacer('2rem');
|
||||||
$return->addElement(new htmlSpacer(null, '10px'), true);
|
|
||||||
$homeServerContainer = new htmlTable();
|
|
||||||
$homeServerContainer->colspan = 5;
|
|
||||||
// get list of lamdaemon servers
|
// get list of lamdaemon servers
|
||||||
$lamdaemonServers = explode(";", $_SESSION['config']->get_scriptServers());
|
$lamdaemonServers = explode(";", $_SESSION['config']->get_scriptServers());
|
||||||
for ($i = 0; $i < sizeof($lamdaemonServers); $i++) {
|
for ($i = 0; $i < sizeof($lamdaemonServers); $i++) {
|
||||||
|
@ -1955,18 +1958,20 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
if (!empty($result)) {
|
if (!empty($result)) {
|
||||||
$returnValue = trim($result);
|
$returnValue = trim($result);
|
||||||
if ($returnValue == 'ok') {
|
if ($returnValue == 'ok') {
|
||||||
$homeServerContainer->addElement(new htmlOutputText($label));
|
$return->addLabel(new htmlOutputText($label));
|
||||||
$homeServerContainer->addElement(new htmlSpacer('5px', null));
|
$okGroup = new htmlGroup();
|
||||||
$homeServerContainer->addElement(new htmlImage('../../graphics/pass.png', 16, 16));
|
$okGroup->addElement(new htmlImage('../../graphics/pass.png', 16, 16));
|
||||||
$homeServerContainer->addElement(new htmlSpacer('5px', null));
|
$okGroup->addElement(new htmlSpacer('5px', null));
|
||||||
$homeServerContainer->addElement(new htmlAccountPageButton(get_class($this), 'homedir', 'delete_' . $i, _('Delete')));
|
$okGroup->addElement(new htmlAccountPageButton(get_class($this), 'homedir', 'delete_' . $i, _('Delete')));
|
||||||
|
$return->addField($okGroup);
|
||||||
}
|
}
|
||||||
elseif ($returnValue == 'missing') {
|
elseif ($returnValue == 'missing') {
|
||||||
$homeServerContainer->addElement(new htmlOutputText($label));
|
$return->addLabel(new htmlOutputText($label));
|
||||||
$homeServerContainer->addElement(new htmlSpacer('5px', null));
|
$failGroup = new htmlGroup();
|
||||||
$homeServerContainer->addElement(new htmlImage('../../graphics/fail.png', 16, 16));
|
$failGroup->addElement(new htmlImage('../../graphics/fail.png', 16, 16));
|
||||||
$homeServerContainer->addElement(new htmlSpacer('5px', null));
|
$failGroup->addElement(new htmlSpacer('5px', null));
|
||||||
$homeServerContainer->addElement(new htmlAccountPageButton(get_class($this), 'homedir', 'create_' . $i, _('Create')));
|
$failGroup->addElement(new htmlAccountPageButton(get_class($this), 'homedir', 'create_' . $i, _('Create')));
|
||||||
|
$return->addField($failGroup);
|
||||||
}
|
}
|
||||||
elseif (trim($returnValue) != '') {
|
elseif (trim($returnValue) != '') {
|
||||||
$messageParams = explode(",", $returnValue);
|
$messageParams = explode(",", $returnValue);
|
||||||
|
@ -1979,15 +1984,12 @@ class posixAccount extends baseModule implements passwordService {
|
||||||
else {
|
else {
|
||||||
$message = new htmlStatusMessage('WARN', htmlspecialchars($messageParams[0]));
|
$message = new htmlStatusMessage('WARN', htmlspecialchars($messageParams[0]));
|
||||||
}
|
}
|
||||||
$message->colspan = 5;
|
$return->add($message, 12);
|
||||||
$homeServerContainer->addElement($message, true);
|
|
||||||
}
|
|
||||||
$homeServerContainer->addNewLine();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$return->addElement($homeServerContainer, true);
|
}
|
||||||
$return->addElement(new htmlSpacer(null, '10px'), true);
|
$return->addVerticalSpacer('2rem');
|
||||||
$return->addElement(new htmlAccountPageButton(get_class($this), 'attributes', 'back', _('Back')));
|
$return->add(new htmlAccountPageButton(get_class($this), 'attributes', 'back', _('Back')), 12, 12, 12, 'text-center');
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -273,13 +273,27 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
function process_attributes() {
|
function process_attributes() {
|
||||||
if (isset($_POST['form_subpage_shadowAccount_attributes_remObjectClass'])) {
|
if (isset($_POST['form_subpage_shadowAccount_attributes_remObjectClass'])) {
|
||||||
$this->attributes['objectClass'] = array_delete(array('shadowAccount'), $this->attributes['objectClass']);
|
$this->attributes['objectClass'] = array_delete(array('shadowAccount'), $this->attributes['objectClass']);
|
||||||
if (isset($this->attributes['shadowMin'])) unset($this->attributes['shadowMin']);
|
if (isset($this->attributes['shadowMin'])) {
|
||||||
if (isset($this->attributes['shadowMax'])) unset($this->attributes['shadowMax']);
|
unset($this->attributes['shadowMin']);
|
||||||
if (isset($this->attributes['shadowWarning'])) unset($this->attributes['shadowWarning']);
|
}
|
||||||
if (isset($this->attributes['shadowInactive'])) unset($this->attributes['shadowInactive']);
|
if (isset($this->attributes['shadowMax'])) {
|
||||||
if (isset($this->attributes['shadowLastChange'])) unset($this->attributes['shadowLastChange']);
|
unset($this->attributes['shadowMax']);
|
||||||
if (isset($this->attributes['shadowExpire'])) unset($this->attributes['shadowExpire']);
|
}
|
||||||
if (isset($this->attributes['shadowFlag'])) unset($this->attributes['shadowFlag']);
|
if (isset($this->attributes['shadowWarning'])) {
|
||||||
|
unset($this->attributes['shadowWarning']);
|
||||||
|
}
|
||||||
|
if (isset($this->attributes['shadowInactive'])) {
|
||||||
|
unset($this->attributes['shadowInactive']);
|
||||||
|
}
|
||||||
|
if (isset($this->attributes['shadowLastChange'])) {
|
||||||
|
unset($this->attributes['shadowLastChange']);
|
||||||
|
}
|
||||||
|
if (isset($this->attributes['shadowExpire'])) {
|
||||||
|
unset($this->attributes['shadowExpire']);
|
||||||
|
}
|
||||||
|
if (isset($this->attributes['shadowFlag'])) {
|
||||||
|
unset($this->attributes['shadowFlag']);
|
||||||
|
}
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
if (!in_array('shadowAccount', $this->attributes['objectClass'])) {
|
if (!in_array('shadowAccount', $this->attributes['objectClass'])) {
|
||||||
|
@ -291,11 +305,21 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
$this->attributes['shadowMax'][0] = $_POST['shadowMax'];
|
$this->attributes['shadowMax'][0] = $_POST['shadowMax'];
|
||||||
$this->attributes['shadowWarning'][0] = $_POST['shadowWarning'];
|
$this->attributes['shadowWarning'][0] = $_POST['shadowWarning'];
|
||||||
$this->attributes['shadowInactive'][0] = $_POST['shadowInactive'];
|
$this->attributes['shadowInactive'][0] = $_POST['shadowInactive'];
|
||||||
if ( !get_preg($this->attributes['shadowMin'][0], 'digit')) $errors[] = $this->messages['shadowMin'][0];
|
if ( !get_preg($this->attributes['shadowMin'][0], 'digit')) {
|
||||||
if ( !get_preg($this->attributes['shadowMax'][0], 'digit')) $errors[] = $this->messages['shadowMax'][0];
|
$errors[] = $this->messages['shadowMin'][0];
|
||||||
if ( $this->attributes['shadowMin'][0] > $this->attributes['shadowMax'][0]) $errors[] = $this->messages['shadow_cmp'][0];
|
}
|
||||||
if ( !get_preg($this->attributes['shadowInactive'][0], 'digit2')) $errors[] = $this->messages['inactive'][0];
|
if ( !get_preg($this->attributes['shadowMax'][0], 'digit')) {
|
||||||
if ( !get_preg($this->attributes['shadowWarning'][0], 'digit')) $errors[] = $this->messages['shadowWarning'][0];
|
$errors[] = $this->messages['shadowMax'][0];
|
||||||
|
}
|
||||||
|
if ( $this->attributes['shadowMin'][0] > $this->attributes['shadowMax'][0]) {
|
||||||
|
$errors[] = $this->messages['shadow_cmp'][0];
|
||||||
|
}
|
||||||
|
if ( !get_preg($this->attributes['shadowInactive'][0], 'digit2')) {
|
||||||
|
$errors[] = $this->messages['inactive'][0];
|
||||||
|
}
|
||||||
|
if ( !get_preg($this->attributes['shadowWarning'][0], 'digit')) {
|
||||||
|
$errors[] = $this->messages['shadowWarning'][0];
|
||||||
|
}
|
||||||
if (isset($_POST['form_subpage_shadowAccount_attributes_expirePassword']) && isset($this->attributes['shadowMax'][0]) && ($this->attributes['shadowMax'][0] != 0)) {
|
if (isset($_POST['form_subpage_shadowAccount_attributes_expirePassword']) && isset($this->attributes['shadowMax'][0]) && ($this->attributes['shadowMax'][0] != 0)) {
|
||||||
$this->attributes['shadowLastChange'][0] = intval(time()/3600/24) - $this->attributes['shadowMax'][0] - 1;
|
$this->attributes['shadowLastChange'][0] = intval(time()/3600/24) - $this->attributes['shadowMax'][0] - 1;
|
||||||
}
|
}
|
||||||
|
@ -311,41 +335,19 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
if (isset($_POST['form_subpage_shadowAccount_attributes_addObjectClass'])) {
|
if (isset($_POST['form_subpage_shadowAccount_attributes_addObjectClass'])) {
|
||||||
$this->attributes['objectClass'][] = 'shadowAccount';
|
$this->attributes['objectClass'][] = 'shadowAccount';
|
||||||
}
|
}
|
||||||
$return = new htmlTable();
|
$return = new htmlResponsiveRow();
|
||||||
if (in_array('shadowAccount', $this->attributes['objectClass'])) {
|
if (in_array('shadowAccount', $this->attributes['objectClass'])) {
|
||||||
$shWarning = '';
|
$pwdWarnInput = $this->addSimpleInputTextField($return, 'shadowWarning', _('Password warning'));
|
||||||
if (isset($this->attributes['shadowWarning'][0])) {
|
|
||||||
$shWarning = $this->attributes['shadowWarning'][0];
|
|
||||||
}
|
|
||||||
$pwdWarnInput = new htmlTableExtendedInputField(_('Password warning'), 'shadowWarning', $shWarning, 'shadowWarning');
|
|
||||||
$pwdWarnInput->setFieldMaxLength(4);
|
|
||||||
$pwdWarnInput->setFieldSize(5);
|
|
||||||
$pwdWarnInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
$pwdWarnInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
||||||
$return->addElement($pwdWarnInput, true);
|
|
||||||
|
|
||||||
$shPwdExpiration = '';
|
$pwdExpInput = $this->addSimpleInputTextField($return, 'shadowInactive', _('Password expiration'));
|
||||||
if (isset($this->attributes['shadowInactive'][0])) $shPwdExpiration = $this->attributes['shadowInactive'][0];
|
|
||||||
$pwdExpInput = new htmlTableExtendedInputField(_('Password expiration'), 'shadowInactive', $shPwdExpiration, 'shadowInactive');
|
|
||||||
$pwdExpInput->setFieldMaxLength(4);
|
|
||||||
$pwdExpInput->setFieldSize(5);
|
|
||||||
$pwdExpInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
$pwdExpInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
||||||
$return->addElement($pwdExpInput, true);
|
|
||||||
|
|
||||||
$shMinAge = '';
|
$minAgeInput = $this->addSimpleInputTextField($return, 'shadowMin', _('Minimum password age'));
|
||||||
if (isset($this->attributes['shadowMin'][0])) $shMinAge = $this->attributes['shadowMin'][0];
|
|
||||||
$minAgeInput = new htmlTableExtendedInputField(_('Minimum password age'), 'shadowMin', $shMinAge, 'shadowMin');
|
|
||||||
$minAgeInput->setFieldMaxLength(5);
|
|
||||||
$minAgeInput->setFieldSize(5);
|
|
||||||
$minAgeInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
$minAgeInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
||||||
$return->addElement($minAgeInput, true);
|
|
||||||
|
|
||||||
$shMaxAge = '';
|
$maxAgeInput = $this->addSimpleInputTextField($return, 'shadowMax', _('Maximum password age'));
|
||||||
if (isset($this->attributes['shadowMax'][0])) $shMaxAge = $this->attributes['shadowMax'][0];
|
|
||||||
$maxAgeInput = new htmlTableExtendedInputField(_('Maximum password age'), 'shadowMax', $shMaxAge, 'shadowMax');
|
|
||||||
$maxAgeInput->setFieldMaxLength(5);
|
|
||||||
$maxAgeInput->setFieldSize(5);
|
|
||||||
$maxAgeInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
$maxAgeInput->setValidationRule(htmlElement::VALIDATE_NUMERIC);
|
||||||
$return->addElement($maxAgeInput, true);
|
|
||||||
|
|
||||||
$expirationDate = " - ";
|
$expirationDate = " - ";
|
||||||
if (isset($this->attributes['shadowExpire'][0])) {
|
if (isset($this->attributes['shadowExpire'][0])) {
|
||||||
|
@ -353,12 +355,12 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
$date = new DateTime('@' . $shAccExpirationDate*3600*24, new DateTimeZone('UTC'));
|
$date = new DateTime('@' . $shAccExpirationDate*3600*24, new DateTimeZone('UTC'));
|
||||||
$expirationDate = $date->format('d.m.Y');
|
$expirationDate = $date->format('d.m.Y');
|
||||||
}
|
}
|
||||||
$return->addElement(new htmlOutputText(_('Account expiration date')));
|
$return->addLabel(new htmlOutputText(_('Account expiration date')));
|
||||||
$expireTable = new htmlTable();
|
$expireTable = new htmlGroup();
|
||||||
$expireTable->addElement(new htmlOutputText($expirationDate, false));
|
$expireTable->addElement(new htmlOutputText($expirationDate, false));
|
||||||
$expireTable->addElement(new htmlAccountPageButton('shadowAccount', 'expire', 'open', 'edit.png', true, _('Change')));
|
$expireTable->addElement(new htmlAccountPageButton('shadowAccount', 'expire', 'open', 'edit.png', true, _('Change')));
|
||||||
$return->addElement($expireTable);
|
$expireTable->addElement(new htmlHelpLink('shadowExpire'), true);
|
||||||
$return->addElement(new htmlHelpLink('shadowExpire'), true);
|
$return->addField($expireTable);
|
||||||
|
|
||||||
$pwdChangeDate = " - ";
|
$pwdChangeDate = " - ";
|
||||||
if (isset($this->attributes['shadowLastChange'][0])) {
|
if (isset($this->attributes['shadowLastChange'][0])) {
|
||||||
|
@ -366,23 +368,22 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
$date = new DateTime('@' . $shPwdChangeDate*3600*24, new DateTimeZone('UTC'));
|
$date = new DateTime('@' . $shPwdChangeDate*3600*24, new DateTimeZone('UTC'));
|
||||||
$pwdChangeDate = $date->format('d.m.Y');
|
$pwdChangeDate = $date->format('d.m.Y');
|
||||||
}
|
}
|
||||||
$return->addElement(new htmlOutputText(_('Last password change')));
|
$return->addLabel(new htmlOutputText(_('Last password change')));
|
||||||
$pwdChangeTable = new htmlTable();
|
$pwdChangeTable = new htmlGroup();
|
||||||
$pwdChangeTable->addElement(new htmlOutputText($pwdChangeDate, false));
|
$pwdChangeTable->addElement(new htmlOutputText($pwdChangeDate, false));
|
||||||
$pwdChangeTable->addElement(new htmlAccountPageButton('shadowAccount', 'pwdChange', 'open', 'edit.png', true, _('Change')));
|
$pwdChangeTable->addElement(new htmlAccountPageButton('shadowAccount', 'pwdChange', 'open', 'edit.png', true, _('Change')));
|
||||||
if (isset($this->attributes['shadowMax'][0]) && ($this->attributes['shadowMax'][0] != '')) {
|
if (isset($this->attributes['shadowMax'][0]) && ($this->attributes['shadowMax'][0] != '')) {
|
||||||
$pwdChangeTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'expirePassword', _('Force password change')));
|
$pwdChangeTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'expirePassword', _('Force password change')));
|
||||||
}
|
}
|
||||||
$return->addElement($pwdChangeTable);
|
$pwdChangeTable->addElement(new htmlHelpLink('shadowLastChange'), true);
|
||||||
$return->addElement(new htmlHelpLink('shadowLastChange'), true);
|
$return->addField($pwdChangeTable);
|
||||||
|
|
||||||
$return->addElement(new htmlOutputText(''), true);
|
$return->addVerticalSpacer('2rem');
|
||||||
$remButton = new htmlAccountPageButton('shadowAccount', 'attributes', 'remObjectClass', _('Remove Shadow account extension'));
|
$remButton = new htmlAccountPageButton('shadowAccount', 'attributes', 'remObjectClass', _('Remove Shadow account extension'));
|
||||||
$remButton->colspan = 4;
|
$return->add($remButton, 12, 12, 12, 'text-center');
|
||||||
$return->addElement($remButton);
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$return->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'addObjectClass', _('Add Shadow account extension')));
|
$return->add(new htmlAccountPageButton('shadowAccount', 'attributes', 'addObjectClass', _('Add Shadow account extension')), 12);
|
||||||
}
|
}
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
@ -454,46 +455,59 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
* @return array meta HTML code
|
* @return array meta HTML code
|
||||||
*/
|
*/
|
||||||
function display_html_expire() {
|
function display_html_expire() {
|
||||||
$return = new htmlTable();
|
$return = new htmlResponsiveRow();
|
||||||
$shAccExpirationDate = time()/(3600*24) + 365;
|
$shAccExpirationDate = time() / (3600 * 24) + 365;
|
||||||
if (isset($this->attributes['shadowExpire'][0])) {
|
if (isset($this->attributes['shadowExpire'][0])) {
|
||||||
$shAccExpirationDate = $this->attributes['shadowExpire'][0];
|
$shAccExpirationDate = $this->attributes['shadowExpire'][0];
|
||||||
}
|
}
|
||||||
$date = new DateTime('@' . $shAccExpirationDate*3600*24, new DateTimeZone('UTC'));
|
$date = new DateTime('@' . $shAccExpirationDate*3600*24, new DateTimeZone('UTC'));
|
||||||
for ( $i=1; $i<=31; $i++ ) $mday[] = $i;
|
for ( $i=1; $i<=31; $i++ ) {
|
||||||
for ( $i=1; $i<=12; $i++ ) $mon[] = $i;
|
$mday[] = $i;
|
||||||
for ( $i=2003; $i<=2050; $i++ ) $year[] = $i;
|
}
|
||||||
$return->addElement(new htmlOutputText(_('Account expiration date')));
|
for ( $i=1; $i<=12; $i++ ) {
|
||||||
$expTable = new htmlTable();
|
$mon[] = $i;
|
||||||
$expTable->addElement(new htmlSelect('shadowExpire_day', $mday, array($date->format('j'))));
|
}
|
||||||
$expTable->addElement(new htmlSelect('shadowExpire_mon', $mon, array($date->format('n'))));
|
for ( $i=2003; $i<=2050; $i++ ) {
|
||||||
$expTable->addElement(new htmlSelect('shadowExpire_yea', $year, array($date->format('Y'))));
|
$year[] = $i;
|
||||||
$return->addElement($expTable);
|
}
|
||||||
$return->addElement(new htmlHelpLink('shadowExpire'), true);
|
$return->addLabel(new htmlOutputText(_('Account expiration date')));
|
||||||
|
$expTable = new htmlGroup();
|
||||||
|
$daySelect = new htmlSelect('shadowExpire_day', $mday, array($date->format('j')));
|
||||||
|
$daySelect->setWidth('3rem');
|
||||||
|
$expTable->addElement($daySelect);
|
||||||
|
$monthSelect = new htmlSelect('shadowExpire_mon', $mon, array($date->format('n')));
|
||||||
|
$monthSelect->setWidth('3rem');
|
||||||
|
$expTable->addElement($monthSelect);
|
||||||
|
$yearSelect = new htmlSelect('shadowExpire_yea', $year, array($date->format('Y')));
|
||||||
|
$yearSelect->setWidth('5rem');
|
||||||
|
$expTable->addElement($yearSelect);
|
||||||
|
$expTable->addElement(new htmlHelpLink('shadowExpire'), true);
|
||||||
|
$return->addField($expTable);
|
||||||
if ($this->getAccountContainer()->getAccountModule('sambaSamAccount') != null) {
|
if ($this->getAccountContainer()->getAccountModule('sambaSamAccount') != null) {
|
||||||
$return->addElement(new htmlTableExtendedInputCheckbox('syncSamba', false, _('Set also for Samba 3')), true);
|
$return->add(new htmlResponsiveInputCheckbox('syncSamba', false, _('Set also for Samba 3')), 12);
|
||||||
}
|
}
|
||||||
if ($this->getAccountContainer()->getAccountModule('windowsUser') != null) {
|
if ($this->getAccountContainer()->getAccountModule('windowsUser') != null) {
|
||||||
$return->addElement(new htmlTableExtendedInputCheckbox('syncWindows', false, _('Set also for Windows')), true);
|
$return->add(new htmlResponsiveInputCheckbox('syncWindows', false, _('Set also for Windows')), 12);
|
||||||
}
|
}
|
||||||
if ($this->getAccountContainer()->getAccountModule('heimdalKerberos') != null) {
|
if ($this->getAccountContainer()->getAccountModule('heimdalKerberos') != null) {
|
||||||
$return->addElement(new htmlTableExtendedInputCheckbox('syncHeimdal', false, _('Set also for Kerberos')), true);
|
$return->add(new htmlResponsiveInputCheckbox('syncHeimdal', false, _('Set also for Kerberos')), 12);
|
||||||
}
|
}
|
||||||
if ($this->getAccountContainer()->getAccountModule('mitKerberos') != null) {
|
if ($this->getAccountContainer()->getAccountModule('mitKerberos') != null) {
|
||||||
$return->addElement(new htmlTableExtendedInputCheckbox('syncMIT', false, _('Set also for Kerberos')), true);
|
$return->add(new htmlResponsiveInputCheckbox('syncMIT', false, _('Set also for Kerberos')), 12);
|
||||||
}
|
}
|
||||||
if ($this->getAccountContainer()->getAccountModule('mitKerberosStructural') != null) {
|
if ($this->getAccountContainer()->getAccountModule('mitKerberosStructural') != null) {
|
||||||
$return->addElement(new htmlTableExtendedInputCheckbox('syncMITStructural', false, _('Set also for Kerberos')), true);
|
$return->add(new htmlResponsiveInputCheckbox('syncMITStructural', false, _('Set also for Kerberos')), 12);
|
||||||
}
|
}
|
||||||
$return->addElement(new htmlSpacer(null, '10px'), true);
|
$return->addVerticalSpacer('2rem');
|
||||||
$buttonTable = new htmlTable();
|
$buttonTable = new htmlGroup();
|
||||||
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'change', _('Change')));
|
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'change', _('Change')));
|
||||||
if (isset($this->attributes['shadowExpire'][0])) {
|
if (isset($this->attributes['shadowExpire'][0])) {
|
||||||
|
$buttonTable->addElement(new htmlSpacer('0.5rem', null));
|
||||||
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'del', _('Remove')));
|
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'del', _('Remove')));
|
||||||
}
|
}
|
||||||
|
$buttonTable->addElement(new htmlSpacer('0.5rem', null));
|
||||||
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'back', _('Cancel')));
|
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'back', _('Cancel')));
|
||||||
$buttonTable->colspan=3;
|
$return->add($buttonTable, 12, 12, 12, 'text-center');
|
||||||
$return->addElement($buttonTable);
|
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -522,31 +536,44 @@ class shadowAccount extends baseModule implements passwordService {
|
||||||
* @return array meta HTML code
|
* @return array meta HTML code
|
||||||
*/
|
*/
|
||||||
function display_html_pwdChange() {
|
function display_html_pwdChange() {
|
||||||
$return = new htmlTable();
|
$return = new htmlResponsiveRow();
|
||||||
$shLastChange = time()/(3600*24);
|
$shLastChange = time()/(3600*24);
|
||||||
if (isset($this->attributes['shadowLastChange'][0])) {
|
if (isset($this->attributes['shadowLastChange'][0])) {
|
||||||
$shLastChange = $this->attributes['shadowLastChange'][0];
|
$shLastChange = $this->attributes['shadowLastChange'][0];
|
||||||
}
|
}
|
||||||
$date = new DateTime('@' . $shLastChange*3600*24, new DateTimeZone('UTC'));
|
$date = new DateTime('@' . $shLastChange*3600*24, new DateTimeZone('UTC'));
|
||||||
for ( $i=1; $i<=31; $i++ ) $mday[] = $i;
|
for ( $i=1; $i<=31; $i++ ) {
|
||||||
for ( $i=1; $i<=12; $i++ ) $mon[] = $i;
|
$mday[] = $i;
|
||||||
for ( $i=2003; $i<=2050; $i++ ) $year[] = $i;
|
}
|
||||||
$return->addElement(new htmlOutputText(_('Last password change')));
|
for ( $i=1; $i<=12; $i++ ) {
|
||||||
$table = new htmlTable();
|
$mon[] = $i;
|
||||||
$table->addElement(new htmlSelect('shadowLastChange_day', $mday, array($date->format('j'))));
|
}
|
||||||
$table->addElement(new htmlSelect('shadowLastChange_mon', $mon, array($date->format('n'))));
|
for ( $i=2003; $i<=2050; $i++ ) {
|
||||||
$table->addElement(new htmlSelect('shadowLastChange_yea', $year, array($date->format('Y'))));
|
$year[] = $i;
|
||||||
$return->addElement($table);
|
}
|
||||||
$return->addElement(new htmlHelpLink('shadowLastChange'), true);
|
$return->addLabel(new htmlOutputText(_('Last password change')));
|
||||||
$return->addElement(new htmlSpacer(null, '10px'), true);
|
$table = new htmlGroup();
|
||||||
$buttonTable = new htmlTable();
|
$daySelect = new htmlSelect('shadowLastChange_day', $mday, array($date->format('j')));
|
||||||
|
$daySelect->setWidth('3rem');
|
||||||
|
$table->addElement($daySelect);
|
||||||
|
$monthSelect = new htmlSelect('shadowLastChange_mon', $mon, array($date->format('n')));
|
||||||
|
$monthSelect->setWidth('3rem');
|
||||||
|
$table->addElement($monthSelect);
|
||||||
|
$yearSelect = new htmlSelect('shadowLastChange_yea', $year, array($date->format('Y')));
|
||||||
|
$yearSelect->setWidth('5rem');
|
||||||
|
$table->addElement($yearSelect);
|
||||||
|
$table->addElement(new htmlHelpLink('shadowLastChange'), true);
|
||||||
|
$return->addField($table);
|
||||||
|
$return->addVerticalSpacer('2rem');
|
||||||
|
$buttonTable = new htmlGroup();
|
||||||
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'changePwdChange', _('Change')));
|
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'changePwdChange', _('Change')));
|
||||||
if (isset($this->attributes['shadowLastChange'][0])) {
|
if (isset($this->attributes['shadowLastChange'][0])) {
|
||||||
|
$buttonTable->addElement(new htmlSpacer('0.5rem', null));
|
||||||
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'delPwdChange', _('Remove')));
|
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'delPwdChange', _('Remove')));
|
||||||
}
|
}
|
||||||
|
$buttonTable->addElement(new htmlSpacer('0.5rem', null));
|
||||||
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'back', _('Cancel')));
|
$buttonTable->addElement(new htmlAccountPageButton('shadowAccount', 'attributes', 'back', _('Cancel')));
|
||||||
$buttonTable->colspan = 3;
|
$return->add($buttonTable, 12, 12, 12, 'text-center');
|
||||||
$return->addElement($buttonTable);
|
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue