| | |
| | |
|
| | | 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;
|
| | |
| | | import com.moral.common.exception.BusinessException;
|
| | | import com.moral.common.util.Crypto;
|
| | | import com.moral.common.util.ResourceUtil;
|
| | | import com.moral.common.util.ValidateUtil;
|
| | | import com.moral.entity.Account;
|
| | | import com.moral.entity.Organization;
|
| | | import com.moral.mapper.AccountMapper;
|
| | |
| | |
|
| | | @Service
|
| | | public class AccountServiceImpl implements AccountService {
|
| | |
|
| | | @Resource
|
| | | private BCryptPasswordEncoder encoder;
|
| | | @Resource
|
| | | private AccountMapper accountMapper;
|
| | |
|
| | |
| | |
|
| | | @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())) {
|
| | | result.put("msg", "登录成功!");
|
| | | result.put("accountId", account.getId());
|
| | | result.put("orgId", account.getOrganizationId());
|
| | | setOrgIdsByAccount(result);
|
| | | } else {
|
| | | result.put("msg","您的账号已禁用,请联系管理员!");
|
| | | }
|
| | |
| | | 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");
|
| | | String accountId = parameters.get("accountId").toString();
|
| | | accountId = accountId.replaceFirst("-", "");
|
| | | if (!isNumeric((String) parameters.get("accountId"))) {
|
| | | if (!isNumeric(accountId)) {
|
| | | throw new BusinessException("accountId 参数不合法!");
|
| | | }
|
| | |
|
| | |
| | | }
|
| | | 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())) {
|
| | | Organization organization = organizationMapper.selectByPrimaryKey(account.getOrganizationId());
|
| | | account.setOrganization(organization);
|
| | | 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);
|
| | |
| | | return accountMapper.selectCount(account);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public Optional<Account> queryAccountByName(String accountName) {
|
| | | Account account = accountMapper.getByAccountName(accountName);
|
| | | return Optional.ofNullable(account);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public Account companyLogin(Map<String, Object> parameters) {
|
| | | ValidateUtil.notNull(parameters.get("account"), "param.is.null");
|
| | | ValidateUtil.notNull(parameters.get("password"), "param.is.null");
|
| | | Account account = new Account();
|
| | | account.setIsDelete(Constants.IS_DELETE_FALSE);
|
| | | account.setAccountName(parameters.get("account").toString());
|
| | | account = accountMapper.selectOne(account);
|
| | | if (ObjectUtils.isEmpty(account)) {
|
| | | throw new BusinessException("账户不存在,请联系管理员!");
|
| | | }
|
| | | if (!encoder.matches(parameters.get("password").toString(), account.getPassword())) {
|
| | | throw new BusinessException("密码错误,请重新输入!");
|
| | | }
|
| | | account.setPassword(parameters.get("password").toString());
|
| | | return account;
|
| | | }
|
| | | }
|