mirror of
https://github.com/1Panel-dev/KubePi.git
synced 2025-10-05 23:37:01 +08:00
87 lines
1.9 KiB
Go
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
|
|
}
|