aboutsummaryrefslogtreecommitdiff
path: root/goldap/oid.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/oid.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/oid.go')
-rw-r--r--goldap/oid.go50
1 files changed, 50 insertions, 0 deletions
diff --git a/goldap/oid.go b/goldap/oid.go
new file mode 100644
index 0000000..b2c5c81
--- /dev/null
+++ b/goldap/oid.go
@@ -0,0 +1,50 @@
+package message
+
+import "fmt"
+
+//
+//
+// LDAPOID ::= OCTET STRING -- Constrained to <numericoid>
+// -- [RFC4512]
+
+func (l LDAPOID) String() string {
+ return string(l)
+}
+
+func (l LDAPOID) Bytes() []byte {
+ return []byte(l)
+}
+
+func (l LDAPOID) Pointer() *LDAPOID { return &l }
+
+func readTaggedLDAPOID(bytes *Bytes, class int, tag int) (ret LDAPOID, err error) {
+ var octetstring OCTETSTRING
+ octetstring, err = readTaggedOCTETSTRING(bytes, class, tag)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readTaggedLDAPOID:\n%s", err.Error())}
+ return
+ }
+ // @TODO: check RFC4512 for <numericoid>
+ ret = LDAPOID(octetstring)
+ return
+}
+
+func readLDAPOID(bytes *Bytes) (ret LDAPOID, err error) {
+ return readTaggedLDAPOID(bytes, classUniversal, tagOctetString)
+}
+
+func (l LDAPOID) write(bytes *Bytes) int {
+ return OCTETSTRING(l).write(bytes)
+}
+
+func (l LDAPOID) writeTagged(bytes *Bytes, class int, tag int) int {
+ return OCTETSTRING(l).writeTagged(bytes, class, tag)
+}
+
+func (l LDAPOID) size() int {
+ return OCTETSTRING(l).size()
+}
+
+func (l LDAPOID) sizeTagged(tag int) int {
+ return OCTETSTRING(l).sizeTagged(tag)
+}