Плагин LDAP для Apache-Answer-инкубаторApache

Ответить
Anonymous
 Плагин LDAP для Apache-Answer-инкубатор

Сообщение Anonymous »

Как подключиться к Apache-Answer-инкубатору через LDAP для аутентификации? И как использовать плагин, созданный в модуле аутентификации для входа в систему? Не могу заставить его работать, так как я новичок в языке. Как использовать это и заставить его запустить? < /P>
package answer
import (
"embed"
"github.com/apache/incubator-answer-plugins/util"

"github.com/apache/incubator-answer/plugin"
"github.com/go-ldap/ldap/v3"
"fmt"

)

//go:embed info.yaml
var Info embed.FS

type Ldapconn struct {
ldapServer string
ldapPort int
bindDN string
password string
conn *ldap.Conn
}
func init() {
plugin.Register(&Ldapconn{})
}
func (Ldapconn) Info() plugin.Info {
info := &util.Info{}
info.GetInfo(Info)

return plugin.Info{
Name: plugin.MakeTranslator("Ldapconn"),
SlugName: info.SlugName,
Description: plugin.MakeTranslator(""),
Author: info.Author,
Version: info.Version,
Link: info.Link,
}
}

func New(ldapServer string, ldapPort int, bindDN string, password string) *Ldapconn {
return &Ldapconn{
ldapServer: ldapServer,
ldapPort: ldapPort,
bindDN: bindDN,
password: password,
}
}

func (c *Ldapconn) Connect() error {
// Connect to the LDAP server.
conn, err := ldap.Dial("tcp", fmt.Sprintf("%s:%d", c.ldapServer, c.ldapPort))
if err != nil {
return fmt.Errorf("failed to connect to LDAP server: %v", err)
}
c.conn = conn

// Bind with provided DN and password.
err = c.conn.Bind(c.bindDN, c.password)
if err != nil {
return fmt.Errorf("failed to bind to LDAP server: %v", err)
}

return nil
}

// Search performs an LDAP search with the provided base DN and filter.
func (c *Ldapconn) Search(baseDN, filter string) ([]*ldap.Entry, error) {
// Prepare the search request.
searchRequest := ldap.NewSearchRequest(
baseDN, // The base DN for the search
ldap.ScopeWholeSubtree, // Scope of the search
ldap.NeverDerefAliases, // Dereferencing aliases
0, // Time limit (0 = no limit)
0, // Size limit (0 = no limit)
false, // TypesOnly flag (false = return attributes)
filter, // Search filter (e.g., "(uid=jdoe)")
[]string{"dn", "cn", "uid"}, // List of attributes to return
nil,
)

// Execute the search.
result, err := c.conn.Search(searchRequest)
if err != nil {
return nil, fmt.Errorf("failed to search LDAP: %v", err)
}

return result.Entries, nil
}

// Close closes the connection to the LDAP server.
func (c *Ldapconn) Close() {
if c.conn != nil {
c.conn.Unbind()
c.conn.Close()
}
}



Подробнее здесь: https://stackoverflow.com/questions/794 ... -incubator
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Apache»