|
@@ -1,5 +1,8 @@
|
|
|
package com.izouma.nineth.service;
|
|
package com.izouma.nineth.service;
|
|
|
|
|
|
|
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
|
|
+import com.github.kevinsawicki.http.HttpRequest;
|
|
|
|
|
+import com.izouma.nineth.annotations.RedisLock;
|
|
|
import com.izouma.nineth.domain.IdentityAuth;
|
|
import com.izouma.nineth.domain.IdentityAuth;
|
|
|
import com.izouma.nineth.domain.User;
|
|
import com.izouma.nineth.domain.User;
|
|
|
import com.izouma.nineth.dto.PageQuery;
|
|
import com.izouma.nineth.dto.PageQuery;
|
|
@@ -9,19 +12,29 @@ import com.izouma.nineth.repo.IdentityAuthRepo;
|
|
|
import com.izouma.nineth.repo.UserRepo;
|
|
import com.izouma.nineth.repo.UserRepo;
|
|
|
import com.izouma.nineth.utils.JpaUtils;
|
|
import com.izouma.nineth.utils.JpaUtils;
|
|
|
import lombok.AllArgsConstructor;
|
|
import lombok.AllArgsConstructor;
|
|
|
|
|
+import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
+import org.springframework.core.env.Environment;
|
|
|
import org.springframework.data.domain.Page;
|
|
import org.springframework.data.domain.Page;
|
|
|
|
|
+import org.springframework.data.redis.core.RedisTemplate;
|
|
|
|
|
+import org.springframework.scheduling.annotation.Scheduled;
|
|
|
import org.springframework.stereotype.Service;
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
|
|
|
|
+import java.util.Arrays;
|
|
|
import java.util.List;
|
|
import java.util.List;
|
|
|
|
|
+import java.util.concurrent.TimeUnit;
|
|
|
import java.util.stream.Collectors;
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
@Service
|
|
@Service
|
|
|
@AllArgsConstructor
|
|
@AllArgsConstructor
|
|
|
|
|
+@Slf4j
|
|
|
public class IdentityAuthService {
|
|
public class IdentityAuthService {
|
|
|
|
|
|
|
|
- private IdentityAuthRepo identityAuthRepo;
|
|
|
|
|
- private UserRepo userRepo;
|
|
|
|
|
- private AdapayService adapayService;
|
|
|
|
|
|
|
+ private IdentityAuthRepo identityAuthRepo;
|
|
|
|
|
+ private UserRepo userRepo;
|
|
|
|
|
+ private AdapayService adapayService;
|
|
|
|
|
+ private RedisTemplate<String, Object> redisTemplate;
|
|
|
|
|
+ private Environment env;
|
|
|
|
|
+ private SysConfigService sysConfigService;
|
|
|
|
|
|
|
|
public Page<IdentityAuth> all(PageQuery pageQuery) {
|
|
public Page<IdentityAuth> all(PageQuery pageQuery) {
|
|
|
return identityAuthRepo.findAll(JpaUtils.toSpecification(pageQuery, IdentityAuth.class), JpaUtils.toPageRequest(pageQuery));
|
|
return identityAuthRepo.findAll(JpaUtils.toSpecification(pageQuery, IdentityAuth.class), JpaUtils.toPageRequest(pageQuery));
|
|
@@ -45,7 +58,7 @@ public class IdentityAuthService {
|
|
|
userRepo.save(user);
|
|
userRepo.save(user);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- public void audit(Long id, AuthStatus status) {
|
|
|
|
|
|
|
+ public void audit(Long id, AuthStatus status, String reason) {
|
|
|
IdentityAuth auth = identityAuthRepo.findByIdAndDelFalse(id).orElseThrow(new BusinessException("申请不存在"));
|
|
IdentityAuth auth = identityAuthRepo.findByIdAndDelFalse(id).orElseThrow(new BusinessException("申请不存在"));
|
|
|
if (auth.getStatus() != AuthStatus.PENDING) {
|
|
if (auth.getStatus() != AuthStatus.PENDING) {
|
|
|
throw new BusinessException("已经审核过");
|
|
throw new BusinessException("已经审核过");
|
|
@@ -55,6 +68,8 @@ public class IdentityAuthService {
|
|
|
user.setAuthId(auth.getId());
|
|
user.setAuthId(auth.getId());
|
|
|
}
|
|
}
|
|
|
auth.setStatus(status);
|
|
auth.setStatus(status);
|
|
|
|
|
+ auth.setReason(reason);
|
|
|
|
|
+ auth.setAutoValidated(true);
|
|
|
identityAuthRepo.save(auth);
|
|
identityAuthRepo.save(auth);
|
|
|
user.setAuthStatus(status);
|
|
user.setAuthStatus(status);
|
|
|
userRepo.save(user);
|
|
userRepo.save(user);
|
|
@@ -68,4 +83,61 @@ public class IdentityAuthService {
|
|
|
List<Long> userIds = auths.stream().map(IdentityAuth::getUserId).distinct().collect(Collectors.toList());
|
|
List<Long> userIds = auths.stream().map(IdentityAuth::getUserId).distinct().collect(Collectors.toList());
|
|
|
return userRepo.findByIdInAndDelFalse(userIds);
|
|
return userRepo.findByIdInAndDelFalse(userIds);
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+ public void validate(String name, String phone, String idno) {
|
|
|
|
|
+ String body = HttpRequest.post("https://jubrige.market.alicloudapi.com/mobile/3-validate-transfer")
|
|
|
|
|
+ .header("Authorization", "APPCODE b48bc8f6759345a79ae20a951f03dabe")
|
|
|
|
|
+ .contentType(HttpRequest.CONTENT_TYPE_FORM)
|
|
|
|
|
+ .form("idCardNo", idno)
|
|
|
|
|
+ .form("mobile", phone)
|
|
|
|
|
+ .form("name", name)
|
|
|
|
|
+ .body();
|
|
|
|
|
+ JSONObject jsonObject = JSONObject.parseObject(body);
|
|
|
|
|
+ if (jsonObject.getInteger("code") != 200) {
|
|
|
|
|
+ String msg = jsonObject.getString("msg");
|
|
|
|
|
+ throw new BusinessException(msg);
|
|
|
|
|
+ } else {
|
|
|
|
|
+ JSONObject data = jsonObject.getJSONObject("data");
|
|
|
|
|
+ int result = data.getIntValue("result");
|
|
|
|
|
+ String desc = data.getString("desc");
|
|
|
|
|
+ if (result != 0) {
|
|
|
|
|
+ throw new BusinessException(desc);
|
|
|
|
|
+ } else {
|
|
|
|
|
+ log.info("{} {} {} 实名认证通过", name, phone, idno);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Scheduled(fixedRate = 60000)
|
|
|
|
|
+ @RedisLock(value = "autoValidate", expire = 30, unit = TimeUnit.MINUTES)
|
|
|
|
|
+ public void autoValidate() {
|
|
|
|
|
+ if (!sysConfigService.getBoolean("auto_validate")) return;
|
|
|
|
|
+ log.info("autoValidate");
|
|
|
|
|
+ if (Arrays.asList(env.getActiveProfiles()).contains("dev")) {
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ try {
|
|
|
|
|
+ List<IdentityAuth> list = identityAuthRepo.findByStatusAndAutoValidated(AuthStatus.PENDING, false);
|
|
|
|
|
+ list.parallelStream().forEach(identityAuth -> {
|
|
|
|
|
+ int count = identityAuthRepo.countByIdNoAndStatus(identityAuth.getIdNo(), AuthStatus.SUCCESS);
|
|
|
|
|
+ boolean success = false;
|
|
|
|
|
+ String reason = null;
|
|
|
|
|
+ if (count >= 3) {
|
|
|
|
|
+ success = false;
|
|
|
|
|
+ reason = "同一身份证注册超过3个";
|
|
|
|
|
+ } else {
|
|
|
|
|
+ try {
|
|
|
|
|
+ User user = userRepo.findById(identityAuth.getUserId())
|
|
|
|
|
+ .orElseThrow(new BusinessException("用户不存在"));
|
|
|
|
|
+ validate(identityAuth.getRealName(), user.getPhone(), identityAuth.getIdNo());
|
|
|
|
|
+ success = true;
|
|
|
|
|
+ } catch (Exception e) {
|
|
|
|
|
+ reason = e.getMessage();
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ audit(identityAuth.getId(), success ? AuthStatus.SUCCESS : AuthStatus.PENDING, reason);
|
|
|
|
|
+ });
|
|
|
|
|
+ } catch (Exception ignored) {
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|