From caa35eaa7d9cae55a57155d9508d1285999f1bba Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期四, 30 十一月 2023 22:16:42 +0800
Subject: [PATCH] 2023年11月30日22:16:31
---
app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java | 344 ++++++++++++++++++++++++++++++++++----------------------
1 files changed, 209 insertions(+), 135 deletions(-)
diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java
index 77ed570..3eb589a 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlOtaLogic.java
@@ -1,10 +1,8 @@
package com.hdl.photovoltaic.other;
-import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.content.ServiceConnection;
-import android.os.IBinder;
import android.text.TextUtils;
@@ -33,7 +31,11 @@
import com.hdl.photovoltaic.utils.Md5Utils;
import com.hdl.sdk.link.common.exception.HDLLinkException;
import com.hdl.sdk.link.common.utils.ByteUtils;
+import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus;
import com.hdl.sdk.link.core.callback.HDLLinkCallBack;
+
+import org.apache.commons.io.FileUtils;
+import org.greenrobot.eventbus.EventBus;
import java.io.File;
import java.io.FileOutputStream;
@@ -41,10 +43,8 @@
import java.io.InputStream;
import java.lang.reflect.Type;
import java.util.ArrayList;
-import java.util.Arrays;
import java.util.List;
import java.util.Objects;
-import java.util.logging.FileHandler;
import okhttp3.ResponseBody;
@@ -88,6 +88,16 @@
private Intent intentServer = null;
private ServiceConnection mServiceConnection = null;
+ /**
+ * 鏈嶅姟鏄惁寮�鍚� true=寮�鍚�
+ */
+ public boolean mServiceStart = false;
+
+ /**
+ * true琛ㄧず缁堟涓嬭浇鍗囩骇鏂囦欢(鐢ㄦ埛琛屼负)
+ */
+ private boolean stopDownload = false;
+
//region -----鍥轰欢鍗囩骇---------
@@ -184,7 +194,7 @@
JsonObject json = new JsonObject();
json.addProperty("hardwareModel", hardwareModel);
json.addProperty("osImageId", osImageId);
- json.addProperty("protocolType", "ZIGBEE");//鍗忚绫诲瀷,鍙敤鍊�:BUSPRO,KNX,ZIGBEE,OTHER
+// json.addProperty("protocolType", "ZIGBEE");//鍗忚绫诲瀷,鍙敤鍊�:BUSPRO,KNX,ZIGBEE,OTHER
HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
@Override
public void onSuccess(String json) {
@@ -245,59 +255,6 @@
}
- /**
- * 鍚戜簯绔幏鍙栥�愯澶囧浐浠躲�戝崌绾у寘涓嬭浇鍦板潃
- *
- * @param firmwareVersionId 鍥轰欢鐗堟湰Id
- */
- public void getDeviceFirmwareDownloadUrl(String firmwareVersionId, CloudCallBeak<DownloadUrlBean> callBack) {
-// "protocolType":"bus",
-// "deviceModel":"029B9988",
-// "firmwareNameEn":"鏍稿績灞�",
-// "firmwareNameCn":"鏍稿績灞�",
-// "imageId":"12345678",
-// "version":"V01.02.20"
- String requestUrl = HttpApi.POST_OTA_GET_LinkDeviceFirmwareDownloadUrl;
- JsonObject json = new JsonObject();
- json.addProperty("firmwareVersionId", firmwareVersionId);
- HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
- @Override
- public void onSuccess(String json) {
-
- if (TextUtils.isEmpty(json)) {
- if (callBack != null) {
- callBack.onSuccess(new DownloadUrlBean());
- }
- return;
- }
- Gson gson = new Gson();
- Type typeOfT = new TypeToken<DownloadUrlBean>() {
- }.getType();
- DownloadUrlBean downloadUrlBean = gson.fromJson(json, typeOfT);
- if (callBack != null) {
- callBack.onSuccess(downloadUrlBean);
- }
- }
-
- @Override
- public void onFailure(HDLException e) {
- if (callBack != null) {
- callBack.onFailure(e);
- }
- }
- });
- }
-
- /**
- * 鍚戜簯绔幏鍙栥�愯澶囧浐浠躲�戜笅杞藉崌绾ф枃浠�
- *
- * @param downloadUrl 浜戠鍥轰欢鍦板潃
- */
- public void getDeviceFirmwareDownloadFile(String downloadUrl, CloudCallBeak<DownloadUrlBean> callBack) {
- String requestUrl = HttpApi.POST_OTA_GET_LinkDeviceFirmwareDownloadUrl;
- JsonObject json = new JsonObject();
-
- }
//endregion
@@ -389,8 +346,9 @@
}
+
/**
- * 浜戠鍙戣捣銆愯澶囬┍鍔ㄣ�戝崌绾TA鎸囦护
+ * 浜戠鍙戣捣銆愯澶囬┍鍔ㄥ崌绾с�慜TA鎸囦护
*
* @param oid 缃戝叧璁惧oid
* @param driverVersionId 椹卞姩鐗堟湰id
@@ -419,49 +377,22 @@
});
}
+
+ //endregion
+
/**
- * 鍚戜簯绔幏鍙栥�愯澶囬┍鍔ㄣ�戝崌绾у寘涓嬭浇鍦板潃
- *
- * @param driverVersionId 椹卞姩鐗堟湰Id
+ * 璁剧疆缁堟涓嬭浇鏂囦欢鎸囦护
*/
- public void getDeviceDriverDownloadUrl(String driverVersionId, CloudCallBeak<DownloadUrlBean> callBack) {
-
- String requestUrl = HttpApi.POST_OTA_GET_LinkDeviceDriverDownloadUrl;
- JsonObject json = new JsonObject();
- json.addProperty("driverVersionId", driverVersionId);
- HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
- @Override
- public void onSuccess(String s) {
- if (TextUtils.isEmpty(s)) {
- if (callBack != null) {
- callBack.onSuccess(new DownloadUrlBean());
- }
- return;
- }
- Gson gson = new Gson();
- Type typeOfT = new TypeToken<DownloadUrlBean>() {
- }.getType();
- DownloadUrlBean downloadUrlBean = gson.fromJson(s, typeOfT);
- if (callBack != null) {
- callBack.onSuccess(downloadUrlBean);
- }
- }
-
- @Override
- public void onFailure(HDLException e) {
- if (callBack != null) {
- callBack.onFailure(e);
- }
- }
- });
+ public void setStopDriversDownload() {
+ this.stopDownload = true;
}
/**
- * 鍚戜簯绔幏鍙栥�愯澶囬┍鍔ㄣ�戜笅杞藉崌绾ф枃浠�
+ * 鍚戜簯绔幏鍙栥�愯澶囧崌绾ф枃浠�(椹卞姩,鍥轰欢)涓嬭浇銆戝崌绾ф枃浠�
*
- * @param downloadUrl 浜戠鍥轰欢鍦板潃
+ * @param downloadUrl 浜戠椹卞姩鍦板潃
*/
- public void getDeviceDriverDownloadFile(String downloadUrl, CloudCallBeak<ResponseBody> callBack) {
+ public void getDeviceUpgradeDownloadFile(String downloadUrl, CloudCallBeak<ResponseBody> callBack) {
HttpClient.getInstance().downLoadFile(downloadUrl, new CloudCallBeak<ResponseBody>() {
@Override
public void onSuccess(ResponseBody s) {
@@ -481,9 +412,6 @@
}
-
-
- //endregion
/**
* 鏈湴鍗囩骇鍖呮帹閫�(鍛婅瘔缃戝叧涓嬭浇鍗囩骇鍖呭湴鍧�绛変俊鎭�)
@@ -539,6 +467,7 @@
intentServer = new Intent();
intentServer.setClass(HDLApp.getInstance(), MyNanoHttpService.class);
this.mServiceConnection = serviceConnection;
+ this.mServiceStart = true;
//鍚姩鏈嶅姟鐩戝惉
HDLApp.getInstance().bindService(intentServer, serviceConnection, Context.BIND_AUTO_CREATE);
}
@@ -549,66 +478,211 @@
public void unLocalService() {
if (intentServer != null && this.mServiceConnection != null) {
HDLApp.getInstance().unbindService(this.mServiceConnection);
+ this.mServiceStart = false;
}
}
/**
- * 澶勭悊涓嬭浇鏂囦欢鏁版嵁
+ * 銆愭祴璇曘�戝鐞嗕笅杞芥枃浠舵暟鎹�
*
* @param zipData 鏂囦欢鏁版嵁娴佸璞�
* @param md5 妫�楠屾枃浠禡D5鍊�
* @return 杩斿洖瑙e瘑鐨刡yte[]
*/
- public byte[] disposeDownLoadFile(ResponseBody zipData, String md5) {
+ public boolean testDisposeDownLoadFile(String fullPath, ResponseBody zipData, String md5) {
+ String driver = driver_type;
+ //-100:娌℃湁鏁版嵁;-101:娌℃湁md5绉橀挜;-102:md5绉橀挜涓嶅;-103:鏈夊紓甯�;
if (zipData == null) {
- return null;
+ this.eventBusPost(fullPath, driver, -100, "娌℃湁鏁版嵁");
+ return false;
}
if (TextUtils.isEmpty(md5)) {
- return null;
+ this.eventBusPost(fullPath, driver, -101, "娌℃湁md5绉橀挜");
+ return false;
}
InputStream is = null;
- List<Byte> byteList = new ArrayList<>();
- byte[] decrypt = null;
+ byte[] buf = new byte[1204 * 4];
+ int len = 0;
+ FileOutputStream fos = null;
+ File file = null;
try {
+ file = new File(fullPath);
is = zipData.byteStream();
- int total = (int) zipData.contentLength();
- byte[] buf = new byte[1024*4];
+ long total = zipData.contentLength();
+ if (total == 0) {
+ this.eventBusPost(fullPath, driver, -100, "娌℃湁鏁版嵁");
+ return false;
+ }
+ fos = new FileOutputStream(file);
long sum = 0;
- int len = 0;
while ((len = is.read(buf)) != -1) {
+ fos.write(buf, 0, len);
sum += len;
- //todo 涓嬭浇涓紝鍙互鑷鍔犲叆杩涘害鏉�(鍙互骞挎挱鍑哄幓)
- int progress = (int) (sum * 1.0f / total * 100);
- for (int i = 0; i < len; i++) {
- byteList.add(buf[i]);
+ //todo 涓嬭浇涓紝鍙互鑷繁璁$畻鐨勮繘搴︽潯(鍙互骞挎挱鍑哄幓)
+ int progress = (int) (100 * sum * 1.0f / total);
+ if (sum != total) {
+ //涓嶇瓑浜�100閮借鎶�,绛変簬100澶勭悊鏁村潡閫昏緫瀹屼箣鍚庡啀鎶�100;
+ this.eventBusPost(fullPath, driver, progress, "姝e父涓婃姤");
}
}
- } catch (Exception e) {
- e.printStackTrace();
- } finally {
- try {
- if (is != null) {
- is.close();
- }
- Byte[] sourceByte = byteList.toArray(new Byte[0]);
- byte[] bytes = new byte[sourceByte.length];
- for (int i = 0; i < sourceByte.length; i++) {
- bytes[i] = sourceByte[i];
- }
- //涓嬭浇鏂囦欢闇�瑕佽В瀵嗕箣鍚庡啀杩涜md5鍘诲仛姣斿
- decrypt = AesUtils.decrypt(bytes);
- if (decrypt != null) {
- String fileMD5 = Md5Utils.encodeMD5(decrypt);
- if (TextUtils.isEmpty(fileMD5) || !Objects.equals(fileMD5, md5)) {
- //鏍¢獙澶辫触,缃┖
- decrypt = null;
- }
- }
- } catch (IOException ignored) {
+ fos.flush();
+ fos.close();
+ is.close();
+ byte[] bytes = FileUtils.readFileToByteArray(file);
+ String fileMD5 = Md5Utils.encodeMD5(bytes);
+ if (TextUtils.isEmpty(fileMD5)) {
+ this.eventBusPost(fullPath, driver, -106, "鏂囦欢鐢熸垚md5澶辫触.");
+ return false;
+ }
+ if (!md5.equals(fileMD5)) {
+ this.eventBusPost(fullPath, driver, -107, "md5姣斿澶辫触.");
+ return false;
+ }
+ this.eventBusPost(fullPath, driver, 100, "涓嬭浇瀹屾垚.");
- }
+
+ return true;
+ } catch (Exception e) {
+ this.eventBusPost(fullPath, driver, -103, e.getMessage());
+ e.printStackTrace();
}
- return decrypt;
+ return false;
+ }
+
+ /**
+ * 澶勭悊涓嬭浇鏂囦欢鏁版嵁
+ *
+ * @param fileFullPath 鏂囦欢鍏ㄨ矾寰�
+ * @param zipData 鏂囦欢鏁版嵁娴佸璞�
+ * @param md5 妫�楠屾枃浠禡D5鍊�
+ * @param driver 椹卞姩鎴栬�呭浐浠�
+ * @return 鎴愬姛true
+ */
+ public boolean disposeDownLoadFile(String fileFullPath, ResponseBody zipData, String md5, String driver) {
+ this.stopDownload = false;
+ //-100:娌℃湁鏁版嵁;-101:娌℃湁md5绉橀挜;-102:md5绉橀挜涓嶅;-103:鏈夊紓甯�;
+ if (zipData == null) {
+ this.eventBusPost(fileFullPath, driver, -100, "娌℃湁鏁版嵁");
+ return false;
+ }
+ if (TextUtils.isEmpty(md5)) {
+ this.eventBusPost(fileFullPath, driver, -101, "娌℃湁md5绉橀挜");
+ return false;
+ }
+ InputStream is = null;
+ byte[] buf = new byte[1204 * 4];
+ int len = 0;
+ FileOutputStream fos = null;
+ File file = null;
+ try {
+ file = new File(fileFullPath);
+ is = zipData.byteStream();
+ long total = zipData.contentLength();
+ if (total == 0) {
+ this.eventBusPost(fileFullPath, driver, -100, "娌℃湁鏁版嵁");
+ return false;
+ }
+ fos = new FileOutputStream(file);
+ long sum = 0;
+ while ((len = is.read(buf)) != -1) {
+ if (this.stopDownload) {
+ this.eventBusPost(fileFullPath, driver, -108, "鐢ㄦ埛鍙栨秷涓嬭浇.");
+ fos.flush();
+ fos.close();
+ is.close();
+ //todo 鐢ㄦ埛缁堟缁х画璇诲彇鏁版嵁;
+ return false;
+ }
+ fos.write(buf, 0, len);
+ sum += len;
+ //todo 涓嬭浇涓紝鍙互鑷繁璁$畻鐨勮繘搴︽潯(鍙互骞挎挱鍑哄幓)
+ int progress = (int) (100 * sum * 1.0f / total);
+ if (sum != total) {
+ //涓嶇瓑浜�100閮借鎶�,绛変簬100澶勭悊鏁村潡閫昏緫瀹屼箣鍚庡啀鎶�100;
+ this.eventBusPost(fileFullPath, driver, progress, "姝e父涓婃姤");
+ }
+ }
+ fos.flush();
+ fos.close();
+ is.close();
+ byte[] bytes = FileUtils.readFileToByteArray(file);
+ //涓嬭浇鏂囦欢闇�瑕佽В瀵嗕箣鍚庡啀杩涜md5鍘诲仛姣斿
+ byte[] decrypt = AesUtils.decrypt(bytes);
+ if (decrypt == null) {
+ this.eventBusPost(fileFullPath, driver, -105, "aes瑙e瘑澶辫触.");
+ return false;
+ }
+ String fileMD5 = Md5Utils.encodeMD5(decrypt);
+ if (TextUtils.isEmpty(fileMD5)) {
+ this.eventBusPost(fileFullPath, driver, -106, "鏂囦欢鐢熸垚md5澶辫触.");
+ return false;
+ }
+ if (!md5.equals(fileMD5)) {
+ this.eventBusPost(fileFullPath, driver, -107, "md5姣斿澶辫触.");
+ return false;
+ }
+ //todo 娉ㄦ剰:瑙e瘑涔嬪悗锛岃閲嶆柊鍐欐暟鎹�;
+ FileUtils.writeByteArrayToFile(file, decrypt, false);
+ this.eventBusPost(fileFullPath, driver, 100, "涓嬭浇瀹屾垚.");
+ return true;
+ } catch (Exception e) {
+ this.eventBusPost(fileFullPath, driver, -103, e.getMessage());
+ e.printStackTrace();
+ }
+ return false;
+ }
+
+
+ /**
+ * 鍙戝竷杩涘害涓婚
+ *
+ * @param type 椹卞姩:driver,鍥轰欢:firmware
+ * @param progressValue 杩涘害鍊�
+ * @param describe 鎻忚堪鏂囨湰
+ */
+ public void eventBusPost(String fileFullPath, String type, int progressValue, String describe) {
+ if (this.stopDownload) {
+ HdlFileLogic.getInstance().deleteFile(fileFullPath);//鍒犻櫎涓嬭浇涓嶅畬鎴愭暟鎹�;
+ BaseEventBus baseEventBus = new BaseEventBus();
+ baseEventBus.setTopic(localDownloadProgress);
+ Progress progress = new Progress();
+ progress.step = -108;
+ progress.describe = "鐢ㄦ埛鍙栨秷涓嬭浇.";
+ baseEventBus.setType(type);
+ baseEventBus.setData(progress);
+ EventBus.getDefault().post(baseEventBus);
+ return;
+ }
+// HdlThreadLogic.runMainThread(new Runnable() {
+// @Override
+// public void run() {
+ BaseEventBus baseEventBus = new BaseEventBus();
+ baseEventBus.setTopic(localDownloadProgress);
+ Progress progress = new Progress();
+ progress.step = progressValue;
+ progress.describe = describe;
+ progress.type = type;
+ baseEventBus.setType(type);
+ baseEventBus.setData(progress);
+ EventBus.getDefault().post(baseEventBus);
+// }
+// });
+ }
+
+
+ //鑷畾涔変笂鎶ヤ笅杞介┍鍔ㄦ垨鍥轰欢杩涘害涓婚
+ public static final String localDownloadProgress = "cloud/download/progress/up";
+
+ public static final String driver_type = "driver";
+ public static final String firmware_type = "firmware";
+
+ public static class Progress {
+ //杩涘害鍊�
+ public int step;
+ //杩涘害鎻忚堪淇℃伅
+ public String describe;
+ //琛ㄧず鏄┍鍔紝鍥轰欢;
+ public String type;
}
--
Gitblit v1.8.0