pubkey/main.go

50 lines
1.1 KiB
Go

2023-12-03 22:04:29 -07:00
package main
import (
"fmt"
"github.com/go-ldap/ldap"
"os"
)
2023-12-03 22:15:18 -07:00
func usage(code int, err error) {
if err != nil {
os.Stderr.WriteString(fmt.Sprintf("error %s\n", err))
}
os.Stderr.WriteString(fmt.Sprintf("usage: %s [uri] [bind_dn] [bind_pw] [base_dn] [uid]\n", os.Args[0]))
os.Exit(code)
}
2023-12-03 22:04:29 -07:00
func main() {
2023-12-03 22:15:18 -07:00
if len(os.Args) != 6 {
usage(1, nil)
}
2023-12-03 22:04:29 -07:00
var ldap_uri string = os.Args[1]
var ldap_bind_dn string = os.Args[2]
var ldap_bind_pw string = os.Args[3]
var ldap_base_dn string = os.Args[4]
var uid string = os.Args[5]
l, err := ldap.DialURL(ldap_uri)
if err != nil {
2023-12-03 22:15:18 -07:00
usage(2, err)
2023-12-03 22:04:29 -07:00
}
defer l.Close()
2023-12-03 22:15:18 -07:00
2023-12-03 22:04:29 -07:00
err = l.Bind(ldap_bind_dn, ldap_bind_pw)
if err != nil {
2023-12-03 22:15:18 -07:00
usage(3, err)
2023-12-03 22:04:29 -07:00
}
search_request := ldap.NewSearchRequest(ldap_base_dn, ldap.ScopeWholeSubtree, ldap.NeverDerefAliases, 0, 0, false, fmt.Sprintf("(&(objectClass=posixAccount)(uid=%s))", uid), []string{"dn", "sshPublicKey"}, nil)
sr, err := l.Search(search_request)
if err != nil {
2023-12-03 22:15:18 -07:00
usage(4, err)
2023-12-03 22:04:29 -07:00
}
for _, entry := range(sr.Entries) {
fmt.Printf("%v", entry.GetAttributeValue("sshPublicKey"))
}
}