aboutsummaryrefslogtreecommitdiff
path: root/goldap/modify_request.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/modify_request.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/modify_request.go')
-rw-r--r--goldap/modify_request.go89
1 files changed, 89 insertions, 0 deletions
diff --git a/goldap/modify_request.go b/goldap/modify_request.go
new file mode 100644
index 0000000..c66c00d
--- /dev/null
+++ b/goldap/modify_request.go
@@ -0,0 +1,89 @@
+package message
+
+import "fmt"
+
+//
+// ModifyRequest ::= [APPLICATION 6] SEQUENCE {
+// object LDAPDN,
+// changes SEQUENCE OF change SEQUENCE {
+// operation ENUMERATED {
+// add (0),
+// delete (1),
+// replace (2),
+// ... },
+// modification PartialAttribute } }
+func readModifyRequest(bytes *Bytes) (ret ModifyRequest, err error) {
+ err = bytes.ReadSubBytes(classApplication, TagModifyRequest, ret.readComponents)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readModifyRequest:\n%s", err.Error())}
+ return
+ }
+ return
+}
+func (m *ModifyRequest) readComponents(bytes *Bytes) (err error) {
+ m.object, err = readLDAPDN(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ err = bytes.ReadSubBytes(classUniversal, tagSequence, m.readChanges)
+ return
+}
+func (m *ModifyRequest) readChanges(bytes *Bytes) (err error) {
+ for bytes.HasMoreData() {
+ var c ModifyRequestChange
+ c, err = readModifyRequestChange(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readChanges:\n%s", err.Error())}
+ return
+ }
+ m.changes = append(m.changes, c)
+ }
+ return
+}
+
+//
+// ModifyRequest ::= [APPLICATION 6] SEQUENCE {
+// object LDAPDN,
+// changes SEQUENCE OF change SEQUENCE {
+// operation ENUMERATED {
+// add (0),
+// delete (1),
+// replace (2),
+// ... },
+// modification PartialAttribute } }
+func (m ModifyRequest) write(bytes *Bytes) (size int) {
+ for i := len(m.changes) - 1; i >= 0; i-- {
+ size += m.changes[i].write(bytes)
+ }
+ size += bytes.WriteTagAndLength(classUniversal, isCompound, tagSequence, size)
+ size += m.object.write(bytes)
+ size += bytes.WriteTagAndLength(classApplication, isCompound, TagModifyRequest, size)
+ return
+}
+
+//
+// ModifyRequest ::= [APPLICATION 6] SEQUENCE {
+// object LDAPDN,
+// changes SEQUENCE OF change SEQUENCE {
+// operation ENUMERATED {
+// add (0),
+// delete (1),
+// replace (2),
+// ... },
+// modification PartialAttribute } }
+func (m ModifyRequest) size() (size int) {
+ for _, change := range m.changes {
+ size += change.size()
+ }
+ size += sizeTagAndLength(tagSequence, size)
+ size += m.object.size()
+ size += sizeTagAndLength(TagModifyRequest, size)
+ return
+}
+func (m *ModifyRequest) Object() LDAPDN {
+ return m.object
+}
+func (m *ModifyRequest) Changes() []ModifyRequestChange {
+ return m.changes
+}