From e863d3485d077c90988c81a756b37ef21cf4962e Mon Sep 17 00:00:00 2001
From: 44323 <443237572@qq.com>
Date: 星期五, 17 十一月 2023 20:16:01 +0800
Subject: [PATCH] 后台bug修改

---
 cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java |  195 ++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 176 insertions(+), 19 deletions(-)

diff --git a/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java b/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java
index 52181c6..6e8911b 100644
--- a/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java
+++ b/cloud-server-other/src/main/java/com/dsh/other/controller/SiteController.java
@@ -4,10 +4,9 @@
 import cn.hutool.http.HttpResponse;
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.dsh.other.entity.Site;
-import com.dsh.other.entity.SiteBooking;
-import com.dsh.other.entity.SiteType;
+import com.dsh.other.entity.*;
 import com.dsh.other.feignclient.account.CityManagerClient;
 import com.dsh.other.feignclient.activity.UserCouponClient;
 import com.dsh.other.feignclient.activity.model.QueryUserCouponByIdAndUserId;
@@ -19,24 +18,23 @@
 import com.dsh.other.model.dto.siteDto.TSiteDTO;
 import com.dsh.other.model.vo.siteVo.ExpireSiteSearchVO;
 import com.dsh.other.model.vo.siteVo.SiteSearchVO;
-import com.dsh.other.service.ISiteBookingService;
-import com.dsh.other.service.ISiteService;
-import com.dsh.other.service.ISiteTypeService;
-import com.dsh.other.util.PayMoneyUtil;
-import com.dsh.other.util.ResultUtil;
-import com.dsh.other.util.TokenUtil;
+import com.dsh.other.service.*;
+import com.dsh.other.util.*;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.web.bind.annotation.*;
+import redis.clients.jedis.Jedis;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
 import java.io.PrintWriter;
+import java.text.SimpleDateFormat;
 import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * @author zhibing.pu
@@ -113,12 +111,13 @@
      * @return
      */
     @RequestMapping("/base/site/addSite")
-    public Object addSite(@RequestBody Site site){
+    public Integer addSite(@RequestBody Site site){
         if(site.getId()!= null ){
-
-            return siteService.updateById(site);
+            siteService.updateById(site);
+            return site.getId();
         }else {
-            return siteService.save(site);
+            boolean save = siteService.save(site);
+            return site.getId();
         }
     }
 
@@ -200,7 +199,8 @@
         }
     }
 
-
+    @Autowired
+    private RedisUtil redisUtil;
 
     @ResponseBody
     @PostMapping("/base/site/querySiteTimes")
@@ -208,16 +208,34 @@
     @ApiImplicitParams({
             @ApiImplicitParam(value = "场地id", name = "id", dataType = "int", required = true),
             @ApiImplicitParam(value = "日期(2023-01-01)", name = "day", dataType = "string", required = true),
+            @ApiImplicitParam(value = "半场名称", name = "halfName", dataType = "string", required = false),
+            @ApiImplicitParam(value = "选择场地的名称", name = "siteName", dataType = "string", required = false)
     })
-    public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day){
+    public  ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day,String halfName,String siteName){
         try {
-            List<QuerySiteTimes> list = siteService.querySiteTimes(id, day);
+            List<QuerySiteTimes> list = siteService.querySiteTimes(id, day,halfName,siteName);
             return ResultUtil.success(list);
         }catch (Exception e){
             e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
+
+//    public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day, String halfName, String siteName) throws Exception {
+//
+//        if (redisUtil.acquireLock(day,day)) {
+//            try {
+//                List<QuerySiteTimes> list = siteService.querySiteTimes(id, day,halfName,siteName);
+//            return ResultUtil.success(list);
+//            } finally {
+//                redisUtil.releaseLock(day);
+//            }
+//        } else {
+//            return ResultUtil.error("系统繁忙,请稍后再试!");
+//        }
+//
+//    }
+
 
 
     /**
@@ -257,6 +275,22 @@
         }
     }
 
+//        public ResultUtil<List<QuerySiteTimes>> querySiteTimes(Integer id, String day, String halfName, String siteName) throws Exception {
+//
+//        if (redisUtil.acquireLock(day,day)) {
+//            try {
+//                List<QuerySiteTimes> list = siteService.querySiteTimes(id, day,halfName,siteName);
+//            return ResultUtil.success(list);
+//            } finally {
+//                redisUtil.releaseLock(day);
+//            }
+//        } else {
+//            return ResultUtil.error("系统繁忙,请稍后再试!");
+//        }
+//
+//    }
+
+
     /**
      * 购买课程微信支付回调
      * @param request
@@ -290,7 +324,7 @@
 
 
     /**
-     * 购买课程支付宝回调
+     * 预约场地支付宝回调
      * @param request
      * @param response
      */
@@ -298,6 +332,7 @@
     @PostMapping("/base/site/aliPaymentSiteCallback")
     public void aliPaymentSiteCallback(HttpServletRequest request, HttpServletResponse response){
         try {
+            System.out.println("回调回调回调");
             Map<String, String> map = payMoneyUtil.alipayCallback(request);
             if(null != map){
                 String code = map.get("out_trade_no");
@@ -320,6 +355,60 @@
     }
 
 
+    /**
+     * 启动游戏支付宝回调
+     * @param request
+     * @param response
+     */
+    @ResponseBody
+    @PostMapping("/base/site/gameCallback")
+    public void gameCallback(HttpServletRequest request, HttpServletResponse response){
+        try {
+            System.out.println("回调回调回调");
+            Map<String, String> map = payMoneyUtil.alipayCallback(request);
+            if(null != map){
+
+                String code = map.get("passback_params");
+//                String trade_no = map.get("trade_no");
+//                SiteBooking siteBooking = siteBookingService.getOne(new QueryWrapper<SiteBooking>().eq("orderNo", code).eq("state", 1));
+//                if(siteBooking.getStatus() == 0){
+//                    siteBooking.setPayTime(new Date());
+//                    siteBooking.setStatus(1);
+//                    siteBooking.setPayOrderNo(trade_no);
+//                    siteBookingService.updateById(siteBooking);
+//                }
+
+                String[] s = code.split("_");
+                Integer i = startGame(Integer.valueOf(s[0]), Integer.valueOf(s[1]), Integer.valueOf(s[2]), Integer.valueOf(s[3]));
+                System.err.println("===========游戏回调游戏回调========="+i);
+                PrintWriter out = response.getWriter();
+                out.write("success");
+                out.flush();
+                out.close();
+            }
+        }catch (Exception e){
+            e.printStackTrace();
+        }
+    }
+
+
+    private static Integer startGame(Integer uid,Integer gameId,Integer spaceId,Integer sutuId){
+        HashMap<String, String> map = new HashMap<>();
+        map.put("sign","0DB011836143EEE2C2E072967C9F4E4B");
+        map.put("app_user_id",uid+"");
+        map.put("game_id",gameId+"");
+        map.put("space_id",spaceId+"");
+        map.put("sutu_id",sutuId+"");
+
+        String s = HttpRequestUtil.postRequest("https://try.daowepark.com/v7/user_api/general/gameStart", map);
+        JSONObject jsonObject = JSONObject.parseObject(s);
+        Object code = jsonObject.get("code");
+        if(String.valueOf(code)!=null && "200".equals(String.valueOf(code))){
+            return 200;
+        }else {
+            return 500;
+        }
+    }
 
 
     @ResponseBody
@@ -355,8 +444,43 @@
         try {
             HashMap<String, Object> map = new HashMap<>();
             SiteBooking byId = siteBookingService.getById(id);
+            Integer storeId = byId.getStoreId();
+            Store byId1 = service.getById(storeId);
+            Site site = siteService.getById(byId.getSiteId());
+            map.put("siteName",byId1.getName());
+            SiteType siteType = siteTypeService.getById(site.getSiteTypeId());
+            map.put("siteType",siteType.getName());
+            map.put("shopName",byId1.getName());
+            map.put("shopAddress",byId1.getAddress());
+
+            map.put("name",site.getName());
+
+
+
             List<Integer> ids = getIds(byId.getSiteId());
+            byId.setStorePhone(byId1.getPhone());
+            
+            //拼接开始结束时间
+            Date startTime = byId.getStartTime();
+            Date endTime = byId.getEndTime();
+            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm");
+
+            String startTimeString = sdf.format(startTime);
+            String endTimeString = sdf.format(endTime);
+
+            String result = startTimeString + "-" + endTimeString.substring(11);
+            byId.setTimes(result);
+
+
+
+
+            byId.setSid(Arrays.asList(storeId));
+            List<Site> list = siteService.list(new LambdaQueryWrapper<Site>().eq(Site::getStoreId, storeId).eq(Site::getSign, 1));
+            List<Integer> collect = list.stream().map(Site::getId).collect(Collectors.toList());
+            byId.setRid(collect);
             map.put("data",byId);
+
+
             map.put("ids",ids);
             return ResultUtil.success(map);
         }catch (Exception e){
@@ -527,13 +651,46 @@
     }
 
 
+    @Autowired
+   private StoreService service;
+
+    @Autowired
+    private IOperatorUserService operatorUserService;
+
+
+    @ResponseBody
+    @PostMapping("/base/site/game")
+    public List<Map<String, Object>> game(@RequestBody Integer appUserId){
+        return service.game(appUserId);
+
+    }
+
+
+    @ResponseBody
+    @PostMapping("/base/site/counts")
+    public Integer counts(@RequestBody Integer stuId){
+        return siteBookingService.count(new QueryWrapper<SiteBooking>().eq("appUserId",stuId));
+
+    }
+
+    @ResponseBody
+    @PostMapping("/base/site/queryOperator")
+    public OperatorUser queryOperator(@RequestBody List<Integer> stores){
+
+        Store one = service.getOne(new QueryWrapper<Store>().in("id", stores));
+        OperatorUser o = operatorUserService.getById(one.getOperatorId());
+
+        return o;
+    }
+
+
 
     @ResponseBody
     @PostMapping("/base/site/getNewAddSiteList")
-    public List<SiteVo> getAppUserSiteList(){
+    public List<SiteVo> getAppUserSiteList(@RequestBody Integer storeId){
         List<SiteVo> siteVos = new ArrayList<>();
 
-        List<Site> list = siteService.list(new QueryWrapper<Site>()
+        List<Site> list = siteService.list(new QueryWrapper<Site>().eq("state",1).eq("storeId",storeId)
                 .orderByDesc("insertTime"));
         if (list.size() > 0 ){
             for (Site site : list) {

--
Gitblit v1.7.1