OpenRewardController.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.Extensions.Options;
  8. using Microsoft.AspNetCore.Authorization;
  9. using System.Web;
  10. using MySystem.MainModels;
  11. using LitJson;
  12. using Library;
  13. namespace MySystem.Areas.Api.Controllers.v1.pos
  14. {
  15. [Area("Api")]
  16. [Route("Api/v1/pos/[controller]/[action]")]
  17. public class OpenRewardController : BaseController
  18. {
  19. public OpenRewardController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting)
  20. {
  21. }
  22. #region 首页-客小爽产品-收益查看-开机奖励
  23. [Authorize]
  24. public JsonResult StatList(string value)
  25. {
  26. value = DesDecrypt(value);
  27. JsonData data = JsonMapper.ToObject(value);
  28. List<Dictionary<string, object>> dataList = StatListDo(value);
  29. return Json(new AppResultJson() { Status = "1", Info = "", Data = dataList });
  30. }
  31. public List<Dictionary<string, object>> StatListDo(string value)
  32. {
  33. JsonData data = JsonMapper.ToObject(value);
  34. int UserId = int.Parse(function.CheckInt(data["UserId"].ToString())); //创客
  35. string ProductType = data["ProductType"].ToString(); //产品类型
  36. int Kind = int.Parse(function.CheckInt(data["Kind"].ToString()));
  37. int PageSize = int.Parse(function.CheckInt(data["PageSize"].ToString()));
  38. int PageNum = int.Parse(function.CheckInt(data["PageNum"].ToString()));
  39. string Date = Kind == 1 ? "Day" : "Month";
  40. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  41. List<string> query = RedisDbconn.Instance.GetList<string>("OpenReward" + Date + ":" + UserId + ":" + ProductType, PageNum, PageSize);
  42. foreach (var subdata in query)
  43. {
  44. Dictionary<string, object> curData = new Dictionary<string, object>();
  45. curData.Add("RewardAmount", RedisDbconn.Instance.Get<decimal>("OpenRewardAmt:" + UserId + ":" + ProductType + ":" + subdata)); //奖励金额
  46. if (Kind == 1)
  47. {
  48. curData.Add("Date", subdata.Substring(0, 4) + "年" + subdata.Substring(4, 2) + "月" + subdata.Substring(6, 2) + "日"); //激活时间
  49. }
  50. else
  51. {
  52. curData.Add("Date", subdata.Substring(0, 4) + "年" + subdata.Substring(4, 2) + "月"); //激活时间
  53. }
  54. curData.Add("DateValue", subdata); //激活时间值
  55. dataList.Add(curData);
  56. }
  57. return dataList;
  58. }
  59. #endregion
  60. #region 首页-客小爽产品-收益查看-开机奖励-详情
  61. [Authorize]
  62. public JsonResult StatDetail(string value)
  63. {
  64. value = DesDecrypt(value);
  65. JsonData data = JsonMapper.ToObject(value);
  66. List<Dictionary<string, object>> dataList = StatDetailDo(value);
  67. return Json(new AppResultJson() { Status = "1", Info = "", Data = dataList });
  68. }
  69. public List<Dictionary<string, object>> StatDetailDo(string value)
  70. {
  71. JsonData data = JsonMapper.ToObject(value);
  72. int UserId = int.Parse(function.CheckInt(data["UserId"].ToString())); //创客
  73. string ProductType = data["ProductType"].ToString(); //产品类型
  74. string PrizeDate = data["PrizeDate"].ToString(); //奖励时间
  75. int PageSize = int.Parse(function.CheckInt(data["PageSize"].ToString()));
  76. int PageNum = int.Parse(function.CheckInt(data["PageNum"].ToString()));
  77. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  78. List<OpenRewardDetail> query = RedisDbconn.Instance.GetList<OpenRewardDetail>("OpenRewardDetail:" + UserId + ":" + ProductType + ":" + PrizeDate, PageNum, PageSize);
  79. foreach (var subdata in query)
  80. {
  81. Dictionary<string, object> curData = new Dictionary<string, object>();
  82. curData.Add("RewardType", subdata.RewardType == 1 ? "开机直接奖励" : "开机间接奖励"); //奖励类型
  83. curData.Add("PrizeAmount", subdata.CreditRewardAmount); //奖励金额
  84. curData.Add("SnNo", subdata.SnNo); //SN号
  85. curData.Add("RealName", subdata.SeoTitle); //机具所属创客
  86. dataList.Add(curData);
  87. }
  88. return dataList;
  89. }
  90. #endregion
  91. #region 检查签名是否合法,合法返回1,不合法返回提示信息
  92. /// <summary>
  93. /// 检查签名是否合法,合法返回1,不合法返回提示信息
  94. /// </summary>
  95. /// <param name="value">请求的参数(json字符串)</param>
  96. /// <param name="signField">要签名的字段</param>
  97. /// <returns></returns>
  98. private string CheckSign(string value, string[] signField)
  99. {
  100. JsonData json = JsonMapper.ToObject(value);
  101. Dictionary<string, string> dic = new Dictionary<string, string>();
  102. for (int i = 0; i < signField.Length; i++)
  103. {
  104. dic.Add(signField[i], json[signField[i]].ToString());
  105. }
  106. string sign = json["sign"].ToString(); //客户端签名字符串
  107. return new Sign().sign(dic, sign);
  108. }
  109. #endregion
  110. }
  111. }