package knowledge import ( "encoding/json" "eta_gn/eta_api/controllers" "eta_gn/eta_api/models" "eta_gn/eta_api/models/knowledge" "eta_gn/eta_api/services" knowledgeServ "eta_gn/eta_api/services/knowledge" "eta_gn/eta_api/utils" "fmt" "html" "io/ioutil" "os" "path" "strconv" "strings" "time" "github.com/h2non/filetype" "github.com/rdlucklib/rdluck_tools/paging" "github.com/tealeg/xlsx" ) // 分类 type ResourceController struct { controllers.BaseAuthController } // ListReport // @Title 获取事件列表接口 // @Description 获取事件列表 // @Param PageSize query int true "每页数据条数" // @Param CurrentIndex query int true "当前页页码,从1开始" // @Param TimeType query string true "筛选的时间类别:publish_time(发布时间),modify_time(更新时间);approve_time(审批时间)" // @Param StartDate query string true "开始时间" // @Param EndDate query string true "结束时间" // @Param Frequency query string true "频度" // @Param ClassifyIds query int true "分类id, 多选, 英文逗号分隔" // @Param State query string true "状态, 多选, 英文逗号分隔" // @Param KeyWord query string true "搜索关键词" // @Param PublishSort query string true "desc:降序,asc 升序(预留)" // @Param FilterReportType query string true "筛选事件类型,1:公共研报,2:共享研报,3:我的研报" // @Param IncludeFile query string true "是否包含文件, no:不包含" // @Param SourceFrom query string true "来源, 用英文逗号分隔" // @Param IsShowMe query string true "只看我, false:全部, true:只看我" // @Param IsShowPublic query string true "只看我, false:全部, true:只看发布" // @Success 200 {object} knowledge.KnowledgeResourceListResp // @router /resource/list [get] func (this *ResourceController) List() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() pageSize, _ := this.GetInt("PageSize") currentIndex, _ := this.GetInt("CurrentIndex") classifyIds := this.GetString("ClassifyIds") state := this.GetString("State") // 添加人 addUserIds, _ := this.GetInt("SysUserIds") // 标签 tagIds := this.GetString("TagIds") keyWord := this.GetString("Keyword") resourceType, _ := this.GetInt("ResourceType") sourceFrom := this.GetString("SourceFrom") includeFile := this.GetString("IncludeFile") IsShowMe, _ := this.GetBool("IsShowMe") isShowPublic, _ := this.GetBool("IsShowPublic") var startSize int if pageSize <= 0 { pageSize = utils.PageSize20 } if currentIndex <= 0 { currentIndex = 1 } startSize = utils.StartIndex(currentIndex, pageSize) var condition string var pars []interface{} condition += ` AND resource_type = ? ` pars = append(pars, resourceType) if includeFile == "no" { condition += ` AND is_file = ? ` pars = append(pars, 0) } if IsShowMe { condition += ` AND admin_id = ? ` pars = append(pars, this.SysUser.AdminId) } if state != "" { stateArr := strings.Split(state, ",") condition += ` AND state in (?) ` pars = append(pars, stateArr) } if isShowPublic { condition += ` AND state = ? ` pars = append(pars, knowledge.KnowledgeResourceStatePassed) } if keyWord != "" { //按照空格划分为关键词数组 keyWordArr := strings.Split(keyWord, " ") lengthKey := len(keyWordArr) if lengthKey == 1 { condition += ` AND (title LIKE ?) ` pars = utils.GetLikeKeywordPars(pars, keyWord, 1) } else if lengthKey > 1 { for k, v := range keyWordArr { if k == 0 { condition += ` AND (title LIKE ? ` pars = utils.GetLikeKeywordPars(pars, v, 1) } else if k == lengthKey-1 { condition += ` OR title LIKE ? ) ` pars = utils.GetLikeKeywordPars(pars, v, 1) } else { condition += ` OR title LIKE ? ` pars = utils.GetLikeKeywordPars(pars, v, 1) } } } } if sourceFrom != "" { sourceArr := strings.Split(sourceFrom, ",") condition += ` AND source_from in (?) ` pars = append(pars, sourceArr) } if classifyIds != "" { //转成数组,并把类型转成int classifyIdsArr := strings.Split(classifyIds, ",") var classifyIdsInt []int for _, v := range classifyIdsArr { classifyId, _ := strconv.Atoi(v) classifyIdsInt = append(classifyIdsInt, classifyId) } condition += ` AND classify_id in (?) ` pars = append(pars, classifyIdsInt) } if addUserIds > 0 { // 转成数组,并把类型转成int addUserIdsArr := strings.Split(strconv.Itoa(addUserIds), ",") var addUserIdsInt []int for _, v := range addUserIdsArr { addUserId, _ := strconv.Atoi(v) addUserIdsInt = append(addUserIdsInt, addUserId) } condition += ` AND admin_id in (?) ` pars = append(pars, addUserIdsInt) } if tagIds != "" { //转成数组,并把类型转成int tagIdsArr := strings.Split(tagIds, ",") var tagIdsInt []int for _, v := range tagIdsArr { tagId, _ := strconv.Atoi(v) tagIdsInt = append(tagIdsInt, tagId) } condition += ` AND tag_id in (?) ` pars = append(pars, tagIdsInt) } var err error var total int var list []*knowledge.KnowledgeResourceList // 共享事件需要连表查询,所以需要单独写 total, err = knowledge.GetKnowledgeResourceListCount(condition, pars) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } listTmp, err := knowledge.GetKnowledgeResourcePageList(condition, pars, startSize, pageSize) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } // 整理分类ID classifyFullNameMap := make(map[int]string) classifyIdsArr := make([]int, 0) for _, v := range listTmp { classifyIdsArr = append(classifyIdsArr, v.ClassifyId) } // 获取分类列表 classifyList, err := knowledge.GetFullClassifyListByIdList(classifyIdsArr, resourceType) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } for _, v := range classifyList { name := v.ClassifyName if v.ParentName != "" { name = v.ParentName + "/" + name } if v.RootName != "" { name = v.RootName + "/" + name } classifyFullNameMap[v.ClassifyId] = name } // 整理标签ID tagNameMap := make(map[int]string) tagIdsArr := make([]int, 0) for _, v := range listTmp { tagIdsArr = append(tagIdsArr, v.TagId) } // 获取标签列表 tagObj := new(knowledge.KnowledgeTag) tagList, err := tagObj.GetListByIdList(tagIdsArr, resourceType) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() } for _, v := range tagList { tagNameMap[v.TagId] = v.TagName } for _, v := range listTmp { var startTime, endTime string if v.StartTime != nil && !v.StartTime.IsZero() { startTime = v.StartTime.In(time.Local).Format(utils.FormatDateTime) if resourceType == knowledge.KnowledgeResourceTypeReport || resourceType == knowledge.KnowledgeResourceTypeKnow { startTime = v.StartTime.In(time.Local).Format(utils.FormatDate) } } if v.EndTime != nil && !v.EndTime.IsZero() { endTime = v.EndTime.In(time.Local).Format(utils.FormatDateTime) if resourceType == knowledge.KnowledgeResourceTypeReport || resourceType == knowledge.KnowledgeResourceTypeKnow { endTime = v.EndTime.In(time.Local).Format(utils.FormatDate) } } modifyTime := v.ModifyTime.In(time.Local).Format(utils.FormatDateTime) createTime := v.CreateTime.In(time.Local).Format(utils.FormatDateTime) tmp := &knowledge.KnowledgeResourceList{ KnowledgeResourceId: v.KnowledgeResourceId, ResourceType: v.ResourceType, ClassifyId: v.ClassifyId, Title: v.Title, CreateTime: createTime, ModifyTime: modifyTime, State: v.State, ResourceCode: v.ResourceCode, AdminId: v.AdminId, AdminRealName: v.AdminRealName, SourceFrom: v.SourceFrom, TagId: v.TagId, StartTime: startTime, EndTime: endTime, } // todo 编辑状态 /*markStatus, err := services.UpdateReportEditMark(item.Id, 0, this.SysUser.AdminId, 2, this.SysUser.RealName, this.Lang) if err != nil { br.Msg = "查询标记状态失败" br.ErrMsg = "查询标记状态失败,Err:" + err.Error() return } if markStatus.Status == 0 { item.CanEdit = true } else { item.Editor = markStatus.Editor }*/ classifyName, ok := classifyFullNameMap[tmp.ClassifyId] if ok { tmp.ClassifyFullName = classifyName } tagName, ok := tagNameMap[v.TagId] if ok { tmp.TagName = tagName } list = append(list, tmp) } page := paging.GetPaging(currentIndex, pageSize, total) resp := new(knowledge.KnowledgeResourceListResp) resp.Paging = page resp.List = list br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // Search // @Title 获取事件列表接口 // @Description 获取事件列表 // @Param PageSize query int true "每页数据条数" // @Param CurrentIndex query int true "当前页页码,从1开始" // @Param TimeType query string true "筛选的时间类别:publish_time(发布时间),modify_time(更新时间);approve_time(审批时间)" // @Param StartDate query string true "开始时间" // @Param EndDate query string true "结束时间" // @Param Frequency query string true "频度" // @Param ClassifyIds query int true "分类id, 多选, 英文逗号分隔" // @Param SysUserIds query int true "用户id, 多选, 英文逗号分隔" // @Param State query int true "状态" // @Param KeyWord query string true "搜索关键词" // @Param PublishSort query string true "desc:降序,asc 升序(预留)" // @Param FilterReportType query string true "筛选事件类型,1:公共研报,2:共享研报,3:我的研报" // @Param IncludeFile query string true "是否包含文件, no:不包含" // @Param SourceFrom query string true "来源, 用英文逗号分隔" // @Param IsShowMe query string true "只看我, false:全部, true:只看我" // @Success 200 {object} knowledge.KnowledgeResourceListResp // @router /resource/search_by_es [get] func (this *ResourceController) Search() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() pageSize, _ := this.GetInt("PageSize") currentIndex, _ := this.GetInt("CurrentIndex") classifyIds := this.GetString("ClassifyIds") // 添加人 addUserIds := this.GetString("SysUserIds") // 标签 tagIds := this.GetString("TagIds") keyWord := this.GetString("Keyword") resourceType, _ := this.GetInt("ResourceType") sourceFrom := this.GetString("SourceFrom") includeFile := this.GetString("IncludeFile") IsShowMe, _ := this.GetBool("IsShowMe") var startSize int if pageSize <= 0 { pageSize = utils.PageSize20 } if currentIndex <= 0 { currentIndex = 1 } startSize = utils.StartIndex(currentIndex, pageSize) isIncludeFile := true if includeFile == "no" { isIncludeFile = false } var searchUserIds []int if addUserIds != "" { // 转成数组,并把类型转成int addUserIdsArr := strings.Split(addUserIds, ",") for _, v := range addUserIdsArr { addUserId, _ := strconv.Atoi(v) searchUserIds = append(searchUserIds, addUserId) } } var myId int if IsShowMe { myId = this.SysUser.AdminId } var sourceFromArr []string if sourceFrom != "" { sourceFromArr = strings.Split(sourceFrom, ",") } var classifyIdsInt []int if classifyIds != "" { //转成数组,并把类型转成int classifyIdsArr := strings.Split(classifyIds, ",") for _, v := range classifyIdsArr { classifyId, _ := strconv.Atoi(v) classifyIdsInt = append(classifyIdsInt, classifyId) } } var tagIdsInt []int if tagIds != "" { //转成数组,并把类型转成int tagIdsArr := strings.Split(tagIds, ",") for _, v := range tagIdsArr { tagId, _ := strconv.Atoi(v) tagIdsInt = append(tagIdsInt, tagId) } } listTmp, total, err := knowledgeServ.SearchKnowledgeResourceByEs( resourceType, keyWord, searchUserIds, myId, classifyIdsInt, sourceFromArr, tagIdsInt, isIncludeFile, startSize, pageSize, ) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } var list []*knowledge.KnowledgeResourceList // 整理分类ID classifyFullNameMap := make(map[int]string) classifyIdsArr := make([]int, 0) for _, v := range listTmp { classifyIdsArr = append(classifyIdsArr, v.ClassifyId) } // 获取分类列表 classifyList, err := knowledge.GetFullClassifyListByIdList(classifyIdsArr, resourceType) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } for _, v := range classifyList { name := v.ClassifyName if v.ParentName != "" { name = v.ParentName + "/" + name } if v.RootName != "" { name = v.RootName + "/" + name } classifyFullNameMap[v.ClassifyId] = name } // 整理标签ID tagNameMap := make(map[int]string) tagIdsArr := make([]int, 0) for _, v := range listTmp { tagIdsArr = append(tagIdsArr, v.TagId) } // 获取标签列表 tagObj := new(knowledge.KnowledgeTag) tagList, err := tagObj.GetListByIdList(tagIdsArr, resourceType) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() } for _, v := range tagList { tagNameMap[v.TagId] = v.TagName } for _, v := range listTmp { var startTime, endTime string if v.StartTime != nil && !v.StartTime.IsZero() { startTime = v.StartTime.In(time.Local).Format(utils.FormatDateTime) if resourceType == knowledge.KnowledgeResourceTypeOpinion || resourceType == knowledge.KnowledgeResourceTypeKnow { startTime = v.StartTime.In(time.Local).Format(utils.FormatDate) } } if v.EndTime != nil && !v.EndTime.IsZero() { endTime = v.EndTime.In(time.Local).Format(utils.FormatDateTime) if resourceType == knowledge.KnowledgeResourceTypeOpinion || resourceType == knowledge.KnowledgeResourceTypeKnow { endTime = v.EndTime.In(time.Local).Format(utils.FormatDate) } } modifyTime := v.ModifyTime.In(time.Local).Format(utils.FormatDateTime) createTime := v.CreateTime.In(time.Local).Format(utils.FormatDateTime) tmp := &knowledge.KnowledgeResourceList{ KnowledgeResourceId: v.KnowledgeResourceId, ResourceType: v.ResourceType, ClassifyId: v.ClassifyId, Title: v.Title, Content: v.Content, CreateTime: createTime, ModifyTime: modifyTime, State: v.State, ResourceCode: v.ResourceCode, AdminId: v.AdminId, AdminRealName: v.AdminRealName, SourceFrom: v.SourceFrom, TagId: v.TagId, StartTime: startTime, EndTime: endTime, } classifyName, ok := classifyFullNameMap[tmp.ClassifyId] if ok { tmp.ClassifyFullName = classifyName } tagName, ok := tagNameMap[v.TagId] if ok { tmp.TagName = tagName } list = append(list, tmp) } // list := make([]*knowledge.KnowledgeResourceList, 0, len(knowledges)) // for _, v := range knowledges { // item := new(knowledge.KnowledgeResourceList) // item.KnowledgeResourceId = v.KnowledgeResourceId // item.ResourceType = v.ResourceType // item.ClassifyId = v.ClassifyId // item.Title = v.Title // item.CreateTime = v.CreateTime.Format(utils.FormatDateTime) // item.ModifyTime = v.ModifyTime.Format(utils.FormatDateTime) // item.State = v.State // item.Content = v.Content // item.ResourceCode = v.ResourceCode // item.AdminId = v.AdminId // item.AdminRealName = v.AdminRealName // item.SourceFrom = v.SourceFrom // item.TagId = v.TagId // if v.StartTime != nil { // item.StartTime = v.StartTime.Format(utils.FormatDateTime) // } // if v.EndTime != nil { // item.EndTime = v.EndTime.Format(utils.FormatDateTime) // } // list = append(list, item) // } page := paging.GetPaging(currentIndex, pageSize, int(total)) resp := new(knowledge.KnowledgeResourceListResp) resp.Paging = page resp.List = list br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // Add // @Title 新增事件接口 // @Description 新增事件(区分事件类型) // @Param request body knowledge.AddReq true "type json string" // @Success 200 {object} knowledge.AddResp // @router /resource/add [post] func (this *ResourceController) Add() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } var reqList []knowledge.AddReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &reqList) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } for _, req := range reqList { if req.Title == `` { br.Msg = "标题不能为空" br.ErrMsg = "标题不能为空" br.IsSendEmail = false return } // 判断标题长度,如果超过600个字符则报错 //fmt.Println(len(req.Title)) if len(req.Title) > 600 { br.Msg = "标题过长" return } if req.ClassifyId <= 0 { br.Msg = "分类必填" br.ErrMsg = "分类必填" br.IsSendEmail = false return } if req.ResourceType == knowledge.KnowledgeResourceTypeEvent || req.ResourceType == knowledge.KnowledgeResourceTypePolicy || req.ResourceType == knowledge.KnowledgeResourceTypeOpinion { if req.StartTime == "" { br.Msg = "开始时间必填" br.ErrMsg = "开始时间必填" return } } _, err, errMsg := knowledgeServ.AddResource(&req, sysUser) if err != nil { br.Msg = "保存失败" if errMsg != "" { br.Msg = errMsg } br.ErrMsg = "保存失败,Err:" + err.Error() return } } /*resp := new(knowledge.AddResp) resp.KnowledgeResourceId = item.KnowledgeResourceId resp.ResourceCode = item.ResourceCode*/ br.Ret = 200 br.Success = true br.Msg = "保存成功" //br.Data = resp } // Edit // @Title 编辑事件基础信息接口 // @Description 编辑事件基础信息(不区分事件类型) // @Param request body knowledge.EditReq true "type json string" // @Success 200 {object} knowledge.EditResp // @router /resource/edit [post] func (this *ResourceController) Edit() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } var req knowledge.EditReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.KnowledgeResourceId <= 0 { br.Msg = "请选择事件" br.ErrMsg = "请选择事件" return } if req.Title == `` { br.Msg = "标题不能为空" br.ErrMsg = "标题不能为空" br.IsSendEmail = false return } if len(req.Title) > 600 { br.Msg = "标题过长" return } if req.ClassifyId <= 0 { br.Msg = "分类必填" br.ErrMsg = "分类必填" br.IsSendEmail = false return } if req.ResourceType == knowledge.KnowledgeResourceTypeEvent || req.ResourceType == knowledge.KnowledgeResourceTypePolicy || req.ResourceType == knowledge.KnowledgeResourceTypeOpinion { if req.StartTime == "" { br.Msg = "开始时间必填" br.ErrMsg = "开始时间必填" return } } // todo 更新标记key /*markStatus, err := services.UpdateReportEditMark(int(req.KnowledgeResourceId), 0, sysUser.AdminId, 1, sysUser.RealName, this.Lang) if err != nil { br.Msg = err.Error() return } if markStatus.Status == 1 { br.Msg = markStatus.Msg //br.Ret = 202 //202 服务器已接受请求,但尚未处理。 return }*/ resourceObj := new(knowledge.KnowledgeResource) resourceInfo, e := resourceObj.GetById(int(req.KnowledgeResourceId)) if e != nil { if utils.IsErrNoRow(e) { br.Msg = "事件已被删除, 请刷新页面" return } br.Msg = "操作失败" br.ErrMsg = "获取事件失败, Err: " + e.Error() return } if resourceInfo.ResourceType != req.ResourceType { br.Msg = "事件类型错误" return } // 编辑事件信息 err, errMsg := knowledgeServ.EditResource(resourceInfo, req, sysUser) if err != nil { br.Msg = "保存失败" if errMsg != "" { br.Msg = errMsg } br.ErrMsg = "保存失败,Err:" + err.Error() return } resp := new(knowledge.EditResp) resp.KnowledgeResourceId = req.KnowledgeResourceId resp.ResourceCode = resourceInfo.ResourceCode br.Ret = 200 br.Success = true br.Msg = "保存成功" br.Data = resp } // Detail // @Title 获取事件详情接口 // @Description 获取事件详情 // @Param request body knowledge.KnowledgeResourceDetailReq true "type json string" // @Success 200 {object} knowledge.KnowledgeResource // @router /resource/detail [get] func (this *ResourceController) Detail() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() /*var req knowledge.KnowledgeResourceDetailReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.KnowledgeResourceId <= 0 { br.Msg = "参数错误" return }*/ knowledgeResourceId, err := this.GetInt("KnowledgeResourceId") if err != nil { br.Msg = "获取参数失败!" br.ErrMsg = "获取参数失败,Err:" + err.Error() return } if knowledgeResourceId <= 0 { br.Msg = "参数错误" return } resourceType, _ := this.GetInt("ResourceType") resourceObj := new(knowledge.KnowledgeResource) item, err := resourceObj.GetById(knowledgeResourceId) if err != nil { if utils.IsErrNoRow(err) { br.Msg = "事件已被删除" return } br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } if item.ResourceType != resourceType { br.Msg = "事件类型错误" return } knowledgeItem := new(knowledge.KnowledgeResourceDetail) var urls []string if item.IsFile == 1 { if item.FileUrl == "" { fileObj := new(knowledge.KnowledgeResourceFile) fileItem, err := fileObj.GetByResourceId(item.KnowledgeResourceId) if err != nil { br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } for _, v := range fileItem { urls = append(urls, v.FileUrl) } } else { urls = append(urls, item.FileUrl) } } item.Content = html.UnescapeString(item.Content) knowledgeItem.KnowledgeResourceId = item.KnowledgeResourceId knowledgeItem.ResourceType = item.ResourceType knowledgeItem.ClassifyId = item.ClassifyId knowledgeItem.Title = item.Title knowledgeItem.CreateTime = item.CreateTime knowledgeItem.ModifyTime = item.ModifyTime knowledgeItem.State = item.State knowledgeItem.Content = item.Content knowledgeItem.ResourceCode = item.ResourceCode knowledgeItem.AdminId = item.AdminId knowledgeItem.AdminRealName = item.AdminRealName knowledgeItem.SourceFrom = item.SourceFrom knowledgeItem.TagId = item.TagId knowledgeItem.StartTime = item.StartTime knowledgeItem.EndTime = item.EndTime knowledgeItem.IsFile = item.IsFile knowledgeItem.FileUrl = urls resp := &knowledge.KnowledgeResourceDetailView{ KnowledgeResourceDetail: knowledgeItem, } br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // SaveReportContent // @Title 保存草稿 // @Description 保存草稿 // @Param request body knowledge.SaveReportContent true "type json string" // @Success 200 {object} knowledge.KnowledgeResourceAuthorResp // @router /resource/saveContent [post] func (this *ResourceController) SaveReportContent() { br := new(models.BaseResponse).Init() br.IsSendEmail = false defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } var req knowledge.SaveReportContent err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } knowledgeResourceId := req.KnowledgeResourceId //noChangeFlag := req.NoChange if knowledgeResourceId <= 0 { resp := new(knowledge.SaveReportContentResp) resp.KnowledgeResourceId = knowledgeResourceId br.Ret = 200 br.Success = true br.Msg = "保存成功" br.Data = resp return } // 获取事件详情 /*resourceInfo, _ := knowledge.GetReportByknowledgeResourceId(req.KnowledgeResourceId) if resourceInfo != nil && resourceInfo.State == 2 { br.Msg = "该事件已发布,不允许编辑" br.ErrMsg = "该事件已发布,不允许编辑" br.IsSendEmail = false return } // 标记更新中 { markStatus, err := services.UpdateReportEditMark(req.KnowledgeResourceId, 0, sysUser.AdminId, 1, sysUser.RealName, this.Lang) if err != nil { br.Msg = err.Error() return } if markStatus.Status == 1 { br.Msg = markStatus.Msg return } } // 内容有过修改的话,那么逻辑处理 if noChangeFlag != 1 { content := req.Content if content == "" { content = this.GetString("Content") } if content != "" { e := utils.ContentXssCheck(req.Content) if e != nil { br.Msg = "存在非法标签" br.ErrMsg = "存在非法标签, Err: " + e.Error() return } contentClean, e := services.FilterReportContentBr(req.Content) if e != nil { br.Msg = "内容去除前后空格失败" br.ErrMsg = "内容去除前后空格失败, Err: " + e.Error() return } content = contentClean contentSub, err := services.GetReportContentSub(content) if err != nil { go alarm_msg.SendAlarmMsg("解析 ContentSub 失败,Err:"+err.Error(), 3) //utils.SendEmail(utils.APPNAME+"失败提醒", "解析 ContentSub 失败,Err:"+err.Error(), utils.EmailSendToUsers) } resourceInfo.Content = html.EscapeString(content) resourceInfo.ContentSub = html.EscapeString(contentSub) resourceInfo.ContentStruct = html.EscapeString(req.ContentStruct) resourceInfo.HeadImg = req.HeadImg resourceInfo.EndImg = req.EndImg resourceInfo.CanvasColor = req.CanvasColor resourceInfo.HeadResourceId = req.HeadResourceId resourceInfo.EndResourceId = req.EndResourceId resourceInfo.ModifyTime = time.Now() resourceInfo.ContentModifyTime = time.Now() updateCols := []string{"Content", "ContentSub", "ContentStruct", "HeadImg", "EndImg", "CanvasColor", "HeadResourceId", "EndResourceId", "ModifyTime", "ContentModifyTime"} err = resourceInfo.UpdateReport(updateCols) if err != nil { br.Msg = "保存失败" br.ErrMsg = "保存失败,Err:" + err.Error() return } go knowledge.AddReportSaveLog(knowledgeResourceId, this.SysUser.AdminId, resourceInfo.Content, resourceInfo.ContentSub, resourceInfo.ContentStruct, resourceInfo.CanvasColor, this.SysUser.AdminName, resourceInfo.HeadResourceId, resourceInfo.EndResourceId) } } */ resp := new(knowledge.SaveReportContentResp) resp.KnowledgeResourceId = knowledgeResourceId br.Ret = 200 br.Success = true br.Msg = "保存成功" br.Data = resp } // BaseDetail // @Title 获取事件基础信息详情接口 // @Description 获取事件基础信息详情接口 // @Param request body knowledge.KnowledgeResourceDetailReq true "type json string" // @Success 200 {object} knowledge.KnowledgeResource // @router /resource/detail/base [get] func (this *ResourceController) BaseDetail() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() /*var req knowledge.KnowledgeResourceDetailReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.KnowledgeResourceId <= 0 { br.Msg = "参数错误" return }*/ /*knowledgeResourceId, err := this.GetInt("KnowledgeResourceId") if err != nil { br.Msg = "获取参数失败!" br.ErrMsg = "获取参数失败,Err:" + err.Error() return } if knowledgeResourceId <= 0 { br.Msg = "参数错误" return } resourceInfo, err := knowledge.GetReportById(knowledgeResourceId) if err != nil { if utils.IsErrNoRow(err) { br.Msg = "事件已被删除" return } br.Msg = "获取失败" br.ErrMsg = "获取失败,Err:" + err.Error() return } // 基础信息就不获取章节信息了 chapterList := make([]*knowledge.KnowledgeResourceChapter, 0) resourceInfo.Content = html.UnescapeString(resourceInfo.Content) resourceInfo.ContentSub = html.UnescapeString(resourceInfo.ContentSub) grandAdminList := make([]knowledge.KnowledgeResourceDetailViewAdmin, 0) permissionList := make([]knowledge.KnowledgeResourceDetailViewPermission, 0) // 处理事件授权用户列表 { obj := report.ReportGrant{} grantList, tmpErr := obj.GetGrantListById(knowledgeResourceId) if tmpErr != nil { br.Msg = "获取章节id授权用户列表失败" br.ErrMsg = "获取章节id授权用户列表失败, Err: " + tmpErr.Error() return } if len(grantList) > 0 { grandAdminIdList := make([]int, 0) for _, v := range grantList { grandAdminIdList = append(grandAdminIdList, v.AdminId) } adminList, tmpErr := system.GetAdminListByIdList(grandAdminIdList) if tmpErr != nil { br.Msg = "获取章节id授权用户列表失败" br.ErrMsg = "获取章节id授权用户列表失败, Err: " + tmpErr.Error() return } for _, v := range adminList { grandAdminList = append(grandAdminList, knowledge.KnowledgeResourceDetailViewAdmin{ AdminId: v.AdminId, AdminName: v.RealName, }) } } } // 处理章节id关联品种id列表 { minClassifyId := resourceInfo.ClassifyIdThird if minClassifyId <= 0 { minClassifyId = resourceInfo.ClassifyIdSecond } if minClassifyId <= 0 { minClassifyId = resourceInfo.ClassifyIdFirst } if minClassifyId <= 0 { br.Msg = "分类异常" br.ErrMsg = "分类异常" return } // 获取分类关联的品种id classifyPermissionList, tmpErr := knowledge.GetPermission(minClassifyId) if tmpErr != nil { br.Msg = "获取分类信息失败" br.ErrMsg = "获取失败,Err:" + tmpErr.Error() return } if len(classifyPermissionList) > 0 { permissionIdList := make([]int, 0) for _, v := range classifyPermissionList { permissionIdList = append(permissionIdList, v.ChartPermissionId) } adminList, tmpErr := knowledge.GetChartPermissionByIdList(permissionIdList) if tmpErr != nil { br.Msg = "获取章节id授权用户列表失败" br.ErrMsg = "获取章节id授权用户列表失败, Err: " + tmpErr.Error() return } for _, v := range adminList { permissionList = append(permissionList, knowledge.KnowledgeResourceDetailViewPermission{ PermissionId: v.ChartPermissionId, PermissionName: v.PermissionName, }) } } } resp := &knowledge.KnowledgeResourceDetailView{ ReportDetail: resourceInfo, ChapterList: chapterList, GrandAdminList: grandAdminList, PermissionList: permissionList, } br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp*/ } // Delete // @Title 删除事件接口 // @Description 删除事件 // @Param request body knowledge.DeleteReq true "type json string" // @Success 200 Ret=200 删除成功 // @router /resource/delete [post] func (this *ResourceController) Delete() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() var req knowledge.DeleteReq err := json.Unmarshal(this.Ctx.Input.RequestBody, &req) if err != nil { br.Msg = "参数解析异常!" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } if req.KnowledgeResourceId <= 0 { br.Msg = "参数错误" br.ErrMsg = "参数错误,事件id不可为空" return } resourceObj := new(knowledge.KnowledgeResource) item, err := resourceObj.GetById(req.KnowledgeResourceId) if err != nil { if utils.IsErrNoRow(err) { br.Msg = "事件不存在" br.ErrMsg = "事件不存在" return } } if item.ResourceType != req.ResourceType { br.Msg = "事件类型不匹配" return } if err = item.Delete(req.KnowledgeResourceId); err != nil { br.Msg = "删除失败" br.ErrMsg = "删除事件失败, Err: " + err.Error() return } go func() { item.IsDelete = 1 er := knowledgeServ.EsAddOrEditKnowledgeResource(item) if er != nil { utils.FileLog.Info("知识资源id:" + strconv.Itoa(req.KnowledgeResourceId) + ",删除事件同步es失败, Err: " + er.Error()) } }() br.Ret = 200 br.Success = true br.Msg = "删除成功" } // ImportData // @Title Excel导入事件 // @Description Excel导入事件 // @Param EntryFile query file true "文件" // @Success 200 Ret=200 录入成功 // @router /resource/import_add [post] func (c *ResourceController) ImportData() { br := new(models.BaseResponse).Init() defer func() { c.Data["json"] = br c.ServeJSON() }() sysUser := c.SysUser if sysUser == nil { br.Msg = "请重新登录" return } resourceType, _ := c.GetInt("ResourceType") file, _, err := c.GetFile("EntryFile") if err != nil { br.Msg = "获取文件失败" br.ErrMsg = "获取文件失败,Err:" + err.Error() return } path := "./static/knowledge_import_" + strconv.Itoa(resourceType) + "_" + time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx" defer file.Close() err = c.SaveToFile("EntryFile", path) if err != nil { br.Msg = "文件保存失败" br.ErrMsg = "文件保存失败,Err:" + err.Error() return } //if utils.RunMode == "debug" { defer os.Remove(path) //} successCount, failCount, err, errMsg := knowledgeServ.ImportResourceData(path, resourceType, sysUser) if err != nil { br.Msg = errMsg br.ErrMsg = err.Error() return } resp := models.EdbdataImportResp{ SuccessCount: successCount, FailCount: failCount, } if failCount > 0 { if successCount == 0 { resp.Status = -1 resp.Msg = "导入失败" } else { resp.Status = 1 resp.Msg = "存在部分导入失败" } } else { resp.Status = 0 } br.Msg = "导入成功" br.Ret = 200 br.Success = true br.Data = resp } // ImportFailListDownload // @Title 下载失败列表 // @Description 下载失败列表 // @Success 200 {object} models.EdbdataClassifyResp // @router /resource/download_fail [get] func (this *ResourceController) ImportFailListDownload() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请重新登录" return } resourceType, _ := this.GetInt("ResourceType") failObj := new(knowledge.KnowledgeImportFail) item, err := failObj.GetListBySysUserId(sysUser.AdminId, resourceType) if err != nil { br.Msg = "获取数据失败" br.Msg = "获取数据失败,Err:" + err.Error() return } xlsxFile := xlsx.NewFile() SheetName := "导入失败数据" if this.Lang == utils.EnLangVersion { SheetName = "Import Fail List" } sheet, err := xlsxFile.AddSheet(SheetName) if err != nil { br.Msg = "获取sheet失败" br.Msg = "获取sheet失败,Err:" + err.Error() return } if resourceType == knowledge.KnowledgeResourceTypeEvent || resourceType == knowledge.KnowledgeResourceTypePolicy { headRow := sheet.AddRow() headRow.AddCell().SetValue("开始日期") headRow.AddCell().SetValue("开始时间") headRow.AddCell().SetValue("结束日期") headRow.AddCell().SetValue("结束时间") headRow.AddCell().SetValue("标题") headRow.AddCell().SetValue("正文") headRow.AddCell().SetValue("来源") headRow.AddCell().SetValue("一级分类") headRow.AddCell().SetValue("二级分类") headRow.AddCell().SetValue("三级分类") headRow.AddCell().SetValue("标签") headRow.AddCell().SetValue("备注") for _, v := range item { row := sheet.AddRow() row.AddCell().SetValue(v.StartDate) row.AddCell().SetValue(v.StartTime) row.AddCell().SetValue(v.EndDate) row.AddCell().SetValue(v.EndTime) row.AddCell().SetValue(v.Title) row.AddCell().SetValue(v.Content) row.AddCell().SetValue(v.SourceFrom) row.AddCell().SetValue(v.ClassifyFirst) row.AddCell().SetValue(v.ClassifySecond) row.AddCell().SetValue(v.ClassifyThird) row.AddCell().SetValue(v.Tag) row.AddCell().SetValue(v.Remark) } } else { headRow := sheet.AddRow() headRow.AddCell().SetValue("时间") headRow.AddCell().SetValue("标题") headRow.AddCell().SetValue("正文") headRow.AddCell().SetValue("来源") headRow.AddCell().SetValue("一级分类") headRow.AddCell().SetValue("二级分类") headRow.AddCell().SetValue("三级分类") headRow.AddCell().SetValue("标签") headRow.AddCell().SetValue("备注") for _, v := range item { row := sheet.AddRow() row.AddCell().SetValue(v.StartDate) row.AddCell().SetValue(v.Title) row.AddCell().SetValue(v.Content) row.AddCell().SetValue(v.SourceFrom) row.AddCell().SetValue(v.ClassifyFirst) row.AddCell().SetValue(v.ClassifySecond) row.AddCell().SetValue(v.ClassifyThird) row.AddCell().SetValue(v.Tag) row.AddCell().SetValue(v.Remark) } } fileName := time.Now().Format(utils.FormatDateTimeUnSpace) + ".xlsx" savePath := "./static/" + fileName err = xlsxFile.Save(savePath) if err != nil { br.Msg = "文件保存失败" br.ErrMsg = "文件保存失败,Err:" + err.Error() return } defer func() { os.Remove(savePath) }() finalFileName := "失败列表.xlsx" if this.Lang == utils.EnLangVersion { finalFileName = "Failure List.xlsx" } this.Ctx.Output.Download(savePath, finalFileName) } // ResourceUpload 上传文件 // @Title 上传文件 // @Description 上传文件 // @Param MenuId query int true "目录ID" // @Param File query file true "文件" // @Success 200 Ret=200 操作成功 // @router /resource/upload [post] func (this *ResourceController) ResourceUpload() { br := new(models.BaseResponse).Init() defer func() { if br.ErrMsg == "" { br.IsSendEmail = false } this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请登录" br.ErrMsg = "请登录,SysUser Is Empty" br.Ret = 408 return } f, h, e := this.GetFile("File") if e != nil { br.Msg = "获取资源信息失败" br.ErrMsg = "获取资源信息失败, Err:" + e.Error() return } defer func() { _ = f.Close() }() // 不依赖于文件扩展名检查文件格式 fileData, e := ioutil.ReadAll(f) if e != nil { br.Msg = "上传失败" br.ErrMsg = "读取文件失败, Err: " + e.Error() return } ext := path.Ext(h.Filename) //fmt.Println("ext", ext) kind, _ := filetype.Match(fileData) //fmt.Println("kind.Extension", kind.Extension) if ext != ".pdf" && ext != ".ppt" && ext != ".pptx" && ext != ".docx" && ext != ".doc" && kind.Extension != "pdf" && kind.Extension != "ppt" && kind.Extension != "pptx" && kind.Extension != "docx" && kind.Extension != "doc" { br.Msg = "文件格式有误" return } uploadDir := utils.STATIC_DIR + "hongze/" + time.Now().Format("20060102") if e = os.MkdirAll(uploadDir, utils.DIR_MOD); e != nil { br.Msg = "存储目录创建失败" br.ErrMsg = "存储目录创建失败, Err:" + e.Error() return } ossFileName := utils.GetRandStringNoSpecialChar(28) + ext filePath := uploadDir + "/" + ossFileName if e = this.SaveToFile("File", filePath); e != nil { br.Msg = "文件保存失败" br.ErrMsg = "文件保存失败, Err:" + e.Error() return } defer func() { _ = os.Remove(filePath) }() // 上传到阿里云 ossDir := utils.RESOURCE_DIR + "knowledge_resource/" resourceUrl := `` savePath := ossDir + time.Now().Format("200601/20060102/") + ossFileName ossClient := services.NewOssClient() if ossClient == nil { br.Msg = "上传失败" br.ErrMsg = "初始化OSS服务失败" return } resourceUrl, e = ossClient.UploadFile(ossFileName, filePath, savePath) if e != nil { br.Msg = "文件上传失败" br.ErrMsg = "文件上传失败,Err:" + e.Error() return } resourceItem := &knowledge.UpdateResourceResp{ FileUrl: resourceUrl, } br.Msg = "上传成功" br.Ret = 200 br.Success = true br.Data = resourceItem } // GetSourceFrom // @Title 获取所有来源 // @Description 获取所有来源 // @Success 200 {object} models.EdbdataClassifyResp // @router /resource/source_from [get] func (this *ResourceController) GetSourceFrom() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请重新登录" return } resourceType, _ := this.GetInt("ResourceType") keyword := this.GetString("Keyword") resourceObj := new(knowledge.KnowledgeResource) list, err := resourceObj.GetSourceFrom(keyword, resourceType) if err != nil { br.Msg = "获取数据失败" br.Msg = "获取数据失败,Err:" + err.Error() return } resp := new(knowledge.GetSourceFromResp) resp.List = list br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // GetAdminList // @Title 获取所有创建人 // @Description 获取所有创建人 // @Success 200 {object} models.EdbdataClassifyResp // @router /resource/admins [get] func (this *ResourceController) GetAdminList() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请重新登录" return } resourceType, _ := this.GetInt("ResourceType") keyword := this.GetString("Keyword") resourceObj := new(knowledge.KnowledgeResource) list, err := resourceObj.GetAdmins(keyword, resourceType) if err != nil { br.Msg = "获取数据失败" br.Msg = "获取数据失败,Err:" + err.Error() return } resp := new(knowledge.GetAdminsResp) resp.List = list br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // TemplateDownload // @Title 下载模板 // @Description 下载模板 // @Success 200 {object} models.EdbdataClassifyResp // @Param ResourceType query int false "来源:1:模板1;2:模板2" // @router /resource/template [get] func (this *ResourceController) TemplateDownload() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() resourceType, _ := this.GetInt("ResourceType") downUrl := "" fileName := "" switch resourceType { case 1: downUrl = "./static/template/政策库上传模板.xlsx" fileName = "政策库上传模板.xlsx" case 2: downUrl = "./static/template/观点库上传模板.xlsx" fileName = "观点库上传模板.xlsx" case 3: downUrl = "./static/template/知识库上传模板.xlsx" fileName = "知识库上传模板.xlsx" default: downUrl = "./static/template/事件库上传模板.xlsx" fileName = "事件库上传模板.xlsx" } // 判断文件是否存在 if _, err := os.Stat(downUrl); os.IsNotExist(err) { br.Msg = "文件不存在" return } fmt.Println(downUrl, fileName) this.Ctx.Output.Download(downUrl, fileName) //this.Ctx.Output.Download("./static/数据导入模板.xlsx", "数据导入模板.xlsx") br.Ret = 200 br.Success = true br.Msg = "下载成功" } // Public // @Title 设置知识库事件公开接口 // @Description 设置知识库事件公开接口 // @Param request body knowledge.AddReq true "type json string" // @Success 200 {object} knowledge.AddResp // @router /resource/public [post] func (this *ResourceController) Public() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() sysUser := this.SysUser if sysUser == nil { br.Msg = "请重新登录" return } var req knowledge.PublicReq if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil { br.Msg = "参数解析失败" br.ErrMsg = "参数解析失败,Err:" + e.Error() return } msg, err := knowledgeServ.SetKnowledgeResourcePublic(req.KnowledgeResourceId) if err != nil { if msg == "" { msg = "设置失败" } br.Msg = msg br.ErrMsg = "设置失败,Err:" + err.Error() return } br.Msg = "设置成功" br.Ret = 200 br.Success = true } // BiDashboardTmpResourceList // @Title 获取bi看报中的知识资源列表 // @Description 获取bi看报中的知识资源列表 // @Success 200 {object} models.EdbdataClassifyResp // @Param biDashboardDetailId query int true "看板详情ID" // @router /resource/bi_dashboard/list [get] func (this *ResourceController) BiDashboardCacheResourceList() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() biDashboardDetailId, _ := this.GetInt("BiDashboardDetailId") resp, msg, err := knowledgeServ.GetKnowledgeResourceTmpList(biDashboardDetailId, this.SysUser.AdminId) if err != nil { if msg == "" { msg = "获取数据失败" } br.Msg = msg br.ErrMsg = "获取数据失败,Err:" + err.Error() return } br.Ret = 200 br.Success = true br.Msg = "获取成功" br.Data = resp } // BiDashboardResourceSave // @Title 将知识资源库添加到bi看板 // @Description 将知识资源库添加到bi看板 // @Param request body knowledge.DeleteReq true "type json string" // @Success 200 {object} models.EdbdataClassifyResp // @router /resource/bi_dashboard/save [post] func (this *ResourceController) BiDashboardResourceSave() { br := new(models.BaseResponse).Init() defer func() { this.Data["json"] = br this.ServeJSON() }() var req knowledge.BiDashboardResourceAddReq if e := json.Unmarshal(this.Ctx.Input.RequestBody, &req); e != nil { br.Msg = "参数解析失败" br.ErrMsg = "参数解析失败,Err:" + e.Error() return } if len(req.KnowledgeResourceList) == 0 { // 则删除缓存中的数据 err := utils.Rc.Delete(utils.CACHE_KEY_BI_DASHBOARD_PREPARE_RESOURCE + strconv.Itoa(this.SysUser.AdminId)) if err != nil { br.Msg = "添加失败" br.ErrMsg = "删除缓存失败,Err:" + err.Error() return } br.Msg = "添加成功" br.Ret = 200 br.Success = true return } cacheData, err := json.Marshal(req) if err != nil { br.Msg = "添加失败" br.ErrMsg = "参数解析失败,Err:" + err.Error() return } err = utils.Rc.Put(utils.CACHE_KEY_BI_DASHBOARD_PREPARE_RESOURCE+strconv.Itoa(this.SysUser.AdminId), cacheData, time.Hour*24) if err != nil { br.Msg = "添加失败" br.ErrMsg = "添加失败,Err:" + err.Error() return } br.Msg = "添加成功" br.Ret = 200 br.Success = true }