1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-22 22:03:39 +03:00

B #5222: Registering image with complex URL in PATH fails (#467)

* B #5222: Secure image downloader: Escape XML references on ImageManager::stat_image
This commit is contained in:
Vlastimil Holer 2017-09-11 11:39:44 +02:00 committed by Ruben S. Montero
parent 50e7464769
commit 98c51bcf4f
4 changed files with 50 additions and 16 deletions

View File

@ -35,6 +35,13 @@ namespace one_util
std::string log_time();
/**
* Escape XML entity and character references
* @param in the string to be escaped
* @return a string copy
*/
std::string xml_escape(const std::string& in);
/**
* sha1 digest
* @param in the string to be hashed

View File

@ -80,6 +80,23 @@ string one_util::log_time()
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
std::string one_util::xml_escape(const std::string& in)
{
std::string result = in;
result = one_util::gsub(result, "&", "&");
result = one_util::gsub(result, "<", "&lt;");
result = one_util::gsub(result, ">", "&gt;");
result = one_util::gsub(result, "'", "&apos;");
result = one_util::gsub(result, "\"", "&quot;");
result = one_util::gsub(result, "\r", "&#x0d;");
return result;
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
string * one_util::base64_encode(const string& in)
{
BIO * bio_mem;

View File

@ -28,6 +28,12 @@ fi
DRIVER_PATH=$(dirname $0)
# Escape single quotes
function esc_sq
{
echo "$1" | sed -e "s/'/'\\\''/g"
}
# Execute a command (first parameter) and use the first kb of stdout
# to determine the file type
function get_type
@ -151,8 +157,8 @@ function s3_curl_args
FROM="$1"
ENDPOINT=${S3_ENDPOINT:-https://s3.amazonaws.com}
OBJECT=$(basename $FROM)
BUCKET=$(basename $(dirname $FROM))
OBJECT=$(basename "$FROM")
BUCKET=$(basename $(dirname "$FROM"))
DATE="`date -u +'%a, %d %b %Y %H:%M:%S GMT'`"
AUTH_STRING="GET\n\n\n${DATE}\n/${BUCKET}/${OBJECT}"
@ -163,7 +169,7 @@ function s3_curl_args
echo " -H \"Date: ${DATE}\"" \
" -H \"Authorization: AWS ${S3_ACCESS_KEY_ID}:${SIGNED_AUTH_STRING}\"" \
" ${ENDPOINT}/${BUCKET}/${OBJECT}"
" '$(esc_sq "${ENDPOINT}/${BUCKET}/${OBJECT}")'"
}
function get_rbd_cmd
@ -176,7 +182,7 @@ function get_rbd_cmd
while IFS= read -r -d '' element; do
URL_ELEMENTS[i++]="$element"
done < <($URL_RB $FROM \
done < <($URL_RB "$FROM" \
USER \
HOST \
SOURCE \
@ -201,18 +207,18 @@ function get_rbd_cmd
fi
if [ -n "$CEPH_USER" ]; then
RBD="$RBD --id ${CEPH_USER}"
RBD="$RBD --id '$(esc_sq "${CEPH_USER}")'"
fi
if [ -n "$CEPH_KEY" ]; then
RBD="$RBD --keyfile ${CEPH_KEY}"
RBD="$RBD --keyfile '$(esc_sq "${CEPH_KEY}")'"
fi
if [ -n "$CEPH_CONF" ]; then
RBD="$RBD --conf ${CEPH_CONF}"
RBD="$RBD --conf '$(esc_sq "${CEPH_CONF}")'"
fi
echo "ssh $DST_HOST $RBD export $SOURCE -"
echo "ssh '$(esc_sq "$DST_HOST")' \"$RBD export '$(esc_sq "$SOURCE")' -\""
}
TEMP=`getopt -o m:s:l:n -l md5:,sha1:,limit:,nodecomp -- "$@"`
@ -268,7 +274,7 @@ http://*|https://*)
# -L to follow redirects
# -sS to hide output except on failure
# --limit_rate to limit the bw
curl_args="$GLOBAL_CURL_ARGS $FROM"
curl_args="$GLOBAL_CURL_ARGS '$(esc_sq "${FROM}")'"
if [ -n "$LIMIT_RATE" ]; then
curl_args="--limit-rate $LIMIT_RATE $curl_args"
@ -282,7 +288,7 @@ ssh://*)
ssh_src=${FROM#ssh://}
ssh_arg=(${ssh_src/:/ })
rmt_cmd="'cat ${ssh_arg[1]}'"
rmt_cmd="\"cat '$(esc_sq "${ssh_arg[1]}")'\""
command="ssh ${ssh_arg[0]} $rmt_cmd"
;;
@ -296,22 +302,22 @@ s3://*)
exit -1
fi
curl_args="$(s3_curl_args $FROM)"
curl_args="$(s3_curl_args "$FROM")"
command="curl $GLOBAL_CURL_ARGS $curl_args"
;;
rbd://*)
command="$(get_rbd_cmd $FROM)"
command="$(get_rbd_cmd "$FROM")"
;;
vcenter://*)
command="$VAR_LOCATION/remotes/datastore/vcenter_downloader.rb \"$FROM\""
command="$VAR_LOCATION/remotes/datastore/vcenter_downloader.rb '$(esc_sq "$FROM")'"
;;
*)
if [ ! -r $FROM ]; then
echo "Cannot read from $FROM" >&2
exit -1
fi
command="cat $FROM"
command="cat '$(esc_sq "$FROM")'"
;;
esac

View File

@ -897,7 +897,9 @@ int ImageManager::stat_image(Template* img_tmpl,
return -1;
}
img_data << "<IMAGE><PATH>" << res << "</PATH></IMAGE>";
img_data << "<IMAGE><PATH>"
<< one_util::xml_escape(res)
<< "</PATH></IMAGE>";
break;
case Image::DATABLOCK:
@ -919,7 +921,9 @@ int ImageManager::stat_image(Template* img_tmpl,
}
else
{
img_data << "<IMAGE><PATH>" << res << "</PATH></IMAGE>";
img_data << "<IMAGE><PATH>"
<< one_util::xml_escape(res)
<< "</PATH></IMAGE>";
}
break;
}