作者 yangfu

模板修改

@@ -34,11 +34,6 @@ func (this *TemplateController) TemplateAdd() { @@ -34,11 +34,6 @@ func (this *TemplateController) TemplateAdd() {
34 msg = protocol.BadRequestParam("1") 34 msg = protocol.BadRequestParam("1")
35 return 35 return
36 } 36 }
37 - //if !(request.Type == 1 || request.Type == 2) {  
38 - // msg = protocol.BadRequestParam("1")  
39 - // log.Error("type error :%v", request.Type)  
40 - // return  
41 - //}  
42 if b, m := this.Valid(request); !b { 37 if b, m := this.Valid(request); !b {
43 msg = m 38 msg = m
44 return 39 return
@@ -52,10 +47,6 @@ func (this *TemplateController) TemplateAdd() { @@ -52,10 +47,6 @@ func (this *TemplateController) TemplateAdd() {
52 return 47 return
53 } 48 }
54 { 49 {
55 - //名称不能超过20字  
56 - //字段只能10个字段  
57 - }  
58 - {  
59 //审批人配置 50 //审批人配置
60 v := request.AuditFlowConfig.NoApprover 51 v := request.AuditFlowConfig.NoApprover
61 if !(v == models.NoApproverPass || v == models.NoApproverToAdmin) { 52 if !(v == models.NoApproverPass || v == models.NoApproverToAdmin) {
@@ -66,47 +57,18 @@ func (this *TemplateController) TemplateAdd() { @@ -66,47 +57,18 @@ func (this *TemplateController) TemplateAdd() {
66 msg = protocol.BadRequestParam("10069") 57 msg = protocol.BadRequestParam("10069")
67 return 58 return
68 } 59 }
69 - var count int  
70 - for i := range request.AuditFlowConfig.ProcessConfig {  
71 - config := request.AuditFlowConfig.ProcessConfig[i]  
72 - if !(config.ApproveType == models.AuditByDepartmentor || config.ApproveType == models.AuditByUser || config.ApproveType == models.AuditByRole) {  
73 - msg = protocol.BadRequestParam("10171")  
74 - return  
75 - }  
76 - if !(config.AcitonType == models.ActionTypeOr || config.AcitonType == models.ActionTypeAnd) {  
77 - msg = protocol.BadRequestParam("10172")  
78 - return  
79 - }  
80 - if config.ApproveType == models.AuditByUser {  
81 - if len(config.ToUser) == 0 {  
82 - msg = protocol.BadRequestParam("10170")  
83 - return  
84 } 60 }
85 - if len(config.ToUser) > 10 {  
86 - msg = protocol.BadRequestParam("10174")  
87 - return  
88 - }  
89 - }  
90 - if config.ApproveType == models.AuditByRole {  
91 - if len(config.ToRole) == 0 {  
92 - msg = protocol.BadRequestParam("10173")  
93 - return  
94 - }  
95 - if len(config.ToRole) > 1 {  
96 - msg = protocol.BadRequestParam("10175") 61 + {
  62 + if msg = audit.ValidFormList(request.Template.InputList); msg.Errno != 0 {
  63 + log.Error("valid fail ,code:%v msg:%v", msg.OriginErrno, msg.Errmsg)
97 return 64 return
98 } 65 }
99 - }  
100 - if config.ProcessType == models.FlowTypeNormal {  
101 - count++  
102 - if count > 1 {  
103 - msg = protocol.BadRequestParam("10176") 66 +
  67 + if msg = audit.ValidAuditFlowConfig(request.AuditFlowConfig); msg.Errno != 0 {
  68 + log.Error("valid fail ,code:%v msg:%v", msg.OriginErrno, msg.Errmsg)
104 return 69 return
105 } 70 }
106 } 71 }
107 - }  
108 - }  
109 -  
110 rsp, err := audit.TemplateAdd(uid, companyId, request) 72 rsp, err := audit.TemplateAdd(uid, companyId, request)
111 msg = protocol.NewReturnResponse(rsp, err) 73 msg = protocol.NewReturnResponse(rsp, err)
112 return 74 return
@@ -145,6 +107,17 @@ func (this *TemplateController) TemplateUpdate() { @@ -145,6 +107,17 @@ func (this *TemplateController) TemplateUpdate() {
145 msg = protocol.BadRequestParam("10272") 107 msg = protocol.BadRequestParam("10272")
146 return 108 return
147 } 109 }
  110 + {
  111 + if msg = audit.ValidFormList(request.Template.InputList); msg.Errno != 0 {
  112 + log.Error("valid fail ,code:%v msg:%v", msg.OriginErrno, msg.Errmsg)
  113 + return
  114 + }
  115 +
  116 + if msg = audit.ValidAuditFlowConfig(request.AuditFlowConfig); msg.Errno != 0 {
  117 + log.Error("valid fail ,code:%v msg:%v", msg.OriginErrno, msg.Errmsg)
  118 + return
  119 + }
  120 + }
148 rsp, err := audit.TemplateUpdate(uid, companyId, request) 121 rsp, err := audit.TemplateUpdate(uid, companyId, request)
149 msg = protocol.NewReturnResponse(rsp, err) 122 msg = protocol.NewReturnResponse(rsp, err)
150 return 123 return
@@ -122,3 +122,12 @@ func GetAuditTemplateByName(companyId int64, name string, chanceTypeId int) (v * @@ -122,3 +122,12 @@ func GetAuditTemplateByName(companyId int64, name string, chanceTypeId int) (v *
122 } 122 }
123 return 123 return
124 } 124 }
  125 +
  126 +func GetAuditTemplateSort(companyId int64, chanceTypeId int) (v *ChanceType, err error) {
  127 + o := orm.NewOrm()
  128 + sql := "select max(sort_num) sort_num from audit_template where company_id=? and chance_type_id=?"
  129 + if err = o.Raw(sql, companyId, chanceTypeId).QueryRow(&v); err == nil {
  130 + return
  131 + }
  132 + return
  133 +}
@@ -110,3 +110,13 @@ func GetChanceTypeByName(companyId int64, name string) (v *ChanceType, err error @@ -110,3 +110,13 @@ func GetChanceTypeByName(companyId int64, name string) (v *ChanceType, err error
110 } 110 }
111 return 111 return
112 } 112 }
  113 +
  114 +//获取一级分类最大序号
  115 +func GetChanceTypeMaxSort(companyId int64) (v *ChanceType, err error) {
  116 + o := orm.NewOrm()
  117 + sql := "select max(sort_num) sort_num from chance_type where company_id=?"
  118 + if err = o.Raw(sql, companyId).QueryRow(&v); err == nil {
  119 + return
  120 + }
  121 + return
  122 +}
@@ -35,14 +35,18 @@ type ResponseMessage struct { @@ -35,14 +35,18 @@ type ResponseMessage struct {
35 Errno int `json:"code"` 35 Errno int `json:"code"`
36 Errmsg string `json:"msg"` 36 Errmsg string `json:"msg"`
37 Data interface{} `json:"data"` 37 Data interface{} `json:"data"`
  38 +
  39 + OriginErrno string `json:"-"`
38 } 40 }
39 41
40 func NewMessage(code string) *ResponseMessage { 42 func NewMessage(code string) *ResponseMessage {
41 ecode := SearchErr(code) 43 ecode := SearchErr(code)
  44 +
42 rsp := &ResponseMessage{ 45 rsp := &ResponseMessage{
43 Errno: transformCode(ecode.Errno), 46 Errno: transformCode(ecode.Errno),
44 Errmsg: ecode.Errmsg, 47 Errmsg: ecode.Errmsg,
45 Data: NullData, 48 Data: NullData,
  49 + OriginErrno: code,
46 } 50 }
47 return rsp 51 return rsp
48 } 52 }
@@ -87,6 +87,9 @@ var errmessge ErrorMap = map[string]string{ @@ -87,6 +87,9 @@ var errmessge ErrorMap = map[string]string{
87 "10281": "请您选择的审批人员", 87 "10281": "请您选择的审批人员",
88 "10282": "请您选择的审批角色", 88 "10282": "请您选择的审批角色",
89 "10283": "特殊审批流程被审批人不可重复", 89 "10283": "特殊审批流程被审批人不可重复",
  90 + "10284": "表单字段已经重复",
  91 + "10285": "未设置基础内容",
  92 + "10286": "未设置特殊审批人",
90 93
91 "10170": "请选择指定成员", 94 "10170": "请选择指定成员",
92 "10171": "请选择审批人类别", 95 "10171": "请选择审批人类别",
@@ -56,6 +56,11 @@ func TemplateAdd(uid, companyId int64, request *protocol.TemplateAddRequest) (rs @@ -56,6 +56,11 @@ func TemplateAdd(uid, companyId int64, request *protocol.TemplateAddRequest) (rs
56 CreateAt: time.Now(), 56 CreateAt: time.Now(),
57 UpdateAt: time.Now(), 57 UpdateAt: time.Now(),
58 } 58 }
  59 + if t, e := models.GetAuditTemplateSort(companyId, request.Template.ChanceTypeId); e == nil {
  60 + template.SortNum = t.SortNum + 1
  61 + } else {
  62 + template.SortNum = 1
  63 + }
59 if templateId, err = orm.Insert(template); err != nil { 64 if templateId, err = orm.Insert(template); err != nil {
60 log.Error(err.Error()) 65 log.Error(err.Error())
61 orm.Rollback() 66 orm.Rollback()
@@ -515,10 +520,18 @@ func TemplateDelete(uid, companyId int64, request *protocol.TemplateDeleteReques @@ -515,10 +520,18 @@ func TemplateDelete(uid, companyId int64, request *protocol.TemplateDeleteReques
515 return 520 return
516 } 521 }
517 orm := orm2.NewOrm() 522 orm := orm2.NewOrm()
  523 + orm.Begin()
518 if err = utils.ExecuteSQLWithOrmer(orm, models.DeleteAuditFormBy, request.TemplateId, companyId); err != nil { 524 if err = utils.ExecuteSQLWithOrmer(orm, models.DeleteAuditFormBy, request.TemplateId, companyId); err != nil {
519 log.Error(err.Error()) 525 log.Error(err.Error())
  526 + orm.Rollback()
  527 + return
  528 + }
  529 + if err = utils.ExecuteSQLWithOrmer(orm, models.DeleteAuditFlowConfigSql, request.TemplateId); err != nil {
  530 + log.Error(err.Error())
  531 + orm.Rollback()
520 return 532 return
521 } 533 }
  534 + orm.Commit()
522 rsp = &protocol.TemplateDeleteResponse{} 535 rsp = &protocol.TemplateDeleteResponse{}
523 return 536 return
524 } 537 }
@@ -605,6 +618,11 @@ func TemplateOperateCategory(uid, companyId int64, request *protocol.TemplateOpe @@ -605,6 +618,11 @@ func TemplateOperateCategory(uid, companyId int64, request *protocol.TemplateOpe
605 err = protocol.NewErrWithMessage("10271") 618 err = protocol.NewErrWithMessage("10271")
606 return 619 return
607 } 620 }
  621 + if c, e := models.GetChanceTypeMaxSort(companyId); e == nil {
  622 + chanceType.SortNum = c.SortNum + 1
  623 + } else {
  624 + chanceType.SortNum = 1
  625 + }
608 if _, err = models.AddChanceType(chanceType); err != nil { 626 if _, err = models.AddChanceType(chanceType); err != nil {
609 log.Error(err.Error()) 627 log.Error(err.Error())
610 } 628 }
@@ -687,7 +705,7 @@ func CategoryEditSort(uid, companyId int64, request *protocol.CategoryEditSortRe @@ -687,7 +705,7 @@ func CategoryEditSort(uid, companyId int64, request *protocol.CategoryEditSortRe
687 func ValidAuditFlowConfig(flowConfig protocol.AuditFlowConfig) (msg *protocol.ResponseMessage) { 705 func ValidAuditFlowConfig(flowConfig protocol.AuditFlowConfig) (msg *protocol.ResponseMessage) {
688 var ( 706 var (
689 count int 707 count int
690 - specailUser map[int]int 708 + specailUser map[int]int = make(map[int]int)
691 ) 709 )
692 msg = protocol.NewMessage("0") 710 msg = protocol.NewMessage("0")
693 for i := range flowConfig.ProcessConfig { 711 for i := range flowConfig.ProcessConfig {
@@ -729,18 +747,16 @@ func ValidAuditFlowConfig(flowConfig protocol.AuditFlowConfig) (msg *protocol.Re @@ -729,18 +747,16 @@ func ValidAuditFlowConfig(flowConfig protocol.AuditFlowConfig) (msg *protocol.Re
729 } 747 }
730 if config.ProcessType == models.FlowTypeSpecail { 748 if config.ProcessType == models.FlowTypeSpecail {
731 if len(config.FromSpecialUser) == 0 { //特殊人为空 749 if len(config.FromSpecialUser) == 0 { //特殊人为空
732 - msg = protocol.BadRequestParam("10281")  
733 - return  
734 - }  
735 - msg = ValidProcessConfig(&config)  
736 - if msg.Errno != 0 { 750 + msg = protocol.BadRequestParam("10286")
737 return 751 return
738 } 752 }
739 - for i := range config.ToUser {  
740 - u := config.ToUser[i] 753 + for i := range config.FromSpecialUser {
  754 + u := config.FromSpecialUser[i]
741 if _, ok := specailUser[u.Id]; ok { 755 if _, ok := specailUser[u.Id]; ok {
742 msg = protocol.BadRequestParam("10283") 756 msg = protocol.BadRequestParam("10283")
743 return 757 return
  758 + } else {
  759 + specailUser[u.Id] = u.Id
744 } 760 }
745 } 761 }
746 } 762 }
@@ -769,3 +785,47 @@ func ValidProcessConfig(config *protocol.ProcessConfig) (msg *protocol.ResponseM @@ -769,3 +785,47 @@ func ValidProcessConfig(config *protocol.ProcessConfig) (msg *protocol.ResponseM
769 } 785 }
770 return 786 return
771 } 787 }
  788 +
  789 +//校验表单
  790 +//名称不能超过20字
  791 +//表单项最低10个字段
  792 +//表单项不能重复
  793 +//基础表单项不能为空
  794 +func ValidFormList(inputs []*protocol.InputElement) (msg *protocol.ResponseMessage) {
  795 + msg = &protocol.ResponseMessage{}
  796 + var mapCheckRe map[string]string = make(map[string]string)
  797 + var countBasic, countExtral int
  798 + var countBasicRequire int
  799 + for i := range inputs {
  800 + input := inputs[i]
  801 + if len([]rune(input.Label)) > 20 {
  802 + msg = protocol.BadRequestParam("10273")
  803 + return
  804 + }
  805 + key := fmt.Sprintf("%v-%v", input.SectionType, input.Label)
  806 + if _, ok := mapCheckRe[key]; ok {
  807 + msg = protocol.BadRequestParam("10284")
  808 + return
  809 + } else {
  810 + mapCheckRe[key] = key
  811 + }
  812 + if input.SectionType == 1 {
  813 + countBasic++
  814 + }
  815 + if input.SectionType == 2 {
  816 + countExtral++
  817 + }
  818 + if input.SectionType == 1 && input.Required == 1 {
  819 + countBasicRequire++
  820 + }
  821 + }
  822 + if countBasic == 0 {
  823 + msg = protocol.BadRequestParam("10285")
  824 + return
  825 + }
  826 + if countBasic >= 10 || countExtral >= 10 {
  827 + msg = protocol.BadRequestParam("10274")
  828 + return
  829 + }
  830 + return
  831 +}
  1 +package audit
  2 +
  3 +import (
  4 + "oppmg/models"
  5 + "oppmg/protocol"
  6 + "testing"
  7 +)
  8 +
  9 +func Test_ValidFormList(t *testing.T) {
  10 + input := []*protocol.InputElement{
  11 + //{
  12 + // Label:"dsaghoida",
  13 + // SectionType:1,
  14 + //},
  15 + //{
  16 + // Label:"dsaghoida2",
  17 + // SectionType:1,
  18 + //},
  19 + {
  20 + Label: "dsaghoid",
  21 + SectionType: 2,
  22 + }, {Label: "1", SectionType: 2}, {Label: "2", SectionType: 2}, {Label: "3", SectionType: 2}, {Label: "4", SectionType: 2}, {Label: "5", SectionType: 2}, {Label: "6", SectionType: 2}, {Label: "7", SectionType: 2}, {Label: "8", SectionType: 2}, {Label: "9", SectionType: 2}, {Label: "10", SectionType: 2},
  23 + }
  24 + msg := ValidFormList(input)
  25 + if msg.Errno != 0 {
  26 + t.Log(msg.Errno, msg.Errmsg)
  27 + }
  28 +}
  29 +
  30 +func Test_ValidAuditFlowConfig(t *testing.T) {
  31 + input := protocol.AuditFlowConfig{
  32 + NoApprover: 0,
  33 + ProcessConfig: []protocol.ProcessConfig{
  34 + {
  35 + ApproveType: models.AuditByRole,
  36 + ProcessType: models.FlowTypeSpecail,
  37 + AcitonType: models.ActionTypeAnd,
  38 + GroupId: 1,
  39 + FromSpecialUser: []protocol.VisibleObject{{Id: 1, Name: "1"}, {Id: 1, Name: "1"}},
  40 + ToUser: []protocol.VisibleObject{{Id: 1, Name: "1"}},
  41 + ToRole: []protocol.VisibleObject{{Id: 1, Name: "1"}},
  42 + },
  43 + },
  44 + }
  45 + msg := ValidAuditFlowConfig(input)
  46 + if msg.Errno != 0 {
  47 + t.Log(msg.OriginErrno, msg.Errmsg)
  48 + }
  49 +}