From effdc98edfb5dde0d9fd8dfba266f6483e6ce9f0 Mon Sep 17 00:00:00 2001 From: Christopher Browning Date: Mon, 3 Feb 2020 12:19:27 -0500 Subject: [PATCH] Add RFC4511-compliant boolean type (#25) --- ber.go | 16 ++++++++++++++++ ber_test.go | 21 +++++++++++++++++++++ 2 files changed, 37 insertions(+) diff --git a/ber.go b/ber.go index b89c7f4..1e186cb 100644 --- a/ber.go +++ b/ber.go @@ -472,6 +472,22 @@ func NewBoolean(ClassType Class, TagType Type, Tag Tag, Value bool, Description return p } +// NewLDAPBoolean returns a RFC 4511-compliant Boolean packet +func NewLDAPBoolean(Value bool, Description string) *Packet { + intValue := int64(0) + + if Value { + intValue = 255 + } + + p := Encode(ClassUniversal, TypePrimitive, TagBoolean, nil, Description) + + p.Value = Value + p.Data.Write(encodeInteger(intValue)) + + return p +} + func NewInteger(ClassType Class, TagType Type, Tag Tag, Value interface{}, Description string) *Packet { p := Encode(ClassType, TagType, Tag, nil, Description) diff --git a/ber_test.go b/ber_test.go index a5cc53d..650fe24 100644 --- a/ber_test.go +++ b/ber_test.go @@ -42,6 +42,27 @@ func TestBoolean(t *testing.T) { } +func TestLDAPBoolean(t *testing.T) { + var value bool = true + + packet := NewLDAPBoolean(value, "first Packet, True") + + newBoolean, ok := packet.Value.(bool) + if !ok || newBoolean != value { + t.Error("error during creating packet") + } + + encodedPacket := packet.Bytes() + + newPacket := DecodePacket(encodedPacket) + + newBoolean, ok = newPacket.Value.(bool) + if !ok || newBoolean != value { + t.Error("error during decoding packet") + } + +} + func TestInteger(t *testing.T) { var value int64 = 10