Running RF Swift
Running RF Swift is pretty straight forward and only requires a few command line to use your hacking tools as you wish.
rfswift
with sudo most of the time.
Options
Let us first discover the different options of the tool by typing rfswift --help
:
rfswift --help
[...]
888~-_ 888~~ ,d88~~\ ,e, 88~\ d8
888 \ 888___ 8888 Y88b e / " _888__ _d88__
888 | 888 'Y88b Y88b d8b / 888 888 888
888 / 888 'Y88b, Y888/Y88b/ 888 888 888
888_-~ 888 8888 Y8/ Y8/ 888 888 888
888 ~-_ 888 \__88P' Y Y 888 888 "88_/
RF toolbox for HAMs and professionals
[+] You are running version: 0.5.2 (Up to date)
rfswift is a super fancy CLI (kidding)
One can use stringer to modify or inspect strings straight from the terminal
Usage:
rfswift [flags]
rfswift [command]
Available Commands:
bindings Manage bindings
commit Commit a container
completion Generate the autocompletion script for the specified shell
delete Delete an rfswift images
exec Exec a command
help Help about any command
host Host configuration
images RF Swift images management remote/local
install Install function script
last Last container run
remove Remove a container
rename Rename a container
retag Rename an image
run Create and run a program
update Update RF Swift
Flags:
-h, --help help for rfswift
Use "rfswift [command] --help" for more information about a command.
sudo
is not necessary. In other cases, you will have to use it particularly on Linux dealing with images and containers, but not host actions.
Stay up-to-date
In case you binary is older than latest official release, you can pull the latest source from our official GitHub repository ↗.
At launch time, the binary will check your binary against latest official release:
[!] You are running version: 0.4.8 (Obsolete)
[+] Do you want to update to the latest version? (yes/no):
Or you can also use the upate
command that will download the latest ↗ binary compiled for your architecture:
rfswift update
...
[!] Your current version (0.4.8) is obsolete. Please update to version (v0.4.9).
[+] Do you want to update to the latest version? (yes/no): yes
Latest release download URL: https://github.com/PentHertz/RF-Swift/releases/download/v0.4.9/rfswift_linux_amd64
[+] Do you want to replace the existing binary with this new release? (yes/no): yes
13.67 MiB / 13.67 MiB [---------------------------------------------------------------------------------------------------------------------------------------------------------------------------] 100.00%%
File downloaded and replaced successfully.
After that, your binary should be up-to-date!
Changing tag and running
After pulling an image, you can choose to change the tag name as you wish for conveniency, and also match the tag to the default image to run as described in the configuration in your profile directory (e.g: on Linux):
cat /home/username/.config/rfswift/config.ini
[general]
imagename = myrfswift:latest
...
type C:\Users\username\AppData\Roaming\rfswift\config.ini
[general]
imagename = myrfswift:latest
...
cat /Users/username/.config/rfswift/config.ini
[general]
imagename = myrfswift:latest
...
So if you change your the tag name of your desired image, or last image you have pulled, to the default tag name myrfswift:latest
that way:
rfswift retag -i penthertz/rfswiftdev:sdr_full_amd64 -t myrfswift:latest
...
[+] You are running version: 0.4.9 (Up to date)
[+] Image renamed!
This will simplify the run
command and avoid you to use -i
argument:
rfswift run -n supertagname1 # -> same as 'rfswift run -i myrfswift:latest -n supertagname1'
...
🧊 Container Summary
╭──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ Container Name │ supertagname1 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ X Display │ :0 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Shell │ /bin/zsh │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Privileged Mode │ true │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Network Mode │ host │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Image Name │ myrfswift:latest (Custom) │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Size on Disk │ 16635.22 MB │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Bindings │ /tmp/.X11-unix:/tmp/.X11-unix,/dev/bus/usb:/dev/bus/usb,/run/dbus/system_bus_socket:/run/dbus/system_bus_socket,/dev/snd:/dev/snd,/dev/dri:/dev/dri,/dev/input:/dev/input │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Extra Hosts │ pluto.local:192.168.2.1 │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
[+] Container 'supertagname1' started successfully
┌─[root@topms] - [~] - [Tue Sep 03, 13:57]
└─[$]> exit
Note that if you run a container without enabling audio with pulseaudio
options, you will generally miss the sound on many tools, and a warning will notify you that the audio is not enabled:
┌──────────────────────────────────────────────────────────────────────────────────────────────────┐
│ ⚠️ Warning │
├──────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Warning: Unable to connect to Pulse server at 127.0.0.1:34567 │
│ To install Pulse server on Linux, follow these steps: │
│ 1. Update your package manager: sudo apt update (for Debian-based) or sudo yum update (for Red │
│ Hat-based). │
│ 2. Install Pulse server: sudo apt install pulse-server (for Debian-based) or sudo yum install │
│ pulse-server (for Red Hat-based). │
│ After installation, enable the module with the following command as unprivileged user: │
│ ./rfswift host audio enable │
└──────────────────────────────────────────────────────────────────────────────────────────────────┘
To enable the audio, use the following command without sudo and you should see the following message:
rfswift host audio enable
...
[+] Successfully loaded module-native-protocol-tcp with index 29
When running a container, you should get a different shell indicating you are using now the container.
Using the run
command, you are creating a new container from desired images everytime:
graph TD; A[corebuild]-->B[Image 1]; A-->C[Docker image 2]; B-->D[Supercontainer #1 of image 1]; B-->E[Supercontainer #2 of image 1]; C-->F[Anothercontainer from image 2]
This architecture has several benefits:
- more portability;
- possibility to have kind of “light” and isolated environment;
- you can create, mess, and destroy the environment;
- have specific environments for specific tasks;
- stop wasting time reinstalling the entire system with your tools;
- better performance than VMs that consume more CPU, memory, and disk space;
- and more such as using it as for microservices, etc.
These benefits are what you are generally what you are looking for when doing lots of assessments, particularly when you have to prepare at the last moment.
Restarting a previous container
Of course, to avoid creating new containers with run
command, you can use exec
command that will automatically restart the latest container you run:
rfswift exec
...
[+] You are running version: 0.4.9 (Up to date)
[+] Container 'a9c76a227726357a9b403d703923a57ae62a024bace11c1d1df893ea6c7e9623' started successfully
🧊 Container Summary
╭──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ Container Name │ supertagname1 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ X Display │ :0 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Shell │ /bin/zsh │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Privileged Mode │ true │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Network Mode │ host │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Image Name │ myrfswift:latest (Custom) │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Size on Disk │ 16635.22 MB │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Bindings │ /tmp/.X11-unix:/tmp/.X11-unix,/dev/bus/usb:/dev/bus/usb,/run/dbus/system_bus_socket:/run/dbus/system_bus_socket,/dev/snd:/dev/snd,/dev/dri:/dev/dri,/dev/input:/dev/input │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Extra Hosts │ pluto.local:192.168.2.1 │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
┌─[root@topms] - [~] - [Tue Sep 03, 14:57]
└─[$]>
With -c
argument precising the name, or container ID, used when creating the container you can also call other container you have previously made:
rfswift exec -c containername3
...
[+] You are running version: 0.4.9 (Up to date)
[+] Container 'containername3' started successfully
🧊 Container Summary
╭──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ Container Name │ containername3 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ X Display │ :0 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Shell │ /bin/zsh │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Privileged Mode │ true │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Network Mode │ host │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Image Name │ penthertz/rfswiftdev:sdr_full_amd64 (Up to date) │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Size on Disk │ 16635.22 MB │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Bindings │ /tmp/.X11-unix:/tmp/.X11-unix,/dev/bus/usb:/dev/bus/usb,/run/dbus/system_bus_socket:/run/dbus/system_bus_socket,/dev/snd:/dev/snd,/dev/dri:/dev/dri,/dev/input:/dev/input │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Extra Hosts │ pluto.local:192.168.2.1 │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
┌─[root@topms] - [~] - [Tue Sep 03, 15:00]
└─[$]>
Starting programs
Depending on the Docker image you are using, some software can be used, like sdrangel
after plugging an SDR device like the RTL-SDR one:
┌─[root@topms] - [~] - [Tue Sep 03, 15:15]
└─[$]> sdrangel
xhost
on Linux, or XQuartz
on macOS (well configured), should be installed on the computer to handle graphic elements.
Of course, other software are installed among images, so you can discover the lists in the next pages.
Retrieving last containers name
If you do not remember how you have named your container, it is not a problem as you can recover the details with the command last
:
rfswift last
[+] You are running version: 0.4.9 (Up to date)
🤖 Last Run Containers
┌───────────────────────────┬─────────────────────────────────────┬────────────────┬──────────────┬──────────┐
│ Created │ Image Tag │ Container Name │ Container ID │ Command │
├───────────────────────────┼─────────────────────────────────────┼────────────────┼──────────────┼──────────┤
│ 2024-09-04T12:51:15+02:00 │ penthertz/rfswift:telecom │ supertelecom │ e1a8c7c5f419 │ /bin/zsh │
├───────────────────────────┼─────────────────────────────────────┼────────────────┼──────────────┼──────────┤
│ 2024-09-04T12:47:11+02:00 │ penthertz/rfswift:reversing │ superreverse │ 70b9269b2819 │ /bin/zsh │
├───────────────────────────┼─────────────────────────────────────┼────────────────┼──────────────┼──────────┤
│ 2024-09-04T12:38:09+02:00 │ penthertz/rfswift:automotive │ superauto │ 9063f86f9cf7 │ /bin/zsh │
├───────────────────────────┼─────────────────────────────────────┼────────────────┼──────────────┼──────────┤
...
Saving Changes to a Container
You can save changes made inside a running container to a new image using the commit
command. This allows you to preserve the current state of your container as a reusable image.
To commit the changes from a container, use the following command in RF Swift:
rfswift commit -c supertelecom -i supernewimage
...
[+] You are running version: 0.4.9 (Up to date)
sha256:3e287dbff4ea78ae782f19f50db6e7645ef45294c8990f2a5d595936c1f9d47b
Renaming a container
If the name of the container does not suit you anymore, you can also rename it with the rename
command as follows:
rfswift rename -n oldcontainername -d newcontainername
...
[+] You are running version: 0.4.9 (Up to date)
[+] Container 'supertelecom2' renamed to 'newnametelecom'!
Deleting a container
If you want to remove a container, and save space once for a while, you can issue the remove
command precing the name or ID of the container:
rfswift remove -c newnametelecom
...
[+] Container 'newnametelecom' removed successfully
Deleting an image
If deleting the container is not enough and need to also remove the image, you can use delete
command with image tag as follows:
rfswift detele -c penthertz/rfswift:<tagname>
Isolation
Network isolation
By default, all images run in host
mode which means there is no network isolation.
RF Swift implement same network isolation as classic Docker:
bridge
: The default network driver.host
: Remove network isolation between the container and the Docker host.none
: Completely isolate a container from the host and other containers.overlay
: Overlay networks connect multiple Docker daemons together.ipvlan
: IPvlan networks provide full control over both IPv4 and IPv6 addressing.macvlan
: Assign a MAC address to a container.
To use bridge
mode and exposing a port to all container and/or on the host, you can use use the following command (with root privileges):
rfswift run -i bluetooth -n containername -t bridge -z 8000 -w 8000:127.0.0.0:80/tcp
...
[+] Binded: '8000:127.0.0.0:80/tcp'
🧊 Container Summary
╭──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ Container Name │ containername │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ X Display │ :0 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Shell │ /bin/zsh │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Privileged Mode │ true │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Network Mode │ bridge │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Exposed Ports │ 8000 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Port Bindings │ 127.0.0.0:80/tcp -> 8000 │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Image Name │ penthertz/rfswift:bluetooth │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Size on Disk │ 10836.73 MB │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Bindings │ /tmp/.X11-unix:/tmp/.X11-unix,/dev/bus/usb:/dev/bus/usb,/run/dbus/system_bus_socket:/run/dbus/system_bus_socket,/dev/snd:/dev/snd,/dev/dri:/dev/dri,/dev/input │
│ │ │
│ │ :/dev/input,/dev/vhci:/dev/vhci │
├─────────────────┼────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ Extra Hosts │ pluto.local:192.168.2.1 │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
The -w
argument will expose the container port tcp/8000
to the host as tcp/80
. Note that we have only exposed it to the host with host IP address 127.0.0.1
, but can also remove the local IP address to bind to any interfaces. The tcp/8000
will also be exposed to other containers as tcp/8000
thanks to argument -z
.
Host isolation
This part is in progress and will be available soon ;)