EmailProc.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. 
  2. using Newtonsoft.Json.Linq;
  3. using System;
  4. using System.Diagnostics;
  5. using CSharpUtil.Extensions.Time;
  6. namespace BossServer.server
  7. {
  8. /// <summary>
  9. /// 邮件类型枚举
  10. /// </summary>
  11. public enum EMailType
  12. {
  13. /// <summary>
  14. /// 系统邮件
  15. /// </summary>
  16. SystemMail = 1,
  17. /// <summary>
  18. /// 好友雇佣
  19. /// </summary>
  20. [Obsolete]
  21. HireCoin,
  22. /// <summary>
  23. /// PVP阶段奖励
  24. /// </summary>
  25. [Obsolete]
  26. PvpLeagueReward,
  27. /// <summary>
  28. /// pvp上榜奖励
  29. /// </summary>
  30. PvpRankReward,
  31. /// <summary>
  32. /// 公会申请被拒
  33. /// </summary>
  34. [Obsolete]
  35. GuildApplyRefuse,
  36. /// <summary>
  37. /// 公会捐献结算
  38. /// </summary>
  39. [Obsolete]
  40. GuildDonateSettle,
  41. /// <summary>
  42. /// 公会钻石礼包
  43. /// </summary>
  44. [Obsolete]
  45. GuildCashGiftReward,
  46. /// <summary>
  47. /// 公会公告/通知邮件
  48. /// </summary>
  49. [Obsolete]
  50. GuildNotice
  51. }
  52. /// <summary>
  53. /// 邮件发送功能
  54. /// </summary>
  55. class EmailProc
  56. {
  57. /// <summary>
  58. /// 邮件最大容量100封
  59. /// </summary>
  60. internal const int MaxMailContent = 100;
  61. /// <summary>
  62. /// 邮件最大过期时间7天
  63. /// </summary>
  64. internal const int MaxMailExpireTs = 604800;
  65. /// <summary>
  66. /// Mysql邮件日志表
  67. /// </summary>
  68. const string MailLog_TableName = "tab_mailrecord";
  69. /// <summary>
  70. /// 系统邮件 - 发送世界boss战奖励邮件
  71. /// </summary>
  72. /// <param name="zoneid"></param>
  73. /// <param name="uid"></param>
  74. /// <param name="index"></param>
  75. /// <param name="rewardName"></param>
  76. /// <param name="reward"></param>
  77. public static void SendWorldBossReward(int zoneid, string uid, int index,string rewardName, string reward)
  78. {
  79. var mail = new Email(EMailType.SystemMail, "世界boss奖励", $"恭喜您在世界boss战斗中输出伤害排{index}名,获得{rewardName}奖励!", reward);
  80. InsertMail(zoneid, uid, mail);
  81. }
  82. /// <summary>
  83. /// 插入邮件
  84. /// </summary>
  85. /// <param name="zoneid"></param>
  86. /// <param name="uid"></param>
  87. /// <param name="mail"></param>
  88. private static int InsertMail(int zoneid, string uid, Email mail)
  89. {
  90. var mem = Redis.Ins.GetDatabase(0);
  91. var key_id = MemKey_User.Mail_CurId_int(zoneid, uid);
  92. var key_queue = MemKey_User.Mail_Queue_hash(zoneid, uid);
  93. mail.insertts = (int)DateTime.Now.ToUnixTimeStamp();
  94. mail.mailId = (int)mem.StringIncrement(key_id);
  95. if (!mem.HashSet(key_queue, mail.mailId.ToString(), mail.ToString()))
  96. { // 重试下
  97. mail.mailId = (int)mem.StringIncrement(key_id);
  98. if (!mem.HashSet(key_queue, mail.mailId.ToString(), mail.ToString()))
  99. {
  100. }
  101. }
  102. logMail(zoneid, uid, mail); // 将邮件写入Mysql中
  103. return mail.mailId;
  104. }
  105. /// <summary>
  106. /// 写邮件日志
  107. /// </summary>
  108. /// <param name="zoneid"></param>
  109. /// <param name="uid"></param>
  110. /// <param name="mail"></param>
  111. private static void logMail(int zoneid, string uid, Email mail)
  112. {
  113. var sql = $" Insert Into {MailLog_TableName} (`mailId`, `zoneid`, `appendix`, `type`, `sender_name`, `sender_uid`, `to_uid`, `title`, `content`, `tag`) " +
  114. $"values({mail.mailId},{zoneid},{mail.appendix}, {mail.type}, {mail.sender_name}, {mail.sender_uid}, {uid}, {mail.title}, {mail.content}, {mail.tag})";
  115. var n = MysqlUtil.Ins.ExecuteSqlNonQuery(sql);
  116. Debug.Assert(n > 0, $"{sql} 执行失败!");
  117. }
  118. }
  119. public class Email
  120. {
  121. public int mailId = 0;
  122. public string sender_uid;
  123. public string sender_name;
  124. public string appendix;
  125. public int type;
  126. public string title;
  127. public string content;
  128. public object tag;
  129. public int readts = 0;
  130. public int drawedts = 0;
  131. public int insertts = 0;
  132. public bool isDrawed() => drawedts > 0;
  133. public bool isExistsReward() => !string.IsNullOrEmpty(appendix);
  134. public int ExpireTs() => insertts + EmailProc.MaxMailExpireTs;
  135. public Email(EMailType emailType,string title, string content,string reward,string uid_sender="系统",string name_sender="系统") {
  136. this.type =(int) emailType;
  137. this.title = title;
  138. this.content = content;
  139. this.appendix = reward;
  140. this.sender_uid = uid_sender;
  141. this.sender_name = name_sender;
  142. }
  143. public override string ToString()
  144. {
  145. return new JObject(this).ToString();
  146. }
  147. }
  148. }