resource.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. package models
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "time"
  5. )
  6. type Resource struct {
  7. Id int `orm:"column(id);" description:"资源id"`
  8. ResourceUrl string `description:"资源地址"`
  9. CreateTime time.Time `description:"创建时间"`
  10. ResourceType int `description:"资源类型,1:图片,2:音频,3:视频 ,4:ppt"`
  11. }
  12. type ResourceResp struct {
  13. Id int64 `orm:"column(id);" description:"用户id"`
  14. ResourceUrl string `description:"资源地址"`
  15. PlaySeconds uint32 `description:"播放时长,单位秒"`
  16. Source string
  17. CacheKey string
  18. ResourceName string `description:"资源名称"`
  19. OpenaiFileId string `description:"openai返回的文件id"`
  20. AiChatTopicId int `description:"主题id"`
  21. }
  22. func AddResource(item *Resource) (newId int64, err error) {
  23. o := orm.NewOrmUsingDB("rddp")
  24. sql := "INSERT INTO resource(resource_url,create_time,resource_type) VALUES(?,?,?)"
  25. res, err := o.Raw(sql, item.ResourceUrl, item.CreateTime, item.ResourceType).Exec()
  26. if err != nil {
  27. return 0, err
  28. }
  29. newId, err = res.LastInsertId()
  30. if err != nil {
  31. return 0, err
  32. }
  33. return newId, err
  34. }
  35. func GetResourceById(id string) (item *Resource, err error) {
  36. o := orm.NewOrmUsingDB("rddp")
  37. sql := "SELECT * FROM resource WHERE id=? "
  38. err = o.Raw(sql, id).QueryRow(&item)
  39. return
  40. }
  41. type ResourceBase64Resp struct {
  42. Image string `description:"图片,base64字符串"`
  43. }
  44. type PptResourceResp struct {
  45. Id int64 `orm:"column(id);" description:"用户id"`
  46. ResourceUrl []string `description:"资源地址"`
  47. PlaySeconds uint32 `description:"播放时长,单位秒"`
  48. }
  49. type ImageSvgToPngResp struct {
  50. Data struct {
  51. ResourceURL string `json:"ResourceUrl"`
  52. } `json:"Data"`
  53. ErrCode string `json:"ErrCode"`
  54. ErrMsg string `json:"ErrMsg"`
  55. IsSendEmail bool `json:"IsSendEmail"`
  56. Msg string `json:"Msg"`
  57. Ret int64 `json:"Ret"`
  58. Success bool `json:"Success"`
  59. }