From d0d64cf47ce37027307ceb64dc72e3ae36796a92 Mon Sep 17 00:00:00 2001
From: zhangc <zc@123>
Date: 星期四, 27 二月 2025 18:28:00 +0800
Subject: [PATCH] 四期

---
 src/main/java/com/zy/common/web/BaseController.java |  164 ++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 140 insertions(+), 24 deletions(-)

diff --git a/src/main/java/com/zy/common/web/BaseController.java b/src/main/java/com/zy/common/web/BaseController.java
index a3f319e..3f0647c 100644
--- a/src/main/java/com/zy/common/web/BaseController.java
+++ b/src/main/java/com/zy/common/web/BaseController.java
@@ -7,7 +7,13 @@
 import com.core.common.Cools;
 import com.core.controller.AbstractBaseController;
 import com.core.exception.CoolException;
+import com.zy.asrs.entity.Node;
+import com.zy.asrs.entity.Tag;
+import com.zy.asrs.service.NodeService;
+import com.zy.asrs.service.TagService;
 import com.zy.system.entity.User;
+import com.zy.system.entity.UserLogin;
+import com.zy.system.service.UserLoginService;
 import com.zy.system.service.UserService;
 import io.swagger.annotations.ApiModelProperty;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -15,26 +21,35 @@
 import javax.servlet.http.HttpServletRequest;
 import java.lang.reflect.Field;
 import java.lang.reflect.Modifier;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
+import java.util.*;
 
 /**
  * Created by vincent on 2019-09-09
  */
 public class BaseController extends AbstractBaseController {
 
+    protected static final String RANGE_TIME_LINK = " - ";
+
     @Autowired
     protected HttpServletRequest request;
     @Autowired
     private UserService userService;
+    @Autowired
+    private TagService tagService;
+    @Autowired
+    private NodeService nodeService;
 
-    protected Long getUserId(){
+    @Autowired
+    private UserLoginService userLoginService;
+
+    protected Long getUserId() {
+        if (Cools.isEmpty(request.getAttribute("userId"))) {
+            return 000L;
+        }
         return Long.parseLong(String.valueOf(request.getAttribute("userId")));
     }
 
-    protected User getUser(){
+    protected User getUser() {
         User user = userService.selectById(getUserId());
         if (null == user) {
             throw new CoolException(BaseRes.DENIED);
@@ -42,21 +57,68 @@
         return user;
     }
 
-    protected String getComment(Class<?> cls, String fieldName){
+    protected String getComment(Class<?> cls, String fieldName) {
         Field[] fields = Cools.getAllFields(cls);
-        for (Field field : fields){
-            if (fieldName.equals(field.getName())){
+        for (Field field : fields) {
+            if (fieldName.equals(field.getName())) {
                 return field.getAnnotation(ApiModelProperty.class).value();
             }
         }
         return "";
     }
 
-    protected <T> Page<T> toPage(Integer curr, Integer limit, Map<String, Object> param){
-        Page<T> page = new Page<T>(curr, limit);
-        param.put("pageNumber", Integer.parseInt(String.valueOf(param.get("curr"))));
-        param.put("pageSize", Integer.parseInt(String.valueOf(param.get("limit"))));
-        page.setCondition(param);
+    protected Tag getOriginTag() {
+        return tagService.getTop();
+    }
+
+    protected Node getOriginNode() {
+        Node node = nodeService.getTop();
+        if (node == null) {
+            throw new CoolException("搴撳尯鏁版嵁閿欒");
+        }
+        return node;
+    }
+
+    /**
+     * 鍒嗛〉缁勮
+     * @param pageNumber
+     * @param pageSize
+     * @param map
+     * @param cls
+     * @param <T>
+     * @return
+     */
+    protected <T> Page<T> toPage(Integer pageNumber, Integer pageSize, Map<String, Object> map, Class<T> cls) {
+        // 鍒嗛〉绱㈠紩鍜屽崟椤垫暟閲忕粍瑁�
+        pageNumber = Optional.ofNullable(pageNumber).orElse(1);
+        pageSize = Optional.ofNullable(pageSize).orElse(10);
+        Page<T> page = new Page<>(pageNumber, pageSize);
+        map.put("pageNumber", pageNumber);
+        map.put("pageSize", pageSize);
+
+        // 鍏ㄥ瓧娈垫ā绯婃悳绱� todo
+        if (!Cools.isEmpty(map.get("condition"))) {
+            Set<String> columns = new HashSet<>();
+            for (Field field : Cools.getAllFields(cls)) {
+                if (Modifier.isFinal(field.getModifiers())
+                        || Modifier.isStatic(field.getModifiers())
+                        || Modifier.isTransient(field.getModifiers())) {
+                    continue;
+                }
+                String column = null;
+                if (field.isAnnotationPresent(TableField.class)) {
+                    column = field.getAnnotation(TableField.class).value();
+                }
+                if (Cools.isEmpty(column)) {
+                    column = field.getName();
+                }
+                if (!map.keySet().contains(column)) {
+                    columns.add(column);
+                }
+            }
+            columns.forEach(col -> map.put(col, map.get("condition")));
+        }
+        page.setCondition(map);
         return page;
     }
 
@@ -66,33 +128,36 @@
      * @param set 鎺掗櫎瀛楁闆嗗悎
      * @param condition 鎼滅储鍐呭
      */
-    protected <T> void allLike(Class<T> cls, Set<String> set, EntityWrapper<T> wrapper, String condition){
+    protected <T> void allLike(Class<T> cls, Set<String> set, EntityWrapper<T> wrapper, String condition) {
         if (Cools.isEmpty(condition)) {
             return;
         }
         List<String> columns = new ArrayList<>();
-        for (Field field :Cools.getAllFields(cls)){
+        for (Field field : Cools.getAllFields(cls)) {
             if (Modifier.isFinal(field.getModifiers())
                     || Modifier.isStatic(field.getModifiers())
-                    || Modifier.isTransient(field.getModifiers())){
+                    || Modifier.isTransient(field.getModifiers())) {
                 continue;
             }
             String column = null;
             if (field.isAnnotationPresent(TableField.class)) {
-                column = field.getAnnotation(TableField.class).value();
+                if (field.getAnnotation(TableField.class).exist()) {
+                    column = field.getAnnotation(TableField.class).value();
+                }
+            } else {
+                if (Cools.isEmpty(column)) {
+                    column = field.getName();
+                }
             }
-            if (Cools.isEmpty(column)) {
-                column = field.getName();
-            }
-            if (!set.contains(column)) {
+            if (!Cools.isEmpty(column) && !set.contains(column)) {
                 columns.add(column);
             }
         }
         if (columns.isEmpty()) {
             return;
         }
-        for (int i=0;i<columns.size();i++){
-            if (i==0){
+        for (int i = 0; i < columns.size(); i++) {
+            if (i == 0) {
                 wrapper.andNew();
             } else {
                 wrapper.or();
@@ -100,4 +165,55 @@
             wrapper.like(columns.get(i), condition);
         }
     }
+
+    public static boolean isJSON(String str) {
+        if (Cools.isEmpty(str)) {
+            return false;
+        } else {
+            str = str.trim();
+            if (str.startsWith("{") && str.endsWith("}")) {
+                return true;
+            } else if (str.startsWith("[") && str.endsWith("]")) {
+                return true;
+            } else {
+                return false;
+            }
+        }
+    }
+
+    protected <T> void hostEq(EntityWrapper<T> wrapper) {
+        Long hostId = getHostId();
+        if (hostId != null) {
+            wrapper.eq("host_id", hostId);
+        }
+    }
+
+    protected Long getHostId() {
+        if (getUserId() == 9527) {
+            return null;
+        }
+        User user = getUser();
+        if (user.getRoleId() == 1) {
+            String hostId = String.valueOf(request.getAttribute("hostId"));
+            if (Cools.isEmpty(hostId)) {
+                UserLogin userLogin = userLoginService.selectOne(new EntityWrapper<UserLogin>().eq("user_id", user.getId()));
+                if (userLogin != null) {
+                    //return userLogin.getHostId();
+                    return 1L;
+                }
+            }
+            return Long.parseLong(hostId);
+        } else {
+            return user.getHostId();
+        }
+    }
+
+    public static boolean isNumber(String str) {
+        for (int i = str.length(); --i >= 0; ) {
+            if (!Character.isDigit(str.charAt(i))) {
+                return false;
+            }
+        }
+        return true;
+    }
 }

--
Gitblit v1.9.1