[Fix] `nvm_get_mirror`: disallow some non-URL characters
This should be improved in the future, but is fine for now
parent
ef7fc2f2c0
commit
d02ddcac2c
15
nvm.sh
15
nvm.sh
|
@ -2023,14 +2023,25 @@ nvm_is_merged_node_version() {
|
||||||
}
|
}
|
||||||
|
|
||||||
nvm_get_mirror() {
|
nvm_get_mirror() {
|
||||||
|
local NVM_MIRROR
|
||||||
|
NVM_MIRROR=''
|
||||||
case "${1}-${2}" in
|
case "${1}-${2}" in
|
||||||
node-std) nvm_echo "${NVM_NODEJS_ORG_MIRROR:-https://nodejs.org/dist}" ;;
|
node-std) NVM_MIRROR="${NVM_NODEJS_ORG_MIRROR:-https://nodejs.org/dist}" ;;
|
||||||
iojs-std) nvm_echo "${NVM_IOJS_ORG_MIRROR:-https://iojs.org/dist}" ;;
|
iojs-std) NVM_MIRROR="${NVM_IOJS_ORG_MIRROR:-https://iojs.org/dist}" ;;
|
||||||
*)
|
*)
|
||||||
nvm_err 'unknown type of node.js or io.js release'
|
nvm_err 'unknown type of node.js or io.js release'
|
||||||
return 1
|
return 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
case "${NVM_MIRROR}" in
|
||||||
|
*\`* | *\\* | *\'* | *\(* )
|
||||||
|
nvm_err '$NVM_NODEJS_ORG_MIRROR and $NVM_IOJS_ORG_MIRROR may only contain a URL'
|
||||||
|
return 2
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
nvm_echo "${NVM_MIRROR}"
|
||||||
}
|
}
|
||||||
|
|
||||||
# args: os, prefixed version, version, tarball, extract directory
|
# args: os, prefixed version, version, tarball, extract directory
|
||||||
|
|
|
@ -30,3 +30,11 @@ unset NVM_NODEJS_ORG_MIRROR
|
||||||
NVM_IOJS_ORG_MIRROR="test://domain"
|
NVM_IOJS_ORG_MIRROR="test://domain"
|
||||||
[ "$(nvm_get_mirror iojs std)" = "test://domain" ] || die "iojs-std mirror should respect NVM_IOJS_ORG_MIRROR"
|
[ "$(nvm_get_mirror iojs std)" = "test://domain" ] || die "iojs-std mirror should respect NVM_IOJS_ORG_MIRROR"
|
||||||
unset NVM_IOJS_ORG_MIRROR
|
unset NVM_IOJS_ORG_MIRROR
|
||||||
|
|
||||||
|
NVM_NODEJS_ORG_MIRROR='`do something bad`'
|
||||||
|
! nvm_get_mirror node std || die 'NVM_NODEJS_ORG_MIRROR errors with command injection attempt'
|
||||||
|
[ "$(nvm_get_mirror node std)" = "" ] || die 'NVM_NODEJS_ORG_MIRROR is protected against command injection'
|
||||||
|
|
||||||
|
NVM_IOJS_ORG_MIRROR='`do something bad`'
|
||||||
|
! nvm_get_mirror iojs std || die 'NVM_IOJS_ORG_MIRROR errors with command injection attempt'
|
||||||
|
[ "$(nvm_get_mirror iojs std)" = "" ] || die 'NVM_IOJS_ORG_MIRROR is protected against command injection'
|
||||||
|
|
Loading…
Reference in New Issue