mirror of
				https://github.com/flatcar/scripts.git
				synced 2025-10-26 13:51:17 +01:00 
			
		
		
		
	Previously shifts were added into the getopts loop to work around differences between different sh implementations but that causes getopts to end the loop early. Instead use an intermediate variable to work around inconsistent OPTIND behavior and explicitly check for the -- separator. Tested in bash, dash, and ash.
		
			
				
	
	
		
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/sh
 | |
| 
 | |
| SCRIPT_DIR="`dirname "$0"`"
 | |
| VM_NAME=
 | |
| VM_UUID=
 | |
| VM_IMAGE=
 | |
| VM_MEMORY=
 | |
| IMAGE_PATH="${SCRIPT_DIR}/${VM_IMAGE}"
 | |
| SSH_PORT=2222
 | |
| SSH_KEYS=""
 | |
| USAGE="Usage: $0 [-a authorized_keys] [--] [qemu options...]
 | |
| Options:
 | |
|     -a FILE     SSH public keys for login access. [~/.ssh/id_{dsa,rsa}.pub]
 | |
|     -p PORT     The port on localhost to map to the VM's sshd. [2222]
 | |
|     -h          this ;-)
 | |
| 
 | |
| This script is a wrapper around qemu for starting CoreOS virtual machines.
 | |
| The -a option may be used to specify a particular ssh public key to give
 | |
| login access to. If -a is not provided ~/.ssh/id_{dsa,rsa}.pub is used.
 | |
| If no public key is provided or found the VM will still boot but you may
 | |
| be unable to login unless you built the image yourself after setting a
 | |
| password for the core user with the 'set_shared_user_password.sh' script.
 | |
| 
 | |
| Any arguments after -a and -p will be passed through to qemu, -- may be
 | |
| used as an explicit separator. See the qemu(1) man page for more details.
 | |
| "
 | |
| 
 | |
| script_args=1
 | |
| while getopts ":a:p:vh" OPTION
 | |
| do
 | |
|     case $OPTION in
 | |
|         a) SSH_KEYS="$OPTARG" ;;
 | |
|         p) SSH_PORT="$OPTARG" ;;
 | |
|         v) set -x ;;
 | |
|         h) echo "$USAGE"; exit ;;
 | |
|         ?) break ;;
 | |
|     esac
 | |
|     script_args=$OPTIND
 | |
| done
 | |
| 
 | |
| shift $((script_args - 1))
 | |
| [ "$1" == "--" ] && shift
 | |
| 
 | |
| 
 | |
| METADATA=$(mktemp -t -d coreos-meta-data.XXXXXXXXXX)
 | |
| if [ $? -ne 0 ] || [ ! -d "$METADATA" ]; then
 | |
|     echo "$0: mktemp -d failed!" >&2
 | |
|     exit 1
 | |
| fi
 | |
| trap "rm -rf '$METADATA'" EXIT
 | |
| 
 | |
| 
 | |
| # Do our best to create an authorized_keys file
 | |
| if [ -n "$SSH_KEYS" ]; then
 | |
|     if [ ! -f "$SSH_KEYS" ]; then
 | |
|         echo "$0: SSH keys file not found: $SSH_KEYS" >&2
 | |
|         exit 1
 | |
|     elif ! cp "$SSH_KEYS" "${METADATA}/authorized_keys"; then
 | |
|         echo "$0: Failed to copy SSH keys from $SSH_KEYS" >&2
 | |
|         exit 1
 | |
|     fi
 | |
| else
 | |
|     # Nothing provided, try fetching from ssh-agent and the local fs
 | |
|     if [ -S "$SSH_AUTH_SOCK" ]; then
 | |
|         ssh-add -L >> "${METADATA}/authorized_keys"
 | |
|     fi
 | |
|     for default_key in ~/.ssh/id_*.pub; do
 | |
|         if [ ! -f "$default_key" ]; then
 | |
|             continue
 | |
|         fi
 | |
|         cat "$default_key" >> "${METADATA}/authorized_keys"
 | |
|     done
 | |
| fi
 | |
| 
 | |
| 
 | |
| # Default to KVM, fall back on full emulation
 | |
| # ${METADATA} will be mounted in CoreOS as /media/metadata
 | |
| qemu-system-x86_64 \
 | |
|     -name "$VM_NAME" \
 | |
|     -uuid "$VM_UUID" \
 | |
|     -m ${VM_MEMORY} \
 | |
|     -machine accel=kvm:tcg \
 | |
|     -drive index=0,if=virtio,media=disk,format=qcow2,file="${IMAGE_PATH}" \
 | |
|     -net nic,vlan=0,model=virtio \
 | |
|     -net user,vlan=0,hostfwd=tcp::"${SSH_PORT}"-:22 \
 | |
|     -fsdev local,id=metadata,security_model=none,readonly,path="${METADATA}" \
 | |
|     -device virtio-9p-pci,fsdev=metadata,mount_tag=metadata \
 | |
|     "$@"
 | |
| RET=$?
 | |
| 
 | |
| 
 | |
| # Cleanup!
 | |
| rm -rf "${METADATA}"
 | |
| trap - EXIT
 | |
| exit $?
 |