|
|
|
@ -1,6 +1,5 @@
|
|
|
|
|
package au.com.royalpay.payment.manage.system.core.impl;
|
|
|
|
|
|
|
|
|
|
import au.com.royalpay.payment.manage.appclient.core.RetailAppService;
|
|
|
|
|
import au.com.royalpay.payment.manage.mappers.system.ClientFilesMapper;
|
|
|
|
|
import au.com.royalpay.payment.manage.mappers.system.ClientRateMapper;
|
|
|
|
|
import au.com.royalpay.payment.manage.mappers.system.ClientsContractMapper;
|
|
|
|
@ -35,8 +34,6 @@ public class ClientContractServiceImpl implements ClientContractService {
|
|
|
|
|
@Resource
|
|
|
|
|
private ClientsContractMapper clientsContractMapper;
|
|
|
|
|
@Resource
|
|
|
|
|
private RetailAppService retailAppService;
|
|
|
|
|
@Resource
|
|
|
|
|
private ClientRateMapper clientRateMapper;
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@ -46,6 +43,12 @@ public class ClientContractServiceImpl implements ClientContractService {
|
|
|
|
|
if (client == null) {
|
|
|
|
|
throw new NotFoundException("merchant not found");
|
|
|
|
|
}
|
|
|
|
|
JSONObject expireInfo = getClientContractExpire(client_id);
|
|
|
|
|
if(expireInfo.getBoolean("rate_waring")){
|
|
|
|
|
List<JSONObject> files = clientFilesMapper.findFileByClientAndType(client_id, "source_agree_file");
|
|
|
|
|
return files.get(0);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
JSONObject contract = clientsContractMapper.findByClientId(client_id);
|
|
|
|
|
Date now = new Date();
|
|
|
|
|
if (contract == null || now.compareTo(contract.getDate("expiry_date")) > 0 ) {
|
|
|
|
@ -59,7 +62,6 @@ public class ClientContractServiceImpl implements ClientContractService {
|
|
|
|
|
saveContract(client_id, now);
|
|
|
|
|
return files.get(0);
|
|
|
|
|
} else {
|
|
|
|
|
JSONObject expireInfo = getClientContractExpire(client_id);
|
|
|
|
|
List<JSONObject> files = clientFilesMapper.findFileByClientAndType(client_id, "source_agree_file");
|
|
|
|
|
JSONObject file = files.get(0);
|
|
|
|
|
if (expireInfo.getBoolean("rate_expire")) {
|
|
|
|
@ -83,13 +85,39 @@ public class ClientContractServiceImpl implements ClientContractService {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
@Transactional
|
|
|
|
|
public void confirmSourceAgreement(int client_id) {
|
|
|
|
|
JSONObject file = clientsContractMapper.findByClientId(client_id);
|
|
|
|
|
if (file == null) {
|
|
|
|
|
JSONObject rateExpire = getClientContractExpire(client_id);
|
|
|
|
|
boolean expire = rateExpire.getBoolean("rate_expire");
|
|
|
|
|
boolean waring = rateExpire.getBoolean("rate_waring");
|
|
|
|
|
if(!(expire && waring)){
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
JSONObject contract = clientsContractMapper.findByClientId(client_id);
|
|
|
|
|
if (contract == null) {
|
|
|
|
|
throw new BadRequestException("generate contract first");
|
|
|
|
|
}
|
|
|
|
|
file.put("has_sign", 1);
|
|
|
|
|
clientsContractMapper.update(file);
|
|
|
|
|
contract.put("has_sign", 1);
|
|
|
|
|
clientsContractMapper.update(contract);
|
|
|
|
|
Date now = new Date();
|
|
|
|
|
List<JSONObject> rateInfo = clientRateMapper.minExpiryTime(client_id, null);
|
|
|
|
|
if(expire){
|
|
|
|
|
rateInfo.forEach((p)->{
|
|
|
|
|
p.remove("client_rate_id");
|
|
|
|
|
p.put("create_time",now);
|
|
|
|
|
p.put("active_time",now);
|
|
|
|
|
p.put("expiry_time",DateUtils.addYears(now,1));
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
if(!expire && waring){
|
|
|
|
|
rateInfo.forEach((p)->{
|
|
|
|
|
p.remove("client_rate_id");
|
|
|
|
|
p.put("create_time",now);
|
|
|
|
|
p.put("active_time",DateUtils.addYears(p.getDate("active_time"),1));
|
|
|
|
|
p.put("expiry_time",DateUtils.addYears(p.getDate("expiry_time"),1));
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@ -109,6 +137,11 @@ public class ClientContractServiceImpl implements ClientContractService {
|
|
|
|
|
}
|
|
|
|
|
List<JSONObject> rateInfo = clientRateMapper.minExpiryTime(client_id, null);
|
|
|
|
|
JSONObject result = new JSONObject();
|
|
|
|
|
if (CollectionUtils.isEmpty(rateInfo)) {
|
|
|
|
|
result.put("rate_expire", true);
|
|
|
|
|
result.put("rate_waring", true);
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
result.put("rate_expire", false);
|
|
|
|
|
result.put("rate_waring", false);
|
|
|
|
|
Date now = new Date();
|
|
|
|
@ -116,9 +149,7 @@ public class ClientContractServiceImpl implements ClientContractService {
|
|
|
|
|
if (contract != null && contract.getDate("expiry_date").compareTo(now) > 0 && contract.getBoolean("has_sign")) {
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
if (CollectionUtils.isEmpty(rateInfo)) {
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
rateInfo.forEach((p) -> {
|
|
|
|
|
if (now.compareTo(p.getDate("expiry_time")) > -1) {
|
|
|
|
|
result.put("rate_expire", true);
|
|
|
|
|