From 41348c4a2a3bc3ebc658386f42c70d70fbd505c5 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Tue, 11 May 2021 11:02:26 +0800
Subject: [PATCH] add basic data udpate

---
 src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java             |    4 ++
 src/main/java/com/xcong/excoin/quartz/job/XchBaseDataUpdateJob.java             |   87 +++++++++++++++++++++++++++++++++++++++++++
 src/main/java/com/xcong/excoin/modules/yunding/entity/YdBasicSettingEntity.java |    5 ++
 src/main/resources/application.yml                                              |    1 
 4 files changed, 97 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java b/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java
index 1aaa265..c6ceec5 100644
--- a/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java
+++ b/src/main/java/com/xcong/excoin/common/aop/ExceptionCatchAspect.java
@@ -60,6 +60,10 @@
             throw ex;
         }
 
+        if ("dev".equals(profiles)) {
+            throw ex;
+        }
+
         SysExceptionDetailEntity exceptionData = new SysExceptionDetailEntity();
         String exStr = printStackTraceToString(ex);
         ThreadPoolUtils.EXECUTOR.execute(new Runnable(){
diff --git a/src/main/java/com/xcong/excoin/modules/yunding/entity/YdBasicSettingEntity.java b/src/main/java/com/xcong/excoin/modules/yunding/entity/YdBasicSettingEntity.java
index 12fac7c..7e294f3 100644
--- a/src/main/java/com/xcong/excoin/modules/yunding/entity/YdBasicSettingEntity.java
+++ b/src/main/java/com/xcong/excoin/modules/yunding/entity/YdBasicSettingEntity.java
@@ -34,4 +34,9 @@
     //24小时爆块
     private BigDecimal explosiveBlock;
 
+    /**
+     * 当前价格
+     */
+    private BigDecimal currentPrice;
+
 }
diff --git a/src/main/java/com/xcong/excoin/quartz/job/XchBaseDataUpdateJob.java b/src/main/java/com/xcong/excoin/quartz/job/XchBaseDataUpdateJob.java
new file mode 100644
index 0000000..4014f9d
--- /dev/null
+++ b/src/main/java/com/xcong/excoin/quartz/job/XchBaseDataUpdateJob.java
@@ -0,0 +1,87 @@
+package com.xcong.excoin.quartz.job;
+
+import cn.hutool.core.collection.CollUtil;
+import com.alibaba.fastjson.JSONObject;
+import com.xcong.excoin.modules.yunding.dao.YdBasicSettingDao;
+import com.xcong.excoin.modules.yunding.entity.YdBasicSettingEntity;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
+import org.springframework.scheduling.annotation.Scheduled;
+import org.springframework.stereotype.Component;
+
+import java.io.BufferedReader;
+import java.io.InputStream;
+import java.io.InputStreamReader;
+import java.math.BigDecimal;
+import java.net.HttpURLConnection;
+import java.net.URL;
+import java.util.List;
+
+/**
+ * @author xxx
+ **/
+@Slf4j
+@Component
+@ConditionalOnProperty(prefix = "app", name = "xch-job", havingValue = "true")
+public class XchBaseDataUpdateJob {
+
+    @Autowired
+    private YdBasicSettingDao ydBasicSettingDao;
+
+    @Scheduled(cron = "* */1 * * * ? ")
+    public void baseDataUpdate() {
+        // 请求价格等数据
+        String result = getUrlResponse("https://api2.chiaexplorer.com/blockchainSummary");
+        // 每t预计收益
+        String profitPerT = getUrlResponse("https://api2.chiaexplorer.com/chart/xchTibDay?period=2w");
+        JSONObject jsonObject = (JSONObject) JSONObject.parse(result);
+        JSONObject perTObject = (JSONObject) JSONObject.parse(profitPerT);
+        List<YdBasicSettingEntity> list = ydBasicSettingDao.selectList(null);
+        if (CollUtil.isNotEmpty(list)) {
+            YdBasicSettingEntity settingEntity = list.get(0);
+            String netspaceStr = jsonObject.getString("netspace");
+            BigDecimal baseUnit = BigDecimal.valueOf(1024);
+            BigDecimal netspace = new BigDecimal(netspaceStr).divide(baseUnit.multiply(baseUnit.multiply(baseUnit.multiply(baseUnit.multiply(baseUnit)))), 2, BigDecimal.ROUND_DOWN);
+            settingEntity.setAllPower(netspace);
+
+            settingEntity.setCurrentPrice(new BigDecimal(jsonObject.getString("price")));
+            List<String> data = JSONObject.parseArray(perTObject.getString("data"), String.class);
+            settingEntity.setPrifitT(new BigDecimal(data.get(0)));
+            settingEntity.setProfitDay(new BigDecimal(data.get(0)).multiply(BigDecimal.valueOf(1024)));
+
+            ydBasicSettingDao.updateById(settingEntity);
+        }
+    }
+
+    private String getUrlResponse(String url) {
+        BufferedReader reader = null;
+        String result = null;
+        StringBuffer sbf = new StringBuffer();
+        // 模拟浏览器
+        String userAgent = "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.66 Safari/537.36";
+        try {
+            URL request = new URL(url);
+            HttpURLConnection connection = (HttpURLConnection) request.openConnection();
+            connection.setRequestMethod("GET");
+            connection.setReadTimeout(30000);
+            connection.setConnectTimeout(30000);
+            connection.setRequestProperty("User-agent", userAgent);
+            connection.connect();
+            InputStream is = connection.getInputStream();
+            reader = new BufferedReader(new InputStreamReader(is, "UTF-8"));
+            String strRead = null;
+            while ((strRead = reader.readLine()) != null) {
+                sbf.append(strRead);
+                sbf.append("\r\n");
+            }
+            reader.close();
+            result = sbf.toString();
+
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+
+        return result;
+    }
+}
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index 31ee018..f38db7e 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -107,6 +107,7 @@
   loop-job: false
   rabbit-consumer: false
   block-job: false
+  xch-job: false
 
 aliyun:
   oss:

--
Gitblit v1.9.1