// @Author gmy 2024/8/13 16:01:00
package controllers

import (
	"encoding/json"
	"eta/eta_index_lib/logic"
	"eta/eta_index_lib/models"
	"eta/eta_index_lib/services"
	"eta/eta_index_lib/utils"
	"fmt"
	"strconv"
	"time"
)

type BaseFromLyController struct {
	BaseAuthController
}

// Add
// @Title 新增粮油商务网指标
// @Description 新增粮油商务网指标
// @router /add [post]
func (this *BaseFromLyController) Add() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	source := utils.DATA_SOURCE_LY
	var req models.AddEdbInfoReq
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
	if err != nil {
		br.Msg = "参数解析异常!"
		br.ErrMsg = "参数解析失败,Err:" + err.Error()
		return
	}
	if req.EdbCode == "" {
		br.Msg = "请输入指标编码!"
		br.ErrMsg = "请输入指标编码,指标编码为空"
		return
	}
	cacheKey = utils.CACHE_EDB_DATA_ADD + strconv.Itoa(source) + "_" + req.EdbCode
	if !utils.Rc.IsExist(cacheKey) {
		utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
		err = models.AddEdbDataFromLy(req.EdbCode)
		if err != nil {
			br.Msg = "获取指标信息失败!"
			br.ErrMsg = "获取指标信息失败 AddEdbDataFromSci99,Err:" + err.Error()
			return
		}
		br.Ret = 200
		br.Success = true
		br.Msg = "获取成功"
	} else {
		br.Ret = 501
		br.Success = true
		br.Msg = "系统处理中,请稍后重试"
	}
}

// Refresh
// @Title 刷新粮油商务网指标接口
// @Description 刷新粮油商务网指标接口
// @Success 200 {object} models.RefreshEdbInfoReq
// @router /refresh [post]
func (this *BaseFromLyController) Refresh() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	source := utils.DATA_SOURCE_LY
	var req models.RefreshEdbInfoReq
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
	if err != nil {
		br.Msg = "参数解析异常!"
		br.ErrMsg = "参数解析失败,Err:" + err.Error()
		return
	}
	if req.EdbCode == "" {
		br.Msg = "请输入指标编码!"
		br.ErrMsg = "请输入指标编码,指标编码为空"
		return
	}
	if req.EdbInfoId <= 0 {
		br.Msg = "请输入指标ID!"
		br.ErrMsg = "请输入指标ID"
		return
	}

	// 获取指标详情
	edbInfo, err := models.GetEdbInfoByEdbCode(source, req.EdbCode)
	if err != nil {
		br.Msg = "指标不存在!"
		br.ErrMsg = "指标不存在"
		return
	}
	cacheKey = utils.CACHE_EDB_DATA_REFRESH + strconv.Itoa(source) + "_" + req.EdbCode
	if utils.Rc.IsExist(cacheKey) {
		br.Ret = 501
		br.Success = true
		br.Msg = "系统处理中,请稍后重试"
		return
	}
	dataUpdateTime := time.Now().Format(utils.FormatDateTime)
	utils.Rc.SetNX(cacheKey, 1, 1*time.Minute)
	err = models.RefreshEdbDataFromBloomberg(req.EdbInfoId, req.EdbCode, req.StartDate)
	if err != nil && err.Error() != utils.ErrNoRow() {
		br.Msg = "刷新指标信息失败!"
		br.ErrMsg = "刷新指标信息失败 RefreshEdbDataFromBloomberg,Err:" + err.Error()
		return
	}

	// 更新指标最大最小值
	erDataUpdateDate, err, errMsg := models.UnifiedModifyEdbInfoMaxAndMinInfoDataUpdate(edbInfo, dataUpdateTime)
	if err != nil {
		br.Msg = errMsg
		br.ErrMsg = err.Error()
		return
	}
	// 添加指标刷新成功日志
	if erDataUpdateDate != "" {
		_ = services.AddEdbInfoUpdateLog(edbInfo.EdbInfoId, 1, "", 1, "", 0, 0)
	} else {
		_ = services.AddEdbInfoUpdateLog(edbInfo.EdbInfoId, 1, "", 2, "未刷新到数据", 0, 0)
	}

	// 更新ES
	go logic.UpdateEs(edbInfo.EdbInfoId)

	br.Ret = 200
	br.Success = true
	br.Msg = "获取成功"
}

// GetLyClassifyByName
// @Title 获取分类
// @Description 获取分类
// @Success 200 {object} models.BaseFromLyClassify
// @router /get/ly/classify/by/name [post]
func (this *BaseFromLyController) GetLyClassifyByName() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		CategoryName string `json:"CategoryName"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}
	categoryName := reqData.CategoryName
	if categoryName == "" {
		br.Msg = "请输入分类!"
		br.ErrMsg = "请输入分类"
		return
	}

	lyClassify, err := models.GetLyClassifyByName(categoryName)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyClassify
	br.Msg = "获取成功"
}

// GetLyIndexRecordByUrl
// @Title 根据url获取指标已读取记录
// @Description 根据url获取指标已读取记录
// @Success 200 {object} models.BaseFromLyIndexRecord
// @router /get/ly/index/record/by/url [post]
func (this *BaseFromLyController) GetLyIndexRecordByUrl() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		Url string `json:"Url"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}
	url := reqData.Url
	if url == "" {
		br.Msg = "请输入地址链接!"
		br.ErrMsg = "请输入地址链接"
		return
	}

	lyIndexRecord, err := models.GetLyIndexRecordByUrl(url)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyIndexRecord
	br.Msg = "获取成功"
}

// AddLyIndexRecord
// @Title 维护指标数据读取进度到数据库
// @Description 维护指标数据读取进度到数据库
// @Success 200 string "处理成功"
// @router /add/ly/index/record [post]
func (this *BaseFromLyController) AddLyIndexRecord() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var req models.BaseFromLyIndexRecord
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
	if err != nil {
		br.Msg = "参数解析异常!"
		br.ErrMsg = "参数解析失败,Err:" + err.Error()
		return
	}

	id, err := models.AddLyIndexRecord(&req)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = id
	br.Msg = "处理成功"
}

// AddLyDataList
// @Title 新增指标数据
// @Description 新增指标数据列表
// @Success 200 string "处理成功"
// @router /add/ly/data/list [post]
func (this *BaseFromLyController) AddLyDataList() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var req []models.BaseFromLyData
	fmt.Println(string(this.Ctx.Input.RequestBody))
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
	if err != nil {
		br.Msg = "参数解析异常!"
		br.ErrMsg = "参数解析失败,Err:" + err.Error()
		return
	}

	err = models.AddLyDataList(req)
	if err != nil {
		br.Msg = "新增指标数据失败!"
		br.ErrMsg = "新增指标数据失败,Err:" + err.Error()
		return
	}

	br.Ret = 200
	br.Success = true
	br.Msg = "处理成功"
}

// AddLyIndex
// @Title 新增指标
// @Description 新增指标
// @Success 200 string "处理成功"
// @router /add/ly/index [post]
func (this *BaseFromLyController) AddLyIndex() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var req models.BaseFromLyIndex
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
	if err != nil {
		br.Msg = "参数解析异常!"
		br.ErrMsg = "参数解析失败,Err:" + err.Error()
		return
	}

	indexId, err := models.AddLyIndex(&req)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = indexId
	br.Msg = "处理成功"
}

// GetLyDataByIndexIdAndDataTime
// @Title 根据指标id和时间获取指标数据
// @Description 根据指标id和时间获取指标数据
// @Success 200 {object} models.BaseFromLyData
// @router /get/ly/data/by/index/id/and/data/time [post]
func (this *BaseFromLyController) GetLyDataByIndexIdAndDataTime() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		IndexId  int    `json:"IndexId"`
		DataTime string `json:"DataTime"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	indexId := reqData.IndexId
	if indexId == 0 {
		br.Msg = "请输入指标id!"
		br.ErrMsg = "请输入指标id"
		return
	}

	dataTime := reqData.DataTime
	if dataTime == "" {
		br.Msg = "请输入时间!"
		br.ErrMsg = "请输入时间"
		return
	}

	lyData, err := models.GetLyDataByIndexIdAndDataTime(indexId, dataTime)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyData
	br.Msg = "获取成功"
}

// GetLyDataByIndexIdAndDataTimeYM
// @Title 根据指标id和年月时间获取指标数据
// @Description 根据指标id和年月时间获取指标数据
// @Success 200 {object} models.BaseFromLyData
// @router /get/ly/data/by/index/id/and/data/time/ym [post]
func (this *BaseFromLyController) GetLyDataByIndexIdAndDataTimeYM() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		IndexId   int    `json:"IndexId"`
		YearMonth string `json:"YearMonth"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	indexId := reqData.IndexId
	if indexId == 0 {
		br.Msg = "请输入指标id!"
		br.ErrMsg = "请输入指标id"
		return
	}

	yearMonth := reqData.YearMonth

	if yearMonth == "" {
		br.Msg = "请输入时间!"
		br.ErrMsg = "请输入时间"
		return
	}

	lyData, err := models.GetLyDataByIndexIdAndDataTimeYM(indexId, yearMonth)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyData
	br.Msg = "获取成功"
}

// UpdateLyDataById
// @Title 更新数据源指标数据
// @Description 更新数据源指标数据
// @Success 200 string "处理成功"
// @router /update/ly/data/by/id [post]
func (this *BaseFromLyController) UpdateLyDataById() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		Id    int     `json:"Id"`
		Value float64 `json:"Value"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	id := reqData.Id
	if id == 0 {
		br.Msg = "请输入id!"
		br.ErrMsg = "请输入id"
		return
	}

	value := reqData.Value
	if value == 0 {
		br.Msg = "请输入值!"
		br.ErrMsg = "请输入值"
		return
	}

	err = models.UpdateLyDataById(id, value)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Msg = "处理成功"
}

// GetLyEdbDataByIndexCodeAndDataTime
// @Title 根据指标编码和模糊日期获取指标库数据
// @Description 根据指标编码和模糊日期获取指标库数据
// @Success 200 {object} []models.EdbDataLy
// @router /get/ly/edb/data/by/index/code/and/data/time [post]
func (this *BaseFromLyController) GetLyEdbDataByIndexCodeAndDataTime() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		IndexCode string `json:"IndexCode"`
		DataTime  string `json:"DataTime"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	indexCode := reqData.IndexCode
	if indexCode == "" {
		br.Msg = "请输入指标id!"
		br.ErrMsg = "请输入指标id"
		return
	}

	dataTime := reqData.DataTime
	if dataTime == "" {
		br.Msg = "请输入时间!"
		br.ErrMsg = "请输入时间"
		return
	}

	lyEdbData, err := models.GetLyEdbDataByIndexCodeAndDataTime(indexCode, dataTime)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyEdbData
	br.Msg = "获取成功"
}

// GetLyEdbDataByIndexCodeAndExactDataTime
// @Title 根据指标编码和精确日期获取指标库数据
// @Description 根据指标编码和精确日期获取指标库数据
// @Success 200 {object} []models.EdbDataLy
// @router /get/ly/edb/data/by/index/code/and/exact/data/time [post]
func (this *BaseFromLyController) GetLyEdbDataByIndexCodeAndExactDataTime() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		IndexCode string `json:"IndexCode"`
		DataTime  string `json:"DataTime"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	indexCode := reqData.IndexCode
	if indexCode == "" {
		br.Msg = "请输入指标id!"
		br.ErrMsg = "请输入指标id"
		return
	}

	dataTime := reqData.DataTime
	if dataTime == "" {
		br.Msg = "请输入时间!"
		br.ErrMsg = "请输入时间"
		return
	}

	lyEdbData, err := models.GetLyEdbDataByIndexCodeAndExactDataTime(indexCode, dataTime)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyEdbData
	br.Msg = "获取成功"
}

// UpdateLyEdbDataById
// @Title 更新指标库数据 须根据指标编码和日期更新 仅适合月度数据
// @Description 更新指标库数据 须根据指标编码和日期更新 仅适合月度数据
// @Success 200 string "处理成功"
// @router /update/ly/edb/data/by/id [post]
func (this *BaseFromLyController) UpdateLyEdbDataById() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		Id    int     `json:"Id"`
		Value float64 `json:"Value"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	id := reqData.Id
	if id == 0 {
		br.Msg = "请输入id!"
		br.ErrMsg = "请输入id"
		return
	}

	value := reqData.Value
	if value == 0 {
		br.Msg = "请输入值!"
		br.ErrMsg = "请输入值"
		return
	}

	err = models.UpdateLyEdbDataById(id, value)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Msg = "处理成功"
}

// GetLyIndexByCode
// @Title 查询指标编码是否存在
// @Description 查询指标编码是否存在
// @Success 200 {object} models.BaseFromLyIndex
// @router /get/ly/index/by/code [post]
func (this *BaseFromLyController) GetLyIndexByCode() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var reqData struct {
		IndexCode string `json:"IndexCode"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	indexCode := reqData.IndexCode
	if indexCode == "" {
		br.Msg = "请输入指标id!"
		br.ErrMsg = "请输入指标id"
		return
	}

	lyIndex, err := models.GetLyIndexByCode(indexCode)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyIndex
	br.Msg = "获取成功"
}

// GetEdbInfoByIndexCode
// @Title 根据指标code获取指标信息
// @Description 根据指标code获取指标信息
// @Success 200 {object} models.EdbInfo
// @router /get/edb/info/by/index/code [post]
func (this *BaseFromLyController) GetEdbInfoByIndexCode() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()

	var reqData struct {
		IndexCode string `json:"IndexCode"`
		Source    int    `json:"Source"`
	}
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqData)
	if err != nil {
		br.ErrMsg = "无法解析请求体"
		return
	}

	indexCode := reqData.IndexCode
	if indexCode == "" {
		br.Msg = "请输入指标id!"
		br.ErrMsg = "请输入指标id"
		return
	}
	source := reqData.Source
	if source == 0 {
		br.Msg = "请输入来源!"
		br.ErrMsg = "请输入来源"
		return
	}

	lyEdbData, err := models.GetEdbInfoByEdbCode(source, indexCode)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Data = lyEdbData
	br.Msg = "获取成功"
}

// AddBatchLyEdbData
// @Title 批量增加粮油指标库数据
// @Description 批量增加粮油指标库数据
// @Success 200 string "处理成功"
// @router /add/batch/ly/edb/data [post]
func (this *BaseFromLyController) AddBatchLyEdbData() {
	br := new(models.BaseResponse).Init()
	var cacheKey string
	defer func() {
		if br.ErrMsg == "" {
			br.IsSendEmail = false
		}
		_ = utils.Rc.Delete(cacheKey)
		this.Data["json"] = br
		this.ServeJSON()
	}()
	var req []models.EdbDataLy
	err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
	if err != nil {
		br.Msg = "参数解析异常!"
		br.ErrMsg = "参数解析失败,Err:" + err.Error()
		return
	}

	err = models.AddLyEdbDataList(req)
	if err != nil {
		return
	}

	br.Ret = 200
	br.Success = true
	br.Msg = "处理成功"
}