From 14de918a79943e4961b09fa01ed320c6cad41f2e Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期三, 28 六月 2023 17:14:51 +0800
Subject: [PATCH] Revert "Revert "Merge branch 'hxb' into wjc""

---
 app/src/main/java/com/hdl/photovoltaic/other/HdlAccountLogic.java |  202 +++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 158 insertions(+), 44 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlAccountLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlAccountLogic.java
index 63c9ae5..0e69701 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlAccountLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlAccountLogic.java
@@ -1,13 +1,33 @@
 package com.hdl.photovoltaic.other;
 
 
+import com.google.gson.Gson;
+import com.google.gson.JsonObject;
+import com.hdl.photovoltaic.ui.bean.LoginUserBean;
+import com.hdl.photovoltaic.ui.bean.LoginUserRegionBean;
+import com.hdl.photovoltaic.bean.HttpResponsePack;
+import com.hdl.photovoltaic.config.AppConfigManage;
+import com.hdl.photovoltaic.config.UserConfigManage;
+import com.hdl.photovoltaic.internet.HttpClient;
+import com.hdl.photovoltaic.internet.api.HttpApi;
+import com.hdl.photovoltaic.listener.BaseSuccessFailureCallBeak;
+import com.hdl.photovoltaic.listener.CloudCallBeak;
+
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+
 /**
- * 鐧婚檰鐣岄潰鐨勯�昏緫
+ * 鐧诲綍鐣岄潰鐨勯�昏緫
  */
 public class HdlAccountLogic {
 
     private static volatile HdlAccountLogic sHdlAccountLogic;
 
+    /**
+     * 鑾峰彇褰撳墠瀵硅薄
+     *
+     * @return HdlAccountLogic
+     */
     public static synchronized HdlAccountLogic getInstance() {
         if (sHdlAccountLogic == null) {
             synchronized (HdlAccountLogic.class) {
@@ -22,55 +42,149 @@
 
 
     /**
-     * 鍒濆鍖栬处鍙风殑Url鍖哄煙鍦板潃(鍙兘鐘舵�佺爜:Sucess  NotAccount  NotNetWork)
+     * 鍒濆鍖栬处鍙风殑Url鍖哄煙鍦板潃
      *
-     * @param i_account
-     * @return
+     * @param i_account 璐﹀彿
      */
-    private void InitAccoutRegionInfo(String i_account) {
-//        String regionUrl = this.GetAccoutRegionInfo(i_account);
-//
-//
-//        if (regionUrl == null) {
-//            return AccountStatu.NotNetWork;
-//        }
-//        if (regionUrl == string.Empty) {
-//            return AccountStatu.NotAccount;
-//        }
-//
-//        return AccountStatu.Sucess;
+    public void regionByAccount(String i_account, CloudCallBeak<LoginUserRegionBean> cloudCallBeak) {
+        JsonObject jsonObject = new JsonObject();
+        jsonObject.addProperty("account", i_account);
+        String full = AppConfigManage.getAPPRegionUrl() + HttpApi.POST_RegionByUserAccount;
+        HttpClient.getInstance().requestFullHttp(full, jsonObject.toString(), true, true, new BaseSuccessFailureCallBeak() {
+            @Override
+            public void onSuccess(HttpResponsePack httpResponsePack) {
+                if (httpResponsePack != null && httpResponsePack.getData() != null) {
+                    Gson gson = new Gson();
+                    String json = gson.toJson(httpResponsePack.getData());
+                    LoginUserRegionBean loginUserRegionBean = new Gson().fromJson(json, LoginUserRegionBean.class);
+                    if (cloudCallBeak != null) {
+                        cloudCallBeak.onSuccess(loginUserRegionBean);
+                    }
+                }
+            }
+
+            @Override
+            public void onFailure(Exception exception) {
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onFailure(exception);
+                }
+            }
+        });
     }
 
     /**
-     * 鑾峰彇璐﹀彿鎵�鍦ㄥ尯鍩�
+     * 鐧诲綍(B绔处鍙�)
+     * 閫氳繃璐﹀彿鍜屽瘑鐮�
      *
-     * @param account
-     * @param callBack
-     * @return https://nearest.hdlcontrol.com/smart-footstone/region/regionByUserAccount
+     * @param account       鎵嬫満鎴栬�呴偖绠�
+     * @param loginPwd      瀵嗙爜
+     * @param cloudCallBeak -
      */
-//    public Disposable regionByAccount(String account, IRegionByAccountCallBack callBack) {
-//        String requestUrl = HDLLinkPMSdk.getInitUrl() + HttpApi.POST_RegionByUserAccount;
-//        return HxHttp.builder()
-//                .url(requestUrl)
-//                .params("account", account)
-//                .build()
-//                .post()
-//                .subscribeWith(new HDLResponse<HDLUserRegionBean>() {
-//                    @Override
-//                    public void onResponse(HDLUserRegionBean response) {
-//                        if (callBack != null) {
-//                            callBack.onSuccess(response);
-//                        }
-//                    }
-//
-//                    @Override
-//                    public void onFailure(HDLException e) {
-//                        HDLExceptionSubmitUtils.submit(requestUrl, account, e);
-//                        if (callBack != null) {
-//                            callBack.onFailure(e);
-//                        }
-//                    }
-//                });
+    public void loginByPassword(String account, String loginPwd, CloudCallBeak<LoginUserBean> cloudCallBeak) {
+        String requestUrl = HttpApi.POST_Login;
+        JsonObject json = new JsonObject();
+        json.addProperty("account", account);
+        json.addProperty("loginPwd", loginPwd);
+//        json.addProperty("platform", "APP");
+        json.addProperty("grantType", "password");
 
-//    }
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+            @Override
+            public void onSuccess(HttpResponsePack httpResponsePack) {
+                if (httpResponsePack != null && httpResponsePack.getData() != null) {
+                    Gson gson = new Gson();
+                    String json = gson.toJson(httpResponsePack.getData());
+                    LoginUserBean loginUserBean = new Gson().fromJson(json, LoginUserBean.class);
+                    saveUserData(loginUserBean);
+                    if (cloudCallBeak != null) {
+                        cloudCallBeak.onSuccess(loginUserBean);
+                    }
+                }
+            }
+
+            @Override
+            public void onFailure(Exception exception) {
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onFailure(exception);
+                }
+            }
+        });
+    }
+
+    /**
+     * 鍒锋柊Token(B绔处鍙�)
+     *
+     * @param account       鎵嬫満鎴栬�呴偖绠�
+     * @param loginPwd      瀵嗙爜
+     * @param cloudCallBeak -
+     */
+    public void refreshToken(String account, String loginPwd, CloudCallBeak<LoginUserBean> cloudCallBeak) {
+        String requestUrl = HttpApi.POST_Login;
+        JsonObject json = new JsonObject();
+        json.addProperty("grantType", "refresh_token");
+//        json.addProperty("refreshToken", UserConfigManage.getInstance().getRefreshToken());
+
+        HttpClient.getInstance().requestHttp(requestUrl, json.toString(), true, true, new BaseSuccessFailureCallBeak() {
+            @Override
+            public void onSuccess(HttpResponsePack httpResponsePack) {
+                if (httpResponsePack != null && httpResponsePack.getData() != null) {
+                    Gson gson = new Gson();
+                    String json = gson.toJson(httpResponsePack.getData());
+                    LoginUserBean loginUserBean = new Gson().fromJson(json, LoginUserBean.class);
+                    saveUserData(loginUserBean);
+                    if (cloudCallBeak != null) {
+                        cloudCallBeak.onSuccess(loginUserBean);
+                    }
+                }
+            }
+
+            @Override
+            public void onFailure(Exception exception) {
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onFailure(exception);
+                }
+            }
+        });
+    }
+
+
+    /**
+     * 閫�鍑虹櫥褰曟椂璋冪敤锛屾竻闄ゆ帹閫佹暟鎹�
+     */
+    public void SignOutClearData() {
+        String requestUrl = HttpApi.POST_GET_IMAGE_LOGOUT;
+        //閫氱煡浜戠锛屽凡缁忛��鍑虹櫥闄�
+    }
+
+    public boolean isPhone(String phone) {
+        Pattern p = Pattern.compile("^((13[0-9])|(14[0|5|6|7|9])|(15[0-3])|(15[5-9])|(16[6|7])|(17[2|3|5|6|7|8])|(18[0-9])|(19[1|8|9]))\\d{8}$");
+        Matcher m = p.matcher(phone);
+        return m.matches();
+    }
+
+    public boolean isMailbox(String mailbox) {
+        String regex = "^(\\w+([-.][A-Za-z0-9]+)*){3,18}@\\w+([-.][A-Za-z0-9]+)*\\.\\w+([-.][A-Za-z0-9]+)*$";
+        return mailbox.matches(regex);
+    }
+
+    /**
+     * 鐧诲綍鎴愬姛淇濆瓨鐧诲綍淇℃伅
+     */
+    private void saveUserData(LoginUserBean obj) {
+        if (obj != null) {
+            UserConfigManage.getInstance().setLogin(true);//鏄惁鐧诲綍
+            UserConfigManage.getInstance().setAcceiptPolicy(true);//鏄惁閫夋嫨闅愮鏀跨瓥
+            UserConfigManage.getInstance().setLoginDateTime(System.currentTimeMillis());//鐧诲綍鏃堕棿
+            UserConfigManage.getInstance().setUserId(obj.getUserId());//鐢ㄦ埛id
+            UserConfigManage.getInstance().setAccount(obj.getAccount());//璐﹀彿
+            UserConfigManage.getInstance().setToken(obj.getAccessToken());//Token
+            UserConfigManage.getInstance().setHeaderPrefix(obj.getHeaderPrefix());//璁よ瘉璇锋眰澶村墠缂�(搴曞眰璇锋眰缁熶竴鍔�)
+            UserConfigManage.getInstance().setRefreshToken(obj.getRefreshToken());//鍒锋柊Token鐢ㄧ殑鍒锋柊Token鐢ㄧ殑
+            boolean isUserId = UserConfigManage.getInstance().getUserId().equals(obj.getUserId());
+            UserConfigManage.getInstance().setTheSameLoginAccount(isUserId);//涓庝笂涓�涓处鍙锋槸鍚﹀悓涓�涓�
+        }
+
+    }
+
+
 }

--
Gitblit v1.8.0