1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
package dhcpv6
// This module defines the OptIANA structure.
// https://www.ietf.org/rfc/rfc3633.txt
import (
"encoding/binary"
"fmt"
)
type OptIANA struct {
IaId [4]byte
T1 uint32
T2 uint32
Options []Option
}
func (op *OptIANA) Code() OptionCode {
return OPTION_IA_NA
}
func (op *OptIANA) ToBytes() []byte {
buf := make([]byte, 16)
binary.BigEndian.PutUint16(buf[0:2], uint16(OPTION_IA_NA))
binary.BigEndian.PutUint16(buf[2:4], uint16(op.Length()))
copy(buf[4:8], op.IaId[:])
binary.BigEndian.PutUint32(buf[8:12], op.T1)
binary.BigEndian.PutUint32(buf[12:16], op.T2)
for _, opt := range op.Options {
buf = append(buf, opt.ToBytes()...)
}
return buf
}
func (op *OptIANA) Length() int {
l := 12
for _, opt := range op.Options {
l += 4 + opt.Length()
}
return l
}
func (op *OptIANA) String() string {
return fmt.Sprintf("OptIANA{IAID=%v, t1=%v, t2=%v, options=%v}",
op.IaId, op.T1, op.T2, op.Options)
}
// DelOption will remove all the options that match a Option code.
func (op *OptIANA) DelOption(code OptionCode) {
op.Options = delOption(op.Options, code)
}
// build an OptIANA structure from a sequence of bytes.
// The input data does not include option code and length bytes.
func ParseOptIANA(data []byte) (*OptIANA, error) {
var err error
opt := OptIANA{}
if len(data) < 12 {
return nil, fmt.Errorf("Invalid IA for Non-temporary Addresses data length. Expected at least 12 bytes, got %v", len(data))
}
copy(opt.IaId[:], data[:4])
opt.T1 = binary.BigEndian.Uint32(data[4:8])
opt.T2 = binary.BigEndian.Uint32(data[8:12])
opt.Options, err = OptionsFromBytes(data[12:])
if err != nil {
return nil, err
}
return &opt, nil
}
|