utils.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package utils
  2. import (
  3. "crypto/hmac"
  4. "crypto/sha1"
  5. "encoding/hex"
  6. "git.qianqiusoft.com/qianqiusoft/go-uuid/uuid"
  7. "git.qianqiusoft.com/qianqiusoft/light-apiengine/logs"
  8. "git.qianqiusoft.com/qianqiusoft/light-apiengine/models"
  9. "github.com/xormplus/xorm"
  10. "net/url"
  11. "strings"
  12. )
  13. const (
  14. hmac_key = "hmac_key_"
  15. )
  16. func NewUUID() string {
  17. //return uuid.NewV4().String()
  18. return uuid.New()
  19. }
  20. func GenerateToken(plain string) string {
  21. hash := hmac.New(sha1.New, []byte(hmac_key))
  22. hash.Write([]byte(plain))
  23. return hex.EncodeToString(hash.Sum(nil))
  24. }
  25. func TotalPage(record, size int) int {
  26. tp := record / size
  27. if tp < 0 {
  28. return 1
  29. }
  30. if record%size == 0 {
  31. return tp
  32. }
  33. return tp + 1
  34. }
  35. func FormatForBrowse(agent, val string) string {
  36. if strings.Contains(strings.ToLower(agent), "safari/") && !strings.Contains(strings.ToLower(agent), "chrome/") {
  37. logs.Debug("Safari浏览器编码")
  38. } else if strings.Contains(strings.ToLower(agent), "firefox/") {
  39. logs.Debug("Firefox浏览器编码")
  40. } else if strings.Contains(strings.ToLower(agent), "chrome/") && strings.Contains(strings.ToLower(agent), "safari/") && !strings.Contains(strings.ToLower(agent), "edge/") {
  41. logs.Debug("Chrome浏览器编码")
  42. } else {
  43. logs.Debug("IE浏览器编码")
  44. val = url.QueryEscape(val)
  45. val = strings.Replace(val, "+", "%20", -1)
  46. }
  47. return val
  48. }
  49. func PageQuery(db *xorm.Engine, param models.PageQueryParam, rowsSlicePtr interface{})(*models.PageResult, error){
  50. pageResult := models.PageResult{}
  51. dbSession := db.Table(param.TableName)
  52. if len(param.SelectFields) > 0{
  53. dbSession = dbSession.Select(param.TableName + ".*")
  54. }else{
  55. dbSession = dbSession.Select(strings.Join(param.SelectFields, ","))
  56. }
  57. count := 0
  58. countSession := db.Table(param.TableName)
  59. countSession.Select("count(*) as records")
  60. for _, join := range param.JoinTables {
  61. dbSession = dbSession.Join(join.JoinOperator, join.TabelName, join.Condition)
  62. }
  63. whereStr, datas, err := param.PageInfo.Filter.Parse("")
  64. if err != nil {
  65. return nil, err
  66. }
  67. dbSession = dbSession.Where(whereStr, datas...)
  68. countSession = countSession.Where(whereStr, datas...)
  69. sidx := strings.Split(param.PageInfo.Sidx, ",")
  70. for _, order := range sidx {
  71. order = strings.TrimSpace(order)
  72. if len(order) == 0 {
  73. continue
  74. }
  75. if strings.ToLower(param.PageInfo.Sord) == "desc" {
  76. dbSession = dbSession.OrderBy(order + " desc")
  77. } else {
  78. dbSession = dbSession.OrderBy(order + " asc")
  79. }
  80. }
  81. err = dbSession.Limit(param.PageInfo.PageSize, (param.PageInfo.PageNum-1)*param.PageInfo.PageSize).Find(rowsSlicePtr)
  82. _, err = countSession.Get(&count)
  83. pageResult.Content = rowsSlicePtr
  84. pageResult.TotalSize = count
  85. pageResult.PageNum = param.PageInfo.PageNum
  86. pageResult.PageSize = param.PageInfo.PageSize
  87. return &pageResult, nil
  88. }