The open source Manufacturer Usage Description project (osMUD for short) is working to improve the security of connected things and their networks. osMUD implements the MUD specification, is free to use, and you can help improve it!
MUD, or Manufacture Usage Description, is an RFC published by the Internet Engineering Task Force (IETF) that allows manufactures to specify the intended network behaviors of the devices they build. The full specification can be found at https://tools.ietf.org/html/draft-ietf-opsawg-mud.
Code contributions can be made through the pull request process. The software is constantly being updated and extended. We would like a community of developers to help add features from the IETF specification into osMUD as well as provide ideas and extensions to other devices. We encourage you to fork the repository and investigate the code. When the implementation of the feature is complete, enter an issue into the project to identify the capability that is being requested to be included in the source base. Then, use the pull request and target the "develop" branch. We will make every attempt to review and accept the capability. The pull request documentation can be found here:
osMUD is designed to easily build, deploy, and run on the OpenWRT platform. Additionally, there are integrations with the dnsmasq and OpenWRT firewall services. In the OpenWRT deployment, osMUD is intended to be run as a service and by default uses typical locations under the /var filesystem. There are multiple configuration options, including where downloaded MUD files are stored, that must be configured when the application is run. When osMUD is installed the service startup script installed under "/etc/init.d/osmud" contains these default locations. These options can changed depending on the needs of a particular deployment.
Additionally, osMUD can be compiled and executed from a Linux command line. If osMUD is not being run as root or as a user that has write access under the /var filesystem, then command line arguments need to be set to directory locations with write access. When running from the command line, use the "-d" argument to keep osMUD from running as a service and to keep the process in the foreground. The other options are:
- -l osMUD-log-file-name
- -x pid-file
- -b mud file storage directory (ensure you do not have a trailing
/
or it will break. Example of good argument:-b /tmp/osmud
)
Another important option is used to configure where DHCP events are written to and used as input for osMUD. These events are used to notify the system of when devices enter and leave the network when using DHCP. The osMUD option "-e <dhcp-event-log-file" is intended to point to these events. osMUD opens this file for read and monitors the file for new events. An integration is included for configuring the "dnsmasq" service to emit these events and more information can be found in "src/dnsmasq/README.md".
Our intention in the future is for osMUD to have the ability to run in other environments with different DHCP/DNS servers and firewalls. Please feel free to suggest future service integrations.
$ cd src/
$ make
This process sets up the OpenWRT build environment in a docker image to build the artifacts required to install on the router. The steps are:
- Create Docker image with required components for build environment
- Build osmud-dnsmasq (dnsmasq with osMUD changes)
- Build osmud
- Install on router
Note: Skip osmud-dnsmasq instructions until we have made the change for dnsmasq to read the DHCP MUD header option.
Build osmud-dnsmasq in OpenWRT
The build process requires cloning the osMUD project into the Docker container, installing the Makefile into the OpenWRT build environment, and then building the application. The project can be cloned into any directory within the Docker container, but if it's put anywhere other than "~/osmud" (off of the root directory), the Makefile will need to be edited to point to the correct directory location of the source code.
- Clone https://github.com/osmud/osmud
- Create an osmud directory for OpenWRT at
lede/package/network/config/osmud
- Copy
osmud/openwrt_toolchain/Makefile
tolede/package/network/config/osmud/Makefile
- Run
make menuconfig
- Select osmud in under
Base System -> osmud
(move to the osmud line and hit "y" to include in the build) - Run
make package/network/config/osmud/compile
to compile only osMUD
This builds osMUD to be something like bin/packages/mips_24kc/base/osmud_1.0-1_mips_24kc.ipk
Note: Skip osmud-dnsmasq instructions until we have made the change for dnsmasq to read the DHCP MUD header option.
Install osmud-dnsmasq on the router
- Scp osmud to the router
scp osmud_1.0.0-1_mips_24kc.ipk root@192.168.1.1:/tmp/ osmud_1.0.0-1_mips_24kc.ipk
- Ensure you have updated the router
opkg update
- Install osmud
opkg install /tmp/osmud_1.0.0-1_mips_24kc.ipk
- For testing, Copy the file
osmud/test/textfile
to/var/log/dhcpmasq.txt
. This is the log file osMUD knows how to read containing DHCP events for osMUD processing. - If you need to add ca-certificates to the router (like lets encrypt) do the following:
- Download the intermediate cert (it gets the root cert by default too) https://letsencrypt.org/certs/lets-encrypt-x3-cross-signed.pem.txt and name it
lets-encrypt-x3-cross-signed.crt
- For more certs see: https://letsencrypt.org/certificates/
- Append the certificate to the router's ca-certificates:
cat lets-encrypt-x3-cross-signed.crt >> /etc/ssl/certs/ca-certificates.crt
- Download the intermediate cert (it gets the root cert by default too) https://letsencrypt.org/certs/lets-encrypt-x3-cross-signed.pem.txt and name it
- Copy the init.d script from osmud/src/openwrt/osmud into the file /etc/init.d/osmud on the router. This script by default uses this startup configuration:
- DNS_FILE_NAME_WITH_PATH="/var/state/osmud/dnswhitelist"
- MUD_FILE_DIRECTORY="/var/state/osmud/mudfiles/"
- BASECONFIGFILE="/var/etc/osmud.conf"
- DHCP_EVENT_FILE="/var/log/dhcpmasq.txt"
- PID_FILE="/var/run/osmud.pid"
- OSMUD_LOG_FILE="/var/log/osmud.log"
- Ensure the osmud startup script is executable
chmod 755 /etc/init.d/osmud
- Create the directory on the rounter
mkdir /etc/osmud
. - Install the file osmud/src/openwrt/create_ip_fw_rule.sh into /etc/osmud/create_ip_fw_rule.sh on the router.
- Make the firewall script executable using
chmod +x /etc/osmud/create_ip_fw_rule.sh
- Start the osmud service using the command line
service osmud start
or using UCI under the menu System->Startup - Verify the service has started using an ssh shell into the router and the command
ps | grep osmud
. You can also verify the startup looking at the log file with the command "cat /var/log/osmud.log".
You should see the MUD files and .p7s certs in /var/state/osmud/mudfiles/
when the osmud process is running and downloads a MUD file.
osMUD will poll for a log file which dnsmasq writes to. This file is located at /var/log/dhcpmasq.txt
. dnsmasq will write to this file after a device is connected to the DHCP server. This means when a device is new, old, or deleted to/from the DHCP server.
Edit /etc/dnsmasq.conf
to include the line dhcp-script=/etc/osmud/detect_new_device.sh
. This will allow dnsmasq to run the script after a device is connected to the DHCP server.
Note: You can find an example of this in /etc/osmud/dnsmasq.sample.conf
after you have installed osMUD (opkg install osmud).
The detect_new_device.sh script will log device information to /var/log/dhcpmasq.txt
when DHCP does something.
osMUD is currently immature. Here is a list of some important things to be aware of with the current state of osMUD
- Blocking process
- Does NOT implement MUD via LLDP
- Does NOT implement MUD via protocols supporting X509 certificates
- Reads DHCP input from text file
- Ignores MUD rules for lateral movement
- Must use OpenWRT Firewall
- Must use osmud-dnsmasq to read DHCP header option for MUD
- Run osMUD as non-blocking process
- DHCP client interface
- Firewall client interface
- Lateral movement will be locked down based on MUD file attributes
- Local MUD file support
- MUD file cache with cache expiration
We will be tackling the above limitations very soon.
View the milestones to see what is being worked on next!