mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-02 22:17:10 +08:00

* Switch CoAP lib Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Revert removed adapter code Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * WIP CoAP refactor Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Add auth key Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix observers map Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix reading message body Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix subtopic parsing Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix error handling Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Fix multi-protocol communication Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Separate client from observer Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Remove unused config Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Remove TCP option Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Inline error check Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Add logging client errors Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Replace RWMutex since we're not using RLock Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Inline error handling Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com> * Inline error handling Signed-off-by: dusanb94 <dusan.borovcanin@mainflux.com>
72 lines
1.7 KiB
Go
72 lines
1.7 KiB
Go
// Copyright 2012 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build aix darwin dragonfly freebsd linux netbsd openbsd solaris windows
|
|
|
|
package ipv4
|
|
|
|
import (
|
|
"net"
|
|
"unsafe"
|
|
|
|
"golang.org/x/net/bpf"
|
|
"golang.org/x/net/internal/socket"
|
|
)
|
|
|
|
func (so *sockOpt) getMulticastInterface(c *socket.Conn) (*net.Interface, error) {
|
|
switch so.typ {
|
|
case ssoTypeIPMreqn:
|
|
return so.getIPMreqn(c)
|
|
default:
|
|
return so.getMulticastIf(c)
|
|
}
|
|
}
|
|
|
|
func (so *sockOpt) setMulticastInterface(c *socket.Conn, ifi *net.Interface) error {
|
|
switch so.typ {
|
|
case ssoTypeIPMreqn:
|
|
return so.setIPMreqn(c, ifi, nil)
|
|
default:
|
|
return so.setMulticastIf(c, ifi)
|
|
}
|
|
}
|
|
|
|
func (so *sockOpt) getICMPFilter(c *socket.Conn) (*ICMPFilter, error) {
|
|
b := make([]byte, so.Len)
|
|
n, err := so.Get(c, b)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
if n != sizeofICMPFilter {
|
|
return nil, errNotImplemented
|
|
}
|
|
return (*ICMPFilter)(unsafe.Pointer(&b[0])), nil
|
|
}
|
|
|
|
func (so *sockOpt) setICMPFilter(c *socket.Conn, f *ICMPFilter) error {
|
|
b := (*[sizeofICMPFilter]byte)(unsafe.Pointer(f))[:sizeofICMPFilter]
|
|
return so.Set(c, b)
|
|
}
|
|
|
|
func (so *sockOpt) setGroup(c *socket.Conn, ifi *net.Interface, grp net.IP) error {
|
|
switch so.typ {
|
|
case ssoTypeIPMreq:
|
|
return so.setIPMreq(c, ifi, grp)
|
|
case ssoTypeIPMreqn:
|
|
return so.setIPMreqn(c, ifi, grp)
|
|
case ssoTypeGroupReq:
|
|
return so.setGroupReq(c, ifi, grp)
|
|
default:
|
|
return errNotImplemented
|
|
}
|
|
}
|
|
|
|
func (so *sockOpt) setSourceGroup(c *socket.Conn, ifi *net.Interface, grp, src net.IP) error {
|
|
return so.setGroupSourceReq(c, ifi, grp, src)
|
|
}
|
|
|
|
func (so *sockOpt) setBPF(c *socket.Conn, f []bpf.RawInstruction) error {
|
|
return so.setAttachFilter(c, f)
|
|
}
|