cronJobs.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. package cronjob
  2. import (
  3. "encoding/csv"
  4. "encoding/xml"
  5. "fmt"
  6. "kng_feed_api/helper"
  7. "kng_feed_api/model"
  8. "log"
  9. "os"
  10. "path/filepath"
  11. "strconv"
  12. "strings"
  13. "time"
  14. )
  15. func CreateXMLFeed() {
  16. const CrossDockingCategoryId = "999"
  17. type Category struct {
  18. Text string `xml:",chardata"`
  19. Id string `xml:"id,attr"`
  20. ParentId string `xml:"parentId,attr"`
  21. URL string `xml:"url,attr"`
  22. }
  23. type Param struct {
  24. Text string `xml:",chardata"`
  25. Name string `xml:"name,attr"`
  26. }
  27. type Offer struct {
  28. Id string `xml:"id,attr"`
  29. Avalieble string `xml:"available,attr"`
  30. Name string `xml:"name"`
  31. URL string `xml:"url"`
  32. CategoryId string `xml:"categoryId"`
  33. Vendor string `xml:"vendor"`
  34. Param []Param `xml:"param"`
  35. }
  36. type Shop struct {
  37. Name string `xml:"name"`
  38. URL string `xml:"url"`
  39. Category []Category `xml:"categories>category"`
  40. Offer []Offer `xml:"offers>offer"`
  41. }
  42. type YamlCatalog struct {
  43. XMLName xml.Name `xml:"yml_catalog"`
  44. Date string `xml:"date,attr"`
  45. Shop Shop `xml:"shop"`
  46. }
  47. fmt.Println("CRON JOB WORK - FROM EXTERNAL FILE ", time.Now())
  48. categoryRows, err := model.GetAllCategories()
  49. if err != nil {
  50. return
  51. }
  52. rows, err := model.GetAllProducts()
  53. if err != nil {
  54. return
  55. }
  56. var ymlCatalog = &YamlCatalog{}
  57. timeNow := time.Now().UTC()
  58. ymlCatalog.Date = timeNow.Format("2006-01-02 15:04")
  59. var shop = &Shop{}
  60. shop.Name = "ООО КНЯГИНЯ"
  61. shop.URL = "https://b2bn.kngnn.ru"
  62. for _, value := range categoryRows {
  63. var category = Category{
  64. Text: value.Name,
  65. ParentId: value.ParentId,
  66. Id: value.Id,
  67. URL: value.Id,
  68. }
  69. shop.Category = append(shop.Category, category)
  70. }
  71. // +++ Предопределенная категория для кросс-докинга
  72. var categoryCrossDocking = Category{
  73. Text: "Кросс-Докинг",
  74. ParentId: "1",
  75. Id: "999",
  76. URL: "999",
  77. }
  78. shop.Category = append(shop.Category, categoryCrossDocking)
  79. // --- Предопределенная категория для кросс-докинга
  80. for _, value := range rows {
  81. var offer = Offer{
  82. Id: value.CodeCarCaDe,
  83. Avalieble: "true",
  84. Name: value.Name,
  85. URL: "https://b2bn.kngnn.ru/?item-code=" + value.CodeUT10,
  86. CategoryId: value.CategoryId,
  87. Vendor: value.Manufacturer,
  88. }
  89. if offer.CategoryId == "" {
  90. offer.CategoryId = categoryCrossDocking.Id
  91. offer.Param = append(offer.Param, Param{
  92. Text: "1",
  93. Name: "cross_docking",
  94. })
  95. } else {
  96. offer.Param = append(offer.Param, Param{
  97. Text: "0",
  98. Name: "cross_docking",
  99. })
  100. }
  101. offer.Param = append(offer.Param, Param{
  102. Text: value.CodeUT10,
  103. Name: "code",
  104. })
  105. offer.Param = append(offer.Param, Param{
  106. Text: value.CodeUT10,
  107. Name: "code_ut10",
  108. })
  109. offer.Param = append(offer.Param, Param{
  110. Text: value.Manufacturer,
  111. Name: "manufacturer",
  112. })
  113. offer.Param = append(offer.Param, Param{
  114. Text: value.ArticleNumber,
  115. Name: "article_number",
  116. })
  117. offer.Param = append(offer.Param, Param{
  118. Text: value.Brand,
  119. Name: "brand",
  120. })
  121. offer.Param = append(offer.Param, Param{
  122. Text: value.Unit,
  123. Name: "unit",
  124. })
  125. offer.Param = append(offer.Param, Param{
  126. Text: value.GroupLimit,
  127. Name: "group_limit",
  128. })
  129. offer.Param = append(offer.Param, Param{
  130. Text: value.GroupPrice,
  131. Name: "group_price",
  132. })
  133. offer.Param = append(offer.Param, Param{
  134. Text: value.NumberCatalog,
  135. Name: "number_catalog",
  136. })
  137. offer.Param = append(offer.Param, Param{
  138. Text: value.NumberDrawing,
  139. Name: "number_drawing",
  140. })
  141. offer.Param = append(offer.Param, Param{
  142. Text: value.NumberBrand,
  143. Name: "number_brand",
  144. })
  145. offer.Param = append(offer.Param, Param{
  146. Text: value.NumberArticle,
  147. Name: "number_article",
  148. })
  149. offer.Param = append(offer.Param, Param{
  150. Text: value.NumberSuffix,
  151. Name: "number_suffix",
  152. })
  153. if value.IdNumbers != nil {
  154. numbers := strings.Split(*value.IdNumbers, ";")
  155. for idx, num := range numbers {
  156. offer.Param = append(offer.Param, Param{
  157. Text: num,
  158. Name: "article_number" + strconv.Itoa(idx+1),
  159. })
  160. }
  161. }
  162. shop.Offer = append(shop.Offer, offer)
  163. }
  164. ymlCatalog.Shop = *shop
  165. byteXmlText, err := xml.MarshalIndent(ymlCatalog, " ", " ")
  166. if err != nil {
  167. log.Printf(err.Error())
  168. } else {
  169. var Header = `<?xml version="1.0" encoding="UTF-8"?>` + "\n"
  170. var byteXmlTextWithHeader = []byte(Header + string(byteXmlText))
  171. err := os.WriteFile(filepath.Join(helper.RootDir(), "feed.xml"), byteXmlTextWithHeader, 0666)
  172. if err != nil {
  173. log.Printf(err.Error())
  174. }
  175. }
  176. }
  177. func CreateCSVDeltaFeed() {
  178. log.Println("DELTA FEED WORK - FROM EXTERNAL FILE ", helper.RootDir())
  179. rows, err := model.GetAllAvailability()
  180. if err != nil {
  181. log.Printf("Не удалось получить данные для формирования дельта-фида из базы по причине [%s]", err)
  182. return
  183. }
  184. file, err := os.Create(filepath.Join(helper.RootDir(), "delta.csv"))
  185. if err != nil {
  186. log.Printf("Не удалось сформировать пустой файл дельта-фида по причине [%s]", err)
  187. return
  188. }
  189. defer file.Close()
  190. csvWriter := csv.NewWriter(file)
  191. csvWriter.Comma = ';'
  192. defer csvWriter.Flush()
  193. var records [][]string
  194. for _, row := range rows {
  195. var record []string
  196. record = append(record, row.CodeCarCaDe)
  197. record = append(record, "1")
  198. record = append(record, strconv.Itoa(row.Available))
  199. records = append(records, record)
  200. }
  201. writeError := csvWriter.WriteAll(records)
  202. if writeError != nil {
  203. log.Printf("Не удалось сохранить файл дельта-фида на диск по причине [%s]", writeError)
  204. return
  205. }
  206. }