summaryrefslogtreecommitdiffhomepage
path: root/dhcpv6/options/requestedoption.go
diff options
context:
space:
mode:
authorAndrea Barberio <insomniac@slackware.it>2017-11-29 21:25:48 +0000
committerAndrea Barberio <insomniac@slackware.it>2017-12-05 23:32:27 +0000
commit1403bbe04ce275148b601c32e9551b2281110347 (patch)
tree6eacd224c2ea6b6e3865cb774970726809363d46 /dhcpv6/options/requestedoption.go
Initial commit
Diffstat (limited to 'dhcpv6/options/requestedoption.go')
-rw-r--r--dhcpv6/options/requestedoption.go72
1 files changed, 72 insertions, 0 deletions
diff --git a/dhcpv6/options/requestedoption.go b/dhcpv6/options/requestedoption.go
new file mode 100644
index 0000000..88e9ff3
--- /dev/null
+++ b/dhcpv6/options/requestedoption.go
@@ -0,0 +1,72 @@
+package options
+
+// This module defines the OptRequestedOption structure.
+// https://www.ietf.org/rfc/rfc3315.txt
+
+import (
+ "encoding/binary"
+ "fmt"
+)
+
+type OptRequestedOption struct {
+ requestedOptions []OptionCode
+}
+
+func (op *OptRequestedOption) Code() OptionCode {
+ return OPTION_ORO
+}
+
+func (op *OptRequestedOption) ToBytes() []byte {
+ buf := make([]byte, 4)
+ roBytes := make([]byte, 2)
+ binary.BigEndian.PutUint16(buf[0:2], uint16(OPTION_ORO))
+ binary.BigEndian.PutUint16(buf[2:4], uint16(op.Length()))
+ for _, ro := range op.requestedOptions {
+ binary.BigEndian.PutUint16(roBytes, uint16(ro))
+ buf = append(buf, roBytes...)
+ }
+ return buf
+}
+
+func (op *OptRequestedOption) RequestedOptions() []OptionCode {
+ return op.requestedOptions
+}
+
+func (op *OptRequestedOption) SetRequestedOptions(opts []OptionCode) {
+ op.requestedOptions = opts
+}
+
+func (op *OptRequestedOption) Length() int {
+ return len(op.requestedOptions) * 2
+}
+
+func (op *OptRequestedOption) String() string {
+ roString := "["
+ for idx, code := range op.requestedOptions {
+ if name, ok := OptionCodeToString[OptionCode(code)]; ok {
+ roString += name
+ } else {
+ roString += "Unknown"
+ }
+ if idx < len(op.requestedOptions)-1 {
+ roString += ", "
+ }
+ }
+ roString += "]"
+ return fmt.Sprintf("OptRequestedOption{options=%v}", roString)
+}
+
+// build an OptRequestedOption structure from a sequence of bytes.
+// The input data does not include option code and length bytes.
+func ParseOptRequestedOption(data []byte) (*OptRequestedOption, error) {
+ if len(data)%2 != 0 {
+ return nil, fmt.Errorf("Invalid OptRequestedOption data: length is not a multiple of 2")
+ }
+ opt := OptRequestedOption{}
+ var rOpts []OptionCode
+ for i := 0; i < len(data); i += 2 {
+ rOpts = append(rOpts, OptionCode(binary.BigEndian.Uint16(data[i:i+2])))
+ }
+ opt.requestedOptions = rOpts
+ return &opt, nil
+}