summaryrefslogtreecommitdiffhomepage
path: root/dhcpv6/option_relaymsg.go
diff options
context:
space:
mode:
authorChristopher Koch <c@chrisko.ch>2019-01-20 04:47:08 +0000
committerinsomniac <insomniacslk@users.noreply.github.com>2019-01-26 23:34:26 +0000
commit3478513076477d0f19eaeaf441f29949a9f6bc92 (patch)
tree4d621abff002cef480901a2ef015620472293db3 /dhcpv6/option_relaymsg.go
parente62883f5b5683ae2259ad01b7ffbe20671deb6b2 (diff)
dhcpv6: easier option parsing
- move option parsing to uio buffer library. - move option code and length reading into FromBytes rather than implementing it in each OptionParser.
Diffstat (limited to 'dhcpv6/option_relaymsg.go')
-rw-r--r--dhcpv6/option_relaymsg.go15
1 files changed, 8 insertions, 7 deletions
diff --git a/dhcpv6/option_relaymsg.go b/dhcpv6/option_relaymsg.go
index 89621ec..09589f6 100644
--- a/dhcpv6/option_relaymsg.go
+++ b/dhcpv6/option_relaymsg.go
@@ -4,8 +4,9 @@ package dhcpv6
// https://www.ietf.org/rfc/rfc3315.txt
import (
- "encoding/binary"
"fmt"
+
+ "github.com/u-root/u-root/pkg/uio"
)
type OptRelayMsg struct {
@@ -17,11 +18,11 @@ func (op *OptRelayMsg) Code() OptionCode {
}
func (op *OptRelayMsg) ToBytes() []byte {
- buf := make([]byte, 4)
- binary.BigEndian.PutUint16(buf[0:2], uint16(OptionRelayMsg))
- binary.BigEndian.PutUint16(buf[2:4], uint16(op.Length()))
- buf = append(buf, op.relayMessage.ToBytes()...)
- return buf
+ buf := uio.NewBigEndianBuffer(nil)
+ buf.Write16(uint16(OptionRelayMsg))
+ buf.Write16(uint16(op.Length()))
+ buf.WriteBytes(op.relayMessage.ToBytes())
+ return buf.Data()
}
func (op *OptRelayMsg) RelayMessage() DHCPv6 {
@@ -44,7 +45,7 @@ func (op *OptRelayMsg) String() string {
// The input data does not include option code and length bytes.
func ParseOptRelayMsg(data []byte) (*OptRelayMsg, error) {
var err error
- opt := OptRelayMsg{}
+ var opt OptRelayMsg
opt.relayMessage, err = FromBytes(data)
if err != nil {
return nil, err