|
@@ -1,31 +1,24 @@
|
|
|
/*
|
|
|
* Copyright [2020] [MaxKey of copyright http://www.maxkey.top]
|
|
|
- *
|
|
|
+ *
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
* You may obtain a copy of the License at
|
|
|
- *
|
|
|
+ *
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
- *
|
|
|
+ *
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
* See the License for the specific language governing permissions and
|
|
|
* limitations under the License.
|
|
|
*/
|
|
|
-
|
|
|
+
|
|
|
|
|
|
package org.maxkey.persistence.service;
|
|
|
|
|
|
|
|
|
-import com.google.common.collect.Lists;
|
|
|
import org.apache.mybatis.jpa.persistence.JpaBaseService;
|
|
|
-import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
|
|
-import org.apache.poi.ss.usermodel.Cell;
|
|
|
-import org.apache.poi.ss.usermodel.Row;
|
|
|
-import org.apache.poi.ss.usermodel.Sheet;
|
|
|
-import org.apache.poi.ss.usermodel.Workbook;
|
|
|
-import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
|
|
import org.maxkey.constants.ConstantsStatus;
|
|
|
import org.maxkey.crypto.ReciprocalUtils;
|
|
|
import org.maxkey.crypto.password.PasswordReciprocal;
|
|
@@ -45,53 +38,47 @@ import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.jdbc.core.JdbcTemplate;
|
|
|
import org.springframework.security.crypto.password.PasswordEncoder;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
-import org.springframework.util.CollectionUtils;
|
|
|
-import org.springframework.web.multipart.MultipartFile;
|
|
|
-
|
|
|
-import java.io.IOException;
|
|
|
-import java.io.InputStream;
|
|
|
-import java.util.*;
|
|
|
-import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
|
/**
|
|
|
* @author Crystal.Sea
|
|
|
+ *
|
|
|
*/
|
|
|
@Service
|
|
|
public class UserInfoService extends JpaBaseService<UserInfo> {
|
|
|
- final static Logger _logger = LoggerFactory.getLogger(UserInfoService.class);
|
|
|
-
|
|
|
- final static String UPDATE_GRIDLIST_SQL = "UPDATE MXK_USERINFO SET GRIDLIST = ? WHERE ID = ?";
|
|
|
- @Autowired
|
|
|
- private PasswordEncoder passwordEncoder;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- PasswordPolicyValidator passwordPolicyValidator;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- KafkaProvisioningService kafkaProvisioningService;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- protected JdbcTemplate jdbcTemplate;
|
|
|
-
|
|
|
- public UserInfoService() {
|
|
|
- super(UserInfoMapper.class);
|
|
|
- }
|
|
|
-
|
|
|
- /* (non-Javadoc)
|
|
|
- * @see com.connsec.db.service.BaseService#getMapper()
|
|
|
- */
|
|
|
- @Override
|
|
|
- public UserInfoMapper getMapper() {
|
|
|
- // TODO Auto-generated method stub
|
|
|
- return (UserInfoMapper) super.getMapper();
|
|
|
- }
|
|
|
-
|
|
|
+ final static Logger _logger = LoggerFactory.getLogger(UserInfoService.class);
|
|
|
+
|
|
|
+ final static String UPDATE_GRIDLIST_SQL = "UPDATE MXK_USERINFO SET GRIDLIST = ? WHERE ID = ?";
|
|
|
+ @Autowired
|
|
|
+ private PasswordEncoder passwordEncoder;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ PasswordPolicyValidator passwordPolicyValidator;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ KafkaProvisioningService kafkaProvisioningService;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ protected JdbcTemplate jdbcTemplate;
|
|
|
+
|
|
|
+ public UserInfoService() {
|
|
|
+ super(UserInfoMapper.class);
|
|
|
+ }
|
|
|
+
|
|
|
+ /* (non-Javadoc)
|
|
|
+ * @see com.connsec.db.service.BaseService#getMapper()
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public UserInfoMapper getMapper() {
|
|
|
+ // TODO Auto-generated method stub
|
|
|
+ return (UserInfoMapper)super.getMapper();
|
|
|
+ }
|
|
|
+
|
|
|
public boolean insert(UserInfo userInfo) {
|
|
|
userInfo = passwordEncoder(userInfo);
|
|
|
if (super.insert(userInfo)) {
|
|
|
kafkaProvisioningService.send(
|
|
|
- KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
+ KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
userInfo,
|
|
|
KafkaIdentityAction.CREATE_ACTION);
|
|
|
return true;
|
|
@@ -99,428 +86,142 @@ public class UserInfoService extends JpaBaseService<UserInfo> {
|
|
|
|
|
|
return false;
|
|
|
}
|
|
|
-
|
|
|
- public boolean batchInsert(List<UserInfo> userInfos) {
|
|
|
- for (UserInfo userInfo : userInfos) {
|
|
|
- userInfo.setId(userInfo.generateId());
|
|
|
- passwordEncoder(userInfo);
|
|
|
- }
|
|
|
- if (super.batchInsert(userInfos)) {
|
|
|
- kafkaProvisioningService.send(
|
|
|
- KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
- userInfos,
|
|
|
- KafkaIdentityAction.CREATE_ACTION);
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- return false;
|
|
|
- }
|
|
|
-
|
|
|
+
|
|
|
public boolean update(UserInfo userInfo) {
|
|
|
userInfo = passwordEncoder(userInfo);
|
|
|
if (super.update(userInfo)) {
|
|
|
kafkaProvisioningService.send(
|
|
|
- KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
+ KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
userInfo,
|
|
|
KafkaIdentityAction.UPDATE_ACTION);
|
|
|
-
|
|
|
+
|
|
|
changePasswordProvisioning(userInfo);
|
|
|
return true;
|
|
|
}
|
|
|
return false;
|
|
|
}
|
|
|
-
|
|
|
- public boolean importing(MultipartFile file) throws IOException {
|
|
|
- if(file ==null){
|
|
|
- return false;
|
|
|
- }
|
|
|
- // 解析excel文件中数据
|
|
|
- List<UserInfo> userInfos = readExcel(file);
|
|
|
- return batchInsert(userInfos);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- private static List<UserInfo> readExcel(MultipartFile file) throws IOException {
|
|
|
- InputStream is = file.getInputStream();
|
|
|
- Workbook wb;
|
|
|
- String xls = ".xls";
|
|
|
- String xlsx = ".xlsx";
|
|
|
- int columnSize = 46;
|
|
|
- List<UserInfo> userInfos = Lists.newArrayList();
|
|
|
-
|
|
|
- try {
|
|
|
- if (file.getOriginalFilename().toLowerCase().endsWith(xls)) {
|
|
|
- wb = new HSSFWorkbook(is);
|
|
|
- } else if (file.getOriginalFilename().toLowerCase().endsWith(xlsx)) {
|
|
|
- wb = new XSSFWorkbook(is);
|
|
|
- } else {
|
|
|
- throw new RuntimeException("maxKey用户导入没有Excel类型");
|
|
|
- }
|
|
|
-
|
|
|
- int sheetSize = wb.getNumberOfSheets();
|
|
|
- //遍历sheet页
|
|
|
- for (int i = 0; i < sheetSize; i++) {
|
|
|
- Sheet sheet = wb.getSheetAt(i);
|
|
|
-
|
|
|
- int rowSize = sheet.getLastRowNum() + 1;
|
|
|
- //遍历行
|
|
|
- for (int j = 1; j < rowSize; j++) {
|
|
|
- Row row = sheet.getRow(j);
|
|
|
- //略过空行和第一行
|
|
|
- if (row == null || j == 0) {
|
|
|
- continue;
|
|
|
- } else {
|
|
|
- //其他行是数据行
|
|
|
- UserInfo userInfo = new UserInfo();
|
|
|
- userInfo.setCreatedDate(DateUtils.formatDateTime(new Date()));
|
|
|
-
|
|
|
- int rangeType = -1;
|
|
|
- for (int k = 0; k < columnSize; k++) {
|
|
|
- if (k == 0) {
|
|
|
- // 登录账号
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setUsername(getValue(cell));
|
|
|
- } else if (k == 1) {
|
|
|
- // 密码
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setPassword(getValue(cell));
|
|
|
- } else if (k == 2) {
|
|
|
- // 员工编码
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setEmployeeNumber(getValue(cell));
|
|
|
- } else if (k == 3) {
|
|
|
- // 用户类型
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setUserType(getValue(cell));
|
|
|
- } else if (k == 4) {
|
|
|
- // 用户名
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setDisplayName(getValue(cell));
|
|
|
- } else if (k == 5) {
|
|
|
- // 姓
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setFamilyName(getValue(cell));
|
|
|
- } else if (k == 6) {
|
|
|
- // 名
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setGivenName(getValue(cell));
|
|
|
- } else if (k == 7) {
|
|
|
- // 中间名
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setMiddleName(getValue(cell));
|
|
|
- } else if (k == 8) {
|
|
|
- // 昵称
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setNickName(getValue(cell));
|
|
|
- } else if (k == 9) {
|
|
|
- // 性别
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setGender(Integer.valueOf(getValue(cell)));
|
|
|
- } else if (k == 10) {
|
|
|
- // AD域账号
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWindowsAccount(getValue(cell));
|
|
|
- } else if (k == 11) {
|
|
|
- // 出生日期
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setBirthDate(getValue(cell));
|
|
|
- } else if (k == 12) {
|
|
|
- // 语言偏好
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setPreferredLanguage(getValue(cell));
|
|
|
- } else if (k == 13) {
|
|
|
- // 时区
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setTimeZone(getValue(cell));
|
|
|
- }else if (k == 14) {
|
|
|
- // 所属机构
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setOrganization(getValue(cell));
|
|
|
- }else if (k == 15) {
|
|
|
- // 分支机构
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setDivision(getValue(cell));
|
|
|
- }else if (k == 16) {
|
|
|
- // 部门名称
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setDepartment(getValue(cell));
|
|
|
- }else if (k == 17) {
|
|
|
- // 成本中心
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setCostCenter(getValue(cell));
|
|
|
- }else if (k == 18) {
|
|
|
- // 职位
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setJobTitle(getValue(cell));
|
|
|
- }else if (k == 19) {
|
|
|
- // 级别
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setJobLevel(getValue(cell));
|
|
|
- }else if (k == 20) {
|
|
|
- // 上级经理
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setManager(getValue(cell));
|
|
|
- }else if (k == 21) {
|
|
|
- // 助理
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setAssistant(getValue(cell));
|
|
|
- }else if (k == 22) {
|
|
|
- // 入职时间
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setEntryDate(getValue(cell));
|
|
|
- }else if (k == 23) {
|
|
|
- // 离职时间
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setQuitDate(getValue(cell));
|
|
|
- }else if (k == 24) {
|
|
|
- // 工作-国家
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkCountry(getValue(cell));
|
|
|
- }else if (k == 25) {
|
|
|
- // 工作-省
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkRegion(getValue(cell));
|
|
|
- }else if (k == 26) {
|
|
|
- // 工作-城市
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setTimeZone(getValue(cell));
|
|
|
- }else if (k == 27) {
|
|
|
- // 工作-地址
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkLocality(getValue(cell));
|
|
|
- }else if (k == 28) {
|
|
|
- // 邮编
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkPostalCode(getValue(cell));
|
|
|
- }else if (k == 29) {
|
|
|
- // 传真
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkFax(getValue(cell));
|
|
|
- }else if (k == 30) {
|
|
|
- // 工作电话
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkPhoneNumber(getValue(cell));
|
|
|
- }else if (k == 31) {
|
|
|
- // 工作邮件
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWorkEmail(getValue(cell));
|
|
|
- }else if (k == 32) {
|
|
|
- // 证件类型 todo 现在数据库中存储的是tinyint
|
|
|
-// Cell cell = row.getCell(k);
|
|
|
-// userInfo.setIdType(getValue(cell));
|
|
|
- }else if (k == 33) {
|
|
|
- // 证件号码
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setIdCardNo(getValue(cell));
|
|
|
- }else if (k == 34) {
|
|
|
- // 婚姻状态 todo 现在数据字段类型是 tinyint
|
|
|
-// Cell cell = row.getCell(k);
|
|
|
-// userInfo.setMarried(getValue(cell));
|
|
|
- }else if (k == 35) {
|
|
|
- // 开始工作时间
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setStartWorkDate(getValue(cell));
|
|
|
- }else if (k == 36) {
|
|
|
- // 国家
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomeCountry(getValue(cell));
|
|
|
- }else if (k == 37) {
|
|
|
- // 省
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomeRegion(getValue(cell));
|
|
|
- }else if (k == 38) {
|
|
|
- // 城市
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomeLocality(getValue(cell));
|
|
|
- }else if (k == 39) {
|
|
|
- // 家庭地址
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomeStreetAddress(getValue(cell));
|
|
|
- }else if (k == 40) {
|
|
|
- // 家庭邮编
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomePostalCode(getValue(cell));
|
|
|
- }else if (k == 41) {
|
|
|
- // 家庭传真
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomeFax(getValue(cell));
|
|
|
- }else if (k == 42) {
|
|
|
- // 家庭电话
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomePhoneNumber(getValue(cell));
|
|
|
- }else if (k == 43) {
|
|
|
- // 家庭邮箱
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setHomeEmail(getValue(cell));
|
|
|
- }else if (k == 44) {
|
|
|
- // 个人主页
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setWebSite(getValue(cell));
|
|
|
- }else if (k == 45) {
|
|
|
- // 即时通讯
|
|
|
- Cell cell = row.getCell(k);
|
|
|
- userInfo.setDefineIm(getValue(cell));
|
|
|
- }
|
|
|
- }
|
|
|
- userInfos.add(userInfo);
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- // 数据去重
|
|
|
- if(CollectionUtils.isEmpty(userInfos)){
|
|
|
- userInfos = userInfos.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getUsername()))), ArrayList::new));
|
|
|
- }
|
|
|
- return userInfos;
|
|
|
- } catch (IOException e) {
|
|
|
- e.printStackTrace();
|
|
|
- }finally {
|
|
|
- if (is != null) {
|
|
|
- is.close();
|
|
|
- }
|
|
|
- }
|
|
|
- return userInfos;
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * 根据数据格式返回数据
|
|
|
- *
|
|
|
- * @param cell
|
|
|
- * @return
|
|
|
- */
|
|
|
- public static String getValue(Cell cell) {
|
|
|
- if (cell == null) {
|
|
|
- return "";
|
|
|
- } else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) {
|
|
|
- return String.valueOf(cell.getBooleanCellValue());
|
|
|
- } else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
|
|
|
- cell.setCellType(Cell.CELL_TYPE_STRING);
|
|
|
- return String.valueOf(cell.getStringCellValue().trim());
|
|
|
- } else {
|
|
|
- return String.valueOf(cell.getStringCellValue().trim());
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public boolean delete(UserInfo userInfo) {
|
|
|
- if (super.delete(userInfo)) {
|
|
|
- kafkaProvisioningService.send(
|
|
|
- KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
- userInfo,
|
|
|
- KafkaIdentityAction.DELETE_ACTION);
|
|
|
- return true;
|
|
|
- }
|
|
|
- return false;
|
|
|
- }
|
|
|
-
|
|
|
- public boolean updateGridList(String gridList) {
|
|
|
- try {
|
|
|
- if (gridList != null && !gridList.equals("")) {
|
|
|
+
|
|
|
+ public boolean delete(UserInfo userInfo) {
|
|
|
+ if( super.delete(userInfo)){
|
|
|
+ kafkaProvisioningService.send(
|
|
|
+ KafkaIdentityTopic.USERINFO_TOPIC,
|
|
|
+ userInfo,
|
|
|
+ KafkaIdentityAction.DELETE_ACTION);
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean updateGridList(String gridList) {
|
|
|
+ try {
|
|
|
+ if (gridList != null && !gridList.equals("")) {
|
|
|
int intGridList = Integer.parseInt(gridList);
|
|
|
jdbcTemplate.update(UPDATE_GRIDLIST_SQL, intGridList,
|
|
|
WebContext.getUserInfo().getId());
|
|
|
WebContext.getUserInfo().setGridList(intGridList);
|
|
|
}
|
|
|
- } catch (Exception e) {
|
|
|
+ }catch(Exception e) {
|
|
|
e.printStackTrace();
|
|
|
return false;
|
|
|
}
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- public boolean updateProtectedApps(UserInfo userinfo) {
|
|
|
- try {
|
|
|
- if (WebContext.getUserInfo() != null) {
|
|
|
- userinfo.setModifiedBy(WebContext.getUserInfo().getId());
|
|
|
- }
|
|
|
- userinfo.setModifiedDate(DateUtils.getCurrentDateTimeAsString());
|
|
|
- return getMapper().updateProtectedApps(userinfo) > 0;
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- return false;
|
|
|
- }
|
|
|
-
|
|
|
- public UserInfo loadByUsername(String username) {
|
|
|
- return getMapper().loadByUsername(username);
|
|
|
- }
|
|
|
-
|
|
|
- public UserInfo loadByAppIdAndUsername(String appId, String username) {
|
|
|
- try {
|
|
|
- UserInfo userinfo = new UserInfo();
|
|
|
- userinfo.setUsername(username);
|
|
|
- return getMapper().loadByAppIdAndUsername(userinfo);
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- return null;
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- public void logisticDeleteAllByCid(String cid) {
|
|
|
- try {
|
|
|
- getMapper().logisticDeleteAllByCid(cid);
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public UserInfo passwordEncoder(UserInfo userInfo) {
|
|
|
- //密码不为空,则需要进行加密处理
|
|
|
- if (userInfo.getPassword() != null && !userInfo.getPassword().equals("")) {
|
|
|
- String password = passwordEncoder.encode(userInfo.getPassword());
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public boolean updateProtectedApps(UserInfo userinfo) {
|
|
|
+ try {
|
|
|
+ if(WebContext.getUserInfo() != null) {
|
|
|
+ userinfo.setModifiedBy(WebContext.getUserInfo().getId());
|
|
|
+ }
|
|
|
+ userinfo.setModifiedDate(DateUtils.getCurrentDateTimeAsString());
|
|
|
+ return getMapper().updateProtectedApps(userinfo) > 0;
|
|
|
+ } catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+ public UserInfo loadByUsername(String username) {
|
|
|
+ return getMapper().loadByUsername(username);
|
|
|
+ }
|
|
|
+
|
|
|
+ public UserInfo loadByAppIdAndUsername(String appId,String username){
|
|
|
+ try {
|
|
|
+ UserInfo userinfo = new UserInfo();
|
|
|
+ userinfo.setUsername(username);
|
|
|
+ return getMapper().loadByAppIdAndUsername(userinfo) ;
|
|
|
+ } catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public void logisticDeleteAllByCid(String cid){
|
|
|
+ try {
|
|
|
+ getMapper().logisticDeleteAllByCid(cid);
|
|
|
+ } catch(Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ public UserInfo passwordEncoder(UserInfo userInfo) {
|
|
|
+ //密码不为空,则需要进行加密处理
|
|
|
+ if(userInfo.getPassword()!=null && !userInfo.getPassword().equals("")) {
|
|
|
+ String password = passwordEncoder.encode(userInfo.getPassword());
|
|
|
userInfo.setDecipherable(ReciprocalUtils.encode(PasswordReciprocal.getInstance().rawPassword(userInfo.getUsername(), userInfo.getPassword())));
|
|
|
- _logger.debug("decipherable : " + userInfo.getDecipherable());
|
|
|
+ _logger.debug("decipherable : "+userInfo.getDecipherable());
|
|
|
userInfo.setPassword(password);
|
|
|
userInfo.setPasswordLastSetTime(DateUtils.getCurrentDateTimeAsString());
|
|
|
-
|
|
|
+
|
|
|
userInfo.setModifiedDate(DateUtils.getCurrentDateTimeAsString());
|
|
|
- }
|
|
|
+ }
|
|
|
return userInfo;
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- public boolean changePassword(String oldPassword,
|
|
|
- String newPassword,
|
|
|
- String confirmPassword) {
|
|
|
- try {
|
|
|
- WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT, "");
|
|
|
- UserInfo userInfo = WebContext.getUserInfo();
|
|
|
- UserInfo changeUserInfo = new UserInfo();
|
|
|
- changeUserInfo.setUsername(userInfo.getUsername());
|
|
|
- changeUserInfo.setPassword(newPassword);
|
|
|
- changeUserInfo.setId(userInfo.getId());
|
|
|
- changeUserInfo.setDecipherable(userInfo.getDecipherable());
|
|
|
-
|
|
|
- if (newPassword.equals(confirmPassword)) {
|
|
|
- if (oldPassword == null ||
|
|
|
- passwordEncoder.matches(oldPassword, userInfo.getPassword())) {
|
|
|
- if (changePassword(changeUserInfo)) {
|
|
|
- userInfo.setPassword(changeUserInfo.getPassword());
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public boolean changePassword(String oldPassword,
|
|
|
+ String newPassword,
|
|
|
+ String confirmPassword) {
|
|
|
+ try {
|
|
|
+ WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT, "");
|
|
|
+ UserInfo userInfo = WebContext.getUserInfo();
|
|
|
+ UserInfo changeUserInfo = new UserInfo();
|
|
|
+ changeUserInfo.setUsername(userInfo.getUsername());
|
|
|
+ changeUserInfo.setPassword(newPassword);
|
|
|
+ changeUserInfo.setId(userInfo.getId());
|
|
|
+ changeUserInfo.setDecipherable(userInfo.getDecipherable());
|
|
|
+
|
|
|
+ if(newPassword.equals(confirmPassword)){
|
|
|
+ if(oldPassword==null ||
|
|
|
+ passwordEncoder.matches(oldPassword, userInfo.getPassword())){
|
|
|
+ if(changePassword(changeUserInfo) ){
|
|
|
+ userInfo.setPassword(changeUserInfo.getPassword());
|
|
|
userInfo.setDecipherable(changeUserInfo.getDecipherable());
|
|
|
- return true;
|
|
|
- }
|
|
|
- return false;
|
|
|
- } else {
|
|
|
- if (oldPassword != null &&
|
|
|
- passwordEncoder.matches(newPassword, userInfo.getPassword())) {
|
|
|
- WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT,
|
|
|
- WebContext.getI18nValue("PasswordPolicy.OLD_PASSWORD_MATCH"));
|
|
|
- } else {
|
|
|
- WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT,
|
|
|
- WebContext.getI18nValue("PasswordPolicy.OLD_PASSWORD_NOT_MATCH"));
|
|
|
- }
|
|
|
- }
|
|
|
- } else {
|
|
|
- WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT,
|
|
|
- WebContext.getI18nValue("PasswordPolicy.CONFIRMPASSWORD_NOT_MATCH"));
|
|
|
- }
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
-
|
|
|
- return false;
|
|
|
- }
|
|
|
-
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ return false;
|
|
|
+ }else {
|
|
|
+ if(oldPassword!=null &&
|
|
|
+ passwordEncoder.matches(newPassword, userInfo.getPassword())) {
|
|
|
+ WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT,
|
|
|
+ WebContext.getI18nValue("PasswordPolicy.OLD_PASSWORD_MATCH"));
|
|
|
+ }else {
|
|
|
+ WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT,
|
|
|
+ WebContext.getI18nValue("PasswordPolicy.OLD_PASSWORD_NOT_MATCH"));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }else {
|
|
|
+ WebContext.setAttribute(PasswordPolicyValidator.PASSWORD_POLICY_VALIDATE_RESULT,
|
|
|
+ WebContext.getI18nValue("PasswordPolicy.CONFIRMPASSWORD_NOT_MATCH"));
|
|
|
+ }
|
|
|
+ } catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
public boolean changePassword(UserInfo changeUserInfo) {
|
|
|
try {
|
|
|
_logger.debug("decipherable old : " + changeUserInfo.getDecipherable());
|
|
@@ -550,116 +251,113 @@ public class UserInfoService extends JpaBaseService<UserInfo> {
|
|
|
|
|
|
return false;
|
|
|
}
|
|
|
-
|
|
|
- public String randomPassword() {
|
|
|
- return passwordPolicyValidator.generateRandomPassword();
|
|
|
- }
|
|
|
-
|
|
|
- public void changePasswordProvisioning(UserInfo userInfo) {
|
|
|
- if (userInfo.getPassword() != null && !userInfo.getPassword().equals("")) {
|
|
|
- ChangePassword changePassword = new ChangePassword();
|
|
|
+
|
|
|
+ public String randomPassword() {
|
|
|
+ return passwordPolicyValidator.generateRandomPassword();
|
|
|
+ }
|
|
|
+
|
|
|
+ public void changePasswordProvisioning(UserInfo userInfo) {
|
|
|
+ if(userInfo.getPassword()!=null && !userInfo.getPassword().equals("")) {
|
|
|
+ ChangePassword changePassword=new ChangePassword();
|
|
|
changePassword.setId(userInfo.getId());
|
|
|
changePassword.setUid(userInfo.getId());
|
|
|
changePassword.setUsername(userInfo.getUsername());
|
|
|
changePassword.setDecipherable(userInfo.getDecipherable());
|
|
|
changePassword.setPassword(userInfo.getPassword());
|
|
|
kafkaProvisioningService.send(
|
|
|
- KafkaIdentityTopic.PASSWORD_TOPIC,
|
|
|
- changePassword,
|
|
|
+ KafkaIdentityTopic.PASSWORD_TOPIC,
|
|
|
+ changePassword,
|
|
|
KafkaIdentityAction.PASSWORD_ACTION);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public boolean changeAppLoginPassword(UserInfo userinfo) {
|
|
|
- try {
|
|
|
- if (WebContext.getUserInfo() != null) {
|
|
|
- userinfo.setModifiedBy(WebContext.getUserInfo().getId());
|
|
|
- }
|
|
|
- userinfo.setModifiedDate(DateUtils.getCurrentDateTimeAsString());
|
|
|
- return getMapper().changeAppLoginPassword(userinfo) > 0;
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- return false;
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- /**
|
|
|
- * 锁定用户:islock:1 用户解锁 2 用户锁定
|
|
|
- *
|
|
|
- * @param userInfo
|
|
|
- */
|
|
|
- public void locked(UserInfo userInfo) {
|
|
|
- try {
|
|
|
- if (userInfo != null && StringUtils.isNotEmpty(userInfo.getId())) {
|
|
|
- userInfo.setIsLocked(ConstantsStatus.STOP);
|
|
|
- getMapper().locked(userInfo);
|
|
|
- }
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * 用户登录成功后,重置错误密码次数和解锁用户
|
|
|
- *
|
|
|
- * @param userInfo
|
|
|
- */
|
|
|
- public void unlock(UserInfo userInfo) {
|
|
|
- try {
|
|
|
- if (userInfo != null && StringUtils.isNotEmpty(userInfo.getId())) {
|
|
|
- userInfo.setIsLocked(ConstantsStatus.START);
|
|
|
- userInfo.setBadPasswordCount(0);
|
|
|
- getMapper().unlock(userInfo);
|
|
|
- }
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * 更新错误密码次数
|
|
|
- *
|
|
|
- * @param userInfo
|
|
|
- */
|
|
|
- public void updateBadPasswordCount(UserInfo userInfo) {
|
|
|
- try {
|
|
|
- if (userInfo != null && StringUtils.isNotEmpty(userInfo.getId())) {
|
|
|
- int updateBadPWDCount = userInfo.getBadPasswordCount() + 1;
|
|
|
- userInfo.setBadPasswordCount(updateBadPWDCount);
|
|
|
- getMapper().updateBadPWDCount(userInfo);
|
|
|
- }
|
|
|
- } catch (Exception e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public boolean changeSharedSecret(UserInfo userInfo) {
|
|
|
- return getMapper().changeSharedSecret(userInfo) > 0;
|
|
|
- }
|
|
|
-
|
|
|
- public boolean changePasswordQuestion(UserInfo userInfo) {
|
|
|
- return getMapper().changePasswordQuestion(userInfo) > 0;
|
|
|
- }
|
|
|
-
|
|
|
- public boolean changeAuthnType(UserInfo userInfo) {
|
|
|
- return getMapper().changeAuthnType(userInfo) > 0;
|
|
|
- }
|
|
|
-
|
|
|
- public boolean changeEmail(UserInfo userInfo) {
|
|
|
- return getMapper().changeEmail(userInfo) > 0;
|
|
|
- }
|
|
|
-
|
|
|
- public boolean changeMobile(UserInfo userInfo) {
|
|
|
- return getMapper().changeMobile(userInfo) > 0;
|
|
|
- }
|
|
|
-
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean changeAppLoginPassword(UserInfo userinfo) {
|
|
|
+ try {
|
|
|
+ if(WebContext.getUserInfo() != null) {
|
|
|
+ userinfo.setModifiedBy(WebContext.getUserInfo().getId());
|
|
|
+ }
|
|
|
+ userinfo.setModifiedDate(DateUtils.getCurrentDateTimeAsString());
|
|
|
+ return getMapper().changeAppLoginPassword(userinfo) > 0;
|
|
|
+ } catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 锁定用户:islock:1 用户解锁 2 用户锁定
|
|
|
+ * @param userInfo
|
|
|
+ */
|
|
|
+ public void locked(UserInfo userInfo) {
|
|
|
+ try {
|
|
|
+ if(userInfo != null && StringUtils.isNotEmpty(userInfo.getId())) {
|
|
|
+ userInfo.setIsLocked(ConstantsStatus.STOP);
|
|
|
+ getMapper().locked(userInfo);
|
|
|
+ }
|
|
|
+ } catch(Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 用户登录成功后,重置错误密码次数和解锁用户
|
|
|
+ * @param userInfo
|
|
|
+ */
|
|
|
+ public void unlock(UserInfo userInfo) {
|
|
|
+ try {
|
|
|
+ if(userInfo != null && StringUtils.isNotEmpty(userInfo.getId())) {
|
|
|
+ userInfo.setIsLocked(ConstantsStatus.START);
|
|
|
+ userInfo.setBadPasswordCount(0);
|
|
|
+ getMapper().unlock(userInfo);
|
|
|
+ }
|
|
|
+ } catch(Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 更新错误密码次数
|
|
|
+ * @param userInfo
|
|
|
+ */
|
|
|
+ public void updateBadPasswordCount(UserInfo userInfo) {
|
|
|
+ try {
|
|
|
+ if(userInfo != null && StringUtils.isNotEmpty(userInfo.getId())) {
|
|
|
+ int updateBadPWDCount = userInfo.getBadPasswordCount() + 1;
|
|
|
+ userInfo.setBadPasswordCount(updateBadPWDCount);
|
|
|
+ getMapper().updateBadPWDCount(userInfo);
|
|
|
+ }
|
|
|
+ } catch(Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean changeSharedSecret(UserInfo userInfo){
|
|
|
+ return getMapper().changeSharedSecret(userInfo)>0;
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean changePasswordQuestion(UserInfo userInfo){
|
|
|
+ return getMapper().changePasswordQuestion(userInfo)>0;
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean changeAuthnType(UserInfo userInfo){
|
|
|
+ return getMapper().changeAuthnType(userInfo)>0;
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean changeEmail(UserInfo userInfo){
|
|
|
+ return getMapper().changeEmail(userInfo)>0;
|
|
|
+ }
|
|
|
+
|
|
|
+ public boolean changeMobile(UserInfo userInfo){
|
|
|
+ return getMapper().changeMobile(userInfo)>0;
|
|
|
+ }
|
|
|
+
|
|
|
public UserInfo queryUserInfoByEmailMobile(String emailMobile) {
|
|
|
return getMapper().queryUserInfoByEmailMobile(emailMobile);
|
|
|
}
|
|
|
-
|
|
|
- public int updateProfile(UserInfo userInfo) {
|
|
|
-
|
|
|
+
|
|
|
+ public int updateProfile(UserInfo userInfo){
|
|
|
+
|
|
|
return getMapper().updateProfile(userInfo);
|
|
|
}
|
|
|
|