forked from vishvananda/netlink
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathrule.go
More file actions
68 lines (62 loc) · 1.36 KB
/
rule.go
File metadata and controls
68 lines (62 loc) · 1.36 KB
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
package netlink
import (
"fmt"
"net"
)
// Rule represents a netlink rule.
type Rule struct {
Priority int
Family int
Table int
Mark int
Mask int
TunID uint
Goto int
Src *net.IPNet
Dst *net.IPNet
Flow int
IifName string
OifName string
SuppressIfgroup int
SuppressPrefixlen int
Invert bool
UID *RuleUIDRange
}
func (r Rule) String() string {
var dst, iif, oif string
if r.Dst != nil {
dst = " to " + r.Dst.String()
}
if r.IifName != "" {
iif = " iif " + r.IifName
}
if r.OifName != "" {
oif = " oif " + r.OifName
}
src := " from all"
if r.Src != nil {
src = " from " + r.Src.String()
}
return fmt.Sprintf("ip rule %d:%s%s%s%s table %d", r.Priority, src, dst, iif, oif, r.Table)
}
// NewRule return empty rules.
func NewRule() *Rule {
return &Rule{
SuppressIfgroup: -1,
SuppressPrefixlen: -1,
Priority: -1,
Mark: -1,
Mask: -1,
Goto: -1,
Flow: -1,
}
}
// NewRuleUIDRange creates rule uid range.
func NewRuleUIDRange(start, end uint32) *RuleUIDRange {
return &RuleUIDRange{Start: start, End: end}
}
// RuleUIDRange represents rule uid range.
type RuleUIDRange struct {
Start uint32
End uint32
}