Readme and add local dir

This commit is contained in:
Christopher Laprise 2018-02-20 17:40:29 -05:00
parent 0990062511
commit 0745b42fab
No known key found for this signature in database
GPG Key ID: 448568C8B281C952
3 changed files with 34 additions and 12 deletions

View File

@ -1,26 +1,37 @@
# Qubes-VM-hardening # Qubes-VM-hardening
Enhancing Qubes VM security and privacy Enhancing Qubes VM security and privacy
### Pre-requisites:
Enabling authentication for sudo (see link below for Qubes doc).
--- ---
## vm-sudo-protect.service ## vm-sudo-protect.service
* Protect /home script files * Protect /home (user) executable files as immutable
* Remove /rw scripts at VM start * Deactivate /rw (root) executables
* Whitelisting for specifying persistent files
* SHA256 checksumming guards against unwanted changes
* Deploy custom defaut files
* Runs at VM start before /rw mounts
## Testing systemd version... ## Installing
Install the two files `vm-sudo-protect.sh` and `vm-sudo-protect.service` into template then use `systemctl` to enable the service. ### Pre-requisites:
Re-enable sudo authentication (see notes below).
Activate by specifying as a Qubes service for each VM; There are two levels... 1. In a template VM, install the two service files
1. `vm-sudo-protect` - similar to the rc.local script. Protects scripts within /home and may be used with wide array of VMs including standalone, netVMs and Whonix. ```
2. `vm-sudo-protect-root` - new feature which **erases** /rw/config, /rw/usrlocal and /rw/bind-dirs. Use with caution! This feature can also replace files on a global or per-VM basis... see script for details. Not recommended for standalone or VMs that rely on /rw root dirs such as netVMs or Whonix. $ sudo sh ./install
```
2. Activate by specifying as a Qubes service for each VM; There are two levels...
- `vm-sudo-protect` - Protects executables/scripts within /home/user and may be used with wide array of Qubes VMs including standalone, netVMs and Whonix.
- `vm-sudo-protect-root` - Protects /home/user as above, automatic /rw executable deactivation, whitelisting, checksumming, deployment. Works with appVMs, netVMs, etc. that are _template-based_.
**removes** dirs specified in $privdirs. Default is /rw/config, /rw/usrlocal and /rw/bind-dirs. Use with caution! This feature can also replace files on a global or per-VM basis... see script for details. Not recommended for standalone or VMs that rely on /rw root dirs such as netVMs or Whonix.
--- ---
## rc.local (old version) ## Releases
- v0.2.0 Protects /home/user files and dirs only
### Description: ### Description:
Placed in /etc/rc.local (or equivalent) of a template VM, this makes the shell init files immutable so PATH and alias cannot be used to hijack commands like su and sudo, nor can impostor apps autostart whenever a VM starts. I combed the dash and bash docs -- as well as Gnome, KDE, Xfce and X11 docs -- to address all the user-writable startup files that apply. Feel free to comment or create an issue if you see an omission or other problem. Placed in /etc/rc.local (or equivalent) of a template VM, this makes the shell init files immutable so PATH and alias cannot be used to hijack commands like su and sudo, nor can impostor apps autostart whenever a VM starts. I combed the dash and bash docs -- as well as Gnome, KDE, Xfce and X11 docs -- to address all the user-writable startup files that apply. Feel free to comment or create an issue if you see an omission or other problem.

11
install Normal file
View File

@ -0,0 +1,11 @@
#!/bin/sh
[ `id -u` -eq 0 ] || exit
cp vm-sudo-protect.sh /usr/lib/qubes/init
chmod +x /usr/lib/qubes/init/vm-sudo-protect.sh
cp vm-sudo-protect.service /lib/systemd/system
systemctl daemon-reload
systemctl enable vm-sudo-protect.service
echo vm-sudo-protect installed!

View File

@ -11,7 +11,7 @@
# to be protected # to be protected
chfiles=".bashrc .bash_profile .bash_login .bash_logout .profile \ chfiles=".bashrc .bash_profile .bash_login .bash_logout .profile \
.xprofile .xinitrc .xserverrc .xsession" .xprofile .xinitrc .xserverrc .xsession"
chdirs="bin .config/autostart .config/plasma-workspace/env \ chdirs="bin .local/bin .config/autostart .config/plasma-workspace/env \
.config/plasma-workspace/shutdown .config/autostart-scripts" .config/plasma-workspace/shutdown .config/autostart-scripts"
vmname=`qubesdb-read /name` vmname=`qubesdb-read /name`
rw=/mnt/rwtmp rw=/mnt/rwtmp
@ -24,7 +24,7 @@ make_immutable() {
touch $chfiles touch $chfiles
chattr -R -f +i $chfiles $chdirs chattr -R -f +i $chfiles $chdirs
cd /root cd /root
touch $rw/home/user/FIXED #debug #touch $rw/home/user/FIXED #debug
} }
# Mount private volume in temp location # Mount private volume in temp location