Files
KubePi/pkg/util/ldap/ldap_client.go
2022-06-10 16:00:01 +08:00

87 lines
1.9 KiB
Go

package ldap
import (
"crypto/tls"
"errors"
"fmt"
"github.com/go-ldap/ldap/v3"
)
type Ldap struct {
Address string `json:"address"`
Port string `json:"port"`
Username string `json:"username"`
Password string `json:"password"`
Conn *ldap.Conn
TLS bool `json:"tls"`
}
func NewLdapClient(address, port, username, password string, tls bool) *Ldap {
return &Ldap{
Username: username,
Address: address,
Password: password,
Port: port,
TLS: tls,
}
}
func (l *Ldap) Connect() error {
var err error
if l.TLS {
l.Conn, err = ldap.DialTLS("tcp", fmt.Sprintf("%s:%s", l.Address, l.Port), &tls.Config{
InsecureSkipVerify: true,
})
} else {
l.Conn, err = ldap.Dial("tcp", fmt.Sprintf("%s:%s", l.Address, l.Port))
}
if err != nil {
return err
}
if err := l.Conn.Bind(l.Username, l.Password); err != nil {
return err
}
return nil
}
func (l *Ldap) Search(dn, filter string, sizeLimit, timeLimit int, attributes []string) ([]*ldap.Entry, error) {
searchRequest := ldap.NewSearchRequest(dn,
ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, timeLimit, false,
filter,
attributes,
nil)
sr, err := l.Conn.SearchWithPaging(searchRequest, uint32(sizeLimit))
if err != nil {
return nil, err
}
if len(sr.Entries) == 0 {
return nil, errors.New("user is not found")
}
defer l.Conn.Close()
return sr.Entries, err
}
func (l *Ldap) Login(dn, filter, password string, sizeLimit, timeLimit int) error {
searchRequest := ldap.NewSearchRequest(dn,
ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, sizeLimit, timeLimit, false,
filter,
[]string{"dn", "cn", "uid"},
nil)
sr, err := l.Conn.Search(searchRequest)
if err != nil {
return err
}
if len(sr.Entries) != 1 {
return errors.New("user is not found")
}
userdn := sr.Entries[0].DN
err = l.Conn.Bind(userdn, password)
if err != nil {
return err
}
defer l.Conn.Close()
return nil
}