summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--dhcpv6/option_statuscode.go2
-rw-r--r--dhcpv6/option_userclass.go26
-rw-r--r--dhcpv6/options.go2
3 files changed, 12 insertions, 18 deletions
diff --git a/dhcpv6/option_statuscode.go b/dhcpv6/option_statuscode.go
index f72c4d3..7740f4d 100644
--- a/dhcpv6/option_statuscode.go
+++ b/dhcpv6/option_statuscode.go
@@ -51,7 +51,7 @@ func (op *OptStatusCode) SetStatusMessage(message []byte) {
// Length returns the option length
func (op *OptStatusCode) Length() int {
- return 2 + 2 + len(op.statusMessage)
+ return 2 + len(op.statusMessage)
}
func (op *OptStatusCode) String() string {
diff --git a/dhcpv6/option_userclass.go b/dhcpv6/option_userclass.go
index 98da207..68dc298 100644
--- a/dhcpv6/option_userclass.go
+++ b/dhcpv6/option_userclass.go
@@ -10,7 +10,7 @@ import (
// OptUserClass represent a DHCPv6 User Class option
type OptUserClass struct {
- userClass []byte
+ UserClass []byte
}
// Code returns the option code
@@ -24,34 +24,28 @@ func (op *OptUserClass) ToBytes() []byte {
binary.BigEndian.PutUint16(buf[0:2], uint16(OPTION_USER_CLASS))
binary.BigEndian.PutUint16(buf[2:4], uint16(op.Length()))
// user-class-data has an internal data length field too..
- binary.BigEndian.PutUint16(buf[4:6], uint16(len(op.userClass)))
- buf = append(buf, op.userClass...)
+ binary.BigEndian.PutUint16(buf[4:6], uint16(len(op.UserClass)))
+ buf = append(buf, op.UserClass...)
return buf
}
-// UserClass returns the user class as a sequence of bytes
-func (op *OptUserClass) UserClass() []byte {
- return op.userClass
-}
-
-// SetUserClass sets the user class from a sequence of bytes
-func (op *OptUserClass) SetUserClass(userClass []byte) {
- op.userClass = userClass
-}
-
// Length returns the option length
func (op *OptUserClass) Length() int {
- return 2 + len(op.userClass)
+ return 2 + len(op.UserClass)
}
func (op *OptUserClass) String() string {
- return fmt.Sprintf("OptUserClass{userclass=%s}", string(op.userClass))
+ return fmt.Sprintf("OptUserClass{userclass=%s}", string(op.UserClass))
}
// ParseOptUserClass builds an OptUserClass structure from a sequence of
// bytes. The input data does not include option code and length bytes.
func ParseOptUserClass(data []byte) (*OptUserClass, error) {
opt := OptUserClass{}
- opt.userClass = append(opt.userClass, data...)
+ dataLen := int(binary.BigEndian.Uint16(data[:2]))
+ if dataLen != len(data)-2 {
+ return nil, fmt.Errorf("ParseOptUserClass: declared data length does not match actual length: %d != %d", dataLen, len(data)-2)
+ }
+ opt.UserClass = append(opt.UserClass, data[2:]...)
return &opt, nil
}
diff --git a/dhcpv6/options.go b/dhcpv6/options.go
index 6962e16..3ee5dad 100644
--- a/dhcpv6/options.go
+++ b/dhcpv6/options.go
@@ -111,7 +111,7 @@ func ParseOption(dataStart []byte) (Option, error) {
return nil, err
}
if length != opt.Length() {
- return nil, fmt.Errorf("Error: declared length is different from actual length for option %v: %v != %v",
+ return nil, fmt.Errorf("Error: declared length is different from actual length for option %d: %d != %d",
code, opt.Length(), length)
}
return opt, nil