 b69bbe25ac
			
		
	
	b69bbe25ac
	
	
	
		
			
			* Bump k8s.io/cri-api to latest version - v0.23.0-alpha.4 * Vendor github.com/vishvananda/netlink for network stats Signed-off-by: David Porter <porterdavid@google.com>
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Package netns allows ultra-simple network namespace handling. NsHandles
 | |
| // can be retrieved and set. Note that the current namespace is thread
 | |
| // local so actions that set and reset namespaces should use LockOSThread
 | |
| // to make sure the namespace doesn't change due to a goroutine switch.
 | |
| // It is best to close NsHandles when you are done with them. This can be
 | |
| // accomplished via a `defer ns.Close()` on the handle. Changing namespaces
 | |
| // requires elevated privileges, so in most cases this code needs to be run
 | |
| // as root.
 | |
| package netns
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 
 | |
| 	"golang.org/x/sys/unix"
 | |
| )
 | |
| 
 | |
| // NsHandle is a handle to a network namespace. It can be cast directly
 | |
| // to an int and used as a file descriptor.
 | |
| type NsHandle int
 | |
| 
 | |
| // Equal determines if two network handles refer to the same network
 | |
| // namespace. This is done by comparing the device and inode that the
 | |
| // file descriptors point to.
 | |
| func (ns NsHandle) Equal(other NsHandle) bool {
 | |
| 	if ns == other {
 | |
| 		return true
 | |
| 	}
 | |
| 	var s1, s2 unix.Stat_t
 | |
| 	if err := unix.Fstat(int(ns), &s1); err != nil {
 | |
| 		return false
 | |
| 	}
 | |
| 	if err := unix.Fstat(int(other), &s2); err != nil {
 | |
| 		return false
 | |
| 	}
 | |
| 	return (s1.Dev == s2.Dev) && (s1.Ino == s2.Ino)
 | |
| }
 | |
| 
 | |
| // String shows the file descriptor number and its dev and inode.
 | |
| func (ns NsHandle) String() string {
 | |
| 	if ns == -1 {
 | |
| 		return "NS(None)"
 | |
| 	}
 | |
| 	var s unix.Stat_t
 | |
| 	if err := unix.Fstat(int(ns), &s); err != nil {
 | |
| 		return fmt.Sprintf("NS(%d: unknown)", ns)
 | |
| 	}
 | |
| 	return fmt.Sprintf("NS(%d: %d, %d)", ns, s.Dev, s.Ino)
 | |
| }
 | |
| 
 | |
| // UniqueId returns a string which uniquely identifies the namespace
 | |
| // associated with the network handle.
 | |
| func (ns NsHandle) UniqueId() string {
 | |
| 	if ns == -1 {
 | |
| 		return "NS(none)"
 | |
| 	}
 | |
| 	var s unix.Stat_t
 | |
| 	if err := unix.Fstat(int(ns), &s); err != nil {
 | |
| 		return "NS(unknown)"
 | |
| 	}
 | |
| 	return fmt.Sprintf("NS(%d:%d)", s.Dev, s.Ino)
 | |
| }
 | |
| 
 | |
| // IsOpen returns true if Close() has not been called.
 | |
| func (ns NsHandle) IsOpen() bool {
 | |
| 	return ns != -1
 | |
| }
 | |
| 
 | |
| // Close closes the NsHandle and resets its file descriptor to -1.
 | |
| // It is not safe to use an NsHandle after Close() is called.
 | |
| func (ns *NsHandle) Close() error {
 | |
| 	if err := unix.Close(int(*ns)); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	(*ns) = -1
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // None gets an empty (closed) NsHandle.
 | |
| func None() NsHandle {
 | |
| 	return NsHandle(-1)
 | |
| }
 |