From 131a0d2dfa1061811567deed40b1036204703b8d Mon Sep 17 00:00:00 2001 From: luodangjia <luodangjia> Date: 星期五, 29 十一月 2024 14:02:27 +0800 Subject: [PATCH] 11.29 --- ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/AppUserController.java | 181 +++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 167 insertions(+), 14 deletions(-) diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/AppUserController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/AppUserController.java index 68fb379..4046e93 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/AppUserController.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/AppUserController.java @@ -1,34 +1,187 @@ package com.ruoyi.account.controller; +import java.time.LocalDateTime; + import com.ruoyi.account.api.model.AppUser; -import com.ruoyi.account.service.IAppUserService; +import com.ruoyi.account.api.model.UserCancellationLog; +import com.ruoyi.account.service.AppUserService; +import com.ruoyi.account.service.UserCancellationLogService; +import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.security.service.TokenService; +import com.ruoyi.other.api.domain.Shop; +import com.ruoyi.other.api.feignClient.StoreClient; +import org.junit.Test; import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiOperation; + +import javax.annotation.Resource; +import java.util.List; +import com.ruoyi.account.api.model.AppUser; +import com.ruoyi.account.service.AppUserService; +import com.ruoyi.account.vo.*; +import com.ruoyi.common.core.web.domain.AjaxResult; +import io.swagger.annotations.Api; +import io.swagger.annotations.ApiImplicitParam; +import io.swagger.annotations.ApiImplicitParams; +import io.swagger.annotations.ApiOperation; +import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; /** - * @author zhibing.pu - * @Date 2024/11/21 9:47 + * <p> + * 前端控制器 + * </p> + * + * @author luodangjia + * @since 2024-11-21 */ +@Api(tags = {"登录注册-小程序"}) @RestController -@RequestMapping("/appUser") +@RequestMapping("/app-user") public class AppUserController { + + @Resource - private IAppUserService appUserService; + private TokenService tokenService; + @Resource + private AppUserService appUserService; + @Resource + private StoreClient storeClient; + + + + @ResponseBody + @PostMapping("/appletLogin") + @ApiOperation(value = "小程序一键登录") + public AjaxResult<LoginVo> appletLogin(@RequestBody AppletLogin appletLogin){ + return appUserService.appletLogin(appletLogin); + } - /** - * 根据id获取用户信息 - * @param id - * @return - */ - @PostMapping("/getAppUserById") - public AppUser getAppUserById(@RequestParam("id") Long id){ - return appUserService.getById(id); + @ResponseBody + @PostMapping("/mobileLogin") + @ApiOperation(value = "手机号登录") + public AjaxResult<LoginVo> mobileLogin(@RequestBody MobileLogin mobileLogin){ + return appUserService.mobileLogin(mobileLogin); + } + + + + @ResponseBody + @PostMapping("/getSMSCode") + @ApiOperation(value = "获取短信验证码") + public AjaxResult getSMSCode(@RequestBody SMSCode smsCode){ + return appUserService.getSMSCode(smsCode); } + + + @ResponseBody + @PostMapping("/registerAccount") + @ApiOperation(value = "注册新账号") + public AjaxResult<LoginVo> registerAccount(@RequestBody RegisterAccount registerAccount){ + return appUserService.registerAccount(registerAccount); + } + + + @ResponseBody + @GetMapping("/getReferrer/{id}") + @ApiOperation(value = "获取推荐人信息") + @ApiImplicitParams({ + @ApiImplicitParam(name = "id", value = "推荐人id", required = true, dataType = "long") + }) + public AjaxResult<String> getReferrer(@PathVariable("id") Long id){ + AppUser appUser = appUserService.getById(id); + String phone = appUser.getPhone(); + phone = phone.substring(0, 3) + "****" + phone.substring(7); + return AjaxResult.success(appUser.getName() + "-" + phone); + } + + + + @ResponseBody + @GetMapping("/getNearbyReferrer") + @ApiOperation(value = "获取附近推荐人列表") + public AjaxResult<BaseTable<NearbyReferrerVo>> getNearbyReferrer(NearbyReferrer nearbyReferrer){ + BaseTable<NearbyReferrerVo> baseTable = appUserService.getNearbyReferrer(nearbyReferrer); + return AjaxResult.success(baseTable); + } + + + @ResponseBody + @PostMapping("/info") + @ApiOperation(value = "我的资料", tags = {"小程序-个人中心首页-我的资料"}) + public R<AppUser> info(){ + Long userId = tokenService.getLoginUserApplet().getUserid(); + AppUser user = appUserService.getById(userId); + return R.ok(user); + } + @Resource + private UserCancellationLogService userCancellationLogService; + + @ResponseBody + @PostMapping("/unregis") + @ApiOperation(value = "注销", tags = {"小程序-个人中心首页-我的资料"}) + public R unregis(){ + Long userId = tokenService.getLoginUserApplet().getUserid(); + AppUser user = appUserService.getById(userId); + + //添加注销记录 + UserCancellationLog userCancellationLog = new UserCancellationLog(); + userCancellationLog.setAppUserId(user.getId()); + userCancellationLog.setVipId(user.getVipId()); + userCancellationLogService.save(userCancellationLog); + + + return R.ok(); + } + + + @PostMapping("/index") + @ApiOperation(value = "个人中心首页", tags = {"小程序-个人中心首页"}) + public R<AppUser> index(){ + System.err.println("=-===="); + Long userId = tokenService.getLoginUserApplet().getUserid(); + //当前用户信息 + AppUser user = appUserService.getById(userId); + //当前用户的推荐人信息 + if (user.getInviteUserId()!=null){ + AppUser inviteUser = appUserService.getById(user.getInviteUserId()); + user.setInviteUserName(inviteUser.getName()); + } + //当前绑定门店的店铺信息 + if (user.getShopId()!=null){ + R<Shop> storeById = storeClient.getStoreById(user.getShopId()); + if (storeById.getData()!=null){ + user.setShopName(storeById.getData().getName()); + } + } + Long count1 = appUserService.lambdaQuery().eq(AppUser::getVipId, 1).eq(AppUser::getTopInviteId, 1).count(); + Long count2 = appUserService.lambdaQuery().eq(AppUser::getVipId, 2).eq(AppUser::getTopInviteId, userId).count(); + Long count3 = appUserService.lambdaQuery().eq(AppUser::getVipId, 3).eq(AppUser::getTopInviteId, userId).count(); + Long count4 = appUserService.lambdaQuery().eq(AppUser::getVipId, 4).eq(AppUser::getTopInviteId, userId).count(); + Long count5 = appUserService.lambdaQuery().eq(AppUser::getVipId, 5).eq(AppUser::getTopInviteId, userId).count(); + Long count6 = appUserService.lambdaQuery().eq(AppUser::getVipId, 6).eq(AppUser::getTopInviteId, userId).count(); + Long count7 = appUserService.lambdaQuery().eq(AppUser::getVipId, 7).eq(AppUser::getTopInviteId, userId).count(); + user.setCount1(count1); + user.setCount2(count2); + user.setCount3(count3); + user.setCount4(count4); + user.setCount5(count5); + user.setCount6(count6); + user.setCount7(count7); + return R.ok(user); + + + } + + + } + -- Gitblit v1.7.1