This is an automated email from the ASF dual-hosted git repository.
rohit pushed a commit to branch 4.11
in repository https://gitbox.apache.org/repos/asf/cloudstack.git
The following commit(s) were added to refs/heads/4.11 by this push:
new 3af54ec CLOUDSTACK-10382: Fix cloud-get-vm-data-configdrive.in (#2688)
3af54ec is described below
commit 3af54ec1a8313c51c0faf98bf41e99450a3d0079
Author: Frank Maximus <[email protected]>
AuthorDate: Thu Jun 7 07:48:24 2018 +0200
CLOUDSTACK-10382: Fix cloud-get-vm-data-configdrive.in (#2688)
---
setup/bindir/cloud-get-vm-data-configdrive.in | 62 ++++++++++++---------------
1 file changed, 27 insertions(+), 35 deletions(-)
diff --git a/setup/bindir/cloud-get-vm-data-configdrive.in
b/setup/bindir/cloud-get-vm-data-configdrive.in
index 946ec3b..c6b70be 100644
--- a/setup/bindir/cloud-get-vm-data-configdrive.in
+++ b/setup/bindir/cloud-get-vm-data-configdrive.in
@@ -21,23 +21,28 @@ mountdir=$(mktemp -d)
filepath=$mountdir/cloudstack
user_data=$filepath/userdata/user_data.txt
-availability_zone=$filepath/metadata/availability_zone.txt
-cloud_identifier=$filepath/metadata/cloud_identifier.txt
-instance_id=$filepath/metadata/instance_id.txt
-local_hostname=$filepath/metadata/local_hostname.txt
-service_offering=$filepath/metadata/service_offering.txt
-vm_id=$filepath/metadata/vm_id.txt
-public_key=$filepath/metadata/public_keys.txt
vm_password=$filepath/password/vm_password.txt
+declare -A metadata=(
+["availability-zone"]=$filepath/metadata/availability-zone.txt
+["cloud-identifier"]=$filepath/metadata/cloud-identifier.txt
+["instance-id"]=$filepath/metadata/instance-id.txt
+["local-hostname"]=$filepath/metadata/local-hostname.txt
+["local-ipv4"]=$filepath/metadata/local-ipv4.txt
+["public-ipv4"]=$filepath/metadata/public-ipv4.txt
+["service-offering"]=$filepath/metadata/service-offering.txt
+["vm-id"]=$filepath/metadata/vm-id.txt
+["public-key"]=$filepath/metadata/public-keys.txt
+)
# If lable name is other than config, please change the below line as required
DefaultDisk=/dev/disk/by-label/config-2
function usage
{
+ keys=${!metadata[@]}
echo -e "USAGE: cloud-get-vm-data -options"
echo -e " where options include:"
- echo -e "\\t-m | --metadata [availability-zone | cloud-identifier |
instance-id | local-hostname | service-offering | vm-id | public-key]
\\n\\t\\tprint vm metadata"
+ echo -e "\\t-m | --metadata [${keys// / | }] \\n\\t\\tprint vm metadata"
echo -e "\\t-p | --password \\n\\t\\tprint vm password"
echo -e "\\t-u | --userdata \\n\\t\\tprint vm userdata"
}
@@ -52,7 +57,7 @@ function prepare_mount
if [ -e $DefaultDisk ]; then
Disk=$DefaultDisk
else
- BLOCK_DEVICE=$(blkid -t LABEL='config' /dev/hd? /dev/sd? /dev/xvd? -o
device)
+ BLOCK_DEVICE=$(blkid -t LABEL='config-2' /dev/sr? /dev/hd? /dev/sd?
/dev/xvd? -o device)
if [ -n $BLOCK_DEVICE ]; then
Disk=$BLOCK_DEVICE
else
@@ -81,34 +86,21 @@ case $1 in
;;
-m | --metadata ) shift
if [ "$1" != "" ]; then
- case $1 in
- availability-zone ) echo -n "availability
zone: "; filename=$availability_zone
- ;;
- cloud-identifier ) echo -n "cloud identifier:
"; filename=$cloud_identifier
- ;;
- instance-id ) echo -n "instance-id: ";
filename=$instance_id
- ;;
- local-hostname ) echo -n "local-hostname:
"; filename=$local_hostname
- ;;
- service-offering ) echo -n "service-offering:
"; filename=$service_offering
- ;;
- vm-id ) echo -n "vm-id: ";
filename=$vm_id
- ;;
- public-key ) echo -n "public-key: ";
filename=$public_key
- ;;
- * ) usage
- remove_mount
- exit 1
- esac
+ if [ -n "${metadata[$1]}" ]; then
+ echo -n "$1: "
+ filename=${metadata[$1]}
+ else
+ usage
+ remove_mount
+ exit 1
+ fi
else
echo -e "METADATA\\n"
- [ -f $availability_zone ] && echo -e "availability
zone:\t" "$(cat $availability_zone)"
- [ -f $cloud_identifier ] && echo -e "cloud
identifier:\t" "$(cat $cloud_identifier)"
- [ -f $instance_id ] && echo -e
"instance-id:\t\t" "$(cat $instance_id)"
- [ -f $local_hostname ] && echo -e
"local-hostname:\t\t" "$(cat $local_hostname)"
- [ -f $service_offering ] && echo -e
"service-offering:\t" "$(cat $service_offering)"
- [ -f $vm_id ] && echo -e
"vm-id:\t\t\t" "$(cat $vm_id)"
- [ -f $public_key ] && echo -e
"public-key:\t\t" "$(cat $public_key)"
+ for entry in "${!metadata[@]}"
+ do
+ file=${metadata[$entry]}
+ [ -f $file ] && printf "%18s :\t%s\n" $entry
"$(cat $file)"
+ done
fi
;;
-p | --password ) echo -n "PASSWORD: "
--
To stop receiving notification emails like this one, please contact
[email protected].