aboutsummaryrefslogtreecommitdiff
path: root/goldap/referral.go
diff options
context:
space:
mode:
authorQuentin Dufour <quentin@deuxfleurs.fr>2021-09-16 13:41:01 +0200
committerQuentin Dufour <quentin@deuxfleurs.fr>2021-09-16 13:41:01 +0200
commit477d7014edc787ba9a977acd19fcbfc55531768b (patch)
treeac8b65be8634fa9526cd727da60893244d11e88a /goldap/referral.go
parenta53641e773730ba171df2602c8d199968d6e6447 (diff)
downloadbottin-477d7014edc787ba9a977acd19fcbfc55531768b.tar.gz
bottin-477d7014edc787ba9a977acd19fcbfc55531768b.zip
Vendor goldap
Diffstat (limited to 'goldap/referral.go')
-rw-r--r--goldap/referral.go50
1 files changed, 50 insertions, 0 deletions
diff --git a/goldap/referral.go b/goldap/referral.go
new file mode 100644
index 0000000..8a04d85
--- /dev/null
+++ b/goldap/referral.go
@@ -0,0 +1,50 @@
+package message
+
+import "fmt"
+
+//
+// Referral ::= SEQUENCE SIZE (1..MAX) OF uri URI
+func readTaggedReferral(bytes *Bytes, class int, tag int) (referral Referral, err error) {
+ err = bytes.ReadSubBytes(class, tag, referral.readComponents)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readTaggedReferral:\n%s", err.Error())}
+ return
+ }
+ return
+}
+func (referral *Referral) readComponents(bytes *Bytes) (err error) {
+ for bytes.HasMoreData() {
+ var uri URI
+ uri, err = readURI(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents:\n%s", err.Error())}
+ return
+ }
+ *referral = append(*referral, uri)
+ }
+ if len(*referral) == 0 {
+ return LdapError{"readComponents: expecting at least one URI"}
+ }
+ return
+}
+func (referral Referral) Pointer() *Referral { return &referral }
+
+//
+// Referral ::= SEQUENCE SIZE (1..MAX) OF uri URI
+func (r Referral) writeTagged(bytes *Bytes, class int, tag int) (size int) {
+ for i := len(r) - 1; i >= 0; i-- {
+ size += r[i].write(bytes)
+ }
+ size += bytes.WriteTagAndLength(class, isCompound, tag, size)
+ return
+}
+
+//
+// Referral ::= SEQUENCE SIZE (1..MAX) OF uri URI
+func (r Referral) sizeTagged(tag int) (size int) {
+ for _, uri := range r {
+ size += uri.size()
+ }
+ size += sizeTagAndLength(tag, size)
+ return
+}