company_apply_v2.go 83 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hz_crm_api/models"
  6. "hongze/hz_crm_api/models/company"
  7. "hongze/hz_crm_api/models/seal"
  8. "hongze/hz_crm_api/models/system"
  9. "hongze/hz_crm_api/services"
  10. "hongze/hz_crm_api/services/company_apply"
  11. contractService "hongze/hz_crm_api/services/contract"
  12. "hongze/hz_crm_api/utils"
  13. "sort"
  14. "strconv"
  15. "strings"
  16. "time"
  17. )
  18. // ApplyServiceUpdate
  19. // @Title 申请服务更新
  20. // @Description 申请服务更新接口
  21. // @Param request body company.CompanyApplyServiceUpdateReq true "type json string"
  22. // @Success Ret=200 申请成功
  23. // @router /apply/service/update [post]
  24. func (this *CompanyApplyController) ApplyServiceUpdate() {
  25. br := new(models.BaseResponse).Init()
  26. defer func() {
  27. this.Data["json"] = br
  28. this.ServeJSON()
  29. }()
  30. sysUser := this.SysUser
  31. if sysUser == nil {
  32. br.Msg = "请登录"
  33. br.ErrMsg = "请登录,SysUser Is Empty"
  34. br.Ret = 408
  35. return
  36. }
  37. var req company.CompanyApplyServiceUpdateReq
  38. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  39. if err != nil {
  40. br.Msg = "参数解析异常!"
  41. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  42. return
  43. }
  44. if req.CompanyId <= 0 {
  45. br.Msg = "参数错误"
  46. br.ErrMsg = "参数错误,客户id小于等于0"
  47. return
  48. }
  49. if req.StartDate == "" {
  50. br.Msg = "请选择合同开始日期"
  51. return
  52. }
  53. if req.EndDate == "" {
  54. br.Msg = "请选择合同结束日期"
  55. return
  56. }
  57. if req.Money <= 0 {
  58. br.Msg = "合同金额不能小于等于0"
  59. }
  60. if req.ContractType == "" {
  61. req.ContractType = "续约合同"
  62. //br.Msg = "请选择合同类型"
  63. //return
  64. }
  65. if req.PermissionIds == "" {
  66. br.Msg = "请选择权限"
  67. br.ErrMsg = "请选择权限"
  68. return
  69. }
  70. roleTypeCode := sysUser.RoleTypeCode
  71. productId := services.GetProductId(roleTypeCode)
  72. if productId == 0 {
  73. br.Msg = "参数错误"
  74. br.ErrMsg = "客户类型为:" + req.CompanyType
  75. return
  76. }
  77. //添加缓存,避免多次点击提交
  78. {
  79. deleteCache := true
  80. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  81. defer func() {
  82. if deleteCache {
  83. utils.Rc.Delete(cacheKey)
  84. }
  85. }()
  86. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  87. deleteCache = false
  88. br.Msg = "系统处理中,请勿重复操作"
  89. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  90. return
  91. }
  92. }
  93. approveRoleTypeCode := ""
  94. if productId == 1 {
  95. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  96. } else {
  97. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  98. }
  99. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  100. if err != nil {
  101. br.Msg = "获取客户信息失败"
  102. br.ErrMsg = "获取客户信息失败"
  103. return
  104. }
  105. if companyProduct.Status != utils.COMPANY_STATUS_FORMAL && companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  106. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  107. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  108. return
  109. }
  110. //客户归属判断-当前销售/咨询组共享销售
  111. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  112. br.Msg = "客户信息异常"
  113. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  114. return
  115. }
  116. mapPermissionIdUpgrade := make(map[int]int, 0)
  117. mapPermissionIdExpensive := make(map[int]int, 0)
  118. var raicontractType string
  119. if productId == 2 {
  120. // CRM13.3改-是否为权益内部人员, 非权益内部人员只能勾选行业不能勾选单独的主客观, 勾选行业(即勾选主观的ID需要加入客观的权限ID)
  121. isRai, e := services.CheckRaiAdmin(sysUser.AdminId)
  122. if e != nil {
  123. br.Msg = "获取失败"
  124. br.ErrMsg = "判断是否为权益内部人员失败, GetRaiAdmin Err: " + e.Error()
  125. return
  126. }
  127. var permissionIdsNew string
  128. permissionIdsNew, mapPermissionIdUpgrade, mapPermissionIdExpensive, err = services.CheckCompanyUpgradeV2(req.PermissionIds, isRai)
  129. if err != nil {
  130. br.Msg = "获取信息失败"
  131. br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  132. return
  133. }
  134. req.PermissionIds = permissionIdsNew
  135. //权益的新签合同重新定义,如果合同起始时间在新签合同起始日期 1年之内的,仍为新签合同。
  136. raicontractType = req.ContractType
  137. if raicontractType != "新签合同" && companyProduct.Status != utils.COMPANY_STATUS_FOREVER {
  138. //startDateTime, _ := time.Parse(utils.FormatDate, req.StartDate)
  139. //startDateTime = startDateTime.AddDate(-1, 0, 0)
  140. totalLastYear, err := contractService.GetCompanyContractCountRaiByLastYear(req.CompanyId, req.StartDate)
  141. if err != nil {
  142. br.Msg = "获取合同信息失败"
  143. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  144. return
  145. }
  146. if totalLastYear > 0 {
  147. raicontractType = "新签合同"
  148. req.ContractType = "新签合同"
  149. }
  150. }
  151. } else {
  152. permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  153. if err != nil {
  154. br.Msg = "获取信息失败"
  155. br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  156. return
  157. }
  158. req.PermissionIds = permissionStr
  159. }
  160. var approveUserId int
  161. var approveUserRealName string
  162. applyMethod := 5 //续约服务
  163. recordApproveContent := `正式客户申请续约`
  164. approveContent := `申请续约`
  165. messageContent := "续约申请单"
  166. operationRemark := `申请续约`
  167. operation := "service_update"
  168. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  169. if req.ContractType == "补充协议" {
  170. applyMethod = 6 //补充协议
  171. recordApproveContent = `正式客户新增补充协议`
  172. approveContent = `新增补充协议`
  173. messageContent = "补充协议申请单"
  174. operationRemark = `新增补充协议`
  175. operation = "add_agreement"
  176. }
  177. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  178. if err != nil && err.Error() != utils.ErrNoRow() {
  179. br.Msg = "获取审批信息失败"
  180. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  181. return
  182. }
  183. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  184. br.Msg = "审批用户不存在"
  185. br.ErrMsg = "审批用户不存在"
  186. return
  187. }
  188. var companyApprovalId int
  189. if req.CompanyApprovalId <= 0 {
  190. contractCode, err := company.GetCompanyContractCode()
  191. if err != nil {
  192. br.Msg = "生成合同编码失败"
  193. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  194. return
  195. }
  196. var sealId int
  197. if productId == 2 {
  198. contractCode, err = seal.GetSealCodeRai() //权益客户合同编号格式替换
  199. if err != nil {
  200. br.Msg = "生成合同编码失败"
  201. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  202. return
  203. }
  204. sealCount, err := seal.GetCountByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  205. if err != nil {
  206. br.Msg = "生成合同编码失败"
  207. br.ErrMsg = "获取用印合同数量信息失败,Err:" + err.Error()
  208. return
  209. }
  210. crmConfig, err := company.GetConfigDetailByCode("rai_seal_check") //权益非标合同是否校验用印提交
  211. if err != nil {
  212. br.Msg = "获取配置失败"
  213. br.ErrMsg = "获取配置失败,Err:" + err.Error()
  214. return
  215. }
  216. if sealCount == 0 && crmConfig.ConfigValue == "1" {
  217. br.Msg = "此合同暂未申请用印,请核对合同期限是否有误"
  218. return
  219. }
  220. if sealCount > 0 {
  221. sealInfo, err := seal.GetSealInfoByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  222. if err != nil {
  223. br.Msg = "生成合同编码失败"
  224. br.ErrMsg = "获取用印合同信息失败,Err:" + err.Error()
  225. return
  226. }
  227. contractCode = sealInfo.Code
  228. sealId = sealInfo.SealId
  229. }
  230. }
  231. //当前是否存在待审批的单子
  232. nowCompanyApprovalInfo, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  233. if (err == nil || nowCompanyApprovalInfo != nil) || err != nil && err.Error() != utils.ErrNoRow() {
  234. br.Msg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  235. br.ErrMsg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  236. return
  237. }
  238. //当前待审批的合同,有且只能存在一条
  239. //count, err := company.GetCompanyContractApproveCount(req.CompanyId, productId)
  240. //if err != nil {
  241. // br.Msg = "获取信息失败"
  242. // br.ErrMsg = "判断是否已存在待审批合同失败,Err:" + err.Error()
  243. // return
  244. //}
  245. //if count > 0 {
  246. // br.Msg = "此客户已提交过申请,请在客户审批列表重新提交"
  247. // return
  248. //}
  249. contract := new(company.CompanyContract)
  250. contract.CompanyId = req.CompanyId
  251. contract.ProductId = productId
  252. contract.ProductName = companyProduct.ProductName
  253. contract.CompanyProductId = companyProduct.CompanyProductId
  254. contract.ContractType = req.ContractType
  255. contract.RaiContractType = raicontractType
  256. contract.ContractCode = contractCode
  257. contract.StartDate = req.StartDate
  258. contract.EndDate = req.EndDate
  259. contract.Money = req.Money
  260. contract.PayMethod = req.PayMethod
  261. contract.PayChannel = req.PayChannel
  262. contract.ImgUrl = req.ImgUrl
  263. contract.Status = 0
  264. contract.Source = "上传附件"
  265. contract.CreateTime = time.Now()
  266. contract.ModifyTime = time.Now()
  267. contract.PackageType = req.PackageType
  268. contract.RaiPackageType = req.RaiPackageType
  269. contract.SellerIdInit = companyProduct.SellerId
  270. contract.SellerNameInit = companyProduct.SellerName
  271. contract.ShareSellerInit = companyProduct.ShareSeller
  272. contract.ShareSellerIdInit = companyProduct.ShareSellerId
  273. contract.SellerIdLast = companyProduct.SellerId
  274. contract.SellerNameLast = companyProduct.SellerName
  275. contract.ShareSellerLast = companyProduct.ShareSeller
  276. contract.ShareSellerIdLast = companyProduct.ShareSellerId
  277. newId, err := company.AddCompanyContract(contract)
  278. if err != nil {
  279. br.Msg = "新增合同失败"
  280. br.ErrMsg = "新增合同失败,Err:" + err.Error()
  281. return
  282. }
  283. //如果用印ID > 0 建立合同ID,与用印申请表的关系
  284. if sealId > 0 {
  285. //用印作废
  286. err = seal.UpdateSealCompanyContractId(int(newId), sealId)
  287. if err != nil {
  288. br.Msg = "操作失败"
  289. br.ErrMsg = "添加用印与合同的关系失败,Err:" + err.Error()
  290. return
  291. }
  292. }
  293. permissionArr := strings.Split(req.PermissionIds, ",")
  294. permissionMap := make(map[int]int) //权限id的map集合,用来避免重复添加权限校验
  295. permissionNameMap, err := services.GetPermissionNameMap()
  296. if err != nil {
  297. br.Msg = "新增合同失败"
  298. br.ErrMsg = "获取权限名称失败,Err:" + err.Error()
  299. return
  300. }
  301. for _, v := range permissionArr {
  302. item := new(company.CompanyContractPermission)
  303. item.CompanyId = req.CompanyId
  304. item.CompanyContractId = int(newId)
  305. chartPermissionId, tmpErr := strconv.Atoi(v)
  306. if tmpErr != nil {
  307. err = tmpErr
  308. return
  309. }
  310. //权限id判断,避免重复添加权限
  311. if _, ok := permissionMap[chartPermissionId]; ok {
  312. continue
  313. }
  314. permissionMap[chartPermissionId] = chartPermissionId
  315. item.ChartPermissionId = chartPermissionId
  316. item.PermissionName = permissionNameMap[chartPermissionId]
  317. //如果是研选扣点包的权限,写入扣点点数
  318. if chartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  319. item.Points = req.Points
  320. }
  321. item.StartDate = req.StartDate
  322. item.EndDate = req.EndDate
  323. item.IsUpgrade = mapPermissionIdUpgrade[chartPermissionId]
  324. item.ExpensiveYx = mapPermissionIdExpensive[chartPermissionId]
  325. item.ModifyTime = time.Now()
  326. item.CreateTime = time.Now()
  327. err = company.AddCompanyContractPermission(item)
  328. if err != nil {
  329. br.Msg = "新增合同失败"
  330. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  331. return
  332. }
  333. //新增日志
  334. {
  335. itemLog := new(company.CompanyContractPermissionLog)
  336. itemLog.CompanyId = req.CompanyId
  337. itemLog.CompanyContractId = int(newId)
  338. itemLog.ChartPermissionId = v
  339. itemLog.StartDate = req.StartDate
  340. itemLog.EndDate = req.EndDate
  341. itemLog.ModifyTime = time.Now()
  342. itemLog.CreateTime = time.Now()
  343. itemLog.LogCreateTime = time.Now()
  344. go company.AddCompanyContractPermissionLog(itemLog)
  345. }
  346. }
  347. approval := new(company.CompanyApproval)
  348. approval.CompanyId = req.CompanyId
  349. approval.ProductId = productId
  350. approval.ApproveStatus = "待审批"
  351. approval.ApproveUserId = 0
  352. approval.ApproveRoleTypeCode = approveRoleTypeCode
  353. approval.ApproveRealName = ""
  354. approval.ApproveTime = time.Now()
  355. approval.ApproveContent = approveContent
  356. approval.ApplyMethod = applyMethod
  357. approval.ApplyReasons = ""
  358. approval.ApplyUserId = sysUser.AdminId
  359. approval.ApplyRealName = sysUser.RealName
  360. approval.CompanyContractId = int(newId)
  361. approval.CreateTime = time.Now()
  362. approval.ModifyTime = time.Now()
  363. approval.IsFormal = companyProduct.IsFormal
  364. companyApprovalId, err = company.AddCompanyApproval(approval)
  365. if err != nil {
  366. br.Msg = "申请失败"
  367. br.ErrMsg = "申请失败,Err:" + err.Error()
  368. return
  369. }
  370. } else {
  371. // 有审批单
  372. recode, err := company.GetCompanyApprovalByApprovalId(req.CompanyApprovalId)
  373. if err != nil {
  374. br.Msg = "申请失败"
  375. br.ErrMsg = "获取审批记录失败,Err:" + err.Error()
  376. return
  377. }
  378. err = company.ModifyCompanyApplyServiceUpdate(&req, productId, recode.CompanyContractId, companyProduct.IsFormal, mapPermissionIdUpgrade, mapPermissionIdExpensive)
  379. if err != nil {
  380. br.Msg = "申请失败"
  381. br.ErrMsg = "申请失败,Err:" + err.Error()
  382. return
  383. }
  384. companyApprovalId = req.CompanyApprovalId
  385. }
  386. //新增操作记录
  387. {
  388. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, approveUserId, companyProduct.CompanyName,
  389. companyProduct.ProductName, sysUser.RealName, operationRemark, operation, recordApproveContent, approveUserRealName, "", companyProduct.Status)
  390. }
  391. //新增客户产品日志
  392. {
  393. logType := "modify"
  394. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  395. }
  396. //新增申请单
  397. err = company_apply.Apply(companyApprovalId, messageContent)
  398. if err != nil {
  399. br.Msg = "发起审批异常,请联系管理员"
  400. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  401. return
  402. }
  403. br.Ret = 200
  404. br.Success = true
  405. br.Msg = "申请成功"
  406. }
  407. // ApplyTurnPositive
  408. // @Title 申请转正
  409. // @Description 申请转正接口
  410. // @Param request body company.CompanyApplyTurnPositiveReq true "type json string"
  411. // @Success Ret=200 申请成功
  412. // @router /apply/turn/positive [post]
  413. func (this *CompanyApplyController) ApplyTurnPositive() {
  414. br := new(models.BaseResponse).Init()
  415. defer func() {
  416. this.Data["json"] = br
  417. this.ServeJSON()
  418. }()
  419. sysUser := this.SysUser
  420. if sysUser == nil {
  421. br.Msg = "请登录"
  422. br.ErrMsg = "请登录,SysUser Is Empty"
  423. br.Ret = 408
  424. return
  425. }
  426. var req company.CompanyApplyTurnPositiveReq
  427. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  428. if err != nil {
  429. br.Msg = "参数解析异常!"
  430. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  431. return
  432. }
  433. if req.CompanyId <= 0 {
  434. br.Msg = "参数错误"
  435. br.ErrMsg = "参数错误,客户id小于等于0"
  436. return
  437. }
  438. if req.StartDate == "" {
  439. br.Msg = "请选择合同开始日期"
  440. return
  441. }
  442. if req.EndDate == "" {
  443. br.Msg = "请选择合同结束日期"
  444. return
  445. }
  446. if req.Money <= 0 {
  447. br.Msg = "合同金额不能小于等于0"
  448. return
  449. }
  450. if req.PermissionIds == "" {
  451. br.Msg = "请选择权限"
  452. return
  453. }
  454. roleTypeCode := sysUser.RoleTypeCode
  455. productId := services.GetProductId(roleTypeCode)
  456. if productId == 0 {
  457. br.Msg = "参数错误"
  458. br.ErrMsg = "客户类型为:" + roleTypeCode
  459. return
  460. }
  461. //添加缓存,避免多次点击提交
  462. {
  463. deleteCache := true
  464. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  465. defer func() {
  466. if deleteCache {
  467. utils.Rc.Delete(cacheKey)
  468. }
  469. }()
  470. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  471. deleteCache = false
  472. br.Msg = "系统处理中,请勿重复操作"
  473. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  474. return
  475. }
  476. }
  477. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  478. if err != nil {
  479. br.Msg = "获取客户信息失败"
  480. br.ErrMsg = "获取客户信息失败"
  481. return
  482. }
  483. if companyProduct == nil {
  484. br.Msg = "获取客户信息失败"
  485. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  486. return
  487. }
  488. if companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT && companyProduct.InitStatus != utils.COMPANY_STATUS_FOREVER {
  489. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  490. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  491. return
  492. }
  493. mapPermissionIdUpgrade := make(map[int]int) // 权益主客观、行业升级、买方研选的处理
  494. permissionNameMap := make(map[int]string) // 权益行业名称处理
  495. permissionNames := req.PermissionNames
  496. expensiveYx := 0
  497. if productId == 2 {
  498. // 给升级的产业ID加一个极大值判断处理
  499. permissionSlice := strings.Split(req.PermissionIds, ",")
  500. mapPermissionId := make(map[int]int)
  501. //var permissionIdsNew string
  502. var permissionIdOnly int //处理普通权限与升级权限同时勾选的时候的拦截
  503. expId := utils.PERMISSION_ID_YANXUAN_DIFF + utils.CHART_PERMISSION_ID_YANXUAN
  504. // 获取行业主观对应的客观ID
  505. subObjMap, e := services.GetRaiSubObjPermissionIdMap()
  506. if e != nil {
  507. br.Msg = "操作失败"
  508. br.ErrMsg = "获取行业主观对应的客观ID失败, Err: " + e.Error()
  509. return
  510. }
  511. strPermissionIdArr := make([]string, 0) // 最终过滤后的权限IDs
  512. for _, v := range permissionSlice {
  513. permissionId, _ := strconv.Atoi(v)
  514. // 研选5w的处理
  515. if permissionId == expId {
  516. //permissionIdsNew += strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) + ","
  517. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN))
  518. expensiveYx = 1
  519. continue
  520. }
  521. // 研选10w的处理
  522. if permissionId == utils.PERMISSION_ID_YANXUAN_10W_DIFF {
  523. //permissionIdsNew += strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) + ","
  524. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN))
  525. expensiveYx = 2
  526. continue
  527. }
  528. if permissionId > utils.PERMISSION_ID_UPGRADE {
  529. //permissionIdsNew += strconv.Itoa(permissionId-utils.PERMISSION_ID_UPGRADE) + ","
  530. permissionIdOnly = permissionId - utils.PERMISSION_ID_UPGRADE
  531. // 升级权限, 需要加入客观的权限
  532. subId := permissionId - utils.PERMISSION_ID_UPGRADE
  533. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(subId))
  534. if subObjMap[subId] > 0 {
  535. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(subObjMap[subId]))
  536. }
  537. } else {
  538. //permissionIdsNew += strconv.Itoa(permissionId) + ","
  539. strPermissionIdArr = append(strPermissionIdArr, v)
  540. permissionIdOnly = permissionId
  541. }
  542. //权益的永续客户主客观权限都开
  543. if companyProduct.InitStatus == utils.COMPANY_STATUS_FOREVER && subObjMap[permissionId] > 0 {
  544. strPermissionIdArr = append(strPermissionIdArr, strconv.Itoa(subObjMap[permissionId]))
  545. }
  546. if _, ok := mapPermissionId[permissionIdOnly]; ok {
  547. br.Msg = "权限设置有误,请重新选择"
  548. br.ErrMsg = "升级权限与普通权限重复选择!" + req.PermissionIds
  549. return
  550. }
  551. mapPermissionId[permissionIdOnly] = permissionIdOnly
  552. }
  553. req.PermissionIds = strings.Join(strPermissionIdArr, ",")
  554. //req.PermissionIds = strings.TrimRight(permissionIdsNew, ",")
  555. // 是否为权益内部人员, 非权益内部人员只能勾选行业不能勾选单独的主客观, 需要通过主观的ID去查客观的ID
  556. //isRai, e := services.CheckRaiAdmin(sysUser.AdminId)
  557. //if e != nil {
  558. // br.Msg = "获取失败"
  559. // br.ErrMsg = "判断是否为权益内部人员失败, GetRaiAdmin Err: " + e.Error()
  560. // return
  561. //}
  562. //if !isRai {
  563. //permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  564. //if err != nil {
  565. // br.Msg = "获取信息失败"
  566. // br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  567. // return
  568. //}
  569. //req.PermissionIds = permissionStr
  570. //}
  571. // 升级map
  572. if permissionNames != "" {
  573. mapPermissionIdUpgrade, err = services.PermissionIdUpgrade(permissionNames)
  574. if err != nil {
  575. br.Msg = "获取信息失败"
  576. br.ErrMsg = "处理升级信息失败,Err:" + err.Error()
  577. return
  578. }
  579. }
  580. permissionNameMap, err = services.GetPermissionNameMap()
  581. if err != nil {
  582. br.Msg = "新增合同失败"
  583. br.ErrMsg = "获取权限名称失败,Err:" + err.Error()
  584. return
  585. }
  586. }
  587. //客户归属判断
  588. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  589. br.Msg = "客户信息异常"
  590. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  591. return
  592. }
  593. if companyProduct.ApproveStatus == "待审批" {
  594. br.Msg = "存在待审批订单,不可重复提交"
  595. return
  596. }
  597. approveContent := `试用转正式`
  598. var approveUserId int
  599. var approveUserRealName string
  600. approveRoleTypeCode := ""
  601. if productId == 1 {
  602. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  603. } else {
  604. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  605. }
  606. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  607. if err != nil && err.Error() != utils.ErrNoRow() {
  608. br.Msg = "获取审批信息失败"
  609. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  610. return
  611. }
  612. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  613. br.Msg = "审批用户不存在"
  614. br.ErrMsg = "审批用户不存在"
  615. return
  616. }
  617. // 合同类型
  618. contractType := req.ContractType
  619. var raicontractType string // 权益合同类型
  620. {
  621. if contractType == "" {
  622. contractType = "新签合同"
  623. }
  624. var condition string
  625. var pars []interface{}
  626. condition += " AND product_id = ?"
  627. pars = append(pars, productId)
  628. condition += " AND status = ?"
  629. pars = append(pars, 1)
  630. list, e := company.GetCompanyContractListByCompanyId(req.CompanyId, condition, pars)
  631. if e != nil {
  632. br.Msg = "获取合同信息失败"
  633. br.ErrMsg = "获取合同信息失败,Err:" + e.Error()
  634. return
  635. }
  636. if len(list) > 0 {
  637. contractType = "续约合同"
  638. }
  639. if productId == 2 {
  640. //权益的新签合同重新定义,如果合同起始时间在新签合同起始日期 1年之内的,仍为新签合同。
  641. raicontractType = contractType
  642. if raicontractType != "新签合同" && companyProduct.Status != utils.COMPANY_STATUS_FOREVER {
  643. //startDateTime, _ := time.Parse(utils.FormatDate, req.StartDate)
  644. //startDateTime = startDateTime.AddDate(-1, 0, 0)
  645. totalLastYear, err := contractService.GetCompanyContractCountRaiByLastYear(req.CompanyId, req.StartDate)
  646. if err != nil {
  647. br.Msg = "获取合同信息失败"
  648. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  649. return
  650. }
  651. if totalLastYear > 0 {
  652. raicontractType = "新签合同"
  653. }
  654. }
  655. }
  656. // 若上面的判断不是续约合同, 则继续查询是否存在正式转试用的记录,如果存在,那么合同类型是续约合同
  657. if contractType != "续约合同" {
  658. total, e := company.GetCompanyProductOperationRecordCount(companyProduct.CompanyId, companyProduct.ProductId)
  659. if e != nil {
  660. br.Msg = "查询用户信息异常"
  661. br.ErrMsg = "查询用户变更记录异常, GetCompanyProductOperationRecordCount err: " + e.Error()
  662. return
  663. }
  664. if total > 0 {
  665. contractType = "续约合同"
  666. }
  667. }
  668. }
  669. //权益合同类型,有一套单独的逻辑
  670. if productId == 2 {
  671. contractType = raicontractType
  672. }
  673. var companyApprovalId int
  674. // 全新的申请转正
  675. if req.CompanyApprovalId <= 0 {
  676. contractCode, err := company.GetCompanyContractCode()
  677. if err != nil {
  678. br.Msg = "生成合同编码失败"
  679. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  680. return
  681. }
  682. //如果是权益的合同,合同编号另 取
  683. //if productId == 2 {
  684. // sealCount, err := seal.GetCountByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  685. // if err != nil {
  686. // br.Msg = "生成合同编码失败"
  687. // br.ErrMsg = "获取用印合同数量信息失败,Err:" + err.Error()
  688. // return
  689. // }
  690. // crmConfig, err := company.GetConfigDetailByCode("rai_seal_check") //权益非标合同是否校验用印提交
  691. // if err != nil {
  692. // br.Msg = "获取配置失败"
  693. // br.ErrMsg = "获取配置失败,Err:" + err.Error()
  694. // return
  695. // }
  696. //
  697. // if sealCount == 0 && crmConfig.ConfigValue == "1" {
  698. // br.Msg = "此合同暂未申请用印,请核对合同期限是否有误"
  699. // return
  700. // }
  701. // if sealCount > 0 {
  702. // sealInfo, err := seal.GetSealInfoByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  703. // if err != nil {
  704. // br.Msg = "生成合同编码失败"
  705. // br.ErrMsg = "获取用印合同信息失败,Err:" + err.Error()
  706. // return
  707. // }
  708. // contractCode = sealInfo.Code
  709. // }
  710. //}
  711. var sealId int
  712. if productId == 2 {
  713. contractCode, err = seal.GetSealCodeRai() //权益客户合同编号格式替换
  714. if err != nil {
  715. br.Msg = "生成合同编码失败"
  716. br.ErrMsg = "生成合同编码失败,Err:" + err.Error()
  717. return
  718. }
  719. sealCount, err := seal.GetCountByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  720. if err != nil {
  721. br.Msg = "生成合同编码失败"
  722. br.ErrMsg = "获取用印合同数量信息失败,Err:" + err.Error()
  723. return
  724. }
  725. crmConfig, err := company.GetConfigDetailByCode("rai_seal_check") //权益非标合同是否校验用印提交
  726. if err != nil {
  727. br.Msg = "获取配置失败"
  728. br.ErrMsg = "获取配置失败,Err:" + err.Error()
  729. return
  730. }
  731. if sealCount == 0 && crmConfig.ConfigValue == "1" {
  732. br.Msg = "此合同暂未申请用印,请核对合同期限是否有误"
  733. return
  734. }
  735. if sealCount > 0 {
  736. sealInfo, err := seal.GetSealInfoByDateAndCompanyId(req.StartDate, req.EndDate, req.CompanyId)
  737. if err != nil {
  738. br.Msg = "生成合同编码失败"
  739. br.ErrMsg = "获取用印合同信息失败,Err:" + err.Error()
  740. return
  741. }
  742. contractCode = sealInfo.Code
  743. sealId = sealInfo.SealId
  744. }
  745. }
  746. //当前是否存在待审批的单子
  747. nowCompanyApprovalInfo, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  748. if (err == nil || nowCompanyApprovalInfo != nil) || err != nil && err.Error() != utils.ErrNoRow() {
  749. br.Msg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  750. br.ErrMsg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  751. return
  752. }
  753. //当前待审批的合同,有且只能存在一条
  754. //count, err := company.GetCompanyContractApproveCount(req.CompanyId, productId)
  755. //if err != nil {
  756. // br.Msg = "获取信息失败"
  757. // br.ErrMsg = "判断是否已存在待审批合同失败,Err:" + err.Error()
  758. // return
  759. //}
  760. //if count > 0 {
  761. // br.Msg = "此客户已提交过申请,请在客户审批列表重新提交"
  762. // return
  763. //}
  764. contract := new(company.CompanyContract)
  765. contract.CompanyId = req.CompanyId
  766. contract.ProductId = productId
  767. contract.ContractType = contractType
  768. contract.RaiContractType = raicontractType
  769. contract.ProductName = companyProduct.ProductName
  770. contract.CompanyProductId = companyProduct.CompanyProductId
  771. contract.ContractCode = contractCode
  772. contract.StartDate = req.StartDate
  773. contract.EndDate = req.EndDate
  774. contract.Money = req.Money
  775. contract.PayMethod = req.PayMethod
  776. contract.PayChannel = req.PayChannel
  777. contract.ImgUrl = req.ImgUrl
  778. contract.Status = 0
  779. contract.Source = "上传附件"
  780. contract.PackageType = req.PackageType
  781. contract.RaiPackageType = req.RaiPackageType
  782. contract.CreateTime = time.Now()
  783. contract.ModifyTime = time.Now()
  784. contract.SellerIdInit = companyProduct.SellerId
  785. contract.SellerNameInit = companyProduct.SellerName
  786. contract.ShareSellerInit = companyProduct.ShareSeller
  787. contract.ShareSellerIdInit = companyProduct.ShareSellerId
  788. contract.SellerIdLast = companyProduct.SellerId
  789. contract.SellerNameLast = companyProduct.SellerName
  790. contract.ShareSellerLast = companyProduct.ShareSeller
  791. contract.ShareSellerIdLast = companyProduct.ShareSellerId
  792. newId, err := company.AddCompanyContract(contract)
  793. if err != nil {
  794. br.Msg = "新增合同失败"
  795. br.ErrMsg = "新增合同失败,Err:" + err.Error()
  796. return
  797. }
  798. //如果用印ID > 0 建立合同ID,与用印申请表的关系
  799. if sealId > 0 {
  800. //用印作废
  801. err = seal.UpdateSealCompanyContractId(int(newId), sealId)
  802. if err != nil {
  803. br.Msg = "操作失败"
  804. br.ErrMsg = "添加用印与合同的关系失败,Err:" + err.Error()
  805. return
  806. }
  807. }
  808. permissionArr := strings.Split(req.PermissionIds, ",")
  809. permissionMap := make(map[int]int) //权限id的map集合,用来避免重复添加权限校验
  810. permissionItems := make([]*company.CompanyContractPermission, 0)
  811. permissionLogs := make([]*company.CompanyContractPermissionLog, 0)
  812. for _, v := range permissionArr {
  813. item := new(company.CompanyContractPermission)
  814. item.CompanyId = req.CompanyId
  815. item.CompanyContractId = int(newId)
  816. chartPermissionId, tmpErr := strconv.Atoi(v)
  817. if tmpErr != nil {
  818. err = tmpErr
  819. return
  820. }
  821. //权限id判断,避免重复添加权限
  822. if _, ok := permissionMap[chartPermissionId]; ok {
  823. continue
  824. }
  825. permissionMap[chartPermissionId] = chartPermissionId
  826. item.ChartPermissionId = chartPermissionId
  827. if _, ok := mapPermissionIdUpgrade[chartPermissionId]; ok {
  828. item.IsUpgrade = 1
  829. }
  830. if chartPermissionId == utils.CHART_PERMISSION_ID_YANXUAN {
  831. item.ExpensiveYx = expensiveYx
  832. }
  833. //如果是研选扣点包,这个行业权限的ID;那么就对点数进行赋值。目前就研选扣点包 这一个行业有点数,先不用数组类型处理。v:查研观向13.2
  834. if chartPermissionId == utils.YAN_XUAN_KOU_DIAN_BAO_ID {
  835. if req.Points <= 0 {
  836. br.Msg = "点数不能为空"
  837. return
  838. }
  839. item.Points = req.Points
  840. }
  841. item.PermissionName = permissionNameMap[chartPermissionId]
  842. item.StartDate = req.StartDate
  843. item.EndDate = req.EndDate
  844. item.ModifyTime = time.Now()
  845. item.CreateTime = time.Now()
  846. permissionItems = append(permissionItems, item)
  847. //新增日志
  848. itemLog := new(company.CompanyContractPermissionLog)
  849. itemLog.CompanyId = req.CompanyId
  850. itemLog.CompanyContractId = int(newId)
  851. itemLog.ChartPermissionId = v
  852. itemLog.StartDate = req.StartDate
  853. itemLog.EndDate = req.EndDate
  854. itemLog.ModifyTime = time.Now()
  855. itemLog.CreateTime = time.Now()
  856. itemLog.LogCreateTime = time.Now()
  857. permissionLogs = append(permissionLogs, itemLog)
  858. }
  859. // 批量新增company_contract_permission和log
  860. if e := company.MultiAddCompanyContractPermission(permissionItems); e != nil {
  861. br.Msg = "新增合同失败"
  862. br.ErrMsg = "批量新增合同权限失败, MultiAddCompanyContractPermission Err:" + e.Error()
  863. return
  864. }
  865. go company.MultiAddCompanyContractPermissionLog(permissionLogs)
  866. applyMethod := 1
  867. approval := new(company.CompanyApproval)
  868. approval.CompanyId = req.CompanyId
  869. approval.ProductId = productId
  870. approval.ApproveStatus = "待审批"
  871. approval.ApproveUserId = 0
  872. approval.ApproveRoleTypeCode = approveRoleTypeCode
  873. approval.ApproveRealName = ""
  874. approval.ApproveTime = time.Now()
  875. approval.ApproveContent = "试用转正式"
  876. approval.ApplyMethod = applyMethod
  877. approval.ApplyReasons = ""
  878. approval.ApplyUserId = sysUser.AdminId
  879. approval.ApplyRealName = sysUser.RealName
  880. approval.CreateTime = time.Now()
  881. approval.ModifyTime = time.Now()
  882. approval.CompanyContractId = int(newId)
  883. approval.IsFormal = companyProduct.IsFormal
  884. companyApprovalId, err = company.AddCompanyApproval(approval)
  885. if err != nil {
  886. br.Msg = "申请失败"
  887. br.ErrMsg = "申请失败,Err:" + err.Error()
  888. return
  889. }
  890. } else {
  891. // 重新申请
  892. recode, err := company.GetCompanyApprovalByApprovalId(req.CompanyApprovalId)
  893. if err != nil {
  894. br.Msg = "申请失败"
  895. br.ErrMsg = "获取审批记录失败,Err:" + err.Error()
  896. return
  897. }
  898. err = company.ModifyCompanyTurnPositive(&req, productId, recode.CompanyContractId, companyProduct.IsFormal, mapPermissionIdUpgrade, expensiveYx)
  899. if err != nil {
  900. br.Msg = "申请失败"
  901. br.ErrMsg = "申请失败,Err:" + err.Error()
  902. return
  903. }
  904. companyApprovalId = req.CompanyApprovalId
  905. }
  906. //新增操作记录
  907. {
  908. remark := "申请转正"
  909. operation := "turn_positive"
  910. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, approveUserId, companyProduct.CompanyName,
  911. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, approveUserRealName, "", companyProduct.Status)
  912. }
  913. //新增客户产品日志
  914. {
  915. logType := "modify"
  916. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  917. }
  918. //新增申请单
  919. err = company_apply.Apply(companyApprovalId, "试用转正式申请单")
  920. if err != nil {
  921. br.Msg = "发起审批异常,请联系管理员"
  922. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  923. return
  924. }
  925. br.Ret = 200
  926. br.Success = true
  927. br.Msg = "申请成功"
  928. }
  929. // ApplyBySystemContract
  930. // @Title 通过系统合同申请转正/服务更新
  931. // @Description 通过系统合同申请转正/服务更新接口
  932. // @Param request body company.CompanyApplyBySystemContractReq true "type json string"
  933. // @Success Ret=200 申请成功
  934. // @router /apply/systemContract [post]
  935. func (this *CompanyApplyController) ApplyBySystemContract() {
  936. br := new(models.BaseResponse).Init()
  937. defer func() {
  938. this.Data["json"] = br
  939. this.ServeJSON()
  940. }()
  941. sysUser := this.SysUser
  942. if sysUser == nil {
  943. br.Msg = "请登录"
  944. br.ErrMsg = "请登录,SysUser Is Empty"
  945. br.Ret = 408
  946. return
  947. }
  948. var req company.CompanyApplyBySystemContractReq
  949. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  950. if err != nil {
  951. br.Msg = "参数解析异常!"
  952. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  953. return
  954. }
  955. if req.CompanyId <= 0 {
  956. br.Msg = "参数错误"
  957. br.ErrMsg = "参数错误,客户id小于等于0"
  958. return
  959. }
  960. //获取客户信息
  961. companyInfo, err := company.GetCompanyById(req.CompanyId)
  962. if err != nil {
  963. br.Msg = "获取客户信息失败"
  964. br.ErrMsg = "获取客户信息失败"
  965. return
  966. }
  967. roleTypeCode := sysUser.RoleTypeCode
  968. productId := services.GetProductId(roleTypeCode)
  969. if productId == 0 {
  970. br.Msg = "参数错误"
  971. br.ErrMsg = "客户类型为:" + roleTypeCode
  972. return
  973. }
  974. //添加缓存,避免多次点击提交
  975. {
  976. deleteCache := true
  977. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  978. defer func() {
  979. if deleteCache {
  980. utils.Rc.Delete(cacheKey)
  981. }
  982. }()
  983. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  984. deleteCache = false
  985. br.Msg = "系统处理中,请勿重复操作"
  986. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  987. return
  988. }
  989. }
  990. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  991. if err != nil {
  992. br.Msg = "获取客户信息失败"
  993. br.ErrMsg = "获取客户信息失败"
  994. return
  995. }
  996. if companyProduct == nil {
  997. br.Msg = "获取客户信息失败"
  998. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  999. return
  1000. }
  1001. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  1002. br.Msg = "客户信息异常"
  1003. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  1004. return
  1005. }
  1006. if companyProduct.ApproveStatus == "待审批" {
  1007. br.Msg = "存在待审批订单,不可重复提交"
  1008. return
  1009. }
  1010. var approveUserId int
  1011. var approveUserRealName string
  1012. approveRoleTypeCode := ""
  1013. if productId == 1 {
  1014. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  1015. } else {
  1016. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  1017. }
  1018. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  1019. if err != nil && err.Error() != utils.ErrNoRow() {
  1020. br.Msg = "获取审批信息失败"
  1021. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  1022. return
  1023. }
  1024. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  1025. br.Msg = "审批用户不存在"
  1026. br.ErrMsg = "审批用户不存在"
  1027. return
  1028. }
  1029. //获取合同详情
  1030. contractDetail, err := contractService.GetContractDetail(req.ContractId)
  1031. if err != nil {
  1032. br.Msg = "查询合同异常"
  1033. br.ErrMsg = fmt.Sprint("查询合同异常,合同id:", req.ContractId, ";Err:", err.Error())
  1034. return
  1035. }
  1036. if contractDetail.ContractBusinessType != "业务合同" {
  1037. br.Msg = "合同类型异常"
  1038. br.ErrMsg = "合同类型异常,当前合同类型为:" + contractDetail.ContractBusinessType
  1039. return
  1040. }
  1041. //判断产品类型是否一致
  1042. if productId != contractDetail.ProductId {
  1043. br.Msg = "合同产品类型异常"
  1044. br.ErrMsg = fmt.Sprint("合同产品类型异常,合同产品类型Id:", contractDetail.ProductId)
  1045. return
  1046. }
  1047. //判断销售归属
  1048. if contractDetail.SellerId != sysUser.AdminId {
  1049. br.Msg = "合同异常"
  1050. br.ErrMsg = fmt.Sprint("合同归属人异常,合同申请人Id:", contractDetail.SellerId, ";当前账号:", sysUser.AdminId)
  1051. return
  1052. }
  1053. //判断合同是否该客户的(组织社会信用代码是否一致)
  1054. if contractDetail.CreditCode != companyInfo.CreditCode {
  1055. br.Msg = "合同异常,请选择社会信用码一致的合同"
  1056. br.ErrMsg = fmt.Sprint("该合同组织社会信用码与客户不符,合同的社会信用码:", contractDetail.CreditCode, ";客户的社会信用码:", companyInfo.CreditCode)
  1057. return
  1058. }
  1059. if contractDetail.Status != "已签回" {
  1060. br.Msg = "合同状态异常"
  1061. br.ErrMsg = fmt.Sprint("合同状态异常,合同状态:", contractDetail.Status)
  1062. return
  1063. }
  1064. //当前客户需要的合同状态
  1065. needContractType, err := services.GetApplyTurnContractType(req.CompanyId, productId)
  1066. if err != nil {
  1067. br.Msg = "获取失败"
  1068. br.ErrMsg = "获取合同类型失败,Err:" + err.Error()
  1069. return
  1070. }
  1071. //判断 系统需要的合同类型 与 实际提交的合同类型是否一致,如果不一致,那么不支持
  1072. if needContractType != "新签合同" && contractDetail.ContractType == "新签合同" {
  1073. br.Msg = "申请失败,该客户曾经开通过正式服务,不允许签署新签合同"
  1074. br.ErrMsg = "申请失败,该客户曾经开通过正式服务,不允许签署新签合同"
  1075. return
  1076. }
  1077. if contractDetail.ContractType == "新签合同" {
  1078. if companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  1079. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  1080. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行转正申请"
  1081. return
  1082. }
  1083. } else {
  1084. if companyProduct.Status != utils.COMPANY_STATUS_FORMAL && companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  1085. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  1086. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行服务更新申请"
  1087. return
  1088. }
  1089. }
  1090. //合同类型
  1091. contractType := contractDetail.ContractType
  1092. var hasContract bool //是否已经存在合同,如果存在,那么就不能是新签合同
  1093. var condition string
  1094. var pars []interface{}
  1095. condition += " AND product_id = ?"
  1096. pars = append(pars, productId)
  1097. condition += " AND status = ?"
  1098. pars = append(pars, 1)
  1099. list, err := company.GetCompanyContractListByCompanyId(req.CompanyId, condition, pars)
  1100. if err != nil {
  1101. br.Msg = "获取合同信息失败"
  1102. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  1103. return
  1104. }
  1105. if len(list) > 0 {
  1106. hasContract = true
  1107. }
  1108. //查询是否存在正式转试用的记录,如果存在,那么合同类型是续约合同
  1109. total, err := company.GetCompanyProductOperationRecordCount(companyProduct.CompanyId, companyProduct.ProductId)
  1110. if err != nil {
  1111. br.Msg = "查询用户信息异常"
  1112. br.ErrMsg = "查询用户变更记录异常"
  1113. return
  1114. }
  1115. if total > 0 {
  1116. hasContract = true
  1117. }
  1118. if hasContract && contractType == "新签合同" {
  1119. br.Msg = "客户已存在老合同,不允许签署新签合同"
  1120. br.ErrMsg = "客户已存在老合同,不允许签署新签合同"
  1121. return
  1122. }
  1123. //合同类型 end
  1124. //获取权限id列表
  1125. permissionMap, err := contractService.GetServicePermissionMap(contractDetail.Service)
  1126. permissionArr := make([]int, 0)
  1127. for _, permissionId := range permissionMap {
  1128. permissionArr = append(permissionArr, permissionId)
  1129. }
  1130. //对权限排序
  1131. sort.Ints(permissionArr)
  1132. // CRM8.8-权益主客观此处拆分成了三级套餐, 根据contract_service写权限
  1133. // CRM8.8-如果是权益客户那么主观客观权限一起带上(暂弃)
  1134. //if companyProduct.ProductId == 2 {
  1135. // var permissionIds string
  1136. // var permissionNames string
  1137. // for _, v := range permissionArr {
  1138. // permissionIds += strconv.Itoa(v) + ","
  1139. // }
  1140. // permissionIds = strings.TrimRight(permissionIds, ",")
  1141. // listSandO, err := company.GetPermissionLookItemsSandO(permissionIds)
  1142. // if err != nil {
  1143. // br.Msg = "获取现有的合同权限信息失败"
  1144. // br.ErrMsg = "获取现有的合同权限ID信息失败,Err:" + err.Error()
  1145. // return
  1146. // }
  1147. // for _, v := range listSandO {
  1148. // permissionNames += "'" + v.PermissionName + "'" + ","
  1149. // }
  1150. // permissionNames = strings.TrimRight(permissionNames, ",")
  1151. // listPermissionByname, err := company.GetPermissionLookItemsSandOByName(permissionNames)
  1152. // if err != nil {
  1153. // br.Msg = "获取现有的合同权限信息失败"
  1154. // br.ErrMsg = "通过名称获取主观客观权限ID信息失败,Err:" + err.Error()
  1155. // return
  1156. // }
  1157. // permissionArr = make([]int, 0)
  1158. // for _, v := range listPermissionByname {
  1159. // permissionArr = append(permissionArr, v.ChartPermissionId)
  1160. // }
  1161. // //对权限排序
  1162. // sort.Ints(permissionArr)
  1163. //}
  1164. //当前已经存在的权限
  1165. currPermissionMap, err := services.GetLastContractPermissionList(companyProduct.CompanyId, companyProduct.ProductId)
  1166. if err != nil {
  1167. br.Msg = "获取现有的合同权限信息失败"
  1168. br.ErrMsg = "获取现有的合同权限信息失败,Err:" + err.Error()
  1169. return
  1170. }
  1171. //权限内日期判断校验
  1172. for _, permissionId := range permissionArr {
  1173. //研选服务不做校验
  1174. if permissionId == 31 {
  1175. continue
  1176. }
  1177. if currPermission, ok := currPermissionMap[permissionId]; ok {
  1178. currStartDate, _ := time.Parse(utils.FormatDate, currPermission.StartDate)
  1179. currEndDate, _ := time.Parse(utils.FormatDate, currPermission.EndDate)
  1180. if !(contractDetail.StartDate.After(currEndDate) || currStartDate.After(contractDetail.EndDate)) {
  1181. br.Msg = currPermission.PermissionName + "合同日期存在重复,不允许申请"
  1182. br.ErrMsg = "权限合同日期存在重复,不允许申请"
  1183. return
  1184. }
  1185. }
  1186. }
  1187. //获取客户产品套餐类型(大套餐、小套餐、无)
  1188. packageType, err := contractService.GetServicePackageType(contractDetail.Service)
  1189. raiPackageType := contractService.GetRaiServicePackageType(contractDetail.Service)
  1190. recordApproveContent := `试用转正式`
  1191. applyMethod := 1
  1192. approveContent := "试用转正式"
  1193. operationRemark := `申请转正`
  1194. operation := "turn_positive"
  1195. messageContent := "试用转正式申请单"
  1196. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  1197. if contractType != "新签合同" {
  1198. if contractType == "补充协议" {
  1199. applyMethod = 6 //补充协议
  1200. recordApproveContent = `正式客户新增补充协议`
  1201. approveContent = `新增补充协议`
  1202. operationRemark = `新增补充协议`
  1203. operation = "add_agreement"
  1204. messageContent = "补充协议申请单"
  1205. } else {
  1206. applyMethod = 5 //续约服务
  1207. recordApproveContent = `正式客户申请续约`
  1208. approveContent = `申请续约`
  1209. operationRemark = `申请续约`
  1210. operation = "service_update"
  1211. messageContent = "续约申请单"
  1212. }
  1213. }
  1214. var raicontractType string
  1215. if productId == 2 {
  1216. //权益的新签合同重新定义,如果合同起始时间在新签合同起始日期 1年之内的,仍为新签合同。
  1217. raicontractType = contractType
  1218. if raicontractType != "新签合同" && companyProduct.Status != utils.COMPANY_STATUS_FOREVER {
  1219. //startDateTime := contractDetail.StartDate.AddDate(-1, 0, 0)
  1220. totalLastYear, err := contractService.GetCompanyContractCountRaiByLastYear(req.CompanyId, contractDetail.StartDate.Format(utils.FormatDate))
  1221. if err != nil {
  1222. br.Msg = "获取合同信息失败"
  1223. br.ErrMsg = "获取合同信息失败,Err:" + err.Error()
  1224. return
  1225. }
  1226. if totalLastYear > 0 {
  1227. raicontractType = "新签合同"
  1228. }
  1229. }
  1230. }
  1231. var companyApprovalId int
  1232. if req.CompanyApprovalId <= 0 {
  1233. //当前是否存在待审批的单子
  1234. nowCompanyApprovalInfo, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  1235. if (err == nil || nowCompanyApprovalInfo != nil) || err != nil && err.Error() != utils.ErrNoRow() {
  1236. br.Msg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  1237. br.ErrMsg = "此客户已存在待审批的申请单,请在申请单审批完成后重新提交"
  1238. return
  1239. }
  1240. ////当前待审批的合同,有且只能存在一条
  1241. //count, err := company.GetCompanyContractApproveCount(req.CompanyId, productId)
  1242. //if err != nil {
  1243. // br.Msg = "获取信息失败"
  1244. // br.ErrMsg = "判断是否已存在待审批合同失败,Err:" + err.Error()
  1245. // return
  1246. //}
  1247. //if count > 0 {
  1248. // br.Msg = "此客户已提交过申请,请在客户审批列表重新提交"
  1249. // return
  1250. //}
  1251. companyContract := &company.CompanyContract{
  1252. CompanyId: req.CompanyId,
  1253. ProductId: contractDetail.ProductId,
  1254. ContractType: contractType,
  1255. RaiContractType: raicontractType,
  1256. ProductName: companyProduct.ProductName,
  1257. CompanyProductId: companyProduct.CompanyProductId,
  1258. ContractCode: contractDetail.ContractCode,
  1259. StartDate: contractDetail.StartDate.Format(utils.FormatDate),
  1260. EndDate: contractDetail.EndDate.Format(utils.FormatDate),
  1261. Money: contractDetail.Price,
  1262. PayMethod: contractDetail.PayRemark,
  1263. PayChannel: contractDetail.PayChannel,
  1264. ImgUrl: contractDetail.CheckBackFileUrl,
  1265. Status: 0,
  1266. Source: "系统合同",
  1267. PackageType: packageType,
  1268. RaiPackageType: raiPackageType,
  1269. CreateTime: time.Now(),
  1270. ModifyTime: time.Now(),
  1271. SellerIdInit: companyProduct.SellerId,
  1272. SellerNameInit: companyProduct.SellerName,
  1273. ShareSellerInit: companyProduct.ShareSeller,
  1274. ShareSellerIdInit: companyProduct.ShareSellerId,
  1275. SellerIdLast: companyProduct.SellerId,
  1276. SellerNameLast: companyProduct.SellerName,
  1277. ShareSellerLast: companyProduct.ShareSeller,
  1278. ShareSellerIdLast: companyProduct.ShareSellerId,
  1279. }
  1280. newId, err := company.AddCompanyContract(companyContract)
  1281. if err != nil {
  1282. br.Msg = "新增合同失败"
  1283. br.ErrMsg = "新增合同失败,Err:" + err.Error()
  1284. return
  1285. }
  1286. upgradeMap := make(map[int]int)
  1287. if utils.RunMode == "release" {
  1288. upgradeMap = map[int]int{22: 39, 21: 38, 20: 37, 19: 36}
  1289. } else {
  1290. upgradeMap = map[int]int{22: 37, 21: 36, 20: 35, 19: 34}
  1291. }
  1292. for _, chartPermissionId := range permissionArr {
  1293. if chartPermissionId < utils.PERMISSION_ID_UPGRADE {
  1294. item := new(company.CompanyContractPermission)
  1295. item.CompanyId = req.CompanyId
  1296. item.CompanyContractId = int(newId)
  1297. item.ChartPermissionId = chartPermissionId
  1298. item.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1299. item.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1300. item.ModifyTime = time.Now()
  1301. item.CreateTime = time.Now()
  1302. err = company.AddCompanyContractPermission(item)
  1303. if err != nil {
  1304. br.Msg = "新增合同失败"
  1305. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  1306. return
  1307. }
  1308. //新增日志
  1309. {
  1310. itemLog := new(company.CompanyContractPermissionLog)
  1311. itemLog.CompanyId = req.CompanyId
  1312. itemLog.CompanyContractId = int(newId)
  1313. itemLog.ChartPermissionId = strconv.Itoa(chartPermissionId)
  1314. itemLog.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1315. itemLog.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1316. itemLog.ModifyTime = time.Now()
  1317. itemLog.CreateTime = time.Now()
  1318. itemLog.LogCreateTime = time.Now()
  1319. go company.AddCompanyContractPermissionLog(itemLog)
  1320. }
  1321. } else {
  1322. // 升级套餐,手动补充主客观套餐
  1323. chartPermissionId -= utils.PERMISSION_ID_UPGRADE
  1324. item := new(company.CompanyContractPermission)
  1325. item.CompanyId = req.CompanyId
  1326. item.CompanyContractId = int(newId)
  1327. item.ChartPermissionId = chartPermissionId
  1328. item.IsUpgrade = 1
  1329. item.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1330. item.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1331. item.ModifyTime = time.Now()
  1332. item.CreateTime = time.Now()
  1333. err = company.AddCompanyContractPermission(item)
  1334. if err != nil {
  1335. br.Msg = "新增合同失败"
  1336. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  1337. return
  1338. }
  1339. //新增日志
  1340. {
  1341. itemLog := new(company.CompanyContractPermissionLog)
  1342. itemLog.CompanyId = req.CompanyId
  1343. itemLog.CompanyContractId = int(newId)
  1344. itemLog.ChartPermissionId = strconv.Itoa(chartPermissionId)
  1345. itemLog.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1346. itemLog.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1347. itemLog.ModifyTime = time.Now()
  1348. itemLog.CreateTime = time.Now()
  1349. itemLog.LogCreateTime = time.Now()
  1350. go company.AddCompanyContractPermissionLog(itemLog)
  1351. }
  1352. // 客观
  1353. upgradeChartPermissionId := upgradeMap[chartPermissionId]
  1354. upItem := new(company.CompanyContractPermission)
  1355. upItem.CompanyId = req.CompanyId
  1356. upItem.CompanyContractId = int(newId)
  1357. upItem.ChartPermissionId = upgradeChartPermissionId
  1358. upItem.IsUpgrade = 1
  1359. upItem.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1360. upItem.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1361. upItem.ModifyTime = time.Now()
  1362. upItem.CreateTime = time.Now()
  1363. err = company.AddCompanyContractPermission(upItem)
  1364. if err != nil {
  1365. br.Msg = "新增合同失败"
  1366. br.ErrMsg = "新增合同权限失败,Err:" + err.Error()
  1367. return
  1368. }
  1369. //新增日志
  1370. {
  1371. itemLog := new(company.CompanyContractPermissionLog)
  1372. itemLog.CompanyId = req.CompanyId
  1373. itemLog.CompanyContractId = int(newId)
  1374. itemLog.ChartPermissionId = strconv.Itoa(upgradeChartPermissionId)
  1375. itemLog.StartDate = contractDetail.StartDate.Format(utils.FormatDate)
  1376. itemLog.EndDate = contractDetail.EndDate.Format(utils.FormatDate)
  1377. itemLog.ModifyTime = time.Now()
  1378. itemLog.CreateTime = time.Now()
  1379. itemLog.LogCreateTime = time.Now()
  1380. go company.AddCompanyContractPermissionLog(itemLog)
  1381. }
  1382. }
  1383. }
  1384. approval := new(company.CompanyApproval)
  1385. approval.CompanyId = req.CompanyId
  1386. approval.ProductId = productId
  1387. approval.ApproveStatus = "待审批"
  1388. approval.ApproveUserId = 0
  1389. approval.ApproveRoleTypeCode = approveRoleTypeCode
  1390. approval.ApproveRealName = ""
  1391. approval.ApproveTime = time.Now()
  1392. approval.ApproveContent = approveContent
  1393. approval.ApplyMethod = applyMethod
  1394. approval.ApplyReasons = ""
  1395. approval.ApplyUserId = sysUser.AdminId
  1396. approval.ApplyRealName = sysUser.RealName
  1397. approval.CreateTime = time.Now()
  1398. approval.ModifyTime = time.Now()
  1399. approval.CompanyContractId = int(newId)
  1400. approval.IsFormal = companyProduct.IsFormal
  1401. companyApprovalId, err = company.AddCompanyApproval(approval)
  1402. if err != nil {
  1403. br.Msg = "申请失败"
  1404. br.ErrMsg = "申请失败,Err:" + err.Error()
  1405. return
  1406. }
  1407. } else {
  1408. recode, err := company.GetCompanyApprovalByApprovalId(req.CompanyApprovalId)
  1409. if err != nil {
  1410. br.Msg = "申请失败"
  1411. br.ErrMsg = "获取审批记录失败,Err:" + err.Error()
  1412. return
  1413. }
  1414. err = company.ModifyCompanyTurnPositiveBySystemContract(contractDetail, permissionArr, req.CompanyId, productId, req.CompanyApprovalId, recode.CompanyContractId, companyProduct.IsFormal, packageType, raiPackageType)
  1415. if err != nil {
  1416. br.Msg = "申请失败"
  1417. br.ErrMsg = "申请失败,Err:" + err.Error()
  1418. return
  1419. }
  1420. companyApprovalId = req.CompanyApprovalId
  1421. }
  1422. //新增操作记录
  1423. {
  1424. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, approveUserId, companyProduct.CompanyName,
  1425. companyProduct.ProductName, sysUser.RealName, operationRemark, operation, recordApproveContent, approveUserRealName, "", companyProduct.Status)
  1426. }
  1427. //新增客户产品日志
  1428. {
  1429. logType := "modify"
  1430. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  1431. }
  1432. err = company_apply.Apply(companyApprovalId, messageContent)
  1433. if err != nil {
  1434. br.Msg = "发起审批异常,请联系管理员"
  1435. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  1436. return
  1437. }
  1438. //待办通知
  1439. //{
  1440. // for _, v := range approveUser {
  1441. // approveUserId = v.AdminId
  1442. // approveUserRealName = v.RealName
  1443. // mobile := v.Mobile
  1444. // err = services.AddCompanyApprovalMessage(sysUser.AdminId, approveUserId, req.CompanyId, companyApprovalId, 1, 1, 1, companyProduct.CompanyName, messageContent, messageContent, mobile)
  1445. // if err != nil {
  1446. // br.Msg = "申请失败"
  1447. // br.ErrMsg = "新增待办通知失败,Err:" + err.Error()
  1448. // return
  1449. // }
  1450. // }
  1451. //}
  1452. br.Ret = 200
  1453. br.Success = true
  1454. br.Msg = "申请成功"
  1455. }
  1456. // ApplyThaw
  1457. // @Title 申请解冻
  1458. // @Description 申请解冻接口
  1459. // @Param request body company.CompanyApplyThawReq true "type json string"
  1460. // @Success Ret=200 申请成功
  1461. // @router /apply/thaw [post]
  1462. func (this *CompanyApplyController) ApplyThaw() {
  1463. br := new(models.BaseResponse).Init()
  1464. defer func() {
  1465. this.Data["json"] = br
  1466. this.ServeJSON()
  1467. }()
  1468. sysUser := this.SysUser
  1469. if sysUser == nil {
  1470. br.Msg = "请登录"
  1471. br.ErrMsg = "请登录,SysUser Is Empty"
  1472. br.Ret = 408
  1473. return
  1474. }
  1475. var req company.CompanyApplyThawReq
  1476. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1477. if err != nil {
  1478. br.Msg = "参数解析异常!"
  1479. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1480. return
  1481. }
  1482. if req.CompanyId <= 0 {
  1483. br.Msg = "参数错误"
  1484. br.ErrMsg = "参数错误,客户id小于等于0"
  1485. return
  1486. }
  1487. roleTypeCode := sysUser.RoleTypeCode
  1488. productId := services.GetProductId(roleTypeCode)
  1489. if productId == 0 {
  1490. br.Msg = "参数错误"
  1491. br.ErrMsg = "客户类型为:" + roleTypeCode
  1492. return
  1493. }
  1494. if productId == utils.COMPANY_PRODUCT_FICC_ID && req.PermissionIds == "" {
  1495. br.Msg = "请勾选需要解冻的品种"
  1496. br.ErrMsg = "请勾选需要解冻的品种"
  1497. return
  1498. }
  1499. // 查询当前销售是否有重新申请的权限
  1500. receiveEnabled, _ := services.CheckCompanyReceiveButton(sysUser.AdminId)
  1501. if !receiveEnabled {
  1502. br.Msg = "无权申请"
  1503. br.ErrMsg = "无权申请"
  1504. return
  1505. }
  1506. //添加缓存,避免多次点击提交
  1507. {
  1508. deleteCache := true
  1509. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  1510. defer func() {
  1511. if deleteCache {
  1512. utils.Rc.Delete(cacheKey)
  1513. }
  1514. }()
  1515. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  1516. deleteCache = false
  1517. br.Msg = "系统处理中,请勿重复操作"
  1518. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  1519. return
  1520. }
  1521. }
  1522. var companyApprovalCount int //某一客户申请的次数
  1523. approveRoleTypeCode := ""
  1524. if productId == 1 {
  1525. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  1526. } else {
  1527. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  1528. companyApprovalCount, err = company.GetCompanyApprovalCount(req.CompanyId, productId, 2)
  1529. if err != nil {
  1530. br.Msg = "获取客户信息失败"
  1531. br.ErrMsg = "获取客户申请的次数失败,Err:" + err.Error()
  1532. return
  1533. }
  1534. permissionArr := strings.Split(req.PermissionIds, ",")
  1535. //如果所选行业不属于研选订阅跟研选扣点包,那就是非研选试用客户
  1536. var isNoResearch bool
  1537. for _, v := range permissionArr {
  1538. if v != strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) && v != strconv.Itoa(utils.YAN_XUAN_KOU_DIAN_BAO_ID) {
  1539. isNoResearch = true
  1540. continue
  1541. }
  1542. }
  1543. if isNoResearch {
  1544. tryOutCountRai, err := company.GetRaiCompanyTryOutCountNoResearch(sysUser.AdminId)
  1545. if err != nil {
  1546. br.Msg = "判断试用客户量失败"
  1547. br.ErrMsg = "判断试用客户量失败,Err:" + err.Error()
  1548. return
  1549. }
  1550. if tryOutCountRai >= utils.COMPANY_STATUS_TRY_OUT_COUNT_RAI {
  1551. br.Msg = "非研选试用客户最多40家"
  1552. return
  1553. }
  1554. }
  1555. }
  1556. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  1557. if err != nil {
  1558. br.Msg = "获取客户信息失败"
  1559. br.ErrMsg = "获取客户信息失败"
  1560. return
  1561. }
  1562. if companyProduct == nil {
  1563. br.Msg = "获取客户信息失败"
  1564. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  1565. return
  1566. }
  1567. if companyProduct.Status != utils.COMPANY_STATUS_FREEZE {
  1568. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行解冻申请"
  1569. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行解冻申请"
  1570. return
  1571. }
  1572. if companyProduct.ApproveStatus == utils.COMPANY_APPROVE_STATUS {
  1573. br.Msg = "存在待审批订单,不可重复提交"
  1574. return
  1575. }
  1576. //客户归属判断
  1577. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  1578. br.Msg = "客户信息异常"
  1579. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  1580. return
  1581. }
  1582. // CRM8.8(仅针对权益客户)-此处同申请试用的逻辑
  1583. if companyProduct.ProductId == utils.COMPANY_PRODUCT_RAI_ID {
  1584. reportPermissions, e := company.GetCompanyReportPermission(req.CompanyId, utils.COMPANY_PRODUCT_RAI_ID)
  1585. if e != nil {
  1586. br.Msg = "客户权限信息异常"
  1587. br.ErrMsg = "客户权限信息异常, Err: " + e.Error()
  1588. return
  1589. }
  1590. reportPermissionArr := make([]string, 0)
  1591. for i := range reportPermissions {
  1592. reportPermissionArr = append(reportPermissionArr, strconv.Itoa(reportPermissions[i].ChartPermissionId))
  1593. }
  1594. if len(reportPermissionArr) > 0 {
  1595. req.PermissionIds = strings.Join(reportPermissionArr, ",")
  1596. }
  1597. }
  1598. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  1599. if err != nil && err.Error() != utils.ErrNoRow() {
  1600. br.Msg = "获取审批信息失败"
  1601. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  1602. return
  1603. }
  1604. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  1605. br.Msg = "审批用户不存在"
  1606. br.ErrMsg = "审批用户不存在"
  1607. return
  1608. }
  1609. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  1610. approveContent := `冻结转试用`
  1611. var companyApprovalId int
  1612. if req.CompanyApprovalId <= 0 {
  1613. applyMethod := 2
  1614. approval := new(company.CompanyApproval)
  1615. approval.CompanyId = req.CompanyId
  1616. approval.ProductId = productId
  1617. approval.ApproveStatus = "待审批"
  1618. approval.ApproveUserId = 0
  1619. approval.ApproveRoleTypeCode = approveRoleTypeCode
  1620. approval.ApproveRealName = ""
  1621. approval.ApproveTime = time.Now()
  1622. approval.ApproveContent = approveContent
  1623. approval.ApplyMethod = applyMethod
  1624. approval.ApplyReasons = req.ApplyRemark
  1625. approval.ApplyUserId = sysUser.AdminId
  1626. approval.ApplyRealName = sysUser.RealName
  1627. approval.CreateTime = time.Now()
  1628. approval.ModifyTime = time.Now()
  1629. companyApprovalId, err = company.AddCompanyApproval(approval)
  1630. if err != nil {
  1631. br.Msg = "申请失败"
  1632. br.ErrMsg = "申请失败,Err:" + err.Error()
  1633. return
  1634. }
  1635. } else {
  1636. err = company.ModifyCompanyApproval(req.CompanyId, productId, req.CompanyApprovalId, approveContent, req.ApplyRemark)
  1637. if err != nil {
  1638. br.Msg = "申请失败"
  1639. br.ErrMsg = "申请失败,Err:" + err.Error()
  1640. return
  1641. }
  1642. companyApprovalId = req.CompanyApprovalId
  1643. //先删除之前申请的权限
  1644. _ = company.DeleteCompanyDelayPermission(req.CompanyApprovalId)
  1645. }
  1646. //处理权限
  1647. {
  1648. if req.PermissionIds != "" {
  1649. // CRM8.8(仅针对权益客户)-此处不再去查询主观对应的客观, 而是根据客户之前拥有的权限来操作
  1650. //permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  1651. //if err != nil {
  1652. // br.Msg = "获取信息失败"
  1653. // br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  1654. // return
  1655. //}
  1656. //req.PermissionIds = permissionStr
  1657. permissionArr := strings.Split(req.PermissionIds, ",")
  1658. for _, v := range permissionArr {
  1659. //fmt.Println(k, v)
  1660. //新增
  1661. if v != "" {
  1662. permissionId, err := strconv.Atoi(v)
  1663. if err != nil {
  1664. br.Msg = "申请失败"
  1665. br.ErrMsg = "权限格式转换失败,Err:" + err.Error()
  1666. return
  1667. }
  1668. delayItem := new(company.CompanyDelayPermission)
  1669. delayItem.CompanyId = req.CompanyId
  1670. delayItem.CompanyApplyId = companyApprovalId
  1671. delayItem.ChartPermissionId = permissionId
  1672. delayItem.StartDate = time.Now().Format(utils.FormatDate)
  1673. if productId == utils.COMPANY_PRODUCT_RAI_ID { // 权益客户试用期改为1个月。 需求池 1035
  1674. delayItem.EndDate = time.Now().AddDate(0, 1, 0).Format(utils.FormatDate)
  1675. } else {
  1676. delayItem.EndDate = time.Now().AddDate(0, 2, 0).Format(utils.FormatDate)
  1677. }
  1678. delayItem.CreateTime = time.Now()
  1679. delayItem.ModifyTime = time.Now()
  1680. err = company.AddCompanyDelayPermission(delayItem)
  1681. if err != nil {
  1682. br.Msg = "申请失败"
  1683. br.ErrMsg = "新增冻结转试用审批权限失败,Err:" + err.Error()
  1684. return
  1685. }
  1686. }
  1687. }
  1688. }
  1689. }
  1690. //新增操作记录
  1691. {
  1692. remark := "申请解冻"
  1693. operation := "thaw"
  1694. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  1695. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, "", "", companyProduct.Status)
  1696. }
  1697. //新增客户产品日志
  1698. {
  1699. logType := "modify"
  1700. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  1701. }
  1702. err = company_apply.Apply(companyApprovalId, "冻结转试用申请单")
  1703. if err != nil {
  1704. br.Msg = "发起审批异常,请联系管理员"
  1705. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  1706. return
  1707. }
  1708. if companyApprovalCount == 0 && productId == 2 {
  1709. //获取王芳信息,自动审批使用
  1710. approvalUserInfo, err := system.CheckSysUserByName("王芳", utils.ROLE_TYPE_CODE_RAI_ADMIN)
  1711. if err != nil {
  1712. br.Msg = "权益客户自动审批失败,请联系管理员"
  1713. br.ErrMsg = "审批失败,Err:" + err.Error()
  1714. return
  1715. }
  1716. //数据校验(校验是否具有审批权限)
  1717. _, _, approvalRecord, err := company_apply.CheckApproveAuth(req.CompanyId, productId, approvalUserInfo)
  1718. if err != nil {
  1719. br.Msg = "权益客户自动审批失败,请联系管理员"
  1720. br.ErrMsg = "校验是否具有审批权限失败,Err:" + err.Error()
  1721. return
  1722. }
  1723. err = company_apply.Approved(approvalRecord, approvalUserInfo, "权益客首次申请解冻自动审批通过")
  1724. if err != nil {
  1725. br.Msg = "权益客户自动审批失败,请联系管理员!"
  1726. br.ErrMsg = "审核失败,Err:" + err.Error()
  1727. return
  1728. }
  1729. }
  1730. br.Ret = 200
  1731. br.Success = true
  1732. br.Msg = "申请成功"
  1733. }
  1734. // ApplyDelay
  1735. // @Title 申请延期
  1736. // @Description 申请延期接口
  1737. // @Param request body company.CompanyApplyDelayReq true "type json string"
  1738. // @Success Ret=200 申请成功
  1739. // @router /apply/delay [post]
  1740. func (this *CompanyApplyController) ApplyDelay() {
  1741. br := new(models.BaseResponse).Init()
  1742. defer func() {
  1743. this.Data["json"] = br
  1744. this.ServeJSON()
  1745. }()
  1746. sysUser := this.SysUser
  1747. if sysUser == nil {
  1748. br.Msg = "请登录"
  1749. br.ErrMsg = "请登录,SysUser Is Empty"
  1750. br.Ret = 408
  1751. return
  1752. }
  1753. var req company.CompanyApplyDelayReq
  1754. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1755. if err != nil {
  1756. br.Msg = "参数解析异常!"
  1757. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  1758. return
  1759. }
  1760. if req.CompanyId <= 0 {
  1761. br.Msg = "参数错误"
  1762. br.ErrMsg = "参数错误,客户id小于等于0"
  1763. return
  1764. }
  1765. roleTypeCode := sysUser.RoleTypeCode
  1766. productId := services.GetProductId(roleTypeCode)
  1767. if productId == 0 {
  1768. br.Msg = "参数错误"
  1769. br.ErrMsg = "客户类型为:" + roleTypeCode
  1770. return
  1771. }
  1772. if productId == utils.COMPANY_PRODUCT_FICC_ID && req.PermissionIds == "" {
  1773. br.Msg = "请勾选需要延期的品种"
  1774. br.ErrMsg = "请勾选需要延期的品种"
  1775. return
  1776. }
  1777. //添加缓存,避免多次点击提交
  1778. {
  1779. deleteCache := true
  1780. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  1781. defer func() {
  1782. if deleteCache {
  1783. utils.Rc.Delete(cacheKey)
  1784. }
  1785. }()
  1786. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  1787. deleteCache = false
  1788. br.Msg = "系统处理中,请勿重复操作"
  1789. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  1790. return
  1791. }
  1792. }
  1793. approveRoleTypeCode := ""
  1794. if productId == 1 {
  1795. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  1796. } else {
  1797. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  1798. }
  1799. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  1800. if err != nil {
  1801. br.Msg = "获取客户信息失败"
  1802. br.ErrMsg = "获取客户信息失败"
  1803. return
  1804. }
  1805. if companyProduct == nil {
  1806. br.Msg = "获取客户信息失败"
  1807. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  1808. return
  1809. }
  1810. if companyProduct.Status != utils.COMPANY_STATUS_TRY_OUT {
  1811. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  1812. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  1813. return
  1814. }
  1815. if companyProduct.ApproveStatus == "待审批" {
  1816. br.Msg = "存在待审批订单,不可重复提交"
  1817. return
  1818. }
  1819. //客户归属判断
  1820. if companyProduct.SellerId != sysUser.AdminId && companyProduct.ShareSellerId != sysUser.AdminId {
  1821. br.Msg = "客户信息异常"
  1822. br.ErrMsg = "客户信息异常,不是当前所属销售,客户所属销售:" + companyProduct.SellerName + ";当前销售:" + sysUser.AdminName
  1823. return
  1824. }
  1825. // CRM8.8(仅针对权益客户)-申请延期的权限不再进行选择, 而是自动将所有的试用权限延期
  1826. if companyProduct.ProductId == utils.COMPANY_PRODUCT_RAI_ID {
  1827. reportPermissions, e := company.GetCompanyReportPermission(req.CompanyId, utils.COMPANY_PRODUCT_RAI_ID)
  1828. if e != nil {
  1829. br.Msg = "客户权限信息异常"
  1830. br.ErrMsg = "客户权限信息异常, Err: " + e.Error()
  1831. return
  1832. }
  1833. reportPermissionArr := make([]string, 0)
  1834. for i := range reportPermissions {
  1835. reportPermissionArr = append(reportPermissionArr, strconv.Itoa(reportPermissions[i].ChartPermissionId))
  1836. }
  1837. if len(reportPermissionArr) > 0 {
  1838. req.PermissionIds = strings.Join(reportPermissionArr, ",")
  1839. }
  1840. }
  1841. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  1842. if err != nil && err.Error() != utils.ErrNoRow() {
  1843. br.Msg = "获取审批信息失败"
  1844. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  1845. return
  1846. }
  1847. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  1848. br.Msg = "审批用户不存在"
  1849. br.ErrMsg = "审批用户不存在"
  1850. return
  1851. }
  1852. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  1853. approveContent := `试用延期`
  1854. var companyApprovalId int
  1855. utils.FileLog.Info("试用延期申请:%d", req.CompanyApprovalId)
  1856. if req.CompanyApprovalId > 0 {
  1857. utils.FileLog.Info("试用延期申请:%d", req.CompanyApprovalId)
  1858. err = company.ModifyCompanyApproval(req.CompanyId, productId, req.CompanyApprovalId, approveContent, req.ApplyRemark)
  1859. if err != nil {
  1860. br.Msg = "申请失败"
  1861. br.ErrMsg = "申请失败,Err:" + err.Error()
  1862. return
  1863. }
  1864. companyApprovalId = req.CompanyApprovalId
  1865. } else {
  1866. applyMethod := 3
  1867. approval := new(company.CompanyApproval)
  1868. approval.CompanyId = req.CompanyId
  1869. approval.ProductId = productId
  1870. approval.ApproveStatus = "待审批"
  1871. approval.ApproveUserId = 0
  1872. approval.ApproveRoleTypeCode = approveRoleTypeCode
  1873. approval.ApproveRealName = ""
  1874. approval.ApproveTime = time.Now()
  1875. approval.ApproveContent = "试用延期"
  1876. approval.ApplyMethod = applyMethod
  1877. approval.ApplyReasons = req.ApplyRemark
  1878. approval.ApplyUserId = sysUser.AdminId
  1879. approval.ApplyRealName = sysUser.RealName
  1880. approval.CreateTime = time.Now()
  1881. approval.ModifyTime = time.Now()
  1882. companyApprovalId, err = company.AddCompanyApproval(approval)
  1883. if err != nil {
  1884. br.Msg = "申请失败"
  1885. br.ErrMsg = "申请失败,Err:" + err.Error()
  1886. return
  1887. }
  1888. }
  1889. //处理权限
  1890. {
  1891. if req.PermissionIds != "" {
  1892. // CRM8.8(仅针对权益客户)-此处不再去查询主观对应的客观, 而是根据客户之前拥有的权限来操作
  1893. //permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  1894. //if err != nil {
  1895. // br.Msg = "获取信息失败"
  1896. // br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  1897. // return
  1898. //}
  1899. //req.PermissionIds = permissionStr
  1900. permissionArr := strings.Split(req.PermissionIds, ",")
  1901. //如果是编辑的话,删除原先相关的所有品种权限
  1902. if req.CompanyApprovalId > 0 {
  1903. err = company.DeleteCompanyDelayPermission(req.CompanyApprovalId)
  1904. if err != nil {
  1905. br.Msg = "申请失败"
  1906. br.ErrMsg = "删除之前的申请记录失败,Err:" + err.Error()
  1907. return
  1908. }
  1909. }
  1910. for k, v := range permissionArr {
  1911. fmt.Println(k, v)
  1912. permissionId, _ := strconv.Atoi(v)
  1913. //companyId, companyApplyId, chartPermissionId int
  1914. count, err := company.GetDelayPermissionCount(req.CompanyId, companyApprovalId, permissionId)
  1915. if err != nil && err.Error() != utils.ErrNoRow() {
  1916. br.Msg = "申请失败"
  1917. br.ErrMsg = "判断权限是否存在失败,Err:" + err.Error()
  1918. return
  1919. }
  1920. if count > 0 { //修改
  1921. err = company.ModifyCompanyDelayPermission(req.CompanyId, companyApprovalId, permissionId)
  1922. if err != nil {
  1923. br.Msg = "申请失败"
  1924. br.ErrMsg = "修改权限失败,Err:" + err.Error()
  1925. return
  1926. }
  1927. } else { //新增
  1928. if v != "" {
  1929. permissionId, err := strconv.Atoi(v)
  1930. if err != nil {
  1931. br.Msg = "申请失败"
  1932. br.ErrMsg = "权限格式转换失败,Err:" + err.Error()
  1933. return
  1934. }
  1935. delayItem := new(company.CompanyDelayPermission)
  1936. delayItem.CompanyId = req.CompanyId
  1937. delayItem.CompanyApplyId = companyApprovalId
  1938. delayItem.ChartPermissionId = permissionId
  1939. delayItem.StartDate = time.Now().Format(utils.FormatDate)
  1940. delayItem.EndDate = time.Now().AddDate(0, 2, 0).Format(utils.FormatDate)
  1941. delayItem.CreateTime = time.Now()
  1942. delayItem.ModifyTime = time.Now()
  1943. err = company.AddCompanyDelayPermission(delayItem)
  1944. if err != nil {
  1945. br.Msg = "申请失败"
  1946. br.ErrMsg = "新增延期审批权限失败,Err:" + err.Error()
  1947. return
  1948. }
  1949. }
  1950. }
  1951. }
  1952. }
  1953. }
  1954. //新增操作记录
  1955. {
  1956. remark := "申请延期"
  1957. operation := "delay"
  1958. go services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  1959. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, "", "", companyProduct.Status)
  1960. }
  1961. //新增客户产品日志
  1962. {
  1963. logType := "modify"
  1964. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  1965. }
  1966. err = company_apply.Apply(companyApprovalId, "试用延期申请单")
  1967. if err != nil {
  1968. br.Msg = "发起审批异常,请联系管理员"
  1969. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  1970. return
  1971. }
  1972. br.Ret = 200
  1973. br.Success = true
  1974. br.Msg = "申请成功"
  1975. }
  1976. // ApplyReceive
  1977. // @Title 申请领取
  1978. // @Description 申请领取接口
  1979. // @Param request body company.CompanyApplyReceiveReq true "type json string"
  1980. // @Success Ret=200 申请成功
  1981. // @router /apply/receive [post]
  1982. func (this *CompanyApplyController) ApplyReceive() {
  1983. br := new(models.BaseResponse).Init()
  1984. defer func() {
  1985. this.Data["json"] = br
  1986. this.ServeJSON()
  1987. }()
  1988. sysUser := this.SysUser
  1989. if sysUser == nil {
  1990. br.Msg = "请登录"
  1991. br.ErrMsg = "请登录,SysUser Is Empty"
  1992. br.Ret = 408
  1993. return
  1994. }
  1995. var req company.CompanyApplyReceiveReq
  1996. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  1997. if err != nil {
  1998. br.Msg = "参数解析异常!"
  1999. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2000. return
  2001. }
  2002. if req.CompanyId <= 0 {
  2003. br.Msg = "参数错误"
  2004. br.ErrMsg = "参数错误,客户id小于等于0"
  2005. return
  2006. }
  2007. // 查询当前销售是否有领取客户的权限
  2008. receiveEnabled, _ := services.CheckCompanyReceiveButton(sysUser.AdminId)
  2009. if !receiveEnabled {
  2010. br.Msg = "领取失败,您目前没有领取客户的权限"
  2011. br.ErrMsg = "领取失败,您目前没有领取客户的权限"
  2012. return
  2013. }
  2014. roleTypeCode := sysUser.RoleTypeCode
  2015. productId := services.GetProductId(roleTypeCode)
  2016. if productId == 0 {
  2017. br.Msg = "参数错误"
  2018. br.ErrMsg = "客户类型为:" + roleTypeCode
  2019. return
  2020. }
  2021. //如果是权益客户,在选择非研选行业试用时,需要判断当前有多少非研选的试用客户(试用状态,且行业是非研选)
  2022. if productId == utils.COMPANY_PRODUCT_RAI_ID {
  2023. permissionArr := strings.Split(req.PermissionIds, ",")
  2024. //如果所选行业不属于研选订阅跟研选扣点包,那就是非研选试用客户
  2025. var isNoResearch bool
  2026. for _, v := range permissionArr {
  2027. if v != strconv.Itoa(utils.CHART_PERMISSION_ID_YANXUAN) && v != strconv.Itoa(utils.YAN_XUAN_KOU_DIAN_BAO_ID) {
  2028. isNoResearch = true
  2029. continue
  2030. }
  2031. }
  2032. if isNoResearch {
  2033. tryOutCountRai, err := company.GetRaiCompanyTryOutCountNoResearch(sysUser.AdminId)
  2034. if err != nil {
  2035. br.Msg = "判断试用客户量失败"
  2036. br.ErrMsg = "判断试用客户量失败,Err:" + err.Error()
  2037. return
  2038. }
  2039. if tryOutCountRai >= utils.COMPANY_STATUS_TRY_OUT_COUNT_RAI {
  2040. br.Msg = "非研选试用客户最多40家"
  2041. return
  2042. }
  2043. }
  2044. }
  2045. //添加缓存,避免多次点击提交
  2046. {
  2047. deleteCache := true
  2048. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  2049. defer func() {
  2050. if deleteCache {
  2051. utils.Rc.Delete(cacheKey)
  2052. }
  2053. }()
  2054. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  2055. deleteCache = false
  2056. br.Msg = "系统处理中,请勿重复操作"
  2057. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  2058. return
  2059. }
  2060. }
  2061. approveRoleTypeCode := ""
  2062. if productId == 1 {
  2063. approveRoleTypeCode = utils.ROLE_TYPE_CODE_FICC_ADMIN
  2064. } else {
  2065. approveRoleTypeCode = utils.ROLE_TYPE_CODE_RAI_ADMIN
  2066. }
  2067. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  2068. if err != nil {
  2069. br.Msg = "获取客户信息失败"
  2070. br.ErrMsg = "获取客户信息失败"
  2071. return
  2072. }
  2073. if companyProduct == nil {
  2074. br.Msg = "获取客户信息失败"
  2075. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2076. return
  2077. }
  2078. if companyProduct.Status != utils.COMPANY_STATUS_LOSE {
  2079. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  2080. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行延期申请"
  2081. return
  2082. }
  2083. if companyProduct.ApproveStatus == "待审批" {
  2084. br.Msg = "存在待审批订单,不可重复提交"
  2085. return
  2086. }
  2087. approveUser, err := company.GetApproveUser(approveRoleTypeCode)
  2088. if err != nil && err.Error() != utils.ErrNoRow() {
  2089. br.Msg = "获取审批信息失败"
  2090. br.ErrMsg = "获取审批人信息失败,Err:" + err.Error()
  2091. return
  2092. }
  2093. if approveUser == nil || (err != nil && err.Error() == utils.ErrNoRow()) {
  2094. br.Msg = "审批用户不存在"
  2095. br.ErrMsg = "审批用户不存在"
  2096. return
  2097. }
  2098. approveContent := `原销售申领客户`
  2099. applyMethod := 4
  2100. var companyApprovalId int
  2101. //申请类型:1:试用->正式,2:冻结—>试用,3:试用延期,4:原销售申请领取流失客户,5:正式客户申请服务更新,6:正式客户补充协议
  2102. if req.CompanyApprovalId <= 0 {
  2103. approval := new(company.CompanyApproval)
  2104. approval.CompanyId = req.CompanyId
  2105. approval.ProductId = productId
  2106. approval.ApproveStatus = "待审批"
  2107. approval.ApproveUserId = 0
  2108. approval.ApproveRoleTypeCode = approveRoleTypeCode
  2109. approval.ApproveRealName = ""
  2110. approval.ApproveTime = time.Now()
  2111. approval.ApproveContent = approveContent
  2112. approval.ApplyMethod = applyMethod
  2113. approval.ApplyReasons = req.ApplyRemark
  2114. approval.ApplyUserId = sysUser.AdminId
  2115. approval.ApplyRealName = sysUser.RealName
  2116. approval.CreateTime = time.Now()
  2117. approval.ModifyTime = time.Now()
  2118. companyApprovalId, err = company.AddCompanyApproval(approval)
  2119. if err != nil {
  2120. br.Msg = "申请失败"
  2121. br.ErrMsg = "申请失败,Err:" + err.Error()
  2122. return
  2123. }
  2124. } else {
  2125. err = company.ModifyCompanyApproval(req.CompanyId, productId, req.CompanyApprovalId, approveContent, req.ApplyRemark)
  2126. if err != nil {
  2127. br.Msg = "申请失败"
  2128. br.ErrMsg = "申请失败,Err:" + err.Error()
  2129. return
  2130. }
  2131. companyApprovalId = req.CompanyApprovalId
  2132. //先删除之前申请的权限
  2133. _ = company.DeleteCompanyDelayPermission(req.CompanyApprovalId)
  2134. }
  2135. //处理权限
  2136. {
  2137. if req.PermissionIds != "" {
  2138. permissionStr, err := company.GetPermissionIdById(req.PermissionIds)
  2139. if err != nil {
  2140. br.Msg = "获取信息失败"
  2141. br.ErrMsg = "获取主观客观权限信息失败,Err:" + err.Error()
  2142. return
  2143. }
  2144. req.PermissionIds = permissionStr
  2145. permissionArr := strings.Split(req.PermissionIds, ",")
  2146. for _, v := range permissionArr {
  2147. if v != "" {
  2148. permissionId, err := strconv.Atoi(v)
  2149. if err != nil {
  2150. br.Msg = "申请失败"
  2151. br.ErrMsg = "权限格式转换失败,Err:" + err.Error()
  2152. return
  2153. }
  2154. delayItem := new(company.CompanyDelayPermission)
  2155. delayItem.CompanyId = req.CompanyId
  2156. delayItem.CompanyApplyId = companyApprovalId
  2157. delayItem.ChartPermissionId = permissionId
  2158. delayItem.StartDate = time.Now().Format(utils.FormatDate)
  2159. if productId == utils.COMPANY_PRODUCT_RAI_ID { // 权益客户试用期改为1个月。 需求池 1035
  2160. delayItem.EndDate = time.Now().AddDate(0, 1, 0).Format(utils.FormatDate)
  2161. } else {
  2162. delayItem.EndDate = time.Now().AddDate(0, 2, 0).Format(utils.FormatDate)
  2163. }
  2164. delayItem.CreateTime = time.Now()
  2165. delayItem.ModifyTime = time.Now()
  2166. err = company.AddCompanyDelayPermission(delayItem)
  2167. if err != nil {
  2168. br.Msg = "申请失败"
  2169. br.ErrMsg = "新增领取客户审批权限失败,Err:" + err.Error()
  2170. return
  2171. }
  2172. }
  2173. }
  2174. }
  2175. }
  2176. //新增操作记录
  2177. {
  2178. remark := "申请领取"
  2179. operation := "apply_receive"
  2180. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  2181. companyProduct.ProductName, sysUser.RealName, remark, operation, approveContent, "", "", companyProduct.Status)
  2182. }
  2183. //新增客户产品日志
  2184. {
  2185. logType := "modify"
  2186. go services.AddCompanyProductLog(companyProduct, this.SysUser.AdminId, logType)
  2187. }
  2188. err = company_apply.Apply(companyApprovalId, "申请领取申请单")
  2189. if err != nil {
  2190. br.Msg = "发起审批异常,请联系管理员"
  2191. br.ErrMsg = "客户审批发起异常,Err:" + err.Error()
  2192. return
  2193. }
  2194. br.Ret = 200
  2195. br.Success = true
  2196. br.Msg = "申请成功"
  2197. }
  2198. // ApplyRevoke
  2199. // @Title 申请撤回
  2200. // @Description 申请撤回接口
  2201. // @Param request body company.CompanyApplyRevokeReq true "type json string"
  2202. // @Success Ret=200 成功
  2203. // @router /apply/revoke [post]
  2204. func (this *CompanyApprovalController) ApplyRevoke() {
  2205. br := new(models.BaseResponse).Init()
  2206. defer func() {
  2207. this.Data["json"] = br
  2208. this.ServeJSON()
  2209. }()
  2210. sysUser := this.SysUser
  2211. if sysUser == nil {
  2212. br.Msg = "请登录"
  2213. br.ErrMsg = "请登录,SysUser Is Empty"
  2214. br.Ret = 408
  2215. return
  2216. }
  2217. var req company.CompanyApplyRevokeReq
  2218. err := json.Unmarshal(this.Ctx.Input.RequestBody, &req)
  2219. if err != nil {
  2220. br.Msg = "参数解析异常!"
  2221. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  2222. return
  2223. }
  2224. if req.CompanyId <= 0 {
  2225. br.Msg = "参数错误"
  2226. br.ErrMsg = "客户Id小于等于0:"
  2227. return
  2228. }
  2229. roleTypeCode := sysUser.RoleTypeCode
  2230. productId := services.GetProductId(roleTypeCode)
  2231. if productId == 0 {
  2232. br.Msg = "参数错误"
  2233. br.ErrMsg = "客户类型为:" + roleTypeCode
  2234. return
  2235. }
  2236. //添加缓存,避免多次点击提交
  2237. {
  2238. deleteCache := true
  2239. cacheKey := "CACHE_COMPANY_APPLY_" + strconv.Itoa(req.CompanyId) + "_" + strconv.Itoa(productId)
  2240. defer func() {
  2241. if deleteCache {
  2242. utils.Rc.Delete(cacheKey)
  2243. }
  2244. }()
  2245. if !utils.Rc.SetNX(cacheKey, 1, 30*time.Second) {
  2246. deleteCache = false
  2247. br.Msg = "系统处理中,请勿重复操作"
  2248. br.ErrMsg = "系统处理中,请勿重复操作" + sysUser.RealName + ";data:" + string(this.Ctx.Input.RequestBody)
  2249. return
  2250. }
  2251. }
  2252. companyProduct, err := company.GetCompanyProductByCompanyIdAndProductId(req.CompanyId, productId)
  2253. if err != nil {
  2254. br.Msg = "获取客户信息失败"
  2255. br.ErrMsg = "获取客户信息失败"
  2256. return
  2257. }
  2258. if companyProduct == nil {
  2259. br.Msg = "获取客户信息失败"
  2260. br.ErrMsg = "客户不存在,不可提交审批:companyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2261. return
  2262. }
  2263. approvalItem, err := company.GetCompanyApprovalById(req.CompanyId, productId)
  2264. if err != nil {
  2265. if err.Error() == utils.ErrNoRow() {
  2266. br.Msg = "待审批信息不存在"
  2267. br.ErrMsg = "待审批信息不存在,CompanyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2268. return
  2269. }
  2270. br.Msg = "获取信息失败"
  2271. br.ErrMsg = "获取信息失败,Err:" + err.Error()
  2272. return
  2273. }
  2274. if approvalItem == nil {
  2275. br.Msg = "待审批信息不存在"
  2276. br.ErrMsg = "待审批信息不存在,CompanyId:" + strconv.Itoa(req.CompanyId) + ";productId:" + strconv.Itoa(productId)
  2277. return
  2278. }
  2279. if approvalItem.ApproveStatus != "待审批" {
  2280. br.Msg = "客户状态为:" + companyProduct.Status + ";不可进行撤回操作"
  2281. br.ErrMsg = "客户状态为:" + companyProduct.Status + ";不可进行撤回操作"
  2282. return
  2283. }
  2284. //撤回审批单
  2285. err = company_apply.CancelApply(approvalItem, sysUser.AdminId)
  2286. if err != nil {
  2287. br.Msg = "撤回失败"
  2288. br.ErrMsg = "撤回失败,Err:" + err.Error()
  2289. return
  2290. }
  2291. //真正撤回操作
  2292. err = company.ApplyRevoke(approvalItem.CompanyApprovalId, approvalItem.CompanyId, approvalItem.ProductId)
  2293. if err != nil {
  2294. br.Msg = "撤回失败"
  2295. br.ErrMsg = "撤回失败,Err:" + err.Error()
  2296. return
  2297. }
  2298. //新增操作记录
  2299. {
  2300. remark := "撤回"
  2301. operation := "apply_revoke"
  2302. services.AddCompanyOperationRecord(req.CompanyId, companyProduct.SellerId, sysUser.AdminId, productId, 0, companyProduct.CompanyName,
  2303. companyProduct.ProductName, sysUser.RealName, remark, operation, "", "", "", companyProduct.Status)
  2304. }
  2305. br.Ret = 200
  2306. br.Success = true
  2307. br.Msg = "撤回成功"
  2308. }