docChangeService.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package stdlib
  2. import (
  3. elastic "app.yhyue.com/moapp/jybase/esv7"
  4. jyDocsRpcUtil "app.yhyue.com/moapp/jydocs/services/util"
  5. "errors"
  6. "gorm.io/gorm"
  7. "log"
  8. "time"
  9. )
  10. const DocOn = 1
  11. const DocOff = 0
  12. // 上架文档
  13. func ChangeDocumentOn(id string, reason int32) bool {
  14. // 查文档
  15. docData := map[string]interface{}{}
  16. rs := jyDocsRpcUtil.GetJyDocsDB().Table("doc").Where("id=? and isDelete=0", id).Find(&docData)
  17. if rs.Error != nil {
  18. log.Println("上架文档 error:"+id, rs.Error)
  19. return false
  20. } else {
  21. if docData["id"] == nil {
  22. log.Println("上架文档 error:"+id, "文档不存在")
  23. return false
  24. }
  25. }
  26. // 上架
  27. err := jyDocsRpcUtil.GetJyDocsDB().Transaction(func(tx *gorm.DB) error {
  28. // 更新大库状态为上架 1-上架
  29. if err := tx.Exec("update doc set downOrUp=? where id=? ", DocOn, id).Error; err != nil {
  30. return err
  31. }
  32. // 存上架记录
  33. date := time.Now().Local().Format("2006-01-02 15:04:05")
  34. if err := tx.Exec("insert into doc_change_record (docId,date,downOrUp,reason) values (?,?,?,?)", id, date, DocOn, reason).Error; err != nil {
  35. return err
  36. }
  37. docData["_id"] = docData["id"]
  38. // todo es加数据 索引待替换 测试
  39. if rs := elastic.Save("doc_lib", "doc", docData); rs != true {
  40. return errors.New("发布到检索库失败")
  41. }
  42. return nil
  43. })
  44. log.Println("上架文档 error:"+id, err)
  45. if err != nil {
  46. return false
  47. }
  48. return true
  49. }
  50. // 下架文档
  51. func ChangeDocumentOff(id string, reason int32) bool {
  52. // 查文档
  53. docData := map[string]interface{}{}
  54. rs := jyDocsRpcUtil.GetJyDocsDB().Table("doc").Where("id=? and isDelete=0", id).Find(&docData)
  55. if rs.Error != nil {
  56. log.Println("下架文档 error:"+id, rs.Error)
  57. return false
  58. } else {
  59. if docData["id"] == nil {
  60. log.Println("下架文档 error:"+id, "文档不存在")
  61. return false
  62. }
  63. }
  64. // 下架
  65. err := jyDocsRpcUtil.GetJyDocsDB().Transaction(func(tx *gorm.DB) error {
  66. // 更新大库状态为下架 0-下架
  67. if err := tx.Exec("update doc set downOrUp=? where id=? ", DocOff, id).Error; err != nil {
  68. return err
  69. }
  70. // 存下架记录
  71. date := time.Now().Local().Format("2006-01-02 15:04:05")
  72. if err := tx.Exec("insert into doc_change_record (docId,date,downOrUp,reason) values (?,?,?,?)", id, date, DocOff, reason).Error; err != nil {
  73. return err
  74. }
  75. //todo 从es删除数据 索引待替换 及测试
  76. if rs := elastic.DelById("doc_lib", "doc", id); rs != true {
  77. return errors.New("从检索库删除失败")
  78. }
  79. return nil
  80. })
  81. if err != nil {
  82. log.Println("上架文档 error:"+id, err)
  83. return false
  84. }
  85. return true
  86. }