tools.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. package public
  2. import (
  3. "crypto/hmac"
  4. "crypto/sha256"
  5. "encoding/base64"
  6. "fmt"
  7. "io/ioutil"
  8. "os"
  9. "strings"
  10. "time"
  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 = ioutil.WriteFile(path, data, 0755)
  23. if err != nil {
  24. return err
  25. }
  26. return nil
  27. }
  28. // JudgeGroup 判断群聊名称是否在白名单
  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. // JudgeUsers 判断用户名称是否在白名单
  41. func JudgeUsers(s string) bool {
  42. // 优先判断黑名单,黑名单用户返回:不在白名单
  43. if len(Config.DenyUsers) != 0 {
  44. for _, v := range Config.DenyUsers {
  45. if v == s {
  46. return false
  47. }
  48. }
  49. }
  50. // 白名单配置逻辑处理
  51. if len(Config.AllowUsers) == 0 {
  52. return true
  53. }
  54. for _, v := range Config.AllowUsers {
  55. if v == s {
  56. return true
  57. }
  58. }
  59. return false
  60. }
  61. // JudgeAdminUsers 判断用户是否为系统管理员
  62. func JudgeAdminUsers(s string) bool {
  63. // 如果secret或者用户的userid都为空的话,那么默认没有管理员
  64. if len(Config.AppSecrets) == 0 || s == "" {
  65. return false
  66. }
  67. // 如果没有指定,则没有人是管理员
  68. if len(Config.AdminUsers) == 0 {
  69. return false
  70. }
  71. for _, v := range Config.AdminUsers {
  72. if v == s {
  73. return true
  74. }
  75. }
  76. return false
  77. }
  78. // JudgeVipUsers 判断用户是否为VIP用户
  79. func JudgeVipUsers(s string) bool {
  80. // 如果secret或者用户的userid都为空的话,那么默认不是VIP用户
  81. if len(Config.AppSecrets) == 0 || s == "" {
  82. return false
  83. }
  84. // 管理员默认是VIP用户
  85. for _, v := range Config.AdminUsers {
  86. if v == s {
  87. return true
  88. }
  89. }
  90. // 如果没有指定,则没有人是VIP用户
  91. if len(Config.VipUsers) == 0 {
  92. return false
  93. }
  94. for _, v := range Config.VipUsers {
  95. if v == s {
  96. return true
  97. }
  98. }
  99. return false
  100. }
  101. func GetReadTime(t time.Time) string {
  102. return t.Format("2006-01-02 15:04:05")
  103. }
  104. func CheckRequest(ts, sg string) bool {
  105. appSecrets := Config.AppSecrets
  106. // 如果没有指定或者outgoing类型机器人下使用,则默认不做校验
  107. if len(appSecrets) == 0 || sg == "" {
  108. return true
  109. }
  110. // 校验appSecret
  111. for _, secret := range appSecrets {
  112. stringToSign := fmt.Sprintf("%s\n%s", ts, secret)
  113. mac := hmac.New(sha256.New, []byte(secret))
  114. _, _ = mac.Write([]byte(stringToSign))
  115. if base64.StdEncoding.EncodeToString(mac.Sum(nil)) == sg {
  116. return true
  117. }
  118. }
  119. return false
  120. }