diff options
| author | Daniel Borkmann <dborkman@redhat.com> | 2013-05-13 11:24:41 +0200 | 
|---|---|---|
| committer | Daniel Borkmann <dborkman@redhat.com> | 2013-05-13 12:27:03 +0200 | 
| commit | 2b100f7515dbd01032967c2d1b81d2f8d63bf9b5 (patch) | |
| tree | 968b9a17fc20f92c0d58cdd11ed49815d8b818f5 | |
| parent | c59245ddcc0541edca71769b3153bc13580a5bbb (diff) | |
zsh: add netsniff-ng zsh auto completion support
Hideo Hattori wrote a set of auto completion scripts for zsh that
support netsniff-ng tools. Big thanks for that! Follow-up commits
still need to address updated command-line options.
Signed-off-by: Hideo Hattori <hhatto.jp@gmail.com>
Signed-off-by: Daniel Borkmann <dborkman@redhat.com>
| -rw-r--r-- | AUTHORS | 1 | ||||
| -rw-r--r-- | astraceroute.zsh | 50 | ||||
| -rw-r--r-- | bpfc.zsh | 18 | ||||
| -rw-r--r-- | curvetun.zsh | 36 | ||||
| -rw-r--r-- | flowtop.zsh | 21 | ||||
| -rw-r--r-- | ifpps.zsh | 29 | ||||
| -rw-r--r-- | netsniff-ng.zsh | 69 | ||||
| -rw-r--r-- | trafgen.zsh | 55 | 
8 files changed, 279 insertions, 0 deletions
| @@ -14,6 +14,7 @@ Major contributors (> 30 commits):  Minor contributors (<= 30 commits): + * Hideo Hattori <hhatto.jp@gmail.com>   * Peter Stuge <peter@stuge.se>   * Scott Moeller <electronjoe@gmail.com>   * Jesper Dangaard Brouer <brouer@redhat.com> diff --git a/astraceroute.zsh b/astraceroute.zsh new file mode 100644 index 0000000..28fa24a --- /dev/null +++ b/astraceroute.zsh @@ -0,0 +1,50 @@ +#compdef astraceroute +# +# astraceroute.zsh -- zsh completion function for astraceroute +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args + +_interfaces () { +    _wanted interfaces expl 'network interface' \ +    _net_interfaces +    _values "Pseudo-device that captures on all interfaces" "any" +} + +_arguments -s -S \ +    "(-H --host)"{-H,--host}"[Host/IPv4/IPv6 to lookup AS route to]:host:_hosts" \ +    "(-p --port)"{-p,--port}"[Hosts port to lookup AS route to]:port:_gnu_generic" \ +    "(-i -d --dev)"{-i,-d,--dev}"[Networking device i.e., eth0]:device:_interfaces" \ +    "(-4 --ipv4)"{-4,--ipv4}"[Use IPv4 requests (default)]" \ +    "(-6 --ipv6)"{-6,--ipv6}"[Use IPv6 requests]" \ +    "(-n --numeric)"{-n,--nemeric}"[Do not do reverse DNS lookup for hops]" \ +    "(-N --dns)"{-N,--dns}"[Do a reverse DNS lookup for hops]" \ +    "(-f --init-ttl)"{-f,--init-ttl}"[Set initial TTL]:ttl:_gnu_generic" \ +    "(-m --max-ttl)"{-m,--max--ttl}"[Set maximum TTL]:ttl:_gnu_generic" \ +    "(-q --num-probes)"{-q,--num-probes}"[Set maximum TTL (default: 30)]:ttl:_gnu_generic" \ +    "(-q --num-probes)"{-q,--num-probes}"[Number of max probes for each hop (default: 3)]:num:_gnu_generic" \ +    "(-x --timeout)"{-x,--timeout}"[Probe response timeout in sec (default: 3)]:timeout:_gnu_generic" \ +    "(-S --syn)"{-S,--syn}"[Set TCP SYN flag in packets]" \ +    "(-A --ack)"{-A,--ack}"[Set TCP ACK flag in packets]" \ +    "(-F --fin)"{-F,--fin}"[Set TCP FIN flag in packets]" \ +    "(-P --psh)"{-P,--psh}"[Set TCP PSH flag in packets]" \ +    "(-U --urg)"{-U,--urg}"[Set TCP URG flag in packets]" \ +    "(-R --rst)"{-R,--rst}"[Set TCP RST flag in packets]" \ +    "(-E --ecn-syn)"{-E,--ecn-syn}"[Send ECN SYN packets (RFC3168)]" \ +    "(-t --tos)"{-t,--tos}"[Set the IP TOS field]:tos:_gnu_generic" \ +    "(-G --nofrag)"{-G,--nofrag}"[Set do not fragment bit]" \ +    "(-X --payload)"{-X,--payload}"[Specify a payload string to test DPIs]:string:_gnu_generic" \ +    "(-Z --show-packet)"{-Z,--show-packet}"[Show returned packet on each hop]" \ +    "(-l --totlen)"{-l,--totlen}"[Specify total packet len]:lengths:_gnu_generic" \ +    "(-w --whois)"{-w,--whois}"[Use a different AS whois DB server (default: /etc/netsniff-ng/whois.conf)]:file:_files" \ +    "(-W --wport)"{-W,--wport}"[Use a different port to AS whois server (default: /etc/netsniff-ng/whois.conf)]:file:_files" \ +    "--city-db[Specifiy path for geoip city database]:path:_files" \ +    "--country-db[Specifiy path for geoip country database]:path:_files" \ +    {-v,--version}"[Print version]:" \ +    {-h,--help}"[Print this help]:" \ +    "*::args:_gnu_generic" diff --git a/bpfc.zsh b/bpfc.zsh new file mode 100644 index 0000000..ae6eb39 --- /dev/null +++ b/bpfc.zsh @@ -0,0 +1,18 @@ +#compdef bpfc +# +# bpfc.zsh --  zsh completion function for bpfc +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args + +_arguments -s -S \ +    "(-i --input)"{-i,--input}"[Berkeley Packet Filter file]:input:_files" \ +    "(-V --verbose)"{-V,--verbose}"[Be more verbose]" \ +    {-v,--version}"[Print version]:" \ +    {-h,--help}"[Print this help]:" \ +    "*::args:_gnu_generic" diff --git a/curvetun.zsh b/curvetun.zsh new file mode 100644 index 0000000..16a1fd3 --- /dev/null +++ b/curvetun.zsh @@ -0,0 +1,36 @@ +#compdef curvetun +# +# curvetun.zsh -- zsh completion function for curvetun +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args + +_interfaces () { +    _wanted interfaces expl 'network interface' \ +    _net_interfaces +    _values "Pseudo-device that captures on all interfaces" "any" +} + +_arguments -s -S \ +    "(-k --keygen)"{-k,--keygen}"[Generate public/private keypair]" \ +    "(-x --export)"{-x,--export}"[Export your public data for remote servers]" \ +    "(-C --dumpc)"{-C,--dumpc}"[Dump parsed clients]" \ +    "(-S --dumps)"{-S,--dumps}"[Dump parsed servers]" \ +    "(-D --nofork)"{-D,--nofork}"[Do not daemonize]" \ +    "(-d --dev)"{-d,--dev}"[Networking tunnel device, e.g. tun0]:device:_interfaces" \ +    {-v,--version}"[Print version]:" \ +    {-h,--help}"[Print this help]:" \ +    "(-s --server -N --no-logging -p --port -t --stun -u --udp -4 --ipv4 -6 --ipv6 -c --client)"{-c,--client}"[Client mode, server alias optional]:client:_gnu_generic" \ +    "(-c --client -s --server)"{-s,--server}"[Server mode]" \ +    "(-c --client -N --no-logging)"{-N,--no-logging}"[Disable server logging (for better anonymity)]" \ +    "(-c --client -p --port)"{-p,--port}"[Port number (mandatory)]:port:_gnu_generic" \ +    "(-c --client -t --stun)"{-t,--stun}"[Show public IP/Port mapping via STUN]:stun:_gnu_generic" \ +    "(-c --client -u --udp)"{-u,--udp}"[Use UDP as carrier instead of TCP]" \ +    "(-c --client -4 --ipv4)"{-4,--ipv4}"[Tunnel devices are IPv4]" \ +    "(-c --client -6 --ipv6)"{-6,--ipv6}"[Tunnel devices are IPv6 (default: same as carrier protocol)]" \ +    "*::args:_gnu_generic" diff --git a/flowtop.zsh b/flowtop.zsh new file mode 100644 index 0000000..1d1b2e7 --- /dev/null +++ b/flowtop.zsh @@ -0,0 +1,21 @@ +#compdef flowtop +# +# flowtop.zsh -- zsh completion function for flowtop +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args + +_arguments -s -S \ +    "(-T --tcp)"{-T,--tcp}"[Show only TCP flows (default)]" \ +    "(-U --udp)"{-U,--udp}"[Show only UDP flows]" \ +    "(-s --show-src)"{-s,--show-src}"[Also show source, not only dest]" \ +    "--city-db[Specifiy path for geoip city database]:path:_files" \ +    "--country-db[Specifiy path for geoip country database]:path:_files" \ +    {-v,--version}"[Print version]:" \ +    {-h,--help}"[Print this help]:" \ +    "*::args:_gnu_generic" diff --git a/ifpps.zsh b/ifpps.zsh new file mode 100644 index 0000000..a4a4a5d --- /dev/null +++ b/ifpps.zsh @@ -0,0 +1,29 @@ +#compdef ifpps +# +# ifpps.zsh -- zsh completion function for ifpps +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args + +_interfaces () { +    _wanted interfaces expl 'network interface' \ +    _net_interfaces +    _values "Pseudo-device that captures on all interfaces" "any" +} + +_arguments -s -S \ +    "(-d --dev)"{-d,--dev}"[Device to fetch statistics for i.e., eth0]:device:_interfaces" \ +    "(-p --promisc)"{-p,--promisc}"[Promiscuous mode]" \ +    "(-t --interval)"{-t,--interval}"[Refresh time in sec (default 1 s)]:interval:_gnu_generic" \ +    "(-c --term)"{-c,--term}"[Output to terminal]" \ +    "(-C --csv)"{-C,--csv}"[Output to terminal as CSV  E.g. post-processing with Gnuplot et al.]" \ +    "(-H --csv-tablehead)"{-H,--csv-tablehead}"[Print CSV table head]" \ +    "(-l --loop)"{-l,--loop}"[Loop terminal output]" \ +    {-v,--version}"[Print version]:" \ +    {-h,--help}"[Print this help]:" \ +    "*::args:_gnu_generic" diff --git a/netsniff-ng.zsh b/netsniff-ng.zsh new file mode 100644 index 0000000..122d661 --- /dev/null +++ b/netsniff-ng.zsh @@ -0,0 +1,69 @@ +#compdef netsniff-ng +# +# netsniff-ng.zsh -- zsh completion function for netsniff-ng +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args +local context state line + +_cpu () { +    _cpus=(${${(f)"$(grep processor /proc/cpuinfo | awk '{print $3}')"}}) +    compadd -a _cpus +} + +_user_info () { +    user_info=(${${(f)"$(awk -F':' '{print $3":"$1}' /etc/passwd)"}}) +    _describe -t usr "user info" user_info && ret=0 +} + +_group_info () { +    group_info=(${${(f)"$(awk -F':' '{print $4":"$1}' /etc/passwd)"}}) +    _describe -t usr "group info" group_info && ret=0 +} + +_interfaces () { +    _wanted interfaces expl 'network interface' \ +    _net_interfaces +    _values "Pseudo-device that captures on all interfaces" "any" +} + +_arguments -s -S \ +    "(-i -d --dev --in)"{-i,-d,--dev,--in}"[Input source as netdev, pcap or pcap stdin]:input:_interfaces" \ +    "(-o --out)"{-o,--out}"[Output sink as netdev, pcap, directory, trafgen, or stdout]::_gnu_generic" \ +    "(-f --filter)"{-f,--filter}"[Use BPF filter file from bpfc or tcpdump-like expression]" \ +    "(-t --type)"{-t,--type}"[Filter type]:filter:(host broadcast multicast others outgoing)" \ +    "(-F --interval)"{-F,--interval}"[Dump interval if -o is a dir: <num>KiB/MiB/GiB/s/sec/min/hrs]:interval:_gnu_generic" \ +    "(-J --jumbo-support)"{-J,--jumbo-support}"[Support for 64KB Super Jumbo Frames (def: 2048B)]" \ +    "(-R --rfraw)"{-R,--rfraw}"[Capture or inject raw 802.11 frames]" \ +    "(-n --num)"{-n,--num}"[Number of packets until exit (def: 0)]" \ +    "(-P --prefix)"{-P,--prefix}"[Prefix for pcaps stored in directory]" \ +    "(-T --magic)"{-T,--magic}"[Pcap magic number/pcap format to store, see -D]" \ +    "(-D --dump-pcap-types)"{-D,--dump-pcap-types}"[Dump pcap types and magic numbers and quit]" \ +    "(-B --dump-bpf)"{-B,--dump-bpf}"[Dump generated BPF assembly]" \ +    "(-r --rand)"{-r,--rand}"[Randomize packet forwarding order (dev->dev)]" \ +    "(-M --no-promisc)"{-M,--no-promisc}"[No promiscuous mode for netdev]" \ +    "(-A --no-sock-mem)"{-A,--no-sock-mem}"[Don\'t tune core socket memory]" \ +    "(-m --mmap)"{-m,--mmap}"[Mmap(2) pcap file i.e., for replaying pcaps]" \ +    "(-G --sg)"{-G,--sg}"[Scatter/gather pcap file I/O]" \ +    "(-c --clrw)"{-c,--clrw}"[Use slower read(2)/write(2) I/O]" \ +    "(-S --ring-size)"{-S,--ring-size}"[Specify ring size to: <num>KiB/MiB/GiB]:ringsize:" \ +    "(-k --kernel-pull)"{-k,--kernel-pull}"[Kernel pull from user interval in us (def: 10us)]:kernelpull:_gnu_generic" \ +    "(-b --bind-cpu)"{-b,--bind-cpu}"[Bind to specific CPU]:cpunum:_cpu" \ +    "(-u --user)"{-u,--user}"[Drop privileges and change to userid]:user:_user_info" \ +    "(-g --group)"{-g,--group}"[Drop privileges and change to groupid]:group:_group_info" \ +    "(-H --prio-high)"{-H,--prio-high}"[Make this high priority process]" \ +    "(-Q --notouch-irq)"{-Q,--notouch-irq}"[Do not touch IRQ CPU affinity of NIC]" \ +    "(-s --silent)"{-s,--silent}"[Do not print captured packets]" \ +    "(-q --less)"{-q,--less}"[Print less-verbose packet information]" \ +    "(-X --hex)"{-X,--hex}"[Print packet data in hex format]" \ +    "(-l --ascii)"{-l,--ascii}"[Print human-readable packet data]" \ +    "(-U --update)"{-U,--update}"[Update GeoIP databases]" \ +    "(-V --verbose)"{-V,--verbose}"[Be more verbose]" \ +    {-v,--version}"[Show version]:" \ +    {-h,--help}"[Guess what?!]:" \ +    "*::args:_gnu_generic" diff --git a/trafgen.zsh b/trafgen.zsh new file mode 100644 index 0000000..4a4fdde --- /dev/null +++ b/trafgen.zsh @@ -0,0 +1,55 @@ +#compdef trafgen +# +# trafgen.zsh -- zsh completion function for trafgen +# +# Copyright (C) 2013 Hideo Hattori <hhatto.jp@gmail.com> +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 as +# published by the Free Software Foundation. + +typeset -A opt_args +local context state line + +_cpu () { +    _cpus=(${${(f)"$(grep processor /proc/cpuinfo | awk '{print $3}')"}}) +    compadd -a _cpus +} + +_user_info () { +    user_info=(${${(f)"$(awk -F':' '{print $3":"$1}' /etc/passwd)"}}) +    _describe -t usr "user info" user_info && ret=0 +} + +_group_info () { +    group_info=(${${(f)"$(awk -F':' '{print $4":"$1}' /etc/passwd)"}}) +    _describe -t usr "group info" group_info && ret=0 +} + +_interfaces () { +    _wanted interfaces expl 'network interface' \ +    _net_interfaces +    _values "Pseudo-device that captures on all interfaces" "any" +} + +_arguments -s -S \ +    "(-i -c --in --conf)"{-i,-c,--in,--conf}"[Packet configuration file/stdin]:input:_files" \ +    "(-o -d --out --dev)"{-o,-d,--out,--dev}"[Networking device i.e., eth0]:device:_interfaces" \ +    "(-p --cpp)"{-p,--cpp}"[Run packet config through C preprocessor]" \ +    "(-J --jumbo-support)"{-J,--jumbo-support}"[Support 64KB super jumbo frames (def: 2048B)]" \ +    "(-R --rfraw)"{-R,--rfraw}"[Inject raw 802.11 frames]" \ +    "(-s --smoke-test)"{-s,--smoke-test}"[Probe if machine survived fuzz-tested packet]" \ +    "(-n --num)"{-n,--num}"[Number of packets until exit (def: 0)]" \ +    "(-r --rand)"{-r,--rand}"[Randomize packet selection (def: round robin)]" \ +    "(-P --cpus)"{-P,--cpus}"[Specify number of forks(<= CPUs) (def: #CPUs)]:cpunum:_cpu" \ +    "(-t --gap)"{-t,--gap}"[Interpacket gap in us (approx)]" \ +    "(-S --ring-size)"{-S,--ring-size}"[Manually set mmap size (KiB/MiB/GiB)]:ringsize:" \ +    "(-k --kernel-pull)"{-k,--kernel-pull}"[Kernel pull from user interval in us (def: 10us)]:kernelpull:_gnu_generic" \ +    "(-E --seed)"{-E,--seed}"[Manually set srand(3) seed]" \ +    "(-u --user)"{-u,--user}"[Drop privileges and change to userid]:user:_user_info" \ +    "(-g --group)"{-g,--group}"[Drop privileges and change to groupid]:group:_group_info" \ +    "(-e --example)"{-e,--example}"[Show built-in packet config example]:" \ +    "(-V --verbose)"{-V,--verbose}"[Be more verbose]" \ +    {-v,--version}"[Show version]:" \ +    {-h,--help}"[Guess what?!]:" \ +    "*::args:_gnu_generic" | 
