aboutsummaryrefslogtreecommitdiff
path: root/goldap/modify_dn_request.go
diff options
context:
space:
mode:
Diffstat (limited to 'goldap/modify_dn_request.go')
-rw-r--r--goldap/modify_dn_request.go87
1 files changed, 87 insertions, 0 deletions
diff --git a/goldap/modify_dn_request.go b/goldap/modify_dn_request.go
new file mode 100644
index 0000000..8c4ab75
--- /dev/null
+++ b/goldap/modify_dn_request.go
@@ -0,0 +1,87 @@
+package message
+
+import "fmt"
+
+//
+// ModifyDNRequest ::= [APPLICATION 12] SEQUENCE {
+// entry LDAPDN,
+// newrdn RelativeLDAPDN,
+// deleteoldrdn BOOLEAN,
+// newSuperior [0] LDAPDN OPTIONAL }
+func readModifyDNRequest(bytes *Bytes) (ret ModifyDNRequest, err error) {
+ err = bytes.ReadSubBytes(classApplication, TagModifyDNRequest, ret.readComponents)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readModifyDNRequest:\n%s", err.Error())}
+ return
+ }
+ return
+}
+func (req *ModifyDNRequest) readComponents(bytes *Bytes) (err error) {
+ req.entry, err = readLDAPDN(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ req.newrdn, err = readRelativeLDAPDN(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ req.deleteoldrdn, err = readBOOLEAN(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ if bytes.HasMoreData() {
+ var tag TagAndLength
+ tag, err = bytes.PreviewTagAndLength()
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ if tag.Tag == TagModifyDNRequestNewSuperior {
+ var ldapdn LDAPDN
+ ldapdn, err = readTaggedLDAPDN(bytes, classContextSpecific, TagModifyDNRequestNewSuperior)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ req.newSuperior = ldapdn.Pointer()
+ }
+ }
+ return
+}
+
+//
+// ModifyDNRequest ::= [APPLICATION 12] SEQUENCE {
+// entry LDAPDN,
+// newrdn RelativeLDAPDN,
+// deleteoldrdn BOOLEAN,
+// newSuperior [0] LDAPDN OPTIONAL }
+func (m ModifyDNRequest) write(bytes *Bytes) (size int) {
+ if m.newSuperior != nil {
+ size += m.newSuperior.writeTagged(bytes, classContextSpecific, TagModifyDNRequestNewSuperior)
+ }
+ size += m.deleteoldrdn.write(bytes)
+ size += m.newrdn.write(bytes)
+ size += m.entry.write(bytes)
+ size += bytes.WriteTagAndLength(classApplication, isCompound, TagModifyDNRequest, size)
+ return
+}
+
+//
+// ModifyDNRequest ::= [APPLICATION 12] SEQUENCE {
+// entry LDAPDN,
+// newrdn RelativeLDAPDN,
+// deleteoldrdn BOOLEAN,
+// newSuperior [0] LDAPDN OPTIONAL }
+func (m ModifyDNRequest) size() (size int) {
+ size += m.entry.size()
+ size += m.newrdn.size()
+ size += m.deleteoldrdn.size()
+ if m.newSuperior != nil {
+ size += m.newSuperior.sizeTagged(TagModifyDNRequestNewSuperior)
+ }
+ size += sizeTagAndLength(TagModifyDNRequest, size)
+ return
+}