1 Star 0 Fork 0

carlmax_my/console-core-go

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
ldap_authing.go 3.00 KB
一键复制 编辑 原始数据 按行查看 历史
carlmax_my 提交于 2024-12-02 21:32 . init project
package ldap
import (
"encoding/json"
"fmt"
"log"
"strings"
"gitee.com/carlmax_my/console-core-go/pkg/errors"
"github.com/go-ldap/ldap/v3"
)
type AuthingLdapFields struct {
Url string `json:"url"` //"ldaps://127.0.0.1:636",
BindDN string `json:"bindDN"` //"cn=admin,dc=sdp-console,dc=com",
BindCredentials string `json:"bindCredentials"` //"123456",
BASE_DN string `json:"BASE_DN"` //"dc=sdp-console,dc=com",
QueryCriteria string `json:"queryCriteria"` //"&(objectClass=organizationalPerson)(cn=%s)"
GroupQueryCriteria string `json:"groupQueryCriteria"` //"&(objectClass=organizationalPerson)(cn=%s)"
}
func FetchLdapEntriesByIdp(jsonStrFields string, group bool) (result []*ldap.Entry, err error) {
var fields AuthingLdapFields
err = json.Unmarshal([]byte(jsonStrFields), &fields)
if err != nil {
return
}
return FetchLdapEntries(&fields, group)
}
func FetchLdapEntries(fields *AuthingLdapFields, group bool) (result []*ldap.Entry, err error) {
opts := newOptionsFromFields(fields)
service := NewLdapService(opts)
// 获取连接
err = service.InitAll()
if err != nil {
return
}
if group {
return service.FetchEntries(fields.GroupQueryCriteria)
} else {
return service.FetchEntries(fields.QueryCriteria)
}
}
func SearchAllUserGroups(jsonStrFields string) ([]*ldap.Entry, error) {
var fields AuthingLdapFields
err := json.Unmarshal([]byte(jsonStrFields), &fields)
if err != nil {
return nil, err
}
l, err := ldap.DialURL(fields.Url)
if err != nil {
return nil, err
}
defer l.Close()
_, err = l.SimpleBind(&ldap.SimpleBindRequest{
Username: fields.BindDN,
Password: fields.BindCredentials,
})
if err != nil {
return nil, err
}
searchRequest := ldap.NewSearchRequest(
fields.BASE_DN, // The base dn to search
ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, 0, false,
fmt.Sprintf("("+fields.QueryCriteria+")", "userID"), // The filter to apply
[]string{"dn", "cn"}, // A list attributes to retrieve
nil,
)
sr, err := l.Search(searchRequest)
if err != nil {
return nil, err
}
log.Println("SearchAllUserGroups", len(sr.Entries))
log.Println("SearchAllUserGroups", len(sr.Entries[0].Attributes))
log.Println("SearchAllUserGroups", sr.Entries[0].Attributes[0].Name)
return sr.Entries, nil
}
func TestLdapConnByIdp(jsonStrFields string) error {
var fields AuthingLdapFields
if err := json.Unmarshal([]byte(jsonStrFields), &fields); err != nil {
return errors.New("invalid ldap config:" + err.Error())
}
return TestLdapConn(&fields)
}
func TestLdapConn(fields *AuthingLdapFields) error {
opts := newOptionsFromFields(fields)
service := NewLdapService(opts)
return service.TryConn()
}
func newOptionsFromFields(fields *AuthingLdapFields) *LdapConnOptions {
opts := NewLdapConnOptions()
opts.ConnUrl = strings.ToLower(fields.Url)
opts.AdminAccount = fields.BindDN
opts.Password = fields.BindCredentials
opts.BaseDn = fields.BASE_DN
opts.SslEncryption = false
return opts
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/carlmax_my/console-core-go.git
git@gitee.com:carlmax_my/console-core-go.git
carlmax_my
console-core-go
console-core-go
v0.0.26

搜索帮助