diff options
author | Chris Koch <chrisko@google.com> | 2019-12-28 06:30:10 -0800 |
---|---|---|
committer | Chris K <c@chrisko.ch> | 2020-01-02 06:40:00 -0700 |
commit | 9a95b101e205d121810f3922999e1af1d39e4c43 (patch) | |
tree | a8e7787a32f68ba96ecea1eb1b9402bd8cfe86f6 /dhcpv6/option_nontemporaryaddress.go | |
parent | b3fbc9f9fdd5ac725d73f2a9109e59d4947f067d (diff) |
v6: use time.Duration for duration fields
Signed-off-by: Chris Koch <chrisko@google.com>
Diffstat (limited to 'dhcpv6/option_nontemporaryaddress.go')
-rw-r--r-- | dhcpv6/option_nontemporaryaddress.go | 38 |
1 files changed, 32 insertions, 6 deletions
diff --git a/dhcpv6/option_nontemporaryaddress.go b/dhcpv6/option_nontemporaryaddress.go index 031f22c..6b3d8d6 100644 --- a/dhcpv6/option_nontemporaryaddress.go +++ b/dhcpv6/option_nontemporaryaddress.go @@ -2,10 +2,29 @@ package dhcpv6 import ( "fmt" + "time" "github.com/u-root/u-root/pkg/uio" ) +// Duration is a duration as embedded in IA messages (IAPD, IANA, IATA). +type Duration struct { + time.Duration +} + +// Marshal encodes the time in uint32 seconds as defined by RFC 3315 for IANA +// messages. +func (d Duration) Marshal(buf *uio.Lexer) { + buf.Write32(uint32(d.Duration.Round(time.Second) / time.Second)) +} + +// Unmarshal decodes time from uint32 seconds as defined by RFC 3315 for IANA +// messages. +func (d *Duration) Unmarshal(buf *uio.Lexer) { + t := buf.Read32() + d.Duration = time.Duration(t) * time.Second +} + // OptIANA implements the identity association for non-temporary addresses // option. // @@ -13,8 +32,8 @@ import ( // https://www.ietf.org/rfc/rfc3633.txt type OptIANA struct { IaId [4]byte - T1 uint32 - T2 uint32 + T1 time.Duration + T2 time.Duration Options Options } @@ -26,8 +45,10 @@ func (op *OptIANA) Code() OptionCode { func (op *OptIANA) ToBytes() []byte { buf := uio.NewBigEndianBuffer(nil) buf.WriteBytes(op.IaId[:]) - buf.Write32(op.T1) - buf.Write32(op.T2) + t1 := Duration{op.T1} + t1.Marshal(buf) + t2 := Duration{op.T2} + t2.Marshal(buf) buf.WriteBytes(op.Options.ToBytes()) return buf.Data() } @@ -59,8 +80,13 @@ func ParseOptIANA(data []byte) (*OptIANA, error) { var opt OptIANA buf := uio.NewBigEndianBuffer(data) buf.ReadBytes(opt.IaId[:]) - opt.T1 = buf.Read32() - opt.T2 = buf.Read32() + + var t1, t2 Duration + t1.Unmarshal(buf) + t2.Unmarshal(buf) + opt.T1 = t1.Duration + opt.T2 = t2.Duration + if err := opt.Options.FromBytes(buf.ReadAll()); err != nil { return nil, err } |