|
|
@ -13,6 +13,7 @@ import lombok.extern.slf4j.Slf4j; |
|
|
|
import org.springblade.core.log.exception.ServiceException; |
|
|
|
import org.springblade.core.log.exception.ServiceException; |
|
|
|
import org.springblade.core.tool.api.R; |
|
|
|
import org.springblade.core.tool.api.R; |
|
|
|
import org.springframework.beans.factory.annotation.Value; |
|
|
|
import org.springframework.beans.factory.annotation.Value; |
|
|
|
|
|
|
|
import org.springframework.data.redis.core.RedisTemplate; |
|
|
|
import org.springframework.stereotype.Service; |
|
|
|
import org.springframework.stereotype.Service; |
|
|
|
|
|
|
|
|
|
|
|
import javax.servlet.http.HttpServletResponse; |
|
|
|
import javax.servlet.http.HttpServletResponse; |
|
|
@ -30,6 +31,9 @@ public class DeLianServiceImpl implements IDeLianService { |
|
|
|
private String hostId; |
|
|
|
private String hostId; |
|
|
|
@Value("${deLian.passWord}") |
|
|
|
@Value("${deLian.passWord}") |
|
|
|
private String passWord; |
|
|
|
private String passWord; |
|
|
|
|
|
|
|
private final RedisTemplate redisTemplate; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private final static String load_strategys_key = "hzims:equipment:delian:strategys:key"; |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public List<StrategyDataVO> getStrategys() { |
|
|
|
public List<StrategyDataVO> getStrategys() { |
|
|
@ -43,6 +47,7 @@ public class DeLianServiceImpl implements IDeLianService { |
|
|
|
HttpResponse response = HttpRequest.post(deLianUrl).body(jsonString).execute(); |
|
|
|
HttpResponse response = HttpRequest.post(deLianUrl).body(jsonString).execute(); |
|
|
|
if (response.getStatus() == HttpServletResponse.SC_OK) { |
|
|
|
if (response.getStatus() == HttpServletResponse.SC_OK) { |
|
|
|
List<StrategyDataVO> responseData = JSONObject.parseArray(JSONObject.parseObject(response.body()).getString("response_data"), StrategyDataVO.class); |
|
|
|
List<StrategyDataVO> responseData = JSONObject.parseArray(JSONObject.parseObject(response.body()).getString("response_data"), StrategyDataVO.class); |
|
|
|
|
|
|
|
redisTemplate.opsForValue().set(load_strategys_key, responseData); |
|
|
|
return responseData; |
|
|
|
return responseData; |
|
|
|
} |
|
|
|
} |
|
|
|
return new ArrayList<>(); |
|
|
|
return new ArrayList<>(); |
|
|
@ -50,16 +55,28 @@ public class DeLianServiceImpl implements IDeLianService { |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public R executeScene(String key) { |
|
|
|
public R executeScene(String key) { |
|
|
|
|
|
|
|
long start = System.currentTimeMillis(); |
|
|
|
|
|
|
|
log.info("executeScene接口请求开始------"); |
|
|
|
HashMap<String, Object> param = getOauthToken(); |
|
|
|
HashMap<String, Object> param = getOauthToken(); |
|
|
|
param.put("request_cmd", DeLianConstants.EXECUTESCENE.getCode()); |
|
|
|
param.put("request_cmd", DeLianConstants.EXECUTESCENE.getCode()); |
|
|
|
List<StrategyDataVO> strategys = getStrategys(); |
|
|
|
List<StrategyDataVO> strategys = new ArrayList<>(); |
|
|
|
|
|
|
|
if (redisTemplate.hasKey(load_strategys_key)) { |
|
|
|
|
|
|
|
strategys = (List<StrategyDataVO>) redisTemplate.opsForValue().get(load_strategys_key); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
strategys = getStrategys(); |
|
|
|
|
|
|
|
} |
|
|
|
for (StrategyDataVO strategy : strategys) { |
|
|
|
for (StrategyDataVO strategy : strategys) { |
|
|
|
if (key.equals(strategy.getSn())) { |
|
|
|
if (key.equals(strategy.getSn())) { |
|
|
|
param.put("request_data", strategy.getSID()); |
|
|
|
param.put("request_data", strategy.getSID()); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
long start1 = System.currentTimeMillis(); |
|
|
|
|
|
|
|
log.info("deLian策略查询耗时:{}", start1 - start); |
|
|
|
|
|
|
|
log.info("deLian一键执行接口请求开始------"); |
|
|
|
HttpResponse response = HttpRequest.post(deLianUrl).body(JSON.toJSONString(param)).execute(); |
|
|
|
HttpResponse response = HttpRequest.post(deLianUrl).body(JSON.toJSONString(param)).execute(); |
|
|
|
if (response.getStatus() == HttpServletResponse.SC_OK) { |
|
|
|
if (response.getStatus() == HttpServletResponse.SC_OK) { |
|
|
|
|
|
|
|
long end = System.currentTimeMillis(); |
|
|
|
|
|
|
|
log.info("deLian一键执行接口耗时:{}", end - start1); |
|
|
|
return R.success("执行成功"); |
|
|
|
return R.success("执行成功"); |
|
|
|
} |
|
|
|
} |
|
|
|
return R.fail("执行成功"); |
|
|
|
return R.fail("执行成功"); |
|
|
@ -88,5 +105,4 @@ public class DeLianServiceImpl implements IDeLianService { |
|
|
|
throw new ServiceException("获取权限失败,请稍后重试!"); |
|
|
|
throw new ServiceException("获取权限失败,请稍后重试!"); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|