summaryrefslogtreecommitdiffhomepage
path: root/dhcpv6/utils.go
diff options
context:
space:
mode:
authorPablo Mazzini <pmazzini@gmail.com>2018-08-03 12:22:05 +0200
committerPablo Mazzini <pmazzini@gmail.com>2018-08-10 15:25:49 +0200
commit27e10b9e7f76b99dbdc0d8fd779b18ef322ed92c (patch)
tree5bfd9b0d94b0e387893519620cec34e5f3a62783 /dhcpv6/utils.go
parent5207d76712250f33111c546d9ace98336d616bfc (diff)
add IsRequested
Diffstat (limited to 'dhcpv6/utils.go')
-rw-r--r--dhcpv6/utils.go17
1 files changed, 13 insertions, 4 deletions
diff --git a/dhcpv6/utils.go b/dhcpv6/utils.go
index 1681661..d1715da 100644
--- a/dhcpv6/utils.go
+++ b/dhcpv6/utils.go
@@ -11,16 +11,25 @@ import (
// if the "boot file" option is included in the packet, which is useful for
// ADVERTISE/REPLY packet.
func IsNetboot(msg DHCPv6) bool {
+ if IsRequested(msg, OptionBootfileURL) {
+ return true
+ }
+ if optbf := msg.GetOneOption(OptionBootfileURL); optbf != nil {
+ return true
+ }
+ return false
+}
+
+// IsRequested function takes a DHCPv6 message and an OptionCode, and returns
+// true if that option is within the requested options of the DHCPv6 message.
+func IsRequested(msg DHCPv6, requested OptionCode) bool {
for _, optoro := range msg.GetOption(OptionORO) {
for _, o := range optoro.(*OptRequestedOption).RequestedOptions() {
- if o == OptionBootfileURL {
+ if o == requested {
return true
}
}
}
- if optbf := msg.GetOneOption(OptionBootfileURL); optbf != nil {
- return true
- }
return false
}