Start a jail task which creates the zfs datasets and installs a new_jail script.

This commit is contained in:
Tom Alexander 2022-10-28 21:05:26 -04:00
parent 9bf06cc90e
commit 33d2118c15
Signed by: talexander
GPG Key ID: D3A179C9A53C0EDE
10 changed files with 160 additions and 21 deletions

View File

@ -35,3 +35,8 @@ users:
gitconfig: "gitconfig_home"
# devfs_rules: "odo_devfs.rules"
# devfs_system_ruleset: "localrules"
# jail_conf: "jail.conf"
jail_zfs_dataset: zroot/freebsd/release/jails
jail_zfs_dataset_mountpoint: /jail/main
jail_list:
- name: cloak

View File

@ -2,24 +2,25 @@
vars:
ansible_become: True
roles:
- sudo
- users
- package_manager
- zrepl
- zsh
- network
- sshd
- base
- firewall
- cpu
- ntp
- build
- graphics
- gpg
- fonts
- alacritty
- sway
- emacs
- firefox
- devfs
- ssh_client
# - sudo
# - users
# - package_manager
# - zrepl
# - zsh
# - network
# - sshd
# - base
# # - firewall
# - cpu
# - ntp
# - build
# - graphics
# - gpg
# - fonts
# - alacritty
# - sway
# - emacs
# - firefox
# - devfs
# - ssh_client
- jail

View File

@ -0,0 +1,14 @@
- import_tasks: tasks/freebsd.yaml
when: 'os_flavor == "freebsd"'
- import_tasks: tasks/linux.yaml
when: 'os_flavor == "linux"'
- include_tasks:
file: tasks/peruser.yaml
apply:
become: yes
become_user: "{{ initialize_user }}"
loop: "{{ users | dict2items | community.general.json_query('[?value.initialize==`true`].key') }}"
loop_control:
loop_var: initialize_user

View File

@ -0,0 +1,42 @@
- name: Create common zfs datasets
zfs:
name: "{{ item }}"
state: present
extra_zfs_properties:
mountpoint: "none"
loop: "{{ ((jail_list | community.general.json_query('[*].dataset')) + [jail_zfs_dataset]) | product(['', '/persistent', '/jails']) | map('join', '') }}"
- name: Create jail zfs datasets
zfs:
name: "{{ item.dataset|default(jail_zfs_dataset) }}/jails/{{ item.name }}"
state: present
extra_zfs_properties: '{{ {''mountpoint'': item.dataset_mountpoint|default(jail_zfs_dataset_mountpoint) + "/jails/" + item.name}|combine(item.properties|default({})) }}'
loop: "{{ jail_list }}"
- name: Create persistent jail zfs datasets
zfs:
name: "{{ item.dataset|default(jail_zfs_dataset) }}/persistent/{{ item.name }}"
state: present
extra_zfs_properties:
mountpoint: "none"
when: item.persist|default([])|length > 0
loop: "{{ jail_list }}"
- name: Create jail specific zfs datasets
zfs:
name: "{{ item.0.dataset|default(jail_zfs_dataset) }}/persistent/{{ item.0.name }}/{{ item.1.name }}"
state: present
extra_zfs_properties: '{{ {''mountpoint'': item.0.dataset_mountpoint|default(jail_zfs_dataset_mountpoint) + "/jails/" + item.0.name + item.1.mount }|combine(item.1.properties|default({})) }}'
loop: "{{ jail_list|subelements('persist', skip_missing=True) }}"
- name: Install scripts
template:
src: "templates/{{ item.src }}.j2"
dest: "{{ item.dest }}"
mode: 0755
owner: root
group: wheel
loop:
- src: new_jail.bash
dest: /usr/local/bin/new_jail

View File

@ -0,0 +1,6 @@
# - name: Install packages
# pacman:
# name:
# - foo
# state: present
# update_cache: true

View File

@ -0,0 +1,2 @@
- import_tasks: tasks/common.yaml
when: jail_zfs_dataset is defined and jail_zfs_dataset_mountpoint is defined

View File

@ -0,0 +1,29 @@
- include_role:
name: per_user
# - name: Create directories
# file:
# name: "{{ account_homedir.stdout }}/{{ item }}"
# state: directory
# mode: 0700
# owner: "{{ account_name.stdout }}"
# group: "{{ group_name.stdout }}"
# loop:
# - ".config/foo"
# - name: Copy files
# copy:
# src: "files/{{ item.src }}"
# dest: "{{ account_homedir.stdout }}/{{ item.dest }}"
# mode: 0600
# owner: "{{ account_name.stdout }}"
# group: "{{ group_name.stdout }}"
# loop:
# - src: foo.conf
# dest: .config/foo/foo.conf
- import_tasks: tasks/peruser_freebsd.yaml
when: 'os_flavor == "freebsd"'
- import_tasks: tasks/peruser_linux.yaml
when: 'os_flavor == "linux"'

View File

@ -0,0 +1,40 @@
#!/usr/bin/env bash
#
# Create a new jail
set -euo pipefail
IFS=$'\n\t'
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
: ${JAIL_MOUNTPOINT:="{{ jail_zfs_dataset_mountpoint }}/jails"}
function die {
echo >&2 "$@"
exit 1
}
[ "$#" -eq 2 ] || die "1 argument required, $# provided"
JAIL_NAME="$2"
export DESTDIR="${JAIL_MOUNTPOINT}/$JAIL_NAME"
function by_src {
cd /usr/src
make -j 16 buildworld
make installworld DESTDIR=$DESTDIR
make distribution DESTDIR=$DESTDIR
}
function by_bin {
DESTRELEASE=13.1-RELEASE
DESTARCH=`uname -m`
SOURCEURL=http://ftp.freebsd.org/pub/FreeBSD/releases/$DESTARCH/$DESTRELEASE/
for component in base ports; do fetch $SOURCEURL/$component.txz -o - | tar -xf - -C "$DESTDIR" ; done
}
if [ "$1" = "src" ]; then
by_src
elif [ "$1" = "bin" ]; then
by_bin
else
die "First argument must be either 'src' or 'bin', got $1"
fi