Skip to main content

iproute for Mac

Project description

iproute4mac

GH Actions CI PyPI Downloads

This is a macOS network wrapper to imitate GNU/Linux iproute2 suite, inspired by the iproute2mac project.

Working staff

Command ip:

objects implemented supported note
address :white_check_mark: :white_check_mark:
addrlabel :x: :grey_question: IPv6 protocol address label
maddress :x: :grey_question:
route :white_check_mark: :white_check_mark:
rule :x: :grey_question: (e.g. source based routing with FreeBSD...)
neighbor :white_check_mark: :white_check_mark: using ARP for IPv4 and NDP for IPv6
ntable :x: :grey_question:
ntbl :x: :grey_question:
link :white_check_mark: :white_check_mark:
l2tp :x: :grey_question:
fou :x: :grey_question: IP-IP tunnel over UDP?
ila :x: :grey_question: IPv6 Identifier Locator Addressing
macsec :x: :x:
tunnel :x: :white_check_mark: IP-IP only
tuntap :x: :grey_question: Tunnelblick third party tuntaposx?
token :x: :grey_question: May be related to non-numeric IPv6 mask?
tcpmetrics :x: :grey_question:
monitor :x: :x:
xfrm :x: :x:
mroute :x: :grey_question: See Max OS: no multicast route for 127.0.0.1
mrule :x: :grey_question:
netns :x: :x:
netconf :x: :white_check_mark:
vrf :x: :grey_question: Virtual Routing and Forwarding
sr :x: :grey_question: IPv6 Segment Routing management
nexthop :x: :grey_question:
mptcp :x: :x: Multipath TCP
ioam :x: :grey_question: IPv6 In-situ OAM (IOAM)
help :white_check_mark: :white_check_mark:
stats :x: :grey_question:

Command bridge:

objects implemented supported note
link :white_check_mark: :white_check_mark: show only
fdb :white_check_mark: :white_check_mark: show only

Examples:

  • ip address [ list | show ]

  • ip address { add | change | replace | delete }

  • ip link [ list | show ]

  • ip link { add | set | change | delete }

  • ip route [ list | show ]

  • ip route { add | change | replace | delete }

  • ip route get

  • ip neigh [ list | show ]

  • ip neigh flush

  • bridge link [ list | show ]

  • bridge fdb [ list | show ]

Installation

Homebrew

The preferred method of installation is Homebrew.

In order to use this tap, you can install directly the package:

brew install signal-09/tap/iproute4mac

Or subscribe the tap repository and then install the package:

brew tap signal-09/tap
brew install iproute4mac

PyPI

Create a Virtual Environment and upgrade pip module:

python3 -m venv venv
source venv/bin/activate
python3 -m pip install -U pip

Then install iproute4mac:

python3 -m pip install iproute4mac

Usage

iproute4mac try to imitate as much as possible the look & feel of the GNU/Linux iproute2 suite, but macOS (Darwin) is a BSD derivative, and some aspects cannot be replicated at all.

ip address show: look at protocol addresses

Implemented syntax:

ip address [ show [ dev IFNAME ] [ scope SCOPE-ID ] [ master DEVICE | nomaster ] [ type TYPE ] [ to PREFIX ] [ FLAG-LIST ] [ label LABEL ] [up] [ vrf NAME ] ]

SCOPE-ID := [ host | link | global | NUMBER ]

FLAG-LIST := [ FLAG-LIST ] FLAG

FLAG := [ permanent | dynamic | secondary | primary | [-]tentative | [-]deprecated | [-]dadfailed | temporary | CONFFLAG-LIST ]

CONFFLAG-LIST := [ CONFFLAG-LIST ] CONFFLAG

CONFFLAG := [ home | nodad | mngtmpaddr | noprefixroute | autojoin ]

TYPE := { bareudp | bond | bond_slave | bridge | bridge_slave | dummy | erspan | geneve | gre | gretap | ifb | ip6erspan | ip6gre | ip6gretap | ip6tnl | ipip | ipoib | ipvlan | ipvtap | macsec | macvlan | macvtap | netdevsim | nlmon | rmnet | sit | team | team_slave | vcan | feth5 | vlan | vrf | vti | vxcan | vxlan | wwan | xfrm }

Shows IPv4 and IPv6 addresses assigned to all network interfaces. The 'show' subcommand can be omitted:

ip address show

Same as above except that only IPv6 addresses assigned to active network interfaces are shown:

ip -6 address show up

Shows IPv4 and IPv6 addresses assigned to network interface en0 in pretty printed JSON:

ip -j -p address show dev en0

Shows IPv4 only addresses assigned to networks member of bridge0:

ip -4 address show master bridge0

Shows IP addresses belonging to private C class network 192.168.0.0/24:

ip address show to 192.168.0.0/24

Notes

  1. qdisc (queuing discipline) is part of the Linux Traffic Control subsystem (TC) managed via the tc utility. Even if this information is not reported, similar results in traffic control and shaping can be achieved using dnctl and pfctl.
  2. address lifetime for IPv6 addresses (-L flag of ifconfig) is not provided anymore in Sonoma (macOS 14); for IPv4, addresses valid and prederred lifetime, is supposed forever (0xffffffff = 4.294.967.295 = 32 bit).
  3. sysctl net.inet6.ip6.temppltime specifies the "preferred lifetime" for privacy addresses, in seconds, and defaults to 86400 (one day).
  4. sysctl net.inet6.ip6.tempvltime specifies the "valid lifetime" for privacy addresses, in second, and defaults to 604800 (one week).
  5. veth can be replaced by feth in macOS

ip address add: add new protocol address

ip address change: change protocol address

ip address replace: change or add protocol address

Implemented syntax:

ip address {add|change|replace} IFADDR dev IFNAME [ LIFETIME ] [ CONFFLAG-LIST ]

Notes

  1. {change|replace} option "really" change address properties (e.g. broadcast) while Linux simply ignore them.

ip address delete: delete protocol address

ip link show: display device attributes

Implemented syntax:

ip link show [ DEVICE | group GROUP ] [ up ] [ master DEVICE | nomaster ] [ type ETYPE ] [ vrf NAME ]

ETYPE := [ TYPE | bridge_slave | bond_slave ]

TYPE := [ bridge | bond | can | dummy | hsr | ifb | ipoib | macvlan | macvtap | vcan | vxcan | veth | vlan | vxlan | ip6tnl | ipip | sit | gre | gretap | erspan | ip6gre | ip6gretap | ip6erspan | vti | nlmon | ipvlan | ipvtap | lowpan | geneve | bareudp | vrf | macsec | netdevsim | rmnet | xfrm ]

Shows the state of all network interfaces on the system:

ip link show

Shows the bridge devices:

ip link show type bridge

Shows the vlan devices:

ip link show type vlan

Shows devices enslaved by bridge0:

ip link show master bridge0

Notes

  1. txqlen (the transmit queue length) is not configurable on specific interface; a system default value is managed via sysctl net.link.generic.system.sndq_maxlen (or net.link.generic.system.rcvq_maxlen).

ip link add: add virtual link

Implemented syntax:

ip link add [ link DEV | parentdev NAME ] [ name ] NAME [ txqueuelen PACKETS ] [ address LLADDR ] [ broadcast LLADDR ] [ mtu MTU ] [ index IDX ] [ numtxqueues QUEUE_COUNT ] [ numrxqueues QUEUE_COUNT ] [ netns { PID | NETNSNAME | NETNSFILE } ] type TYPE [ ARGS ]

Create a VLAN with TAG 100 linked to en1:

ip link add link en1 name vlan100 type vlan id 100

Create a new bridge interface (auto numbering1):

ip link add type bridge

Create a new bridge with a specified name:

ip link add bridge20 type bridge

Create a new static bond (vs lacp) interface:

ip link add bond1 type bond mode active-backup

Notes

  1. macOS ifconfig print the created interface name to the standard output

ip link delete: delete virtual link

Implemented syntax:

ip link delete { DEVICE | dev DEVICE | group DEVGROUP } type TYPE [ ARGS ]

Delete any kind of virtual interface:

ip link del vlan100

ip link set (or change): change device attributes

Implemented syntax:

ip route show: list routes

Implemented syntax:

ip route [ show [ SELECTOR ] ]

SELECTOR := [ root PREFIX ] [ match PREFIX ] [ exact PREFIX ] [ table2 TABLE_ID ] [ vrf NAME ] [ proto RTPROTO ] [ type TYPE ] [ scope SCOPE ]

TYPE := { unicast | local | broadcast | multicast | throw | unreachable | prohibit | blackhole | nat }

TABLE_ID := [ local | main | default | all | NUMBER ]

SCOPE := [ host | link | global | NUMBER ]

RTPROTO := [ kernel | boot | static | NUMBER ]

List routes using a specific gateway:

ip route show via 192.168.0.1

List IPv6 routes using a specific network interface:

ip -6 route show dev en1

List routes for multicast:

ip route show type multicast

List availabe routes to reach specific network:

ip route show to match 192.168.1.0/24

List IPv4 and IPv6 routes2

ip route show table all

Notes

  1. iif is not honored (is treated like dev and oif).
  2. Route tables are not implemented in macOS (Darwin), but "table all" will result in show IPv4 + IPv6 routes

ip route add: add new route

ip route delete: delete route

ip route change: change route

ip route replace: change or add new one

Implemented syntax:

ip route { add | delete | change | append | replace } ROUTE

ROUTE := NODE_SPEC [ INFO_SPEC ]

NODE_SPEC := [ TYPE ] PREFIX [ tos TOS ] [ table TABLE_ID ] [ proto RTPROTO ] [ scope SCOPE ] [ metric METRIC ] [ ttl-propagate { enabled | disabled } ]

INFO_SPEC := { NH | nhid ID } OPTIONS FLAGS [ nexthop NH ]...

NH := [ encap ENCAPTYPE ENCAPHDR ] [ via [ FAMILY ] ADDRESS ] [ dev STRING ] [ weight NUMBER ] NHFLAGS

FAMILY := [ inet | inet6 | mpls | bridge | link ]

OPTIONS := FLAGS [ mtu NUMBER ] [ advmss NUMBER ] [ as [ to ] ADDRESS ] [ rtt TIME ] [ rttvar TIME ] [ reordering NUMBER ] [ window NUMBER ] [ cwnd NUMBER ] [ initcwnd NUMBER ] [ ssthresh NUMBER ] [ realms REALM ] [ src ADDRESS ] [ rto_min TIME ] [ hoplimit NUMBER ] [ initrwnd NUMBER ] [ features FEATURES ] [ quickack BOOL ] [ congctl NAME ] [ pref PREF ] [ expires TIME ] [ fastopen_no_cookie BOOL ]

TYPE := { unicast | local | broadcast | multicast | throw | unreachable | prohibit | blackhole | nat }

TABLE_ID := [ local | main | default | all | NUMBER ]

SCOPE := [ host | link | global | NUMBER ]

NHFLAGS := [ onlink | pervasive ]

RTPROTO := [ kernel | boot | static | NUMBER ]

PREF := [ low | medium | high ]

TIME := NUMBER[s|ms]

BOOL := [1|0]

FEATURES := ecn

ENCAPTYPE := [ mpls | ip | ip6 | seg6 | seg6local | rpl | ioam6 ]

ENCAPHDR := [ MPLSLABEL | SEG6HDR | SEG6LOCAL | IOAM6HDR ]

SEG6HDR := [ mode SEGMODE ] segs ADDR1,ADDRi,ADDRn [hmac HMACKEYID] [cleanup]

SEGMODE := [ encap | inline ]

SEG6LOCAL := action ACTION [ OPTIONS ] [ count ]

ACTION := { End | End.X | End.T | End.DX2 | End.DX6 | End.DX4 | End.DT6 | End.DT4 | End.DT46 | End.B6 | End.B6.Encaps | End.BM | End.S | End.AS | End.AM | End.BPF }

OPTIONS := OPTION [ OPTIONS ]

OPTION := { srh SEG6HDR | nh4 ADDR | nh6 ADDR | iif DEV | oif DEV | table TABLEID | vrftable TABLEID | endpoint PROGNAME }

IOAM6HDR := trace prealloc type IOAM6_TRACE_TYPE ns IOAM6_NAMESPACE size IOAM6_TRACE_SIZE

Add direct routing on a specific network interface:

ip route add 192.168.22.0/24 dev en1

Change interface for a given route:

ip route change 192.168.22.0/24 dev en0

Replace default gateway:

ip route replace default via 192.168.0.254

Delete route:

ip route del 192.168.22.0/24

ip route get: get a single route

Implemented syntax:

ip route get ROUTE_GET_FLAGS ADDRESS [ from ADDRESS iif STRING ] [ oif STRING ] [ mark MARK ] [ tos TOS ] [ vrf NAME ] [ ipproto PROTOCOL ] [ sport NUMBER ] [ dport NUMBER ]

ROUTE_GET_FLAGS := [ fibmatch ]

Shows the route to reach Google DNS 8.8.8.8:

ip route get 8.8.8.8

ip neigh show: list neighbour entries

Notes

  1. NOARP and PERMANENT states are not catched

ip neigh flush: flush neighbour entries

Same syntax of ip neigh show

Contributing

Every contribute is welcome!

Fork the repository

Fork button

Clone the fork

git clone https://github.com/YOUR-USERNAME/iproute4mac

Create a branch

Before making changes to the project, you should create a new branch and check it out (see "GitHub flow").

git branch BRANCH-NAME
git checkout BRANCH-NAME

Create a developer environment

python3 -m venv venv
source venv/bin/activate

Then install requiered packages:

python3 -m pip install -U pip
python3 -m pip install pre-commit pytest pytest-console-scripts
pre-commit install

Coding style

Ruff is used to enforce coding style. You can checkout the compliance with the following command:

pre-commit run --all-files [--show-diff-on-failure]

Commit your work

Create as few commit as possible to make diff checking easier. In case of modification of already pushed commit, amend it if possible:

git add -A
git commit --amend
git push --force

In case of multiple and not organic commits, "Squash and merge" policy will be applied.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iproute4mac-0.5.2.tar.gz (57.6 kB view details)

Uploaded Source

Built Distribution

iproute4mac-0.5.2-py3-none-any.whl (57.8 kB view details)

Uploaded Python 3

File details

Details for the file iproute4mac-0.5.2.tar.gz.

File metadata

  • Download URL: iproute4mac-0.5.2.tar.gz
  • Upload date:
  • Size: 57.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for iproute4mac-0.5.2.tar.gz
Algorithm Hash digest
SHA256 a14ac473d075a766bbd153d51b8c1883c0247ea3ce3763c6fcb54b143fab0f06
MD5 e0fe4ee281ed618440c8f6e6275d8cce
BLAKE2b-256 8e68b304a7b316d053a0679b9542e4ddf7e7b72cd3e5d46503cdec391d711570

See more details on using hashes here.

Provenance

File details

Details for the file iproute4mac-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: iproute4mac-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 57.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for iproute4mac-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4f5dc93865dc03f7fb155599c624344b4b4ff8d0ca5fb74b9b583f26bd6f0f26
MD5 906210a94ef4906bc7d5bc662db787df
BLAKE2b-256 5d326720dd7493e47b9d8fee5c8aa0b784ff3827451d4650a8b351ae71159c11

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page