From ca72da809fdf68f2d6833ed77ad92c9aadc0663d Mon Sep 17 00:00:00 2001
From: fengxiang <110431245@qq.com>
Date: Tue, 22 May 2018 09:30:20 +0800
Subject: [PATCH] 地图 增加 监控点入口

---
 src/main/java/com/moral/service/impl/AccountServiceImpl.java |   73 +++++++++++++++++++++++++++---------
 1 files changed, 55 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/moral/service/impl/AccountServiceImpl.java b/src/main/java/com/moral/service/impl/AccountServiceImpl.java
index 0a93e6b..1fbcfa1 100644
--- a/src/main/java/com/moral/service/impl/AccountServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/AccountServiceImpl.java
@@ -2,19 +2,16 @@
 
 import static com.moral.common.bean.Constants.IS_DELETE_FALSE;
 import static com.moral.common.bean.Constants.IS_DELETE_TRUE;
-import static com.moral.common.util.Crypto.md5;
 import static com.moral.common.util.ResourceUtil.getValue;
 import static org.apache.commons.lang3.StringUtils.isNumeric;
 import static org.springframework.util.ObjectUtils.isEmpty;
 
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
+import java.util.*;
 
 import javax.annotation.Resource;
 
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.ObjectUtils;
@@ -26,7 +23,9 @@
 import com.moral.common.util.Crypto;
 import com.moral.common.util.ResourceUtil;
 import com.moral.entity.Account;
+import com.moral.entity.Organization;
 import com.moral.mapper.AccountMapper;
+import com.moral.mapper.OrganizationMapper;
 import com.moral.service.AccountService;
 import com.moral.service.OrganizationService;
 
@@ -35,21 +34,27 @@
 
 @Service
 public class AccountServiceImpl implements AccountService {
-
+    @Resource
+	private  BCryptPasswordEncoder encoder;
 	@Resource
 	private AccountMapper accountMapper;
 
 	@Resource
 	private OrganizationService organizationService;
 
+	@Resource
+	private OrganizationMapper organizationMapper;
+
 	@Override
 	public Map<String, Object> screenLogin(Map<String, Object> parameters) {
 		Map<String, Object> result = new HashMap<String, Object>();
 		Account account = new Account();
 		account.setAccountName((String) parameters.get("account"));
-		account.setPassword(md5((String) parameters.get("password")));
+		String rawPassword = (String) parameters.get("password");
+//		account.setPassword(encoder.encode((String) parameters.get("password")));
 		account = accountMapper.selectOne(account);
-		if (isEmpty(account)) {
+		boolean isValid = account == null ? false:encoder.matches(rawPassword,account.getPassword());
+		if (!isValid) {
 			result.put("msg", "���������������������������������");
 		} else {
 			if (IS_DELETE_FALSE.equals(account.getIsDelete())) {
@@ -69,7 +74,10 @@
 		account.setAccountName(accountName);
 		return accountMapper.selectOne(account);
 	}
-
+	@Override
+	public Account getAccountById(Integer id){
+		return accountMapper.selectByPrimaryKey(id);
+	}
 	@Override
 	public void setOrgIdsByAccount(Map<String, Object> parameters) {
 		String accountId = (String) parameters.get("accountId");
@@ -109,27 +117,44 @@
 		}
 		PageHelper.startPage(Integer.valueOf((String) parameters.get("pageIndex")), Integer.valueOf((String) parameters.get("pageSize")));
 		List<Account> accounts = accountMapper.selectByExample(example);
+		Set<Integer> organizationIds = new HashSet<Integer>();
+		for (Account account : accounts) {
+			if (!ObjectUtils.isEmpty(account.getOrganizationId())) {
+				organizationIds.add(account.getOrganizationId());
+			}
+		}
+		if(!ObjectUtils.isEmpty(organizationIds)){
+			example = new Example(Organization.class);
+			example.or().andIn("id", organizationIds);
+			List<Organization> organizations = organizationMapper.selectByExample(example);
+			for (Account account : accounts) {
+				for (Organization organization : organizations) {
+					if (account.getOrganizationId() == organization.getId()) {
+						account.setOrganization(organization);
+						break;
+					}
+				}
+			}
+		}
+
 		return new PageBean<Account>(accounts);
 	}
 
 	@Override
 	@Transactional
 	public Integer saveOrUpdateAccount(Account account) {
+		// ������������
+		if(!StringUtils.isBlank(account.getPassword())){
+			account.setPassword(encoder.encode(account.getPassword()));
+		}
 		if (ObjectUtils.isEmpty(account.getId())) {
 			account.setIsDelete(Constants.IS_DELETE_FALSE);
 			account.setCreateTime(new Date());
-			account.setPassword(Crypto.md5(ResourceUtil.getValue("password")));
+			account.setPassword(encoder.encode(ResourceUtil.getValue("password")));
 			return accountMapper.insertSelective(account);
 		} else {
 			return accountMapper.updateByPrimaryKeySelective(account);
 		}
-	}
-
-	@Override
-	@Transactional
-	public Integer deleteAccountByLogic(Account account) {
-		account.setIsDelete(Constants.IS_DELETE_TRUE);
-		return accountMapper.updateByPrimaryKeySelective(account);
 	}
 
 	@Override
@@ -142,4 +167,16 @@
 		return accountMapper.updateByExampleSelective(account, example);
 	}
 
+	@Override
+	public Integer getAccountCountByAccountName(String accountName) {
+		Account account = new Account();
+		account.setAccountName(accountName);
+		return accountMapper.selectCount(account);
+	}
+
+	@Override
+	public Optional<Account> queryAccountByName(String accountName) {
+		Account account = accountMapper.getByAccountName(accountName);
+		return Optional.ofNullable(account);
+	}
 }

--
Gitblit v1.8.0