From f8cc44e926fd22f9d1d864dc684c827f6960270b Mon Sep 17 00:00:00 2001
From: hjl <1657978663@qq.com>
Date: 星期五, 26 七月 2024 11:51:30 +0800
Subject: [PATCH] feat: 最新代码及配置

---
 ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/controller/UserController.java |  133 ++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 121 insertions(+), 12 deletions(-)

diff --git a/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/controller/UserController.java b/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/controller/UserController.java
index 2551710..7d0b568 100644
--- a/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/controller/UserController.java
+++ b/ruoyi-service/ruoyi-user/src/main/java/com/ruoyi/user/controller/UserController.java
@@ -24,6 +24,7 @@
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 
@@ -31,6 +32,7 @@
 import javax.servlet.http.HttpServletResponse;
 import java.util.HashMap;
 import java.util.List;
+import java.util.Map;
 
 /**
  * <p>
@@ -59,13 +61,40 @@
     private RecoveryServeService recoveryServeService;
 
     /**
+     * 用户端默认头像
+     */
+    @Value("${default.profilePicture}")
+    private String profilePicture;
+
+    /**
+     * 解密用户敏感数据
+     *
+     * @param encryptedData 明文,加密数据
+     * @param iv            加密算法的初始向量
+     * @param code          用户允许登录后,回调内容会带上 code(有效期五分钟),开发者需要将 code 发送到开发者服务器后台,使用code 换取 session_key api,将 code 换成 openid 和 session_key
+     * @return 登录信息
+     */
+    @ApiOperation("微信授权一键登录")
+    @GetMapping("/wxAuthorize")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "用户允许登录后回调内容code", name = "code", dataType = "String", required = true),
+            @ApiImplicitParam(value = "明文,加密数据", name = "encryptedData", dataType = "String", required = true),
+            @ApiImplicitParam(value = "加密算法的初始向量", name = "iv", dataType = "String", required = true)
+    })
+    public R<Map<String, Object>> decodeUserInfo(@RequestParam("code") String code,
+                                                 @RequestParam("encryptedData") String encryptedData,
+                                                 @RequestParam("iv") String iv) {
+        return R.ok(userService.decodeUserInfo(code, encryptedData, iv));
+    }
+
+    /**
      * 用户端-获取微信openId
      *
      * @param code 随机code
      */
     @ApiOperation(value = "获取微信openId", tags = {"用户端-登录"})
     @PostMapping(value = "/decodeOpenid")
-    public R<String> decodeOpenid(HttpServletResponse response, @RequestParam String code) {
+    public R<String> decodeOpenid(HttpServletResponse response, String code) {
         return userService.decodeOpenid(response, code);
     }
 
@@ -84,13 +113,13 @@
             // 手机验证码校验获取缓存验证码
             Object phoneCodeRedis = redisService.getCacheObject(RedisConstants.USER_LOGIN_PHONE_CODE + phone);
             if (null == phoneCodeRedis) {
-                return R.errorCode("登录失败,验证码已过期!");
+                return R.errorCode("验证码错误!");
             } else {
                 // redis 验证码的value 为 code:时间戳
                 String rCodeAndTime = String.valueOf(phoneCodeRedis);
                 String rCode = rCodeAndTime.split(":")[0];
                 if (!rCode.equalsIgnoreCase(phoneCode)) {
-                    return R.errorCode("登录失败,验证码无效!");
+                    return R.errorCode("验证码错误!");
                 }
             }
         }
@@ -106,7 +135,8 @@
             // 随机编号
             user.setUserNo(String.format(Constants.USER_NO_PRE, RandomUtil.randomNumbers(Constants.EIGHT)));
             user.setState(Constants.ONE);
-            user.setNickname(phone);
+            user.setProfilePicture(profilePicture);
+            user.setNickname(String.format(Constants.USER_NO_PRE, StringUtils.getCharAndNum(Constants.SIX)));
             user.setPhone(phone);
             user.setCity(loginPhoneRequest.getCity());
             user.setOpenId(loginPhoneRequest.getOpenId());
@@ -132,11 +162,15 @@
     @ApiImplicitParams({
             @ApiImplicitParam(value = "0:用户注册协议、1:用户隐私协议", name = "type", dataType = "Integer", required = true)
     })
-    public R<Agreement> recoverySearch(@RequestParam Integer type) {
-        if (!Constants.ZERO.equals(type) || !Constants.ONE.equals(type)) {
+    public R<Agreement> registerOrAgreement(@RequestParam Integer type) {
+        if (!Constants.ZERO.equals(type) && !Constants.ONE.equals(type)) {
             throw new GlobalException("获取类型异常!");
         }
-        return R.ok(adminClient.dataInfo(type).getData());
+        R<Agreement> r = adminClient.agreementPolicy(type);
+        if (500 == r.getCode()) {
+            return R.fail(r.getMsg());
+        }
+        return R.ok(r.getData());
     }
 
     /**
@@ -145,7 +179,29 @@
     @ApiOperation(value = "轮播图列表", tags = {"用户端-首页"})
     @GetMapping(value = "/banner")
     public R<List<Rotate>> banner() {
-        return R.ok(adminClient.bannerList().getData());
+        R<List<Rotate>> r = adminClient.bannerList();
+        List<Rotate> data = r.getData();
+        if (null == data) {
+            return R.fail(r.getMsg());
+        }
+        for (Rotate datum : data) {
+            RecoveryServe recoveryServe = recoveryServeService.lambdaQuery()
+                    .eq(RecoveryServe::getId, datum.getRotateServeId()).one();
+            if (null != recoveryServe) {
+                Integer classifyId = recoveryServe.getClassifyId();
+                RecoveryClassify classify = recoveryClassifyService.lambdaQuery()
+                        .eq(RecoveryClassify::getId, classifyId).one();
+                if (null != classify) {
+                    String supClassify = classify.getSupClassify();
+                    if (Constants.RECOVERY.equals(supClassify)) {
+                        datum.setType(Constants.ONE);
+                    } else {
+                        datum.setType(Constants.ZERO);
+                    }
+                }
+            }
+        }
+        return R.ok(data);
     }
 
     /**
@@ -155,6 +211,15 @@
     @GetMapping(value = "/notice")
     public R<List<Notices>> notice() {
         return R.ok(adminClient.noticesList().getData());
+    }
+
+    /**
+     * 用户端-通知公告详情
+     */
+    @ApiOperation(value = "通知公告详情", tags = {"用户端-首页"})
+    @GetMapping(value = "/noticeDetail")
+    public R<Notices> notice(@RequestParam Integer id) {
+        return R.ok(adminClient.noticesDetail(id).getData());
     }
 
     /**
@@ -182,7 +247,8 @@
     @ApiOperation(value = "首页回收分类推荐", tags = {"用户端-首页"})
     public R<List<RecoveryClassify>> recommend() {
         return R.ok(recoveryClassifyService.lambdaQuery().eq(RecoveryClassify::getIsRecommend, Constants.ONE)
-                .eq(RecoveryClassify::getIsDelete, 0).orderByAsc(RecoveryClassify::getOrder).list());
+                .eq(RecoveryClassify::getIsDelete, 0).orderByDesc(RecoveryClassify::getSort)
+                .orderByDesc(RecoveryClassify::getCreateTime).list());
     }
 
     /**
@@ -196,9 +262,22 @@
     public R<List<RecoveryServe>> recoverySearch(@RequestParam String keyword) {
         LambdaQueryChainWrapper<RecoveryServe> wrapper = recoveryServeService.lambdaQuery()
                 .eq(RecoveryServe::getIsDelete, 0)
-                .orderByAsc(RecoveryServe::getSort);
-        wrapper = StringUtils.isNotBlank(keyword) ? wrapper.like(RecoveryServe::getServeName, keyword) : wrapper;
-        return R.ok(wrapper.list());
+                .orderByDesc(RecoveryServe::getSort);
+        wrapper = null != keyword && !"".equals(keyword.trim()) ?
+                wrapper.like(RecoveryServe::getServeName, keyword) : wrapper;
+        List<RecoveryServe> serveList = wrapper.orderByDesc(RecoveryServe::getCreateTime).list();
+        for (RecoveryServe recoveryServe : serveList) {
+            RecoveryClassify classify = recoveryClassifyService.lambdaQuery()
+                    .eq(RecoveryClassify::getId, recoveryServe.getClassifyId()).one();
+            if (null != classify) {
+                if (Constants.RECOVERY.equals(classify.getSupClassify())) {
+                    recoveryServe.setType(Constants.ONE);
+                } else {
+                    recoveryServe.setType(Constants.ZERO);
+                }
+            }
+        }
+        return R.ok(serveList);
     }
 
     /**
@@ -215,4 +294,34 @@
                 .eq(User::getIsDelete, 0).one());
     }
 
+    /**
+     * 用户端-修改头像&昵称
+     */
+    @ApiOperation(value = "修改头像&昵称", tags = {"用户端-个人中心"})
+    @GetMapping(value = "/updateInfo")
+    public R<Boolean> updateInfo(@RequestParam String picture, @RequestParam String nickname) {
+        LoginUserInfo loginUser = tokenService.getLoginUserByUser();
+        if (null == loginUser) {
+            return R.loginExpire("登录失效!");
+        }
+        return R.ok(userService.lambdaUpdate().eq(User::getId, loginUser.getUserid())
+                .set(User::getProfilePicture, picture)
+                .set(User::getNickname, nickname).update());
+    }
+
+    /**
+     * 用户端-修改用户定位城市
+     */
+    @ApiOperation(value = "修改用户定位城市", tags = {"用户端-个人中心"})
+    @GetMapping(value = "/updateCity")
+    public R<Boolean> updateCity(@RequestParam String city, @RequestParam String cityCode) {
+        LoginUserInfo loginUser = tokenService.getLoginUserByUser();
+        if (null == loginUser) {
+            return R.loginExpire("登录失效!");
+        }
+        return R.ok(userService.lambdaUpdate().eq(User::getId, loginUser.getUserid())
+                .set(User::getCity, city)
+                .set(User::getCityCode, cityCode).update());
+    }
+
 }

--
Gitblit v1.7.1