Skip to content

Commit

Permalink
progress
Browse files Browse the repository at this point in the history
  • Loading branch information
cpuschma committed Oct 30, 2024
1 parent d0a241d commit 40b2662
Show file tree
Hide file tree
Showing 6 changed files with 112 additions and 34 deletions.
2 changes: 1 addition & 1 deletion client.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ type Client interface {
Modify(*ModifyRequest) error
ModifyDN(*ModifyDNRequest) error
ModifyWithResult(*ModifyRequest) (*ModifyResult, error)
Extended(*ExtendedRequest) (*ExtendResponse, error)
Extended(*ExtendedRequest) (*ExtendedResponse, error)

Compare(dn, attribute, value string) (bool, error)
PasswordModify(*PasswordModifyRequest) (*PasswordModifyResult, error)
Expand Down
30 changes: 14 additions & 16 deletions extend.go → extended.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ import (
// ExtendedRequest TODO
// See: https://www.rfc-editor.org/rfc/rfc4511#section-4.12
type ExtendedRequest struct {
// ExtendedRequest ::= [APPLICATION 23] SEQUENCE {
// requestName [0] LDAPOID,
// requestValue [1] OCTET STRING OPTIONAL }

Name string
Value *ber.Packet
}
Expand All @@ -20,14 +24,6 @@ func NewExtendedRequest(name string, value *ber.Packet) *ExtendedRequest {
}

func (er ExtendedRequest) appendTo(envelope *ber.Packet) error {
// ExtendedRequest ::= [APPLICATION 23] SEQUENCE {
// requestName [0] LDAPOID,
// requestValue [1] OCTET STRING OPTIONAL }
//
// Despite the RFC documentation stating otherwise, the requestName field needs to be
// of class application and type EOC, otherwise the directory server will terminate
// the connection right away (tested against OpenLDAP, Active Directory).

pkt := ber.Encode(ber.ClassApplication, ber.TypeConstructed, ApplicationExtendedRequest, nil, "Extended Request")
pkt.AppendChild(ber.NewString(ber.ClassContext, ber.TypePrimitive, ber.TagEOC, er.Name, "Extended Request Name"))
if er.Value != nil {
Expand All @@ -37,22 +33,23 @@ func (er ExtendedRequest) appendTo(envelope *ber.Packet) error {
return nil
}

type ExtendResponse struct {
type ExtendedResponse struct {
// ExtendedResponse ::= [APPLICATION 24] SEQUENCE {
// COMPONENTS OF LDAPResult,
// responseName [10] LDAPOID OPTIONAL,
// responseValue [11] OCTET STRING OPTIONAL }

Name string
Value *ber.Packet
}

func (l *Conn) Extended(er *ExtendedRequest) (*ExtendResponse, error) {
func (l *Conn) Extended(er *ExtendedRequest) (*ExtendedResponse, error) {
msgCtx, err := l.doRequest(er)
if err != nil {
return nil, err
}
defer l.finishMessage(msgCtx)

// ExtendedResponse ::= [APPLICATION 24] SEQUENCE {
// COMPONENTS OF LDAPResult,
// responseName [10] LDAPOID OPTIONAL,
// responseValue [11] OCTET STRING OPTIONAL }
packet, err := l.readPacket(msgCtx)
if err != nil {
return nil, err
Expand All @@ -68,9 +65,10 @@ func (l *Conn) Extended(er *ExtendedRequest) (*ExtendResponse, error) {
)
}

response := new(ExtendResponse)
response := new(ExtendedResponse)
response.Name = packet.Children[1].Children[3].Data.String()
if len(packet.Children) == 4 {

if len(packet.Children[1].Children) == 5 {
response.Value = packet.Children[1].Children[4]
}

Expand Down
41 changes: 41 additions & 0 deletions extended_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
package ldap

import (
"testing"
)

func TestExtendedRequest_WhoAmI(t *testing.T) {
l, err := DialURL(ldapServer)
if err != nil {
t.Errorf("%s failed: %v", t.Name(), err)
return
}
defer l.Close()

l.Bind("", "") // anonymous
defer l.Unbind()

rfc4532req := NewExtendedRequest("1.3.6.1.4.1.4203.1.11.3", nil) // request value is <nil>

var rfc4532resp *ExtendedResponse
if rfc4532resp, err = l.Extended(rfc4532req); err != nil {
t.Errorf("%s failed: %v", t.Name(), err)
return
}
t.Logf("%#v\n", rfc4532resp)
}

func TestExtendedRequest_FastBind(t *testing.T) {
conn, err := DialURL(ldapServer)
if err != nil {
t.Error(err)
}
defer conn.Close()

request := NewExtendedRequest(`1.3.6.1.4.1.4203.1.11.3`)

Check failure on line 35 in extended_test.go

View workflow job for this annotation

GitHub Actions / lint

not enough arguments in call to NewExtendedRequest
_, err = conn.Extended(request)
if err != nil {
t.Errorf("%s failed: %v", t.Name(), err)
return
}
}
2 changes: 1 addition & 1 deletion v3/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ type Client interface {
Modify(*ModifyRequest) error
ModifyDN(*ModifyDNRequest) error
ModifyWithResult(*ModifyRequest) (*ModifyResult, error)
Extended(*ExtendedRequest) (*ExtendResponse, error)
Extended(*ExtendedRequest) (*ExtendedResponse, error)

Compare(dn, attribute, value string) (bool, error)
PasswordModify(*PasswordModifyRequest) (*PasswordModifyResult, error)
Expand Down
30 changes: 14 additions & 16 deletions v3/extend.go → v3/extended.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ import (
// ExtendedRequest TODO
// See: https://www.rfc-editor.org/rfc/rfc4511#section-4.12
type ExtendedRequest struct {
// ExtendedRequest ::= [APPLICATION 23] SEQUENCE {
// requestName [0] LDAPOID,
// requestValue [1] OCTET STRING OPTIONAL }

Name string
Value *ber.Packet
}
Expand All @@ -20,14 +24,6 @@ func NewExtendedRequest(name string, value *ber.Packet) *ExtendedRequest {
}

func (er ExtendedRequest) appendTo(envelope *ber.Packet) error {
// ExtendedRequest ::= [APPLICATION 23] SEQUENCE {
// requestName [0] LDAPOID,
// requestValue [1] OCTET STRING OPTIONAL }
//
// Despite the RFC documentation stating otherwise, the requestName field needs to be
// of class application and type EOC, otherwise the directory server will terminate
// the connection right away (tested against OpenLDAP, Active Directory).

pkt := ber.Encode(ber.ClassApplication, ber.TypeConstructed, ApplicationExtendedRequest, nil, "Extended Request")
pkt.AppendChild(ber.NewString(ber.ClassContext, ber.TypePrimitive, ber.TagEOC, er.Name, "Extended Request Name"))
if er.Value != nil {
Expand All @@ -37,22 +33,23 @@ func (er ExtendedRequest) appendTo(envelope *ber.Packet) error {
return nil
}

type ExtendResponse struct {
type ExtendedResponse struct {
// ExtendedResponse ::= [APPLICATION 24] SEQUENCE {
// COMPONENTS OF LDAPResult,
// responseName [10] LDAPOID OPTIONAL,
// responseValue [11] OCTET STRING OPTIONAL }

Name string
Value *ber.Packet
}

func (l *Conn) Extended(er *ExtendedRequest) (*ExtendResponse, error) {
func (l *Conn) Extended(er *ExtendedRequest) (*ExtendedResponse, error) {
msgCtx, err := l.doRequest(er)
if err != nil {
return nil, err
}
defer l.finishMessage(msgCtx)

// ExtendedResponse ::= [APPLICATION 24] SEQUENCE {
// COMPONENTS OF LDAPResult,
// responseName [10] LDAPOID OPTIONAL,
// responseValue [11] OCTET STRING OPTIONAL }
packet, err := l.readPacket(msgCtx)
if err != nil {
return nil, err
Expand All @@ -68,9 +65,10 @@ func (l *Conn) Extended(er *ExtendedRequest) (*ExtendResponse, error) {
)
}

response := new(ExtendResponse)
response := new(ExtendedResponse)
response.Name = packet.Children[1].Children[3].Data.String()
if len(packet.Children) == 4 {

if len(packet.Children[1].Children) == 5 {
response.Value = packet.Children[1].Children[4]
}

Expand Down
41 changes: 41 additions & 0 deletions v3/extended_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
package ldap

import (
"testing"
)

func TestExtendedRequest_WhoAmI(t *testing.T) {
l, err := DialURL(ldapServer)
if err != nil {
t.Errorf("%s failed: %v", t.Name(), err)
return
}
defer l.Close()

l.Bind("", "") // anonymous
defer l.Unbind()

rfc4532req := NewExtendedRequest("1.3.6.1.4.1.4203.1.11.3", nil) // request value is <nil>

var rfc4532resp *ExtendedResponse
if rfc4532resp, err = l.Extended(rfc4532req); err != nil {
t.Errorf("%s failed: %v", t.Name(), err)
return
}
t.Logf("%#v\n", rfc4532resp)
}

func TestExtendedRequest_FastBind(t *testing.T) {
conn, err := DialURL(ldapServer)
if err != nil {
t.Error(err)
}
defer conn.Close()

request := NewExtendedRequest(`1.3.6.1.4.1.4203.1.11.3`)
_, err = conn.Extended(request)
if err != nil {
t.Errorf("%s failed: %v", t.Name(), err)
return
}
}

0 comments on commit 40b2662

Please sign in to comment.