summaryrefslogtreecommitdiff
path: root/others/vm3/.config
diff options
context:
space:
mode:
authorroot <root@sg1.noml.ch>2025-05-22 18:36:01 +0800
committerroot <root@sg1.noml.ch>2025-05-22 18:36:01 +0800
commit3a52e92fbbbab4df949740f89a389d68281a9428 (patch)
tree5cb3b864eb0e3f3b90a1efd9cbdee1fb9f158f4a /others/vm3/.config
parent8cb260002db7c46ea5fe2c3f589b485e5f5d970d (diff)
Diffstat (limited to 'others/vm3/.config')
-rwxr-xr-xothers/vm3/.config/cloud-init-generator/debian12.sh67
-rwxr-xr-xothers/vm3/.config/cloud-init-generator/fedora40.sh105
-rwxr-xr-xothers/vm3/.config/cloud-init-generator/freebsd14.0.sh75
-rwxr-xr-xothers/vm3/.config/cloud-init-generator/freebsd14.0.shbackup59
-rw-r--r--others/vm3/.config/cloud-init-generator/rocky9.0.sh53
-rwxr-xr-xothers/vm3/.config/cloud-init-generator/ubuntu24.04.sh62
-rwxr-xr-xothers/vm3/.config/init/install_packages.sh12
-rwxr-xr-xothers/vm3/.config/init/make_rootkey.sh4
8 files changed, 0 insertions, 437 deletions
diff --git a/others/vm3/.config/cloud-init-generator/debian12.sh b/others/vm3/.config/cloud-init-generator/debian12.sh
deleted file mode 100755
index 6bfa54b..0000000
--- a/others/vm3/.config/cloud-init-generator/debian12.sh
+++ /dev/null
@@ -1,67 +0,0 @@
1#!/bin/bash
2# generates user data, meta data, and seed.iso for cloud init. for debian
3# requires the name of the vm as an argument
4#
5# osinfo-query os to list all available vm types to deploy. debian is debian12
6# use no cloud and some other tools because cloud init does not work
7#
8#qemu-img resize debian-11-generic-amd64.qcow2 +10G # try this if you want to install something big like kde
9# sudo apt update
10# sudo apt install kde-plasma-desktop
11
12#
13image_url="https://cloud.debian.org/images/cloud/bookworm/latest/debian-12-nocloud-amd64.qcow2"
14sshkeysdir="/root/k"
15scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" #&& echo $scriptdir
16dir_path="/var/lib/libvirt/images/.image_store"
17src_file="${dir_path}/debian12.qcow2"
18config_dir="/var/lib/libvirt/images/.temp"
19user_data="${config_dir}/user-data"
20meta_data="${config_dir}/meta-data"
21seed_iso="${config_dir}/seed.iso"
22# note that cloud init specifically looks for "user-data" and "meta-data" in the seed.iso disk. do not deviate from the naming convention.
23if [ $# -ne 1 ]; then
24 echo "Usage: $0 <vm-name>"
25 exit 1
26fi
27sudo mkdir -p "$dir_path" # make image store dir
28sudo mkdir -p "$config_dir"
29
30[ ! -f "$src_file" ] && echo "source image does not exist! downloading..." && sudo wget -O "$src_file" "$image_url"
31
32# generate all the lines from the file
33SSH_INJECT_OPTS=$(find ${sshkeysdir} -name "*.pub" -exec echo "--ssh-inject user:file:{}" \;)
34
35flag_file="${dir_path}/debian12_customized"
36
37# NOTE to delete customfile if debqcow2 is deleted. otherwise it will be ambiguous
38# this to check if image is already customised
39if [ -f "$flag_file" ]; then
40 echo "Image already customized, skipping customization..."
41else
42 echo "Customizing image..."
43 # to install virt customise tool
44 sudo dnf install -y libguestfs libguestfs-tools libvirt virt-install virt-manager guestfs-tools
45 export LIBGUESTFS_BACKEND=direct
46 sudo -E virt-customize -a /var/lib/libvirt/images/.image_store/debian12.qcow2 \
47 --run-command 'useradd -m -s /bin/bash user' \
48 $SSH_INJECT_OPTS \
49 --update \
50 --install openssh-server,git,cloud-guest-utils,tmux \
51 --run-command 'echo "user ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers.d/user' \
52 --run-command 'sed -i "s/PermitRootLogin yes/PermitRootLogin no/" /etc/ssh/sshd_config' \
53 --run-command 'sed -i "s/#PasswordAuthentication yes/PasswordAuthentication no/" /etc/ssh/sshd_config' \
54 --run-command 'cd /home/user && git clone https://git.0nom.ch/keys && chown -R user:user keys && sudo -u user ./keys/add-ssh-keys.sh' \
55 --run-command 'tee -a /etc/bash.bashrc > /dev/null << "EOF"
56LS_COLORS=$LS_COLORS:'\''di=38;5;135:ex=00;32:'\'' ; export LS_COLORS
57PS1='\''[\[\033[01;32m\]\u\[\033[00m\]@\h \[\033[38;5;135m\]\W\[\033[00m\]]\$ '\''
58EOF' \
59 --run-command 'tee -a /home/user/.bashrc > /dev/null << "EOF"
60LS_COLORS=$LS_COLORS:'\''di=38;5;135:ex=00;32:'\'' ; export LS_COLORS
61PS1='\''[\[\033[01;32m\]\u\[\033[00m\]@\h \[\033[38;5;135m\]\W\[\033[00m\]]\$ '\''
62EOF' \
63 --run-command 'echo "sudo growpart /dev/vda 1 && sudo resize2fs /dev/vda1 && source /etc/bash.bashrc" > /home/user/start.sh && chmod +x /home/user/start.sh' && \
64
65 # Create flag file after successful customization
66 sudo touch "$flag_file"
67fi
diff --git a/others/vm3/.config/cloud-init-generator/fedora40.sh b/others/vm3/.config/cloud-init-generator/fedora40.sh
deleted file mode 100755
index bd3e0c3..0000000
--- a/others/vm3/.config/cloud-init-generator/fedora40.sh
+++ /dev/null
@@ -1,105 +0,0 @@
1#!/bin/bash
2
3# generates user data, meta data, and seed.iso for cloud init. for fedora
4# requires the name of the vm as an argument
5#
6# osinfo-query os to list all available vm types to deploy. fedora is fedora 40
7
8
9image_url="https://download.fedoraproject.org/pub/fedora/linux/releases/41/Cloud/x86_64/images/Fedora-Cloud-Base-Generic-41-1.4.x86_64.qcow2"
10
11sshkeysdir="/root/k"
12
13scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" #&& echo $scriptdir
14dir_path="/var/lib/libvirt/images/.image_store"
15src_file="${dir_path}/fedora40.qcow2"
16config_dir="/var/lib/libvirt/images/.temp"
17user_data="${config_dir}/user-data"
18meta_data="${config_dir}/meta-data"
19seed_iso="${config_dir}/seed.iso"
20# note that cloud init specifically looks for "user-data" and "meta-data" in the seed.iso disk. do not deviate from the naming convention.
21
22if [ $# -ne 1 ]; then
23 echo "Usage: $0 <vm-name>"
24 exit 1
25fi
26
27sudo mkdir -p "$dir_path"
28sudo mkdir -p "$config_dir"
29
30[ ! -f "$src_file" ] && echo "source image does not exist! downloading..." && sudo wget -O "$src_file" "$image_url"
31
32cat > "$user_data" << EOF
33#cloud-config
34users:
35 - name: user
36 ssh-authorized-keys:
37EOF
38
39for key in $sshkeysdir/*.pub; do
40 echo " - $(cat "$key")" >> $user_data
41done
42
43
44
45
46
47
48
49
50
51cat >> "$user_data" << 'EOF'
52 sudo: ['ALL=(ALL) NOPASSWD:ALL']
53 groups: wheel
54 shell: /bin/bash
55runcmd:
56 - sudo growpart /dev/sda 1
57 - sudo xfs_growfs /
58 - |
59 cat > /etc/yum.repos.d/local-fedora.repo << 'FOE'
60 [local-fedora]
61 name=Local Fedora Mirror
62 baseurl=http://192.168.124.227/fedora-base
63 enabled=1
64 gpgcheck=0
65 priority=1
66 [local-updates]
67 name=Local Fedora Updates
68 baseurl=http://192.168.124.227/fedora-updates
69 enabled=1
70 gpgcheck=0
71 priority=1
72 [local-updates-testing]
73 name=Local Fedora Updates Testing
74 baseurl=http://192.168.124.227/fedora-updates-testing
75 enabled=1
76 gpgcheck=0
77 priority=1
78 FOE
79 - sudo sed -i 's/enabled=1/enabled=0/' /etc/yum.repos.d/fedora.repo
80 - sudo sed -i 's/enabled=1/enabled=0/' /etc/yum.repos.d/fedora-updates.repo
81 - sudo sed -i 's/enabled=1/enabled=0/' /etc/yum.repos.d/fedora-updates-testing.repo
82 - sudo dnf install -y vim git
83 - cd /home/user
84 - git clone https://git.0nom.ch/setup
85 - sudo ./setup/setup.sh
86 - touch /home/user/runcmd_done
87EOF
88
89
90
91
92
93
94
95
96
97cat > "$meta_data" << EOF
98instance-id: vm_id
99local-hostname: $1
100EOF
101
102genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; }
103
104echo "Configuration files generated successfully"
105
diff --git a/others/vm3/.config/cloud-init-generator/freebsd14.0.sh b/others/vm3/.config/cloud-init-generator/freebsd14.0.sh
deleted file mode 100755
index c498efa..0000000
--- a/others/vm3/.config/cloud-init-generator/freebsd14.0.sh
+++ /dev/null
@@ -1,75 +0,0 @@
1#!/bin/bash
2# generates configuration for FreeBSD VM deployment
3# requires the name of the vm as an argument
4image_url="https://download.freebsd.org/releases/VM-IMAGES/14.2-RELEASE/amd64/Latest/FreeBSD-14.2-RELEASE-amd64-BASIC-CLOUDINIT.zfs.qcow2.xz"
5sshkeysdir="/root/k"
6scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
7dir_path="/var/lib/libvirt/images/.image_store"
8src_file="${dir_path}/freebsd14.0.qcow2"
9config_dir="/var/lib/libvirt/images/.temp"
10user_data="${config_dir}/user-data"
11meta_data="${config_dir}/meta-data"
12seed_iso="${config_dir}/seed.iso"
13
14if [ $# -ne 1 ]; then
15 echo "Usage: $0 <vm-name>"
16 exit 1
17fi
18
19sudo mkdir -p "$dir_path"
20sudo mkdir -p "$config_dir"
21
22# Download and extract FreeBSD image if it doesn't exist
23if [ ! -f "$src_file" ]; then
24 echo "source image does not exist! downloading..."
25 sudo wget -O "${src_file}.xz" "$image_url"
26 sudo xz -d "${src_file}.xz"
27fi
28
29cat > "$user_data" << EOF
30#cloud-config
31users:
32 - name: user
33 passwd: 'yourpassword'
34 lock_passwd: false
35 ssh-authorized-keys:
36EOF
37
38for key in $sshkeysdir/*.pub; do
39 echo " - $(cat "$key")" >> $user_data
40done
41
42cat >> "$user_data" << 'EOF'
43 groups: wheel
44 shell: /bin/tcsh
45
46# FreeBSD specific configuration
47package_update: true
48package_upgrade: true
49
50packages:
51 - vim-console
52 - git
53 - doas
54
55write_files:
56 - path: /usr/local/etc/doas.conf
57 content: |
58 permit nopass :wheel
59 permissions: '0600'
60
61runcmd:
62 - pw usermod user -s /bin/tcsh
63 - env ASSUME_ALWAYS_YES=YES pkg update
64 - env ASSUME_ALWAYS_YES=YES pkg upgrade
65 - env ASSUME_ALWAYS_YES=YES pkg install vim-console git doas
66 - touch /home/user/runcmd_done
67EOF
68
69cat > "$meta_data" << EOF
70instance-id: vm_id
71local-hostname: $1
72EOF
73
74genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; }
75echo "Configuration files generated successfully"
diff --git a/others/vm3/.config/cloud-init-generator/freebsd14.0.shbackup b/others/vm3/.config/cloud-init-generator/freebsd14.0.shbackup
deleted file mode 100755
index 81fcc72..0000000
--- a/others/vm3/.config/cloud-init-generator/freebsd14.0.shbackup
+++ /dev/null
@@ -1,59 +0,0 @@
1#!/bin/bash
2# generates configuration for FreeBSD VM deployment
3# requires the name of the vm as an argument
4
5image_url="https://download.freebsd.org/releases/VM-IMAGES/14.2-RELEASE/amd64/Latest/FreeBSD-14.2-RELEASE-amd64-BASIC-CLOUDINIT.zfs.qcow2.xz"
6sshkeysdir="/root/k"
7scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
8dir_path="/var/lib/libvirt/images/.image_store"
9src_file="${dir_path}/freebsd14.0.qcow2"
10config_dir="/var/lib/libvirt/images/.temp"
11user_data="${config_dir}/user-data"
12meta_data="${config_dir}/meta-data"
13seed_iso="${config_dir}/seed.iso"
14
15if [ $# -ne 1 ]; then
16 echo "Usage: $0 <vm-name>"
17 exit 1
18fi
19
20sudo mkdir -p "$dir_path"
21sudo mkdir -p "$config_dir"
22
23# Download and extract FreeBSD image if it doesn't exist
24if [ ! -f "$src_file" ]; then
25 echo "source image does not exist! downloading..."
26 sudo wget -O "${src_file}.xz" "$image_url"
27 sudo xz -d "${src_file}.xz"
28fi
29
30# Note: FreeBSD uses a different user setup mechanism
31cat > "$user_data" << EOF
32#cloud-config
33users:
34 - name: user
35 ssh-authorized-keys:
36EOF
37
38for key in $sshkeysdir/*.pub; do
39 echo " - $(cat "$key")" >> $user_data
40done
41
42cat >> "$user_data" << 'EOF'
43 sudo: ['ALL=(ALL) NOPASSWD:ALL']
44 groups: wheel
45 shell: /bin/sh
46runcmd:
47 - pw usermod user -s /bin/sh
48 - pkg update -f
49 - pkg install -y vim git sudo
50 - touch /home/user/runcmd_done
51EOF
52
53cat > "$meta_data" << EOF
54instance-id: vm_id
55local-hostname: $1
56EOF
57
58genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; }
59echo "Configuration files generated successfully"
diff --git a/others/vm3/.config/cloud-init-generator/rocky9.0.sh b/others/vm3/.config/cloud-init-generator/rocky9.0.sh
deleted file mode 100644
index c880206..0000000
--- a/others/vm3/.config/cloud-init-generator/rocky9.0.sh
+++ /dev/null
@@ -1,53 +0,0 @@
1
2#!/bin/bash
3# generates user data, meta data, and seed.iso for cloud init. for rocky
4# requires the name of the vm as an argument
5#
6# osinfo-query os to list all available vm types to deploy. rocky is rocky9.0 or similar
7image_url="https://dl.rockylinux.org/pub/rocky/9/images/x86_64/Rocky-9-GenericCloud-Base.latest.x86_64.qcow2"
8sshkeysdir="/root/k"
9scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" #&& echo $scriptdir
10dir_path="/var/lib/libvirt/images/.image_store"
11src_file="${dir_path}/rocky9.0.qcow2"
12config_dir="/var/lib/libvirt/images/.temp"
13user_data="${config_dir}/user-data"
14meta_data="${config_dir}/meta-data"
15seed_iso="${config_dir}/seed.iso"
16# note that cloud init specifically looks for "user-data" and "meta-data" in the seed.iso disk. do not deviate from the naming convention.
17if [ $# -ne 1 ]; then
18 echo "Usage: $0 <vm-name>"
19 exit 1
20fi
21sudo mkdir -p "$dir_path"
22sudo mkdir -p "$config_dir"
23[ ! -f "$src_file" ] && echo "source image does not exist! downloading..." && sudo wget -O "$src_file" "$image_url"
24cat > "$user_data" << EOF
25#cloud-config
26users:
27 - name: user
28 ssh-authorized-keys:
29EOF
30for key in $sshkeysdir/*.pub; do
31 echo " - $(cat "$key")" >> $user_data
32done
33cat >> "$user_data" << 'EOF'
34 sudo: ['ALL=(ALL) NOPASSWD:ALL']
35 groups: wheel
36 shell: /bin/bash
37runcmd:
38 - sudo systemctl enable --now serial-getty@ttyS0.service
39 - sudo growpart /dev/sda 1
40 - sudo xfs_growfs /
41 - sudo dnf install -y vim git
42 - cd /home/user
43 - git clone https://git.0nom.ch/setup
44 - touch /home/user/runcmd_done
45EOF
46cat > "$meta_data" << EOF
47instance-id: vm_id
48local-hostname: $1
49EOF
50genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; }
51echo "Configuration files generated successfully"
52
53
diff --git a/others/vm3/.config/cloud-init-generator/ubuntu24.04.sh b/others/vm3/.config/cloud-init-generator/ubuntu24.04.sh
deleted file mode 100755
index 11e0a98..0000000
--- a/others/vm3/.config/cloud-init-generator/ubuntu24.04.sh
+++ /dev/null
@@ -1,62 +0,0 @@
1#!/bin/bash
2# generates user data, meta data, and seed.iso for cloud init. for Ubuntu
3# requires the name of the vm as an argument
4
5image_url="https://cloud-images.ubuntu.com/noble/current/noble-server-cloudimg-amd64.img"
6sshkeysdir="/root/k"
7scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
8dir_path="/var/lib/libvirt/images/.image_store"
9src_file="${dir_path}/ubuntu24.04.qcow2"
10config_dir="/var/lib/libvirt/images/.temp"
11user_data="${config_dir}/user-data"
12meta_data="${config_dir}/meta-data"
13seed_iso="${config_dir}/seed.iso"
14temp_img="${dir_path}/ubuntu_temp.img"
15
16if [ $# -ne 1 ]; then
17 echo "Usage: $0 <vm-name>"
18 exit 1
19fi
20
21sudo mkdir -p "$dir_path"
22sudo mkdir -p "$config_dir"
23
24if [ ! -f "$src_file" ]; then
25 echo "source image does not exist! downloading..."
26 sudo wget -O "$temp_img" "$image_url"
27 echo "Converting to qcow2 format..."
28 sudo qemu-img convert -f raw -O qcow2 "$temp_img" "$src_file"
29 sudo rm "$temp_img"
30fi
31
32cat > "$user_data" << EOF
33#cloud-config
34users:
35 - name: ubuntu
36 ssh-authorized-keys:
37EOF
38
39for key in $sshkeysdir/*.pub; do
40 echo " - $(cat "$key")" >> $user_data
41done
42
43cat >> "$user_data" << 'EOF'
44 sudo: ['ALL=(ALL) NOPASSWD:ALL']
45 groups: sudo
46 shell: /bin/bash
47runcmd:
48 - sudo growpart /dev/sda 1
49 - sudo resize2fs /dev/sda1
50 - sudo apt-get update
51 - sudo apt-get install -y vim git
52 - cd /home/ubuntu
53 - touch /home/ubuntu/runcmd_done
54EOF
55
56cat > "$meta_data" << EOF
57instance-id: vm_id
58local-hostname: $1
59EOF
60
61genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; }
62echo "Configuration files generated successfully"
diff --git a/others/vm3/.config/init/install_packages.sh b/others/vm3/.config/init/install_packages.sh
deleted file mode 100755
index d5ca81f..0000000
--- a/others/vm3/.config/init/install_packages.sh
+++ /dev/null
@@ -1,12 +0,0 @@
1#!/bin/bash
2
3#install packages
4packages=("nc" "htop" "wireguard-tools" "bind-utils" "tmux" "net-tools" "curl" "mlocate" "dnsmasq" "qemu-kvm" "libvirt" "libvirt-daemon-kvm" "virt-install" "virt-manager" "genisoimage" "bc")
5
6for package in "${packages[@]}"; do
7 if ! rpm -q "$package" &> /dev/null; then
8 sudo dnf install -y "$package"
9 fi
10done
11
12sudo systemctl enable --now libvirtd
diff --git a/others/vm3/.config/init/make_rootkey.sh b/others/vm3/.config/init/make_rootkey.sh
deleted file mode 100755
index f725985..0000000
--- a/others/vm3/.config/init/make_rootkey.sh
+++ /dev/null
@@ -1,4 +0,0 @@
1#!/bin/bash
2
3sudo mkdir -p /root/k
4ssh-keygen -t ed25519 -f /root/k/k1 -N ""