package modules
import (
"html"
"net/http"
"strings"
"time"
"golang-fave/assets"
"golang-fave/engine/fetdata"
"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[0])), "%.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_GenerateXml(wrap *wrapper.Wrapper) string {
return `
` + html.EscapeString((*wrap.Config).API.XML.Name) + `
` + html.EscapeString((*wrap.Config).API.XML.Company) + `
` + html.EscapeString((*wrap.Config).API.XML.Url) + `
` + this.api_GenerateXmlCurrencies(wrap) + `
` + this.api_GenerateXmlCategories(wrap) + `
` + this.api_GenerateXmlOffers(wrap) + `
`
}
func (this *Modules) RegisterModule_Api() *Module {
return this.newModule(MInfo{
WantDB: true,
Mount: "api",
Name: "Api",
Order: 803,
System: true,
Icon: assets.SysSvgIconPage,
Sub: &[]MISub{},
}, func(wrap *wrapper.Wrapper) {
if len(wrap.UrlArgs) == 2 && wrap.UrlArgs[0] == "api" && wrap.UrlArgs[1] == "products" {
if (*wrap.Config).API.XML.Enabled == 1 {
// Fix url
if wrap.R.URL.Path[len(wrap.R.URL.Path)-1] != '/' {
http.Redirect(wrap.W, wrap.R, wrap.R.URL.Path+"/"+utils.ExtractGetParams(wrap.R.RequestURI), 301)
return
}
// XML
wrap.W.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
wrap.W.Header().Set("Content-Type", "text/xml; charset=utf-8")
wrap.W.WriteHeader(http.StatusOK)
wrap.W.Write([]byte(this.api_GenerateXml(wrap)))
} else {
wrap.W.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
wrap.W.WriteHeader(http.StatusNotFound)
wrap.W.Write([]byte("Disabled!"))
}
} else if len(wrap.UrlArgs) == 1 {
// Fix url
if wrap.R.URL.Path[len(wrap.R.URL.Path)-1] != '/' {
http.Redirect(wrap.W, wrap.R, wrap.R.URL.Path+"/"+utils.ExtractGetParams(wrap.R.RequestURI), 301)
return
}
// Some info
wrap.W.Header().Set("Cache-Control", "no-cache, no-store, must-revalidate")
wrap.W.WriteHeader(http.StatusOK)
wrap.W.Write([]byte("Fave engine API mount point!"))
} else {
// User error 404 page
wrap.RenderFrontEnd("404", fetdata.New(wrap, nil, true), http.StatusNotFound)
return
}
}, func(wrap *wrapper.Wrapper) (string, string, string) {
// No any page for back-end
return "", "", ""
})
}