cronJobs.go 5.6 KB

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