aboutsummaryrefslogtreecommitdiff
path: root/goldap/integer.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/integer.go
parenta53641e773730ba171df2602c8d199968d6e6447 (diff)
downloadbottin-477d7014edc787ba9a977acd19fcbfc55531768b.tar.gz
bottin-477d7014edc787ba9a977acd19fcbfc55531768b.zip
Vendor goldap
Diffstat (limited to 'goldap/integer.go')
-rw-r--r--goldap/integer.go53
1 files changed, 53 insertions, 0 deletions
diff --git a/goldap/integer.go b/goldap/integer.go
new file mode 100644
index 0000000..79e4248
--- /dev/null
+++ b/goldap/integer.go
@@ -0,0 +1,53 @@
+package message
+
+import "fmt"
+
+func readINTEGER(bytes *Bytes) (ret INTEGER, err error) {
+ var value interface{}
+ value, err = bytes.ReadPrimitiveSubBytes(classUniversal, tagInteger, tagInteger)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readINTEGER:\n%s", err.Error())}
+ return
+ }
+ ret = INTEGER(value.(int32))
+ return
+}
+func readTaggedINTEGER(bytes *Bytes, class int, tag int) (ret INTEGER, err error) {
+ var value interface{}
+ value, err = bytes.ReadPrimitiveSubBytes(class, tag, tagInteger)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readTaggedINTEGER:\n%s", err.Error())}
+ return
+ }
+ ret = INTEGER(value.(int32))
+ return
+}
+func readTaggedPositiveINTEGER(bytes *Bytes, class int, tag int) (ret INTEGER, err error) {
+ ret, err = readTaggedINTEGER(bytes, class, tag)
+ if err != nil {
+ err = LdapError{fmt.Sprintf("readTaggedPositiveINTEGER:\n%s", err.Error())}
+ return
+ }
+ if !(ret >= 0 && ret <= maxInt) {
+ err = LdapError{fmt.Sprintf("readTaggedPositiveINTEGER: Invalid INTEGER value %d ! Expected value between 0 and %d", ret, maxInt)}
+ }
+ return
+}
+func readPositiveINTEGER(bytes *Bytes) (ret INTEGER, err error) {
+ return readTaggedPositiveINTEGER(bytes, classUniversal, tagInteger)
+}
+func (i INTEGER) write(bytes *Bytes) int {
+ return bytes.WritePrimitiveSubBytes(classUniversal, tagInteger, i)
+}
+func (i INTEGER) writeTagged(bytes *Bytes, class int, tag int) int {
+ return bytes.WritePrimitiveSubBytes(class, tag, i)
+}
+func (i INTEGER) size() int {
+ return SizePrimitiveSubBytes(tagInteger, i)
+}
+func (i INTEGER) sizeTagged(tag int) int {
+ return SizePrimitiveSubBytes(tag, i)
+}
+func (l INTEGER) Int() int {
+ return int(l)
+}