Added hardened Ubuntu guides
@ -0,0 +1,264 @@
|
|||||||
|
<!--
|
||||||
|
Title: How to setup hardened Ubuntu environment on Intel computer
|
||||||
|
Description: Learn how to setup air-gapped and non-persistent Ubuntu environment running on Intel computer.
|
||||||
|
Author: Sun Knudsen <https://github.com/sunknudsen>
|
||||||
|
Contributors: Sun Knudsen <https://github.com/sunknudsen>
|
||||||
|
Reviewers:
|
||||||
|
Publication date: 2023-02-13T21:06:22.975Z
|
||||||
|
Listed: true
|
||||||
|
-->
|
||||||
|
|
||||||
|
# How to setup hardened Ubuntu environment on Intel computer
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
The following hardware is required.
|
||||||
|
|
||||||
|
- Computer [compatible](https://ubuntu.com/download/desktop) with Ubuntu 22.04.1 LTS
|
||||||
|
- USB flash drive (used to create Ubuntu for desktops bootable installer, 4GB min)
|
||||||
|
- USB flash drive (used to install Ubuntu for desktops, 16GB min)
|
||||||
|
|
||||||
|
## Recommendations
|
||||||
|
|
||||||
|
Physically removing internal disk(s) and wireless interface(s) if not soldered to motherboard or disabling interface(s) using BIOS if soldered is recommended to strengthen data persistence and air gap hardening.
|
||||||
|
|
||||||
|
Installing Ubuntu for desktops on [datAshur PRO²](https://istorage-uk.com/product/datashur-pro2/) USB flash drive is recommended to enforce access control, data persistence and tamper resistance hardening.
|
||||||
|
|
||||||
|
## Bootable installer creation guide
|
||||||
|
|
||||||
|
### Step 1: install [Raspberry Pi Imager](https://www.raspberrypi.com/software/)
|
||||||
|
|
||||||
|
#### macOS
|
||||||
|
|
||||||
|
Go to https://www.raspberrypi.com/software/, download and install Raspberry Pi Imager.
|
||||||
|
|
||||||
|
#### Ubuntu (or other Debian-based OS)
|
||||||
|
|
||||||
|
> Heads-up: depends on [Qt](https://www.qt.io/).
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo add-apt-repository -y universe
|
||||||
|
|
||||||
|
$ sudo apt install -y rpi-imager
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 2: disable Raspberry Pi Imager [telemetry](https://github.com/raspberrypi/rpi-imager#telemetry)
|
||||||
|
|
||||||
|
#### macOS
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ defaults write org.raspberrypi.Imager.plist telemetry -bool NO
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Ubuntu (or other Debian-based OS)
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ mkdir -p ~/.config/Raspberry\ Pi
|
||||||
|
|
||||||
|
$ cat << "EOF" > ~/.config/Raspberry\ Pi/Imager.conf
|
||||||
|
[General]
|
||||||
|
telemetry=false
|
||||||
|
EOF
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 3: download [Ubuntu for desktops](https://ubuntu.com/desktop)
|
||||||
|
|
||||||
|
> Heads-up: for additional security, [verify](https://ubuntu.com/tutorials/how-to-verify-ubuntu) Ubuntu for desktops download.
|
||||||
|
|
||||||
|
Go to https://ubuntu.com/download/desktop and download Ubuntu 22.04.1 LTS.
|
||||||
|
|
||||||
|
### Step 4: create Ubuntu for desktops bootable installer
|
||||||
|
|
||||||
|
Open “Raspberry Pi Imager”, click “CHOOSE OS”, then “Use custom”, select Ubuntu for desktops `.iso`, click “CHOOSE STORAGE”, select USB flash drive and, finally, click “WRITE”.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/79a21/79a2151136e1b02228d26cb02d89acb5d744733d" alt="Raspberry Pi Imager"
|
||||||
|
|
||||||
|
👍
|
||||||
|
|
||||||
|
## Installation guide
|
||||||
|
|
||||||
|
### Step 1 (optional): physically remove internal disk(s)
|
||||||
|
|
||||||
|
### Step 2 (optional): initialize datAshur PRO² and enable bootable mode (see product [documentation](https://istorage-uk.com/product-documentation/) for instructions)
|
||||||
|
|
||||||
|
### Step 3: insert both USB flash drives into computer
|
||||||
|
|
||||||
|
### Step 4 (if applicable): enable “Secure Boot” and disable “Boot Order Lock”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/b0133/b013395b25f9be05f46aea896f039303e3396f5b" alt="Secure Boot"
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/7d962/7d962ffc0725d21bd2451fa02f8213756260fc72" alt="Boot Order Lock"
|
||||||
|
|
||||||
|
### Step 5: boot to Ubuntu for desktops bootable installer and select “Try or Install Ubuntu”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/e0283/e028399ae25f89816298a067b6459c0ec7286439" alt="Try or Install Ubuntu"
|
||||||
|
|
||||||
|
### Step 6: connect Ethernet cable or connect to Wi-Fi network
|
||||||
|
|
||||||
|
### Step 7: install Ubuntu
|
||||||
|
|
||||||
|
#### Click “Install Ubuntu”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/1df5d/1df5d1abb70f46704aece01e3d3da2e7aa5386c0" alt="Install Ubuntu"
|
||||||
|
|
||||||
|
#### Choose keyboard layout and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/4797b/4797b042ed1b79acefb1dae79c6239a6965eee82" alt="Keyboard layout"
|
||||||
|
|
||||||
|
#### Select “Minimal installation” and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/124cc/124ccc5bd1ebe053cdfb6a2194f919c32992b647" alt="Updates and other software"
|
||||||
|
|
||||||
|
#### Select “Something else” and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/eb5d0/eb5d089cc88a3c9d755557be28390bd582ff8afb" alt="Installation type"
|
||||||
|
|
||||||
|
#### Delete all partitions on USB flash drive on which Ubuntu for desktops is being installed
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/ecbc1/ecbc1f0e0e3765e73d64687cf54169aca73f9bc9" alt="Delete partitions"
|
||||||
|
|
||||||
|
#### Create 512MB EFI partition on USB flash drive on which Ubuntu for desktops is being installed
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/7cea2/7cea24544245fc18012605f53cd3a439edbe61a3" alt="EFI partition"
|
||||||
|
|
||||||
|
#### Create ext4 partition and set mount point to `/` on USB flash drive on which Ubuntu for desktops is being installed
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/cb3f9/cb3f949de8feb5e59c4685f348946b32384734f2" alt="ext4 partition"
|
||||||
|
|
||||||
|
#### Choose “Device for boot loader installation” and click “Install now”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/c6402/c6402eebf149d3a50758030e8a2b868c06de7938" alt="Install now"
|
||||||
|
|
||||||
|
#### Confirm changes about to be written to disk and click “Continue”
|
||||||
|
|
||||||
|
> WARNING: make sure changes only apply to USB flash drive on which Ubuntu for desktops is being installed.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/71a75/71a75890a6eecbac67b6768825b0bf4ef711e12b" alt="Write the changes to disk"
|
||||||
|
|
||||||
|
#### Choose timezone and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/eba56/eba56d555df9b68ea861ba5de962dbad3f4387c7" alt="Where are you"
|
||||||
|
|
||||||
|
#### Choose credentials, select “Log in automatically” (optional) and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/3ccf6/3ccf655c29bfc9eec3f31deba46b55b566d97ebe" alt="Who are you"
|
||||||
|
|
||||||
|
#### Reboot
|
||||||
|
|
||||||
|
## Configuration guide
|
||||||
|
|
||||||
|
### Step 1: disable telemetry
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/f9421/f94217ddbbe4c3492cbc55f447d201af05e1aeb6" alt="Help improve Ubuntu"
|
||||||
|
|
||||||
|
### Step 2: run `update-manager` and click “Install Now”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/ba2c6/ba2c625b422fba0d5f91729ec31678d9c8b0eec4" alt="Software Updater"
|
||||||
|
|
||||||
|
### Step 3: reboot
|
||||||
|
|
||||||
|
### Step 4 (if applicable): enable “Boot Order Lock”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/76449/76449f7e98499ab1be7755fabd22bd9c8fd8630d" alt="Boot Order Lock"
|
||||||
|
|
||||||
|
### Step 5 (optional): center new windows
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ gsettings set org.gnome.mutter center-new-windows true
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 6 (optional): enable dark mode
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ gsettings set org.gnome.desktop.interface color-scheme prefer-dark
|
||||||
|
|
||||||
|
$ gsettings set org.gnome.desktop.interface gtk-theme Yaru-dark
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 7: disable auto-mount
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ gsettings set org.gnome.desktop.media-handling automount false
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 8: add `universe` APT repository
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo add-apt-repository -y universe
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 9: install `curl`, `libfuse2`, `overlayroot` and `zbar-tools`
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo apt install -y curl libfuse2 overlayroot zbar-tools
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 10 (if applicable): download [Superbacked](https://superbacked.com/) and allow executing `superbacked.AppImage` as program
|
||||||
|
|
||||||
|
#### Download Superbacked
|
||||||
|
|
||||||
|
> Heads-up: replace `ABCDEFGH` with your license code.
|
||||||
|
|
||||||
|
> Heads-up: for additional security, [verify](/faq/release-integrity) Superbacked download.
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ curl --fail --location --output ~/Desktop/superbacked.AppImage "https://superbacked.com/api/downloads/superbacked-std-x64-latest.AppImage?license=ABCDEFGH"
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Allow executing `superbacked.AppImage` as program
|
||||||
|
|
||||||
|
Right-click “superbacked.AppImage”, click “Properties”, click “Permissions” and, finally, select “Allow executing file as program”.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/ad431/ad43100c76f78cebd402a983f43b5e1f21be8615" alt="Allow executing file as program"
|
||||||
|
|
||||||
|
### Step 11: set `ext4` and `vfat` filesystems to read-only
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo sed -i 's/errors=remount-ro/errors=remount-ro,noload,ro/g' /etc/fstab
|
||||||
|
|
||||||
|
$ sudo sed -i 's/umask=0077/umask=0077,ro/g' /etc/fstab
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 12: disable `fsck.repair`
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo sed -i 's/quiet splash/quiet splash fsck.repair=no/g' /etc/default/grub
|
||||||
|
|
||||||
|
$ sudo update-grub
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 13: set `overlayroot` to `tmpfs`
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo sed -i 's/overlayroot=""/overlayroot="tmpfs"/g' /etc/overlayroot.conf
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 14: clear Bash history
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ history -cw
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 15: reboot
|
||||||
|
|
||||||
|
> Heads-up: filesystem will be mounted as read-only following reboot.
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo systemctl reboot
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 16: shutdown
|
||||||
|
|
||||||
|
> Heads-up: filesystem is ready for optional hardware read-only hardening.
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo systemctl poweroff
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 17 (optional): physically remove internal disk(s) and wireless interface(s) if not soldered to motherboard or disable interface(s) using BIOS if soldered
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/25204/2520461bf32b37a288fa05ddb83e7230e1974bf2" alt="Disable interfaces"
|
||||||
|
|
||||||
|
### Step 18 (optional): enable datAshur PRO² global read-only (see product [documentation](https://istorage-uk.com/product-documentation/) for instructions)
|
||||||
|
|
||||||
|
👍
|
After Width: | Height: | Size: 91 KiB |
After Width: | Height: | Size: 114 KiB |
After Width: | Height: | Size: 172 KiB |
After Width: | Height: | Size: 208 KiB |
After Width: | Height: | Size: 117 KiB |
After Width: | Height: | Size: 172 KiB |
After Width: | Height: | Size: 208 KiB |
After Width: | Height: | Size: 123 KiB |
After Width: | Height: | Size: 100 KiB |
After Width: | Height: | Size: 119 KiB |
After Width: | Height: | Size: 108 KiB |
After Width: | Height: | Size: 88 KiB |
After Width: | Height: | Size: 137 KiB |
After Width: | Height: | Size: 124 KiB |
After Width: | Height: | Size: 95 KiB |
After Width: | Height: | Size: 116 KiB |
After Width: | Height: | Size: 132 KiB |
After Width: | Height: | Size: 56 KiB |
After Width: | Height: | Size: 114 KiB |
After Width: | Height: | Size: 125 KiB |
After Width: | Height: | Size: 108 KiB |
After Width: | Height: | Size: 132 KiB |
@ -0,0 +1,214 @@
|
|||||||
|
<!--
|
||||||
|
Title: How to setup hardened Ubuntu environment on Raspberry Pi
|
||||||
|
Description: Learn how to setup air-gapped and non-persistent Ubuntu environment running on Raspberry Pi.
|
||||||
|
Author: Sun Knudsen <https://github.com/sunknudsen>
|
||||||
|
Contributors: Sun Knudsen <https://github.com/sunknudsen>
|
||||||
|
Reviewers:
|
||||||
|
Publication date: 2023-02-13T21:05:15.462Z
|
||||||
|
Listed: true
|
||||||
|
-->
|
||||||
|
|
||||||
|
# How to setup hardened Ubuntu environment on Raspberry Pi
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
The following hardware is required.
|
||||||
|
|
||||||
|
- [Raspberry Pi 4](https://www.raspberrypi.com/products/raspberry-pi-4-model-b/) (2GB min)
|
||||||
|
- Raspberry Pi [15W USB-C Power Supply](https://www.raspberrypi.com/products/type-c-power-supply/)
|
||||||
|
- Raspberry Pi [keyboard](https://www.raspberrypi.com/products/raspberry-pi-keyboard-and-hub/) and [mouse](https://www.raspberrypi.com/products/raspberry-pi-mouse/) (or equivalent)
|
||||||
|
- Raspberry Pi [Micro HDMI to Standard HDMI (A/M) Cable](https://www.raspberrypi.com/products/micro-hdmi-to-standard-hdmi-a-cable/) (or equivalent)
|
||||||
|
- microSD card or USB flash drive (used to install Ubuntu for desktops, 16GB min)
|
||||||
|
- HDMI display (720p min)
|
||||||
|
|
||||||
|
## Recommendations
|
||||||
|
|
||||||
|
Installing Ubuntu for desktops on [datAshur PRO²](https://istorage-uk.com/product/datashur-pro2/) USB flash drive is recommended to enforce access control, data persistence and tamper resistance hardening.
|
||||||
|
|
||||||
|
## Bootable installer creation guide
|
||||||
|
|
||||||
|
### Step 1: install [Raspberry Pi Imager](https://www.raspberrypi.com/software/)
|
||||||
|
|
||||||
|
#### macOS
|
||||||
|
|
||||||
|
Go to https://www.raspberrypi.com/software/, download and install Raspberry Pi Imager.
|
||||||
|
|
||||||
|
#### Ubuntu (or other Debian-based OS)
|
||||||
|
|
||||||
|
> Heads-up: depends on [Qt](https://www.qt.io/).
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo add-apt-repository -y universe
|
||||||
|
|
||||||
|
$ sudo apt install -y rpi-imager
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 2: disable Raspberry Pi Imager [telemetry](https://github.com/raspberrypi/rpi-imager#telemetry)
|
||||||
|
|
||||||
|
#### macOS
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ defaults write org.raspberrypi.Imager.plist telemetry -bool NO
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Ubuntu (or other Debian-based OS)
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ mkdir -p ~/.config/Raspberry\ Pi
|
||||||
|
|
||||||
|
$ cat << "EOF" > ~/.config/Raspberry\ Pi/Imager.conf
|
||||||
|
[General]
|
||||||
|
telemetry=false
|
||||||
|
EOF
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 3: download [Ubuntu for desktops](https://ubuntu.com/desktop)
|
||||||
|
|
||||||
|
> Heads-up: for additional security, [verify](https://ubuntu.com/tutorials/how-to-verify-ubuntu) Ubuntu for desktops download.
|
||||||
|
|
||||||
|
Go to https://ubuntu.com/download/raspberry-pi and download Ubuntu Desktop 22.04.1 LTS.
|
||||||
|
|
||||||
|
### Step 4: copy Ubuntu for desktops to USB flash drive
|
||||||
|
|
||||||
|
Open “Raspberry Pi Imager”, click “CHOOSE OS”, then “Use custom”, select Ubuntu for desktops `.img.xz`, click “CHOOSE STORAGE”, select USB flash drive and, finally, click “WRITE”.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/79a21/79a2151136e1b02228d26cb02d89acb5d744733d" alt="Raspberry Pi Imager"
|
||||||
|
|
||||||
|
👍
|
||||||
|
|
||||||
|
## Installation guide
|
||||||
|
|
||||||
|
### Step 1: choose language and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/e7214/e72140cf87f7d7c135153dc6b37483b34ee209ea" alt="Welcome"
|
||||||
|
|
||||||
|
### Step 2: choose keyboard layout and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/4797b/4797b042ed1b79acefb1dae79c6239a6965eee82" alt="Keyboard layout"
|
||||||
|
|
||||||
|
### Step 3: choose timezone and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/eba56/eba56d555df9b68ea861ba5de962dbad3f4387c7" alt="Where are you"
|
||||||
|
|
||||||
|
### Step 4: choose credentials, select “Log in automatically” (optional) and click “Continue”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/3ccf6/3ccf655c29bfc9eec3f31deba46b55b566d97ebe" alt="Who are you"
|
||||||
|
|
||||||
|
👍
|
||||||
|
|
||||||
|
## Configuration guide
|
||||||
|
|
||||||
|
### Step 1: disable telemetry
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/f9421/f94217ddbbe4c3492cbc55f447d201af05e1aeb6" alt="Help improve Ubuntu"
|
||||||
|
|
||||||
|
### Step 2: run `update-manager` and click “Install Now”
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/ba2c6/ba2c625b422fba0d5f91729ec31678d9c8b0eec4" alt="Software Updater"
|
||||||
|
|
||||||
|
### Step 3: reboot
|
||||||
|
|
||||||
|
### Step 4 (optional): center new windows
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ gsettings set org.gnome.mutter center-new-windows true
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 5 (optional): enable dark mode
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ gsettings set org.gnome.desktop.interface color-scheme prefer-dark
|
||||||
|
|
||||||
|
$ gsettings set org.gnome.desktop.interface gtk-theme Yaru-dark
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 6: disable auto-mount
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ gsettings set org.gnome.desktop.media-handling automount false
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 7: add `universe` APT repository
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo add-apt-repository -y universe
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 8: install `curl`, `libfuse2`, `overlayroot`, `zbar-tools` and `zlib1g-dev`
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo apt install -y curl libfuse2 overlayroot zbar-tools zlib1g-dev
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 9 (if applicable): download [Superbacked](https://superbacked.com/) and allow executing `superbacked.AppImage` as program
|
||||||
|
|
||||||
|
#### Download Superbacked
|
||||||
|
|
||||||
|
> Heads-up: replace `ABCDEFGH` with your license code.
|
||||||
|
|
||||||
|
> Heads-up: for additional security, [verify](/faq/release-integrity) Superbacked download.
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ curl --fail --location --output ~/Desktop/superbacked.AppImage "https://superbacked.com/api/downloads/superbacked-std-arm64-latest.AppImage?license=ABCDEFGH"
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Allow executing `superbacked.AppImage` as program
|
||||||
|
|
||||||
|
Right-click “superbacked.AppImage”, click “Properties”, click “Permissions” and, finally, select “Allow executing file as program”.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/ad431/ad43100c76f78cebd402a983f43b5e1f21be8615" alt="Allow executing file as program"
|
||||||
|
|
||||||
|
### Step 10: disable Bluetooth and Wi-Fi
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ cat << "EOF" | sudo tee -a /boot/firmware/config.txt
|
||||||
|
dtoverlay=disable-bt
|
||||||
|
dtoverlay=disable-wifi
|
||||||
|
EOF
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 11: set `ext4` and `vfat` filesystems to read-only
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo sed -i 's/discard,x-systemd.growfs/discard,noload,ro/g' /etc/fstab
|
||||||
|
|
||||||
|
$ sudo sed -i 's/defaults/defaults,ro/g' /etc/fstab
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 12: disable `fsck.repair`
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo sed -i 's/splash/splash fsck.repair=no/g' /boot/firmware/cmdline.txt
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 13: set `overlayroot` to `tmpfs`
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo sed -i 's/overlayroot=""/overlayroot="tmpfs"/g' /etc/overlayroot.conf
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 14: clear Bash history
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ history -cw
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 15: reboot
|
||||||
|
|
||||||
|
> Heads-up: filesystem will be mounted as read-only following reboot.
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo systemctl reboot
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 16: shutdown
|
||||||
|
|
||||||
|
> Heads-up: filesystem is ready for optional hardware read-only hardening.
|
||||||
|
|
||||||
|
```shell-session
|
||||||
|
$ sudo systemctl poweroff
|
||||||
|
```
|
||||||
|
|
||||||
|
### Step 17 (optional): enable datAshur PRO² global read-only (see product [documentation](https://istorage-uk.com/product-documentation/) for instructions)
|
||||||
|
|
||||||
|
👍
|
After Width: | Height: | Size: 94 KiB |
After Width: | Height: | Size: 114 KiB |
After Width: | Height: | Size: 100 KiB |
After Width: | Height: | Size: 110 KiB |
After Width: | Height: | Size: 126 KiB |
After Width: | Height: | Size: 98 KiB |
After Width: | Height: | Size: 120 KiB |
After Width: | Height: | Size: 131 KiB |
After Width: | Height: | Size: 95 KiB |
After Width: | Height: | Size: 98 KiB |
After Width: | Height: | Size: 90 KiB |