nfqueue

package
v0.0.0-...-61ca646 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 28, 2017 License: GPL-2.0 Imports: 4 Imported by: 51

Documentation

Overview

Go bindings for the NFQUEUE netfilter target libnetfilter_queue is a userspace library providing an API to access packets that have been queued by the Linux kernel packet filter.

This provides an easy way to filter packets from userspace, and use tools or libraries that are not accessible from kernelspace.

BUG(nfqueue): This package currently displays lots of debug information

Index

Constants

This section is empty.

Variables

View Source
var ErrNotInitialized = errors.New("nfqueue: queue not initialized")
View Source
var ErrOpenFailed = errors.New("nfqueue: open failed")
View Source
var ErrRuntime = errors.New("nfqueue: runtime error")
View Source
var NFQNL_COPY_META uint8 = C.NFQNL_COPY_META
View Source
var NFQNL_COPY_NONE uint8 = C.NFQNL_COPY_NONE
View Source
var NFQNL_COPY_PACKET uint8 = C.NFQNL_COPY_PACKET
View Source
var NF_ACCEPT = C.NF_ACCEPT
View Source
var NF_DROP = C.NF_DROP
View Source
var NF_QUEUE = C.NF_QUEUE
View Source
var NF_REPEAT = C.NF_REPEAT
View Source
var NF_STOP = C.NF_STOP

Functions

func GoCallbackWrapper

func GoCallbackWrapper(ptr_q *unsafe.Pointer, ptr_nfad *unsafe.Pointer) int

Cast argument to Queue* before calling the real callback

Notes:

This function must _nerver_ be called directly.

BUG(GoCallbackWrapper): The return value from the Go callback is used as a verdict. This works, and avoids packets without verdict to be queued, but prevents using out-of-order replies.

Types

type Callback

type Callback func(*Payload) int

Prototype for a NFQUEUE callback. The callback receives the NFQUEUE ID of the packet, and the packet payload. Packet data start from the IP layer (ethernet information are not included). It must return the verdict for the packet.

type Payload

type Payload struct {

	// NFQueue ID of the packet
	Id uint32
	// Packet data
	Data []byte
	// contains filtered or unexported fields
}

Payload is a structure describing a packet received from the kernel

func (*Payload) GetInDev

func (p *Payload) GetInDev() uint32

Returns the interface that the packet was received through

func (*Payload) GetNFMark

func (p *Payload) GetNFMark() uint32

Returns the packet mark

func (*Payload) GetOutDev

func (p *Payload) GetOutDev() uint32

Returns the interface that the packet will be routed out

func (*Payload) GetPhysInDev

func (p *Payload) GetPhysInDev() uint32

Returns the physical interface that the packet was received through

func (*Payload) GetPhysOutDev

func (p *Payload) GetPhysOutDev() uint32

Returns the physical interface that the packet will be routed out

func (*Payload) SetVerdict

func (p *Payload) SetVerdict(verdict int) error

SetVerdict issues a verdict for a packet.

Every queued packet _must_ have a verdict specified by userspace.

func (*Payload) SetVerdictModified

func (p *Payload) SetVerdictModified(verdict int, data []byte) error

SetVerdictModified issues a verdict for a packet, but replaces the packet with the provided one.

Every queued packet _must_ have a verdict specified by userspace.

type Queue

type Queue struct {
	// contains filtered or unexported fields
}

Queue is an opaque structure describing a connection to a kernel NFQUEUE, and the associated Go callback.

func (*Queue) Bind

func (q *Queue) Bind(af_family int) error

Bind binds a Queue to a given protocol family.

Usually, the family is syscall.AF_INET for IPv4, and syscall.AF_INET6 for IPv6

func (*Queue) Close

func (q *Queue) Close()

func (*Queue) CreateQueue

func (q *Queue) CreateQueue(queue_num int) error

Create a new queue handle

The queue must be initialized (using Init) and bound (using Bind), and a callback function must be set (using SetCallback).

func (*Queue) DestroyQueue

func (q *Queue) DestroyQueue() error

Destroy a queue handle

This also unbind from the nfqueue handler, so you don't have to call Unbind() Note that errors from this function can usually be ignored.

func (*Queue) Init

func (q *Queue) Init() error

Init creates a netfilter queue which can be used to receive packets from the kernel.

func (*Queue) Loop

func (q *Queue) Loop() error

Main loop: Loop starts a loop, receiving kernel events and processing packets using the callback function.

func (*Queue) SetCallback

func (q *Queue) SetCallback(cb Callback) error

SetCallback sets the callback function, fired when a packet is received.

func (*Queue) SetMode

func (q *Queue) SetMode(mode uint8) error

SetMode sets the amount of packet data that nfqueue copies to userspace

Default mode is NFQNL_COPY_PACKET

func (*Queue) SetQueueMaxLen

func (q *Queue) SetQueueMaxLen(maxlen uint32) error

SetQueueMaxLen fixes the number of packets the kernel will store before internally before dropping upcoming packets

func (*Queue) StopLoop

func (q *Queue) StopLoop()

func (*Queue) Unbind

func (q *Queue) Unbind(af_family int) error

Unbind a queue from the given protocol family.

Note that errors from this function can usually be ignored.

Notes

Bugs

  • This package currently displays lots of debug information

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL