{{Header}}
{{#seo:
|description=MAC Address Spoofing and Tracking Threats
|image=MACaddress2131.jpg
}}
[[File:MACaddress2131.jpg|thumb]]
{{intro|
MAC Address Spoofing and Tracking Threats
}}
= Introduction =
All network cards, both wired and wireless, have a unique identifier called a {{Code2|MAC address}}. [https://en.wikipedia.org/wiki/MAC_address] MAC addresses are stored in hardware and are used to assign an address to computers on the local network.
The MAC address is normally not traceable because it is not passively sent to computers beyond the local router. [Unless the computer is infected with [https://en.wikipedia.org/wiki/Malware malware] designed to disclose this identifier.] However, other computers on the local network can potentially log it, which would then provide proof the user's computer connected to that specific network. If users intend to use an untrusted, public network then {{Code2|MAC spoofing}} should be considered. [https://en.wikipedia.org/wiki/MAC_spoofing]
= MAC Spoofing Warning =
{{mbox
| image = [[File:Ambox_warning_pn.svg.png|40px]]
| text =
'''Warning:''' According to recent research, MAC address spoofing is not effective against advanced tracking techniques that can still enumerate the address by inspecting the physical characteristics of the Wi-Fi card. [[https://papers.mathyvanhoef.com/asiaccs2016.pdf Why MAC Address Randomization is not Enough: An Analysis of Wi-Fi Network Discovery Mechanisms]] Unfortunately, a viable solution requires manufacturers to modify drivers or firmware of their hardware products to add privacy preserving mitigations.
}}
== Auto-connect Risk ==
Apart from the difficulty in creating an appropriate MAC address for spoofing purposes, there are also technical hurdles to overcome in the form of preventing automatic network connections.
It is futile to prepare a spoofed MAC address if the computer instantly connects to the public network after booting, disclosing the user's real MAC address in the process:
* {{project_name_gateway_long}} as a host: {{project_name_gateway_long}} automatically connects to the internet after start.
* USB Wi-FI Device: Automatic connections might also occur, depending on the configuration.
== Burner Wi-Fi USB Sticks ==
One immediate workaround for the Wi-Fi card profiling threat is to buy new "burner" Wi-Fi USB sticks from different manufacturers. Take care to disable the computer's native Wi-Fi functionality in the BIOS settings if pursuing this option -- the computer's characteristics will have likely been logged if it was ever used from an untrusted hotspot. Burner devices should only be enabled for connectivity at the intended public destination. If this advice is ignored and burner devices are used for network connections at locations tied to or regularly visited by the user, this will defy the original purpose. A different burner stick should be used for each new location to avoid geographical profiling / tracking.
== Random MAC Addresses ==
{{mbox
| image = [[File:Ambox_warning_pn.svg.png|40px]]
| text =
'''Warning:''' Using a completely random MAC address is not recommended. While this technique might be sufficient to confuse lesser adversaries, it will not defeat skilled adversaries.
}}
The problem with using a random MAC address is that the chosen vendor ID may be non-existent. Even if it exists, it is possible to end up with a vendor ID which has either never been used or not for decades. When spoofing MAC addresses, it is critical to use a popular vendor ID. The initial, second part of the MAC address can safely be random or unique. [Also note that if MAC address changing is always enabled, it might cause connectivity problems on some networks.]
Research on this issue is still ongoing. At present, {{project_name_short}} cannot provide detailed instructions on how to create appropriate MAC addresses fulfilling the criteria above.
= Other Location Tracking Risks =
== Authentication Fingerprinting Techniques ==
An authentication technique can fingerprint devices by observing inter-packet timings on a LAN's wire-segment; one side effect is that user devices can be tracked. The timing effects are the result of how various components in a machine create packets. [[https://nweb.eng.fiu.edu/selcuk/papers/uluagac-gtid-cns-13.pdf A Passive Technique for Fingerprinting Wireless Devices with Wired-side Observations]] Fortunately, this technique cannot be used to identify devices across the Internet. [The primary weakness of this technique is that it relies on fine-grained packet timing; timing that is lost as a result of buffering in switches and routers. Therefore, this technique and similar methods are not suited for identification across the Internet. Rather, it is perfectly suited for the significant challenge of local network access control and other local network activities like counterfeit detection.]
This technique can be defeated by inducing random delays in a machine's packet stream. Since there is no problem with impersonating other devices on the LAN, it does not matter that such an authentication system will view these machines as "unknown". [Figure 7(a) shows attackers that can vary their packet sizes, change their data rate, and tunnel their packets through another protocol. Figure 7(b) presents attackers that can introduce constant or random delays to the packet stream and load the CPU with intensive applications to overshadow normal behavior. Figure 7(c) shows an attacker that can modify or change its operating system. GTID (the passive fingerprinting method) detects these attacks and classifies all of these devices that generated attack traffic from previously seen devices as unknown.] Note also that spectrum analyzers have been used to fingerprint the unique electromagnetic (EM) characteristics of a Wi-Fi card. The disposable USB Wi-Fi workaround described further above would mitigate this attack. [There have also been physical layer approaches to fingerprinting wireless devices. Radio frequency (RF) emitter fingerprinting uses the distinct EM characteristics that arise from differences in circuit topology and manufacturing tolerances. This approach has a history of use in cellular systems and has more recently been applied to Wi-Fi and Bluetooth emitters. The EM properties fingerprint the unique transmitter of a signal and these differ from emitter to emitter. This technique requires expensive signal analyzer hardware to be within RF range of the target.]
= MAC Spoofing on Different Networks =
== Home Connections ==
{{mbox
| type = notice
| image = [[File:Ambox_notice.png|40px|alt=Info]]
| text = '''Tip:''' MAC address changes for home connections are not required.
}}
{{mbox
| image = [[File:Ambox_warning_pn.svg.png|40px]]
| text =
'''Warning:''' This recommendation comes with an important caveat. If a browser exploit is successfully used to reveal activities outside a VM, then the physical MAC address might be discovered by the attacker. If a user is already under suspicion, this would eventually provide proof of identity. In this scenario, if the MAC address was changed beforehand, then root access is required to discover the real physical address (this has not yet been tested).
}}
=== Connectivity Risk ===
If the user's home network has a cable modem internet connection, the ISP either provides the cable modem device as part of the service or requires pre-registration of the MAC address of the self-provided cable modem in order to setup the service.
If a user manages to hack or change the MAC address of the modem, the service would immediately cease functioning because the IP address assignment is apportioned for, and bound to, that specific MAC address. As a result, when connecting from behind a cable modem/NAT router, MAC address spoofing of the computer's ethernet adapter may be pointless. If a user is traced, the trackable endpoint will be the MAC address of the cable modem device.
== Public Computers ==
{{mbox
| type = notice
| image = [[File:Ambox_notice.png|40px|alt=Info]]
| text = This refers to use of computers in public places like libraries and Internet cafes.
}}
The MAC address should not be changed in this scenario, otherwise it may bring undesired administrator attention to the service/user and/or simply prevent access to the Internet.
= Changing MAC Addresses =
== Kicksecure ==
TODO: please help to test and improve these instructions.
{{Box|text=
'''1.''' Edit the network interfaces file.
* users: Edit ''/etc/network/interfaces''
'''2.''' Install macchanger.
In a terminal, run.
{{CodeSelect|code=
su
}}
{{CodeSelect|code=
apt update && apt install macchanger
}}
'''3.''' Change the MAC address.
{{mbox
| type = notice
| image = [[File:Ambox_notice.png|40px|alt=Info]]
| text = The following steps will manually change the MAC address for the device. An example is provided for a wireless device (wlan0
). Replace wlan0
to match the device being spoofed, such as an ethernet device (eth0
) and so on.
}}
{{CodeSelect|code=
su
}}
{{CodeSelect|code=
ifconfig wlan0 down
}}
{{CodeSelect|code=
macchanger -a wlan0
}}
{{CodeSelect|code=
ifconfig wlan0 up
}}
If instructions from Step 1+ did not work, the following steps might also work without macchanger. Replace wlan0
to match the specific device.
{{CodeSelect|code=
su
}}
{{CodeSelect|code=
ifconfig wlan0 down
}}
{{CodeSelect|code=
ifconfig wlan0 hw ether 00:AA:BB:CC:DD:EE
}}
{{CodeSelect|code=
ifconfig wlan0 up
}}
Or use iproute2 commands to change the MAC address.
{{CodeSelect|code=
ip link set down wlan0
}}
{{CodeSelect|code=
ip link set wlan0 address 00:AA:BB:CC:DD:EE
}}
{{CodeSelect|code=
ip link set up wlan0
}}
'''4.''' Complete the MAC address change.
Below iface eth0 inet dhcp
, add.
{{CodeSelect|code=
hwaddress ether 00:00....
}}
'''5.''' ''Optional:'' Automatically randomize the MAC address on boot.
If this is desired, add.
{{CodeSelect|code=
pre-up macchanger -e eth0
}}
'''6.''' Change new network interfaces settings.
To prevent new network interfaces being brought up automatically, comment the following.
{{CodeSelect|code=
auto eth0
}}
Then configure manual bring ups with the following setting.
{{CodeSelect|code=
sudo ifup eth0
}}
}}
== Qubes Hosts ==
{{mbox
| type = notice
| image = [[File:Ambox_notice.png|40px|alt=Info]]
| text = Qubes OS does not currently "anonymize" or spoof the MAC address automatically in all cases.
}}
Qubes users can manually change MAC addresses in the NetVM by following either the Network Manager or macchanger guides. [https://github.com/QubesOS/qubes-issues/issues/938 MAC Address Randomization capability for Wi-Fi] has been implemented.
[https://github.com/QubesOS/qubes-core-agent-linux/pull/297 network: enable MAC randomization for wifi connections by default] was implemented.
{{quotation
|quote=This is currently applied by Debian and Fedora templates only.
|context=https://github.com/QubesOS/qubes-issues/issues/938#issuecomment-1221605861
}}
{{quotation
|quote=ethernet mac randomization by default, which was denied.
|context=https://github.com/QubesOS/qubes-issues/issues/938#issuecomment-1300587911
}}
{{quotation
|quote=Consequently, users wanting ethernet mac randomization will need to modify their templates manually, and in all new downloaded templates after OEL deprecation,
|context=https://github.com/QubesOS/qubes-issues/issues/938#issuecomment-1300587911
}}
Refer to the following Qubes documentation and related support items for further information and advice:
* [https://github.com/Qubes-Community/Contents/blob/master/docs/privacy/anonymizing-your-mac-address.md Qubes documentation: Anonymizing your MAC Address]
* [https://groups.google.com/g/qubes-users/c/gUPK-YqkC3E/m/WsarnjrddrsJ Qubes-Users forum: Instructions for Installing Macchanger Needed]
* [https://github.com/QubesOS/qubes-issues/issues/2361 Explore local network privacy solutions beyond MAC address randomization]
== Sources ==
See footnote. [
* https://tails.boum.org/contribute/design/MAC_address/
* https://gitlab.tails.boum.org/tails/tails/-/issues/5421
* https://gitlab.tails.boum.org/tails/blueprints/-/wikis/macchanger/
* Worth reading! Thanks to Tails!
* [[Dev/MAC]]
]
= References =
{{reflist|close=1}}
= License =
{{License_Amnesia|{{FULLPAGENAME}}}}
{{Footer}}
[[Category:Documentation]]