docxTemplater/handlers/handlers.go
Danil Solovyov fba01b2518 Changes:
- Добавлена проверка токенов при запросе /amo/state
  - Исправлена работа с amo oauth-токенами
  - Добавлены примеры шаблонизатора
  - Добавлена возможность генерации и создания шаблонов из примеров
  - В ответ генератора добавлены ссылки для скачивания сгенерированных файлов
  - Вернул очиску temp после загрузки файла в Яндекс.Диск
  - yadisk.UploadResources - добавлено ожидание окончания отправки файла и таймаут в 5 секунд для отправки файла
  - Добавлены эндпоинты для загрузки файлов в хранилища
  - Актуализирован генератор по вебхуку
  - Обновлены генератор по данным
  - Обновлен генератор по лиду
2022-11-25 00:37:47 +05:00

93 lines
2.1 KiB
Go

package handlers
import (
"encoding/json"
"errors"
"github.com/Pena-Co-Ltd/amocrm_templategen_back/amo"
"github.com/Pena-Co-Ltd/amocrm_templategen_back/dal"
"github.com/Pena-Co-Ltd/amocrm_templategen_back/dal/model"
GDisk "github.com/Pena-Co-Ltd/amocrm_templategen_back/gdisk"
"github.com/Pena-Co-Ltd/amocrm_templategen_back/middleware"
YaDisk "github.com/Pena-Co-Ltd/amocrm_templategen_back/yadisk"
"go.uber.org/zap"
"html/template"
"io/ioutil"
"net/http"
)
type Handlers struct {
dal *dal.MongoDAL
YaDisk *YaDisk.ClientApp
GDisk *GDisk.ClientApp
Amo *amo.ClientApp
logger *zap.Logger
opts *HandlerVars
}
type HandlerVars struct {
Domain string
AmoRedirectUrn string
}
func NewHandlers(dal *dal.MongoDAL, yaDisk *YaDisk.ClientApp, gDisk *GDisk.ClientApp, amo *amo.ClientApp,
logger *zap.Logger, vars *HandlerVars) *Handlers {
return &Handlers{dal, yaDisk, gDisk, amo, logger, vars}
}
// LOCAL FUNCTIONS
func execTemplate(tplFile string, data interface{}, w http.ResponseWriter) error {
tpl := template.Must(template.ParseFiles("./template/"+tplFile, "./template/header.gohtml",
"./template/footer.gohtml"))
return tpl.Execute(w, data)
}
func sendResponse(w http.ResponseWriter, status int, response interface{}) error {
w.Header().Set("Content-Type", "application/json; charset=utf-8")
w.WriteHeader(status)
e := json.NewEncoder(w)
e.SetEscapeHTML(false)
return e.Encode(response)
}
func (h *Handlers) reportError(w http.ResponseWriter, err error, status int) {
h.logger.Error("ErrorHandler", zap.Error(err))
sendResponse(w, status, err.Error())
}
func getAmoByJwt(r *http.Request) *model.Amo {
amoData, ok := r.Context().Value("amoData").(*model.Amo)
if ok {
return amoData
}
return nil
}
func getJwtUser(r *http.Request) *middleware.UserClaims {
user, ok := r.Context().Value("JWT").(*middleware.UserClaims)
if ok {
return user
}
return nil
}
func decodePost(s interface{}, r *http.Request) error {
reqBody, err := ioutil.ReadAll(r.Body)
if err != nil {
return err
}
err = json.Unmarshal(reqBody, s)
return err
}
// ERRORS
var ErrorUnauthorized = errors.New("unauthorized")