package modules
import (
"html"
"strings"
"time"
"golang-fave/engine/wrapper"
"golang-fave/utils"
)
func (this *Modules) api_GenerateXmlCurrencies(wrap *wrapper.Wrapper) string {
result := ``
rows, err := wrap.DB.Query(
`SELECT
code,
coefficient
FROM
shop_currencies
ORDER BY
id ASC
;`,
)
if err == nil {
defer rows.Close()
values := make([]string, 2)
scan := make([]interface{}, len(values))
for i := range values {
scan[i] = &values[i]
}
for rows.Next() {
err = rows.Scan(scan...)
if err == nil {
result += ``
}
}
}
return result
}
func (this *Modules) api_GenerateXmlCategories(wrap *wrapper.Wrapper) string {
result := ``
rows, err := wrap.DB.Query(
`SELECT
data.id,
data.user,
data.name,
data.alias,
data.lft,
data.rgt,
MAX(data.parent_id) AS parent_id
FROM
(
SELECT
node.id,
node.user,
node.name,
node.alias,
node.lft,
node.rgt,
parent.id AS parent_id
FROM
shop_cats AS node,
shop_cats AS parent
WHERE
node.lft BETWEEN parent.lft AND parent.rgt AND
node.id > 1
ORDER BY
node.lft ASC
) AS data
WHERE
data.id <> data.parent_id
GROUP BY
data.id
ORDER BY
data.lft ASC
;`,
)
if err == nil {
defer rows.Close()
values := make([]string, 7)
scan := make([]interface{}, len(values))
for i := range values {
scan[i] = &values[i]
}
for rows.Next() {
err = rows.Scan(scan...)
if err == nil {
if utils.StrToInt(string(values[6])) > 1 {
result += `` + html.EscapeString(string(values[2])) + ``
} else {
result += `` + html.EscapeString(string(values[2])) + ``
}
}
}
}
return result
}
func (this *Modules) api_GenerateXmlOfferPictures(wrap *wrapper.Wrapper, product_id int) string {
result := ``
rows, err := wrap.DB.Query(
`SELECT
shop_product_images.product_id,
shop_product_images.filename
FROM
shop_product_images
WHERE
shop_product_images.product_id = ?
;`,
product_id,
)
if err == nil {
defer rows.Close()
values := make([]string, 2)
scan := make([]interface{}, len(values))
for i := range values {
scan[i] = &values[i]
}
for rows.Next() {
err = rows.Scan(scan...)
if err == nil {
result += `` + html.EscapeString((*wrap.Config).API.XML.Url) + `products/images/` + html.EscapeString(string(values[0])) + `/` + html.EscapeString(string(values[1])) + ``
}
}
}
return result
}
func (this *Modules) api_GenerateXmlOfferAttributes(wrap *wrapper.Wrapper, product_id int) string {
result := ``
filter_ids := []int{}
filter_names := map[int]string{}
filter_values := map[int][]string{}
rows, err := wrap.DB.Query(
`SELECT
shop_filters.id,
shop_filters.filter,
shop_filters_values.name
FROM
shop_filter_product_values
LEFT JOIN shop_filters_values ON shop_filters_values.id = shop_filter_product_values.filter_value_id
LEFT JOIN shop_filters ON shop_filters.id = shop_filters_values.filter_id
WHERE
shop_filter_product_values.product_id = ?
ORDER BY
shop_filters.filter ASC,
shop_filters_values.name ASC
;`,
product_id,
)
if err == nil {
defer rows.Close()
values := make([]string, 3)
scan := make([]interface{}, len(values))
for i := range values {
scan[i] = &values[i]
}
for rows.Next() {
err = rows.Scan(scan...)
if err == nil {
if !utils.InArrayInt(filter_ids, utils.StrToInt(string(values[0]))) {
filter_ids = append(filter_ids, utils.StrToInt(string(values[0])))
}
filter_names[utils.StrToInt(string(values[0]))] = html.EscapeString(string(values[1]))
filter_values[utils.StrToInt(string(values[0]))] = append(filter_values[utils.StrToInt(string(values[0]))], string(values[2]))
}
}
}
for _, filter_id := range filter_ids {
result += `` + html.EscapeString(strings.Join(filter_values[filter_id], ", ")) + ``
}
return result
}
func (this *Modules) api_GenerateXmlOffers(wrap *wrapper.Wrapper) string {
result := ``
rows, err := wrap.DB.Query(
`SELECT
shop_products.id,
shop_currencies.code,
shop_products.price,
shop_products.name,
shop_products.alias,
shop_products.vendor,
shop_products.quantity,
shop_products.category,
shop_products.content
FROM
shop_products
LEFT JOIN shop_currencies ON shop_currencies.id = shop_products.currency
WHERE
shop_products.active = 1 AND
shop_products.category > 1
ORDER BY
shop_products.id
;`,
)
if err == nil {
defer rows.Close()
values := make([]string, 9)
scan := make([]interface{}, len(values))
for i := range values {
scan[i] = &values[i]
}
for rows.Next() {
err = rows.Scan(scan...)
if err == nil {
result += ``
result += `` + html.EscapeString((*wrap.Config).API.XML.Url) + `shop/` + html.EscapeString(string(values[4])) + `/`
result += `` + utils.Float64ToStrF(utils.StrToFloat64(string(values[2])), "%.2f") + ``
result += `` + html.EscapeString(string(values[1])) + ``
result += `` + html.EscapeString(string(values[7])) + ``
result += this.api_GenerateXmlOfferPictures(wrap, utils.StrToInt(string(values[0])))
result += `` + html.EscapeString(string(values[5])) + ``
result += `` + html.EscapeString(string(values[6])) + ``
result += `` + html.EscapeString(string(values[3])) + ``
result += ``
result += this.api_GenerateXmlOfferAttributes(wrap, utils.StrToInt(string(values[0])))
result += ``
}
}
}
return result
}
func (this *Modules) api_Generate(wrap *wrapper.Wrapper, currencies, categories, offers string) string {
return `` +
`` +
`` +
`` +
`` + html.EscapeString((*wrap.Config).API.XML.Name) + `` +
`` + html.EscapeString((*wrap.Config).API.XML.Company) + `` +
`` + html.EscapeString((*wrap.Config).API.XML.Url) + `` +
`` + currencies + `` +
`` + categories + `` +
`` + offers + `` +
`` +
``
}
func (this *Modules) api_GenerateXml(wrap *wrapper.Wrapper) string {
return this.api_Generate(
wrap,
this.api_GenerateXmlCurrencies(wrap),
this.api_GenerateXmlCategories(wrap),
this.api_GenerateXmlOffers(wrap),
)
}
func (this *Modules) api_GenerateEmptyXml(wrap *wrapper.Wrapper) string {
return this.api_Generate(wrap, "", "", "")
}