aboutsummaryrefslogtreecommitdiff
path: root/goldap/boolean.go
diff options
context:
space:
mode:
authorQuentin Dufour <quentin@deuxfleurs.fr>2021-07-07 01:49:33 +0200
committerQuentin Dufour <quentin@deuxfleurs.fr>2021-09-16 13:09:26 +0200
commit563fc272a36c8be317fbe95c8308ca2dfa29c3aa (patch)
tree0b6f9a6a15516e7234fc928ecbebbd32d3154074 /goldap/boolean.go
parentaa912b5ceb24cb8772709171ea9589b0771bbe54 (diff)
downloadbottin-563fc272a36c8be317fbe95c8308ca2dfa29c3aa.tar.gz
bottin-563fc272a36c8be317fbe95c8308ca2dfa29c3aa.zip
Vendor goldap, fix ASN.1 BER integer and length encoding
- Add tests for goldap to prevent regressions - Disable reconnection for our functional tests
Diffstat (limited to 'goldap/boolean.go')
-rw-r--r--goldap/boolean.go62
1 files changed, 62 insertions, 0 deletions
diff --git a/goldap/boolean.go b/goldap/boolean.go
new file mode 100644
index 0000000..7e3b254
--- /dev/null
+++ b/goldap/boolean.go
@@ -0,0 +1,62 @@
+package message
+
+import "fmt"
+
+func readBOOLEAN(bytes *Bytes) (ret BOOLEAN, err error) {
+ var value interface{}
+ value, err = bytes.ReadPrimitiveSubBytes(classUniversal, tagBoolean, tagBoolean)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readBOOLEAN:\n%s", err.Error())}
+ return
+ }
+ ret = BOOLEAN(value.(bool))
+ return
+}
+
+func (boolean BOOLEAN) write(bytes *Bytes) int {
+ return bytes.WritePrimitiveSubBytes(classUniversal, tagBoolean, boolean)
+}
+
+func (boolean BOOLEAN) writeTagged(bytes *Bytes, class int, tag int) int {
+ return bytes.WritePrimitiveSubBytes(class, tag, boolean)
+}
+
+func readTaggedBOOLEAN(bytes *Bytes, class int, tag int) (ret BOOLEAN, err error) {
+ var value interface{}
+ value, err = bytes.ReadPrimitiveSubBytes(class, tag, tagBoolean)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readTaggedBOOLEAN:\n%s", err.Error())}
+ return
+ }
+ ret = BOOLEAN(value.(bool))
+ return
+}
+
+func SizePrimitiveSubBytes(tag int, value interface{}) (size int) {
+ switch value.(type) {
+ case BOOLEAN:
+ size = sizeBool(bool(value.(BOOLEAN)))
+ case INTEGER:
+ size = sizeInt32(int32(value.(INTEGER)))
+ case ENUMERATED:
+ size = sizeInt32(int32(value.(ENUMERATED)))
+ case OCTETSTRING:
+ size = sizeOctetString([]byte(string(value.(OCTETSTRING))))
+ default:
+ panic(fmt.Sprintf("SizePrimitiveSubBytes: invalid value type %v", value))
+ }
+ size += sizeTagAndLength(tag, size)
+ return
+}
+
+func (boolean BOOLEAN) size() int {
+ return SizePrimitiveSubBytes(tagBoolean, boolean)
+}
+
+func (boolean BOOLEAN) sizeTagged(tag int) int {
+ return SizePrimitiveSubBytes(tag, boolean)
+}
+
+func (boolean BOOLEAN) Bool() bool {
+ return bool(boolean)
+}