2023-04-17 08:48:09 +03:00
|
|
|
package handler
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
2023-04-22 04:29:10 +03:00
|
|
|
"errors"
|
|
|
|
"io/ioutil"
|
2023-04-17 08:48:09 +03:00
|
|
|
"net/http"
|
|
|
|
"strconv"
|
|
|
|
|
|
|
|
"github.com/gin-gonic/gin"
|
2023-04-22 04:29:10 +03:00
|
|
|
"github.com/google/uuid"
|
2023-04-17 08:48:09 +03:00
|
|
|
"github.com/xuri/excelize/v2"
|
|
|
|
"gitstore.ru/tolikproh/sirius/internal/model"
|
|
|
|
)
|
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
func GinConvert(c *gin.Context) {
|
|
|
|
file, err := c.FormFile("file")
|
|
|
|
if err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": err.Error(),
|
|
|
|
})
|
2023-04-17 08:48:09 +03:00
|
|
|
}
|
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
fileUuid := uuid.New().String()
|
|
|
|
fileUpload := "./upload/" + fileUuid + "_" + file.Filename
|
|
|
|
// сохраняем загруженный файл в /tmp
|
|
|
|
err = c.SaveUploadedFile(file, fileUpload)
|
2023-04-17 08:48:09 +03:00
|
|
|
if err != nil {
|
2023-04-22 04:29:10 +03:00
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": err.Error(),
|
2023-04-17 08:48:09 +03:00
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
var sirius model.Sirius
|
|
|
|
siriusJson, err := ioutil.ReadFile(fileUpload)
|
|
|
|
if err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": errors.New("No read file").Error(),
|
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
2023-04-17 08:48:09 +03:00
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
siriusJson = bytes.TrimPrefix(siriusJson, []byte("\xef\xbb\xbf"))
|
2023-04-17 08:48:09 +03:00
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
if !json.Valid(siriusJson) {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": errors.New("Formated file not supported").Error(),
|
2023-04-17 08:48:09 +03:00
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
err = json.Unmarshal(siriusJson, &sirius)
|
2023-04-17 08:48:09 +03:00
|
|
|
if err != nil {
|
2023-04-22 04:29:10 +03:00
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": errors.New("Error unmarshal file").Error(),
|
2023-04-17 08:48:09 +03:00
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-04-22 04:29:10 +03:00
|
|
|
fileConverted := "./convert/" + fileUuid + ".xlsx"
|
|
|
|
if err := SaveToExel(fileConverted, sirius.NewBolid().ZoneInfo()); err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": errors.New("Error create file").Error(),
|
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
siriusExel, err := ioutil.ReadFile(fileConverted)
|
|
|
|
if err != nil {
|
|
|
|
c.JSON(http.StatusBadRequest, gin.H{
|
|
|
|
"error": errors.New("No read file exel").Error(),
|
2023-04-17 08:48:09 +03:00
|
|
|
})
|
|
|
|
return
|
|
|
|
}
|
2023-04-22 04:29:10 +03:00
|
|
|
c.Data(200, "application/vnd.ms-excel", siriusExel)
|
2023-04-17 08:48:09 +03:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func SaveToExel(filename string, data []model.ZoneInfo) error {
|
|
|
|
f := excelize.NewFile()
|
|
|
|
defer func() {
|
|
|
|
if err := f.Close(); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
// Create a new sheet.
|
|
|
|
f.SetCellValue("Sheet1", "A2", "№ зоны")
|
|
|
|
f.SetCellValue("Sheet1", "B2", "Описание зоны")
|
|
|
|
f.SetCellValue("Sheet1", "C2", "Адреса в зоне")
|
|
|
|
i := 3
|
|
|
|
for _, d := range data {
|
|
|
|
f.SetCellValue("Sheet1", "A"+strconv.Itoa(i), d.ZoneNum)
|
|
|
|
f.SetCellValue("Sheet1", "B"+strconv.Itoa(i), d.ZoneName)
|
|
|
|
f.SetCellValue("Sheet1", "C"+strconv.Itoa(i), d.InputString())
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
// Save spreadsheet by the given path.
|
|
|
|
if err := f.SaveAs(filename); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|