package controller import ( "crypto/md5" "encoding/hex" "fmt" "github.com/gin-gonic/gin" "hepa-calc-admin-api/api/dao" "hepa-calc-admin-api/api/dto" "hepa-calc-admin-api/api/requests" "hepa-calc-admin-api/api/responses" "hepa-calc-admin-api/config" "hepa-calc-admin-api/extend/aliyun" "hepa-calc-admin-api/global" "hepa-calc-admin-api/utils" "math" "sort" "time" ) type Public struct{} // Login 登陆 func (b *Public) Login(c *gin.Context) { publicRequest := requests.PublicRequest{} req := publicRequest.Login if err := c.ShouldBind(&req); err != nil { responses.FailWithMessage(err.Error(), c) return } // 参数验证 if err := global.Validate.Struct(req); err != nil { responses.FailWithMessage(utils.Translate(err), c) return } if err := c.ShouldBind(&req); err != nil { responses.FailWithMessage(err.Error(), c) return } // 验证验证码 if config.C.Env == "prod" { isValid := utils.VerifyCaptcha(req.CaptchaId, req.Captcha) if !isValid { // 验证码错误 responses.FailWithMessage("验证码错误", c) return } } // 获取用户信息 AdminUserDao := dao.AdminUserDao{} maps := make(map[string]interface{}) maps["access"] = req.Access adminUser, err := AdminUserDao.GetAdminUser(maps) if err != nil || adminUser == nil { responses.FailWithMessage("用户名或密码错误", c) return } // 检测用户密码 password := md5.Sum([]byte(req.Password + adminUser.Salt)) // 将哈希值转换为16进制字符串 passwordString := hex.EncodeToString(password[:]) fmt.Println(passwordString) if passwordString != adminUser.Password { responses.FailWithMessage("用户名或密码错误", c) return } // 检测用户状态 if adminUser.IsDeleted == 1 { responses.FailWithMessage("非法用户", c) return } if adminUser.IsDisabled == 1 { responses.FailWithMessage("您的账号已被禁用,请联系管理员处理", c) return } // 下发token token := &utils.Token{ UserId: fmt.Sprintf("%d", adminUser.UserId), } // 生成jwt jwt, err := token.NewJWT() if err != nil || jwt == "" { responses.FailWithMessage("登陆失败", c) return } g := dto.AdminLoginDto(adminUser) g.LoadToken(jwt) responses.OkWithData(g, c) } // GetCaptcha 获取验证码 func (b *Public) GetCaptcha(c *gin.Context) { id, b64s, err := utils.GenerateCaptcha() if err != nil { responses.FailWithMessage("验证码获取失败", c) } responses.OkWithData(gin.H{ "id": id, "b64s": b64s, }, c) } // GetIndex 首页 func (b *Public) GetIndex(c *gin.Context) { userDao := dao.UserDao{} questionDao := dao.QuestionDao{} orderMemberDao := dao.OrderMemberDao{} orderSingleDao := dao.OrderSingleDao{} // 获取问题数量 maps := make(map[string]interface{}) maps["question_status"] = 1 questionCount, err := questionDao.GetQuestionCount(maps) if err != nil { questionCount = 0 } // 获取用户数量 maps = make(map[string]interface{}) userCount, err := userDao.GetUserCount(maps) if err != nil { questionCount = 0 } // 获取有效会员数 maps = make(map[string]interface{}) maps["user_status"] = 1 maps["is_member"] = 1 validMemberCount, err := userDao.GetUserCount(maps) if err != nil { validMemberCount = 0 } // 获取问题总提交次数 maps = make(map[string]interface{}) questionSubmitCount, err := questionDao.GetQuestionSum(maps, "submit_count") if err != nil { questionSubmitCount = 0 } // 获取问题总支付次数 maps = make(map[string]interface{}) questionPayCount, err := questionDao.GetQuestionSum(maps, "pay_count") if err != nil { questionPayCount = 0 } // 获取会员购买次数 maps = make(map[string]interface{}) maps["order_status"] = 2 maps["pay_status"] = 2 maps["refund_status"] = 0 maps["cancel_status"] = 0 memberBuyCount, err := orderMemberDao.GetOrderMemberCount(maps) if err != nil { memberBuyCount = 0 } // 获取会员购买总金额 maps = make(map[string]interface{}) maps["order_status"] = 2 maps["pay_status"] = 2 maps["refund_status"] = 0 maps["cancel_status"] = 0 memberAmountTotal, err := orderMemberDao.GetOrderMemberSum(maps, "payment_amount_total") if err != nil { memberAmountTotal = 0 } // 获取会员购买总金额 maps = make(map[string]interface{}) maps["order_status"] = 2 maps["pay_status"] = 2 maps["refund_status"] = 0 maps["cancel_status"] = 0 singleAmountTotal, err := orderSingleDao.GetOrderSingleSum(maps, "payment_amount_total") if err != nil { singleAmountTotal = 0 } g := dto.IndexDto{ QuestionCount: questionCount, UserCount: userCount, ValidMemberCount: validMemberCount, QuestionSubmitCount: int64(questionSubmitCount), QuestionPayCount: int64(questionPayCount), MemberBuyCount: memberBuyCount, MemberAmountTotal: memberAmountTotal, SingleAmountTotal: singleAmountTotal, AmountTotal: math.Round((memberAmountTotal+singleAmountTotal)*100) / 100, } responses.OkWithData(g, c) } // GetIndexData 首页动态统计数据 func (b *Public) GetIndexData(c *gin.Context) { publicRequest := requests.PublicRequest{} req := publicRequest.GetIndexData if err := c.ShouldBind(&req); err != nil { responses.FailWithMessage(err.Error(), c) return } // 参数验证 if err := global.Validate.Struct(req); err != nil { responses.FailWithMessage(utils.Translate(err), c) return } if err := c.ShouldBind(&req); err != nil { responses.FailWithMessage(err.Error(), c) return } // 返回值 g := make([]*dto.IndexDataDto, 0) results := make(map[string]int64) // 分类(1:新增用户数 2:新增算算次数 3:新增单项支付数 4:新增会员购买数) if req.Type == 1 { // 新增用户数 endTime, _ := time.Parse("2006-01-02", req.EndTime) req.EndTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second).Format("2006-01-02 15:04:05") userDao := dao.UserDao{} maps := make(map[string]interface{}) users, err := userDao.GetUserListByTime(maps, req.StartTime, req.EndTime, "created_at") if err != nil { responses.FailWithMessage(err.Error(), c) return } for _, user := range users { date := time.Time(user.CreatedAt).Format("2006-01-02") results[date]++ } } // 新增算算数 if req.Type == 2 { endTime, _ := time.Parse("2006-01-02", req.EndTime) req.EndTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second).Format("2006-01-02 15:04:05") questionDao := dao.QuestionDao{} maps := make(map[string]interface{}) maps["question_status"] = 1 questions, err := questionDao.GetQuestionListByTime(maps, req.StartTime, req.EndTime, "created_at") if err != nil { responses.FailWithMessage(err.Error(), c) return } for _, question := range questions { date := time.Time(question.CreatedAt).Format("2006-01-02") results[date]++ } } // 新增单项支付数 if req.Type == 3 { endTime, _ := time.Parse("2006-01-02", req.EndTime) req.EndTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second).Format("2006-01-02 15:04:05") orderSingleDao := dao.OrderSingleDao{} maps := make(map[string]interface{}) maps["order_status"] = 2 maps["pay_status"] = 2 maps["refund_status"] = 0 maps["cancel_status"] = 0 orderSingles, err := orderSingleDao.GetOrderSingleListByTime(maps, req.StartTime, req.EndTime, "pay_time") if err != nil { responses.FailWithMessage(err.Error(), c) return } for _, orderSingle := range orderSingles { payTime := time.Time(*orderSingle.PayTime) date := payTime.Format("2006-01-02") results[date]++ } } // 新增会员购买数 if req.Type == 4 { endTime, _ := time.Parse("2006-01-02", req.EndTime) req.EndTime = endTime.Add(23*time.Hour + 59*time.Minute + 59*time.Second).Format("2006-01-02 15:04:05") orderMemberDao := dao.OrderMemberDao{} maps := make(map[string]interface{}) maps["order_status"] = 2 maps["pay_status"] = 2 maps["refund_status"] = 0 maps["cancel_status"] = 0 orderMembers, err := orderMemberDao.GetOrderMemberListByTime(maps, req.StartTime, req.EndTime, "pay_time") if err != nil { responses.FailWithMessage(err.Error(), c) return } for _, orderMember := range orderMembers { payTime := time.Time(*orderMember.PayTime) date := payTime.Format("2006-01-02") results[date]++ } } // 提取 map 的键 keys := make([]string, 0, len(results)) for key := range results { keys = append(keys, key) } // 对键进行排序 sort.Strings(keys) for _, k := range keys { response := &dto.IndexDataDto{ Date: k, Count: results[k], } g = append(g, response) } responses.OkWithData(g, c) } // GetOssSign 获取oss签名 func (b *Public) GetOssSign(c *gin.Context) { publicRequest := requests.PublicRequest{} req := publicRequest.GetOssSign if err := c.ShouldBind(&req); err != nil { responses.FailWithMessage(err.Error(), c) return } // 参数验证 if err := global.Validate.Struct(req); err != nil { responses.FailWithMessage(utils.Translate(err), c) return } // 获取oss签名 dir := "basic/calss/" // 生成签名 ossSign, err := aliyun.GetOssSign(dir) if err != nil { responses.FailWithMessage("获取签名失败", c) return } responses.OkWithData(ossSign, c) }