tools.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. package public
  2. import (
  3. "crypto/hmac"
  4. "crypto/sha256"
  5. "encoding/base64"
  6. "fmt"
  7. "os"
  8. "strings"
  9. "time"
  10. "unicode/utf8"
  11. )
  12. // 将内容写入到文件,如果文件名带路径,则会判断路径是否存在,不存在则创建
  13. func WriteToFile(path string, data []byte) error {
  14. tmp := strings.Split(path, "/")
  15. if len(tmp) > 0 {
  16. tmp = tmp[:len(tmp)-1]
  17. }
  18. err := os.MkdirAll(strings.Join(tmp, "/"), os.ModePerm)
  19. if err != nil {
  20. return err
  21. }
  22. err = os.WriteFile(path, data, 0755)
  23. if err != nil {
  24. return err
  25. }
  26. return nil
  27. }
  28. // JudgeGroup 判断群ID是否在白名单
  29. func JudgeGroup(s string) bool {
  30. if len(Config.AllowGroups) == 0 {
  31. return true
  32. }
  33. for _, v := range Config.AllowGroups {
  34. if v == s {
  35. return true
  36. }
  37. }
  38. return false
  39. }
  40. // JudgeOutgoingGroup 判断群ID是否在为outgoing白名单
  41. func JudgeOutgoingGroup(s string) bool {
  42. if len(Config.AllowOutgoingGroups) == 0 {
  43. return true
  44. }
  45. for _, v := range Config.AllowOutgoingGroups {
  46. if v == s {
  47. return true
  48. }
  49. }
  50. return false
  51. }
  52. // JudgeUsers 判断用户是否在白名单
  53. func JudgeUsers(s string) bool {
  54. // 优先判断黑名单,黑名单用户返回:不在白名单
  55. if len(Config.DenyUsers) != 0 {
  56. for _, v := range Config.DenyUsers {
  57. if v == s {
  58. return false
  59. }
  60. }
  61. }
  62. // 白名单配置逻辑处理
  63. if len(Config.AllowUsers) == 0 {
  64. return true
  65. }
  66. for _, v := range Config.AllowUsers {
  67. if v == s {
  68. return true
  69. }
  70. }
  71. return false
  72. }
  73. // JudgeAdminUsers 判断用户是否为系统管理员
  74. func JudgeAdminUsers(s string) bool {
  75. // 如果secret或者用户的userid都为空的话,那么默认没有管理员
  76. if len(Config.AppSecrets) == 0 || s == "" {
  77. return false
  78. }
  79. // 如果没有指定,则没有人是管理员
  80. if len(Config.AdminUsers) == 0 {
  81. return false
  82. }
  83. for _, v := range Config.AdminUsers {
  84. if v == s {
  85. return true
  86. }
  87. }
  88. return false
  89. }
  90. // JudgeVipUsers 判断用户是否为VIP用户
  91. func JudgeVipUsers(s string) bool {
  92. // 如果secret或者用户的userid都为空的话,那么默认不是VIP用户
  93. if len(Config.AppSecrets) == 0 || s == "" {
  94. return false
  95. }
  96. // 管理员默认是VIP用户
  97. for _, v := range Config.AdminUsers {
  98. if v == s {
  99. return true
  100. }
  101. }
  102. // 如果没有指定,则没有人是VIP用户
  103. if len(Config.VipUsers) == 0 {
  104. return false
  105. }
  106. for _, v := range Config.VipUsers {
  107. if v == s {
  108. return true
  109. }
  110. }
  111. return false
  112. }
  113. func GetReadTime(t time.Time) string {
  114. return t.Format("2006-01-02 15:04:05")
  115. }
  116. func CheckRequestWithCredentials(ts, sg string) (clientId string, pass bool) {
  117. clientId, pass = "", false
  118. credentials := Config.Credentials
  119. if len(credentials) == 0 || len(Config.AllowOutgoingGroups) == 0 {
  120. return "", true
  121. }
  122. for _, credential := range Config.Credentials {
  123. stringToSign := fmt.Sprintf("%s\n%s", ts, credential.ClientSecret)
  124. mac := hmac.New(sha256.New, []byte(credential.ClientSecret))
  125. _, _ = mac.Write([]byte(stringToSign))
  126. if base64.StdEncoding.EncodeToString(mac.Sum(nil)) == sg {
  127. return credential.ClientID, true
  128. }
  129. }
  130. return
  131. }
  132. func CheckRequest(ts, sg string) bool {
  133. appSecrets := Config.AppSecrets
  134. // 如果没有指定或者outgoing类型机器人下使用,则默认不做校验
  135. if len(appSecrets) == 0 || sg == "" {
  136. return true
  137. }
  138. // 校验appSecret
  139. for _, secret := range appSecrets {
  140. stringToSign := fmt.Sprintf("%s\n%s", ts, secret)
  141. mac := hmac.New(sha256.New, []byte(secret))
  142. _, _ = mac.Write([]byte(stringToSign))
  143. if base64.StdEncoding.EncodeToString(mac.Sum(nil)) == sg {
  144. return true
  145. }
  146. }
  147. return false
  148. }
  149. // JudgeSensitiveWord 判断内容是否包含敏感词
  150. func JudgeSensitiveWord(s string) bool {
  151. if len(Config.SensitiveWords) == 0 {
  152. return false
  153. }
  154. for _, v := range Config.SensitiveWords {
  155. if strings.Contains(s, v) {
  156. return true
  157. }
  158. }
  159. return false
  160. }
  161. // SolveSensitiveWord 将敏感词用 🚫 占位
  162. func SolveSensitiveWord(s string) string {
  163. for _, v := range Config.SensitiveWords {
  164. if strings.Contains(s, v) {
  165. return strings.Replace(s, v, printStars(utf8.RuneCountInString(v)), -1)
  166. }
  167. }
  168. return s
  169. }
  170. // 将对应敏感词替换为 🚫
  171. func printStars(num int) string {
  172. s := ""
  173. for i := 0; i < num; i++ {
  174. s += "🚫"
  175. }
  176. return s
  177. }