aboutsummaryrefslogtreecommitdiff
path: root/goldap/filter_and.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/filter_and.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/filter_and.go')
-rw-r--r--goldap/filter_and.go54
1 files changed, 54 insertions, 0 deletions
diff --git a/goldap/filter_and.go b/goldap/filter_and.go
new file mode 100644
index 0000000..981284d
--- /dev/null
+++ b/goldap/filter_and.go
@@ -0,0 +1,54 @@
+package message
+
+import "fmt"
+
+// and [0] SET SIZE (1..MAX) OF filter Filter,
+
+func (filterAnd FilterAnd) getFilterTag() int {
+ return TagFilterAnd
+}
+
+func (filterAnd FilterAnd) size() (size int) {
+ for _, filter := range filterAnd {
+ size += filter.size()
+ }
+ size += sizeTagAndLength(TagFilterAnd, size)
+ return
+}
+
+func (filterAnd *FilterAnd) readComponents(bytes *Bytes) (err error) {
+ count := 0
+ for bytes.HasMoreData() {
+ count++
+ var filter Filter
+ filter, err = readFilter(bytes)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readComponents (filter %d):\n%s", count, err.Error())}
+ return
+ }
+ *filterAnd = append(*filterAnd, filter)
+ }
+ if len(*filterAnd) == 0 {
+ err = LdapError{"readComponents: expecting at least one Filter"}
+ return
+ }
+ return
+}
+
+func (filterAnd FilterAnd) write(bytes *Bytes) (size int) {
+
+ for i := len(filterAnd) - 1; i >= 0; i-- {
+ size += filterAnd[i].write(bytes)
+ }
+ size += bytes.WriteTagAndLength(classContextSpecific, isCompound, TagFilterAnd, size)
+ return
+}
+
+func readFilterAnd(bytes *Bytes) (filterand FilterAnd, err error) {
+ err = bytes.ReadSubBytes(classContextSpecific, TagFilterAnd, filterand.readComponents)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readFilterAnd:\n%s", err.Error())}
+ return
+ }
+ return
+}