Merge pull request #3326 from YevhenBondarenko/develop/2.5.4-mail
smtp password
This commit is contained in:
commit
5e2c06700e
@ -15,6 +15,7 @@
|
||||
*/
|
||||
package org.thingsboard.server.controller;
|
||||
|
||||
import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import org.springframework.web.bind.annotation.PathVariable;
|
||||
@ -59,7 +60,11 @@ public class AdminController extends BaseController {
|
||||
public AdminSettings getAdminSettings(@PathVariable("key") String key) throws ThingsboardException {
|
||||
try {
|
||||
accessControlService.checkPermission(getCurrentUser(), Resource.ADMIN_SETTINGS, Operation.READ);
|
||||
return checkNotNull(adminSettingsService.findAdminSettingsByKey(TenantId.SYS_TENANT_ID, key));
|
||||
AdminSettings adminSettings = checkNotNull(adminSettingsService.findAdminSettingsByKey(TenantId.SYS_TENANT_ID, key));
|
||||
if (adminSettings.getKey().equals("mail")) {
|
||||
((ObjectNode) adminSettings.getJsonValue()).put("password", "");
|
||||
}
|
||||
return adminSettings;
|
||||
} catch (Exception e) {
|
||||
throw handleException(e);
|
||||
}
|
||||
@ -74,6 +79,7 @@ public class AdminController extends BaseController {
|
||||
adminSettings = checkNotNull(adminSettingsService.saveAdminSettings(TenantId.SYS_TENANT_ID, adminSettings));
|
||||
if (adminSettings.getKey().equals("mail")) {
|
||||
mailService.updateMailConfiguration();
|
||||
((ObjectNode) adminSettings.getJsonValue()).put("password", "");
|
||||
}
|
||||
return adminSettings;
|
||||
} catch (Exception e) {
|
||||
|
||||
@ -15,6 +15,7 @@
|
||||
*/
|
||||
package org.thingsboard.server.dao.settings;
|
||||
|
||||
import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.apache.commons.lang3.StringUtils;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
@ -52,6 +53,13 @@ public class AdminSettingsServiceImpl implements AdminSettingsService {
|
||||
public AdminSettings saveAdminSettings(TenantId tenantId, AdminSettings adminSettings) {
|
||||
log.trace("Executing saveAdminSettings [{}]", adminSettings);
|
||||
adminSettingsValidator.validate(adminSettings, data -> tenantId);
|
||||
if (adminSettings.getKey().equals("mail") && "".equals(adminSettings.getJsonValue().get("password").asText())) {
|
||||
AdminSettings mailSettings = findAdminSettingsByKey(tenantId, "mail");
|
||||
if (mailSettings != null) {
|
||||
((ObjectNode) adminSettings.getJsonValue()).put("password", mailSettings.getJsonValue().get("password").asText());
|
||||
}
|
||||
}
|
||||
|
||||
return adminSettingsDao.save(tenantId, adminSettings);
|
||||
}
|
||||
|
||||
|
||||
@ -123,16 +123,16 @@
|
||||
</md-input-container>
|
||||
<md-input-container class="md-block">
|
||||
<label translate>admin.proxy-password</label>
|
||||
<input name="proxyPassword" ng-model="vm.settings.jsonValue.proxyPassword">
|
||||
<input name="proxyPassword" type="password" autocomplete="new-password" ng-model="vm.settings.jsonValue.proxyPassword">
|
||||
</md-input-container>
|
||||
</section>
|
||||
<md-input-container class="md-block">
|
||||
<label translate>common.username</label>
|
||||
<input name="username" placeholder="{{ 'common.enter-username' | translate }}" ng-model="vm.settings.jsonValue.username">
|
||||
<input placeholder="{{ 'common.enter-username' | translate }}" ng-model="vm.settings.jsonValue.username" autocomplete="new-username" >
|
||||
</md-input-container>
|
||||
<md-input-container class="md-block">
|
||||
<label translate>common.password</label>
|
||||
<input name="password" placeholder="{{ 'common.enter-password' | translate }}" type="password" ng-model="vm.settings.jsonValue.password">
|
||||
<input placeholder="{{ 'common.enter-password' | translate }}" type="password" ng-model="vm.settings.jsonValue.password" autocomplete="new-password">
|
||||
</md-input-container>
|
||||
<div layout="row" layout-align="end center" width="100%" layout-wrap>
|
||||
<md-button ng-disabled="$root.loading || vm.settingsForm.$invalid" ng-click="vm.sendTestMail()" class="md-raised">{{'admin.send-test-mail' | translate}}</md-button>
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user