Merge branch 'develop' of https://gitee.com/fusenpack/fusenapi into develop
This commit is contained in:
		
						commit
						e164ced733
					
				| @ -186,6 +186,12 @@ func (l *UserLogoSetLogic) UserLogoSet(req *types.UserLogoSetReq, userinfo *auth | |||||||
| 				logc.Errorf(l.ctx, "userMaterialInfo Metadata template_tag_id err:%+v", err) | 				logc.Errorf(l.ctx, "userMaterialInfo Metadata template_tag_id err:%+v", err) | ||||||
| 				return err | 				return err | ||||||
| 			} | 			} | ||||||
|  | 
 | ||||||
|  | 			userMaterialVrsionData, userMaterialVersionEx := metadataMapOldUserMaterial["version"] | ||||||
|  | 			if !userMaterialVersionEx { | ||||||
|  | 				userMaterialVrsionData = "" | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
| 			userMaterialTemplateIdTagIds := userMaterialTemplateIdTagIdData.([]interface{}) | 			userMaterialTemplateIdTagIds := userMaterialTemplateIdTagIdData.([]interface{}) | ||||||
| 
 | 
 | ||||||
| 			userMaterialTemplateIdTagId := userMaterialTemplateIdTagIds[0].(string) | 			userMaterialTemplateIdTagId := userMaterialTemplateIdTagIds[0].(string) | ||||||
| @ -193,7 +199,8 @@ func (l *UserLogoSetLogic) UserLogoSet(req *types.UserLogoSetReq, userinfo *auth | |||||||
| 			userMaterialTemplateTag := userMaterialTemplateTagData.(map[string]interface{}) | 			userMaterialTemplateTag := userMaterialTemplateTagData.(map[string]interface{}) | ||||||
| 			userMaterialTemplateTagIndex := userMaterialTemplateTag[userMaterialTemplateIdTagId] | 			userMaterialTemplateTagIndex := userMaterialTemplateTag[userMaterialTemplateIdTagId] | ||||||
| 
 | 
 | ||||||
| 			templateTagSelected := make(map[string]interface{}, 3) | 			templateTagSelected := make(map[string]interface{}, 4) | ||||||
|  | 			templateTagSelected["version"] = userMaterialVrsionData | ||||||
| 			templateTagSelected["color"] = userMaterialTemplateTagIndex | 			templateTagSelected["color"] = userMaterialTemplateTagIndex | ||||||
| 			templateTagSelected["template_tag"] = userMaterialTemplateIdTagId | 			templateTagSelected["template_tag"] = userMaterialTemplateIdTagId | ||||||
| 			templateTagSelected["selected_index"] = 0 | 			templateTagSelected["selected_index"] = 0 | ||||||
|  | |||||||
| @ -48,7 +48,7 @@ func (l *CreateLdapOrganizationLogic) CreateLdapOrganization(req *types.CreateLd | |||||||
| 		return resp.SetStatusWithMessage(basic.CodeRequestParamsErr, "参数错误,组织英文名不能包含中文") | 		return resp.SetStatusWithMessage(basic.CodeRequestParamsErr, "参数错误,组织英文名不能包含中文") | ||||||
| 	} | 	} | ||||||
| 	if req.ParentOrganizationDN == "" { | 	if req.ParentOrganizationDN == "" { | ||||||
| 		return resp.SetStatusWithMessage(basic.CodeRequestParamsErr, "参数错误,父级DN不能为空") | 		req.ParentOrganizationDN = l.svcCtx.Config.Ldap.BaseDN //不传则是第一层级 | ||||||
| 	} | 	} | ||||||
| 	if req.BusinessCategory == "" { | 	if req.BusinessCategory == "" { | ||||||
| 		return resp.SetStatusWithMessage(basic.CodeRequestParamsErr, "参数错误,组织分类名不能为空") | 		return resp.SetStatusWithMessage(basic.CodeRequestParamsErr, "参数错误,组织分类名不能为空") | ||||||
|  | |||||||
| @ -33,12 +33,13 @@ func NewGetLdapOrganizationsLogic(ctx context.Context, svcCtx *svc.ServiceContex | |||||||
| // func (l *GetLdapOrganizationsLogic) BeforeLogic(w http.ResponseWriter, r *http.Request) { | // func (l *GetLdapOrganizationsLogic) BeforeLogic(w http.ResponseWriter, r *http.Request) { | ||||||
| // } | // } | ||||||
| type DNItem struct { | type DNItem struct { | ||||||
| 	Attribute map[string]interface{} `json:"attribute"` | 	Attribute   map[string]interface{} `json:"attribute"` | ||||||
| 	HasMember bool                   `json:"has_member"` //是否有成员 | 	MemberCount int                    `json:"member_count"` | ||||||
| 	DN        string                 `json:"dn"` | 	Level       int                    `json:"level"` | ||||||
| 	ParentDN  string                 `json:"parent_dn"` | 	DN          string                 `json:"dn"` | ||||||
| 	Sort      int                    `json:"sort"` | 	ParentDN    string                 `json:"parent_dn"` | ||||||
| 	Child     []*DNItem              `json:"child"` | 	Sort        int                    `json:"sort"` | ||||||
|  | 	Child       []*DNItem              `json:"child"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (l *GetLdapOrganizationsLogic) GetLdapOrganizations(req *types.Request, r *http.Request) (resp *basic.Response) { | func (l *GetLdapOrganizationsLogic) GetLdapOrganizations(req *types.Request, r *http.Request) (resp *basic.Response) { | ||||||
| @ -55,7 +56,7 @@ func (l *GetLdapOrganizationsLogic) GetLdapOrganizations(req *types.Request, r * | |||||||
| 	if len(peopleDNSlice) <= 1 { | 	if len(peopleDNSlice) <= 1 { | ||||||
| 		return resp.SetStatusWithMessage(basic.CodeServiceErr, "基础用户组的DN未配置") | 		return resp.SetStatusWithMessage(basic.CodeServiceErr, "基础用户组的DN未配置") | ||||||
| 	} | 	} | ||||||
| 	filter := "(|(&(objectClass=groupOfUniqueNames)(objectClass=top))(objectClass=organization))" | 	filter := "(&(objectClass=groupOfUniqueNames)(objectClass=top))" | ||||||
| 	fields := []string{"businessCategory", "dn", "uniqueMember"} | 	fields := []string{"businessCategory", "dn", "uniqueMember"} | ||||||
| 	searchResult, err := l.svcCtx.Ldap.Search(l.svcCtx.Config.Ldap.BaseDN, ldap.ScopeWholeSubtree, filter, fields, nil) | 	searchResult, err := l.svcCtx.Ldap.Search(l.svcCtx.Config.Ldap.BaseDN, ldap.ScopeWholeSubtree, filter, fields, nil) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| @ -67,22 +68,25 @@ func (l *GetLdapOrganizationsLogic) GetLdapOrganizations(req *types.Request, r * | |||||||
| 	for _, v := range searchResult.Entries { | 	for _, v := range searchResult.Entries { | ||||||
| 		sortNum++ | 		sortNum++ | ||||||
| 		attribute := make(map[string]interface{}) | 		attribute := make(map[string]interface{}) | ||||||
| 		hasMember := false | 		memberCount := 0 | ||||||
| 		for _, attr := range v.Attributes { | 		for _, attr := range v.Attributes { | ||||||
| 			//判断是否有成员(不包含root用户所以判断大于1) | 			//判断是否有成员(不包含root用户所以判断大于1) | ||||||
| 			if attr.Name == "uniqueMember" && len(attr.Values) > 1 { | 			if attr.Name == "uniqueMember" { | ||||||
| 				hasMember = true | 				memberCount = len(attr.Values) | ||||||
| 				continue | 				continue | ||||||
| 			} | 			} | ||||||
| 			attribute[attr.Name] = strings.Join(attr.Values, ",") | 			attribute[attr.Name] = strings.Join(attr.Values, ",") | ||||||
| 		} | 		} | ||||||
|  | 		dnSlice := strings.ReplaceAll(v.DN, ","+l.svcCtx.Config.Ldap.BaseDN, "") //把最顶级的组织去掉 | ||||||
|  | 		level := len(strings.Split(dnSlice, ",")) | ||||||
| 		mapDN[v.DN] = &DNItem{ | 		mapDN[v.DN] = &DNItem{ | ||||||
| 			DN:        v.DN, | 			DN:          v.DN, | ||||||
| 			ParentDN:  "", | 			ParentDN:    "", | ||||||
| 			HasMember: hasMember, | 			Level:       level, | ||||||
| 			Attribute: attribute, | 			MemberCount: memberCount, | ||||||
| 			Sort:      sortNum, | 			Attribute:   attribute, | ||||||
| 			Child:     make([]*DNItem, 0, 100), | 			Sort:        sortNum, | ||||||
|  | 			Child:       make([]*DNItem, 0, 100), | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	//组织树形层级关系 | 	//组织树形层级关系 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user