diff options
| author | root <root@sg1.noml.ch> | 2025-05-22 18:36:01 +0800 |
|---|---|---|
| committer | root <root@sg1.noml.ch> | 2025-05-22 18:36:01 +0800 |
| commit | 3a52e92fbbbab4df949740f89a389d68281a9428 (patch) | |
| tree | 5cb3b864eb0e3f3b90a1efd9cbdee1fb9f158f4a /others/vm3/.config | |
| parent | 8cb260002db7c46ea5fe2c3f589b485e5f5d970d (diff) | |
Diffstat (limited to 'others/vm3/.config')
| -rwxr-xr-x | others/vm3/.config/cloud-init-generator/debian12.sh | 67 | ||||
| -rwxr-xr-x | others/vm3/.config/cloud-init-generator/fedora40.sh | 105 | ||||
| -rwxr-xr-x | others/vm3/.config/cloud-init-generator/freebsd14.0.sh | 75 | ||||
| -rwxr-xr-x | others/vm3/.config/cloud-init-generator/freebsd14.0.shbackup | 59 | ||||
| -rw-r--r-- | others/vm3/.config/cloud-init-generator/rocky9.0.sh | 53 | ||||
| -rwxr-xr-x | others/vm3/.config/cloud-init-generator/ubuntu24.04.sh | 62 | ||||
| -rwxr-xr-x | others/vm3/.config/init/install_packages.sh | 12 | ||||
| -rwxr-xr-x | others/vm3/.config/init/make_rootkey.sh | 4 |
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 | # | ||
| 13 | image_url="https://cloud.debian.org/images/cloud/bookworm/latest/debian-12-nocloud-amd64.qcow2" | ||
| 14 | sshkeysdir="/root/k" | ||
| 15 | scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" #&& echo $scriptdir | ||
| 16 | dir_path="/var/lib/libvirt/images/.image_store" | ||
| 17 | src_file="${dir_path}/debian12.qcow2" | ||
| 18 | config_dir="/var/lib/libvirt/images/.temp" | ||
| 19 | user_data="${config_dir}/user-data" | ||
| 20 | meta_data="${config_dir}/meta-data" | ||
| 21 | seed_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. | ||
| 23 | if [ $# -ne 1 ]; then | ||
| 24 | echo "Usage: $0 <vm-name>" | ||
| 25 | exit 1 | ||
| 26 | fi | ||
| 27 | sudo mkdir -p "$dir_path" # make image store dir | ||
| 28 | sudo 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 | ||
| 33 | SSH_INJECT_OPTS=$(find ${sshkeysdir} -name "*.pub" -exec echo "--ssh-inject user:file:{}" \;) | ||
| 34 | |||
| 35 | flag_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 | ||
| 39 | if [ -f "$flag_file" ]; then | ||
| 40 | echo "Image already customized, skipping customization..." | ||
| 41 | else | ||
| 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" | ||
| 56 | LS_COLORS=$LS_COLORS:'\''di=38;5;135:ex=00;32:'\'' ; export LS_COLORS | ||
| 57 | PS1='\''[\[\033[01;32m\]\u\[\033[00m\]@\h \[\033[38;5;135m\]\W\[\033[00m\]]\$ '\'' | ||
| 58 | EOF' \ | ||
| 59 | --run-command 'tee -a /home/user/.bashrc > /dev/null << "EOF" | ||
| 60 | LS_COLORS=$LS_COLORS:'\''di=38;5;135:ex=00;32:'\'' ; export LS_COLORS | ||
| 61 | PS1='\''[\[\033[01;32m\]\u\[\033[00m\]@\h \[\033[38;5;135m\]\W\[\033[00m\]]\$ '\'' | ||
| 62 | EOF' \ | ||
| 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" | ||
| 67 | fi | ||
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 | |||
| 9 | image_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 | |||
| 11 | sshkeysdir="/root/k" | ||
| 12 | |||
| 13 | scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" #&& echo $scriptdir | ||
| 14 | dir_path="/var/lib/libvirt/images/.image_store" | ||
| 15 | src_file="${dir_path}/fedora40.qcow2" | ||
| 16 | config_dir="/var/lib/libvirt/images/.temp" | ||
| 17 | user_data="${config_dir}/user-data" | ||
| 18 | meta_data="${config_dir}/meta-data" | ||
| 19 | seed_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 | |||
| 22 | if [ $# -ne 1 ]; then | ||
| 23 | echo "Usage: $0 <vm-name>" | ||
| 24 | exit 1 | ||
| 25 | fi | ||
| 26 | |||
| 27 | sudo mkdir -p "$dir_path" | ||
| 28 | sudo 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 | cat > "$user_data" << EOF | ||
| 33 | #cloud-config | ||
| 34 | users: | ||
| 35 | - name: user | ||
| 36 | ssh-authorized-keys: | ||
| 37 | EOF | ||
| 38 | |||
| 39 | for key in $sshkeysdir/*.pub; do | ||
| 40 | echo " - $(cat "$key")" >> $user_data | ||
| 41 | done | ||
| 42 | |||
| 43 | |||
| 44 | |||
| 45 | |||
| 46 | |||
| 47 | |||
| 48 | |||
| 49 | |||
| 50 | |||
| 51 | cat >> "$user_data" << 'EOF' | ||
| 52 | sudo: ['ALL=(ALL) NOPASSWD:ALL'] | ||
| 53 | groups: wheel | ||
| 54 | shell: /bin/bash | ||
| 55 | runcmd: | ||
| 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 | ||
| 87 | EOF | ||
| 88 | |||
| 89 | |||
| 90 | |||
| 91 | |||
| 92 | |||
| 93 | |||
| 94 | |||
| 95 | |||
| 96 | |||
| 97 | cat > "$meta_data" << EOF | ||
| 98 | instance-id: vm_id | ||
| 99 | local-hostname: $1 | ||
| 100 | EOF | ||
| 101 | |||
| 102 | genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; } | ||
| 103 | |||
| 104 | echo "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 | ||
| 4 | image_url="https://download.freebsd.org/releases/VM-IMAGES/14.2-RELEASE/amd64/Latest/FreeBSD-14.2-RELEASE-amd64-BASIC-CLOUDINIT.zfs.qcow2.xz" | ||
| 5 | sshkeysdir="/root/k" | ||
| 6 | scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" | ||
| 7 | dir_path="/var/lib/libvirt/images/.image_store" | ||
| 8 | src_file="${dir_path}/freebsd14.0.qcow2" | ||
| 9 | config_dir="/var/lib/libvirt/images/.temp" | ||
| 10 | user_data="${config_dir}/user-data" | ||
| 11 | meta_data="${config_dir}/meta-data" | ||
| 12 | seed_iso="${config_dir}/seed.iso" | ||
| 13 | |||
| 14 | if [ $# -ne 1 ]; then | ||
| 15 | echo "Usage: $0 <vm-name>" | ||
| 16 | exit 1 | ||
| 17 | fi | ||
| 18 | |||
| 19 | sudo mkdir -p "$dir_path" | ||
| 20 | sudo mkdir -p "$config_dir" | ||
| 21 | |||
| 22 | # Download and extract FreeBSD image if it doesn't exist | ||
| 23 | if [ ! -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" | ||
| 27 | fi | ||
| 28 | |||
| 29 | cat > "$user_data" << EOF | ||
| 30 | #cloud-config | ||
| 31 | users: | ||
| 32 | - name: user | ||
| 33 | passwd: 'yourpassword' | ||
| 34 | lock_passwd: false | ||
| 35 | ssh-authorized-keys: | ||
| 36 | EOF | ||
| 37 | |||
| 38 | for key in $sshkeysdir/*.pub; do | ||
| 39 | echo " - $(cat "$key")" >> $user_data | ||
| 40 | done | ||
| 41 | |||
| 42 | cat >> "$user_data" << 'EOF' | ||
| 43 | groups: wheel | ||
| 44 | shell: /bin/tcsh | ||
| 45 | |||
| 46 | # FreeBSD specific configuration | ||
| 47 | package_update: true | ||
| 48 | package_upgrade: true | ||
| 49 | |||
| 50 | packages: | ||
| 51 | - vim-console | ||
| 52 | - git | ||
| 53 | - doas | ||
| 54 | |||
| 55 | write_files: | ||
| 56 | - path: /usr/local/etc/doas.conf | ||
| 57 | content: | | ||
| 58 | permit nopass :wheel | ||
| 59 | permissions: '0600' | ||
| 60 | |||
| 61 | runcmd: | ||
| 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 | ||
| 67 | EOF | ||
| 68 | |||
| 69 | cat > "$meta_data" << EOF | ||
| 70 | instance-id: vm_id | ||
| 71 | local-hostname: $1 | ||
| 72 | EOF | ||
| 73 | |||
| 74 | genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; } | ||
| 75 | echo "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 | |||
| 5 | image_url="https://download.freebsd.org/releases/VM-IMAGES/14.2-RELEASE/amd64/Latest/FreeBSD-14.2-RELEASE-amd64-BASIC-CLOUDINIT.zfs.qcow2.xz" | ||
| 6 | sshkeysdir="/root/k" | ||
| 7 | scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" | ||
| 8 | dir_path="/var/lib/libvirt/images/.image_store" | ||
| 9 | src_file="${dir_path}/freebsd14.0.qcow2" | ||
| 10 | config_dir="/var/lib/libvirt/images/.temp" | ||
| 11 | user_data="${config_dir}/user-data" | ||
| 12 | meta_data="${config_dir}/meta-data" | ||
| 13 | seed_iso="${config_dir}/seed.iso" | ||
| 14 | |||
| 15 | if [ $# -ne 1 ]; then | ||
| 16 | echo "Usage: $0 <vm-name>" | ||
| 17 | exit 1 | ||
| 18 | fi | ||
| 19 | |||
| 20 | sudo mkdir -p "$dir_path" | ||
| 21 | sudo mkdir -p "$config_dir" | ||
| 22 | |||
| 23 | # Download and extract FreeBSD image if it doesn't exist | ||
| 24 | if [ ! -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" | ||
| 28 | fi | ||
| 29 | |||
| 30 | # Note: FreeBSD uses a different user setup mechanism | ||
| 31 | cat > "$user_data" << EOF | ||
| 32 | #cloud-config | ||
| 33 | users: | ||
| 34 | - name: user | ||
| 35 | ssh-authorized-keys: | ||
| 36 | EOF | ||
| 37 | |||
| 38 | for key in $sshkeysdir/*.pub; do | ||
| 39 | echo " - $(cat "$key")" >> $user_data | ||
| 40 | done | ||
| 41 | |||
| 42 | cat >> "$user_data" << 'EOF' | ||
| 43 | sudo: ['ALL=(ALL) NOPASSWD:ALL'] | ||
| 44 | groups: wheel | ||
| 45 | shell: /bin/sh | ||
| 46 | runcmd: | ||
| 47 | - pw usermod user -s /bin/sh | ||
| 48 | - pkg update -f | ||
| 49 | - pkg install -y vim git sudo | ||
| 50 | - touch /home/user/runcmd_done | ||
| 51 | EOF | ||
| 52 | |||
| 53 | cat > "$meta_data" << EOF | ||
| 54 | instance-id: vm_id | ||
| 55 | local-hostname: $1 | ||
| 56 | EOF | ||
| 57 | |||
| 58 | genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; } | ||
| 59 | echo "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 | ||
| 7 | image_url="https://dl.rockylinux.org/pub/rocky/9/images/x86_64/Rocky-9-GenericCloud-Base.latest.x86_64.qcow2" | ||
| 8 | sshkeysdir="/root/k" | ||
| 9 | scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" #&& echo $scriptdir | ||
| 10 | dir_path="/var/lib/libvirt/images/.image_store" | ||
| 11 | src_file="${dir_path}/rocky9.0.qcow2" | ||
| 12 | config_dir="/var/lib/libvirt/images/.temp" | ||
| 13 | user_data="${config_dir}/user-data" | ||
| 14 | meta_data="${config_dir}/meta-data" | ||
| 15 | seed_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. | ||
| 17 | if [ $# -ne 1 ]; then | ||
| 18 | echo "Usage: $0 <vm-name>" | ||
| 19 | exit 1 | ||
| 20 | fi | ||
| 21 | sudo mkdir -p "$dir_path" | ||
| 22 | sudo mkdir -p "$config_dir" | ||
| 23 | [ ! -f "$src_file" ] && echo "source image does not exist! downloading..." && sudo wget -O "$src_file" "$image_url" | ||
| 24 | cat > "$user_data" << EOF | ||
| 25 | #cloud-config | ||
| 26 | users: | ||
| 27 | - name: user | ||
| 28 | ssh-authorized-keys: | ||
| 29 | EOF | ||
| 30 | for key in $sshkeysdir/*.pub; do | ||
| 31 | echo " - $(cat "$key")" >> $user_data | ||
| 32 | done | ||
| 33 | cat >> "$user_data" << 'EOF' | ||
| 34 | sudo: ['ALL=(ALL) NOPASSWD:ALL'] | ||
| 35 | groups: wheel | ||
| 36 | shell: /bin/bash | ||
| 37 | runcmd: | ||
| 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 | ||
| 45 | EOF | ||
| 46 | cat > "$meta_data" << EOF | ||
| 47 | instance-id: vm_id | ||
| 48 | local-hostname: $1 | ||
| 49 | EOF | ||
| 50 | genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; } | ||
| 51 | echo "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 | |||
| 5 | image_url="https://cloud-images.ubuntu.com/noble/current/noble-server-cloudimg-amd64.img" | ||
| 6 | sshkeysdir="/root/k" | ||
| 7 | scriptdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" | ||
| 8 | dir_path="/var/lib/libvirt/images/.image_store" | ||
| 9 | src_file="${dir_path}/ubuntu24.04.qcow2" | ||
| 10 | config_dir="/var/lib/libvirt/images/.temp" | ||
| 11 | user_data="${config_dir}/user-data" | ||
| 12 | meta_data="${config_dir}/meta-data" | ||
| 13 | seed_iso="${config_dir}/seed.iso" | ||
| 14 | temp_img="${dir_path}/ubuntu_temp.img" | ||
| 15 | |||
| 16 | if [ $# -ne 1 ]; then | ||
| 17 | echo "Usage: $0 <vm-name>" | ||
| 18 | exit 1 | ||
| 19 | fi | ||
| 20 | |||
| 21 | sudo mkdir -p "$dir_path" | ||
| 22 | sudo mkdir -p "$config_dir" | ||
| 23 | |||
| 24 | if [ ! -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" | ||
| 30 | fi | ||
| 31 | |||
| 32 | cat > "$user_data" << EOF | ||
| 33 | #cloud-config | ||
| 34 | users: | ||
| 35 | - name: ubuntu | ||
| 36 | ssh-authorized-keys: | ||
| 37 | EOF | ||
| 38 | |||
| 39 | for key in $sshkeysdir/*.pub; do | ||
| 40 | echo " - $(cat "$key")" >> $user_data | ||
| 41 | done | ||
| 42 | |||
| 43 | cat >> "$user_data" << 'EOF' | ||
| 44 | sudo: ['ALL=(ALL) NOPASSWD:ALL'] | ||
| 45 | groups: sudo | ||
| 46 | shell: /bin/bash | ||
| 47 | runcmd: | ||
| 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 | ||
| 54 | EOF | ||
| 55 | |||
| 56 | cat > "$meta_data" << EOF | ||
| 57 | instance-id: vm_id | ||
| 58 | local-hostname: $1 | ||
| 59 | EOF | ||
| 60 | |||
| 61 | genisoimage -output "$seed_iso" -volid cidata -joliet -rock "$user_data" "$meta_data" &> /dev/null || { echo "Failed to create seed.iso."; exit 1; } | ||
| 62 | echo "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 | ||
| 4 | packages=("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 | |||
| 6 | for package in "${packages[@]}"; do | ||
| 7 | if ! rpm -q "$package" &> /dev/null; then | ||
| 8 | sudo dnf install -y "$package" | ||
| 9 | fi | ||
| 10 | done | ||
| 11 | |||
| 12 | sudo 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 | |||
| 3 | sudo mkdir -p /root/k | ||
| 4 | ssh-keygen -t ed25519 -f /root/k/k1 -N "" | ||
