Updated bash API with unicode support and better usability
This commit is contained in:
parent
26d039f278
commit
a80146dd25
1 changed files with 44 additions and 7 deletions
|
@ -16,6 +16,19 @@ function mistCheckDeps {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
urlencode() {
|
||||||
|
# urlencode <string>
|
||||||
|
local LANG=C
|
||||||
|
local length="${#1}"
|
||||||
|
for (( i = 0; i < length; i++ )); do
|
||||||
|
local c="${1:i:1}"
|
||||||
|
case $c in
|
||||||
|
[a-zA-Z0-9.~_-]) printf "$c" ;;
|
||||||
|
*) printf '%%%02X' "'$c" ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
function mistCall {
|
function mistCall {
|
||||||
mistCheckDeps || return 3
|
mistCheckDeps || return 3
|
||||||
|
|
||||||
|
@ -28,32 +41,56 @@ function mistCall {
|
||||||
echo " {\"auth\":{...}, COMMAND, \"minimal\":1}" >&2
|
echo " {\"auth\":{...}, COMMAND, \"minimal\":1}" >&2
|
||||||
echo "" >&2
|
echo "" >&2
|
||||||
fi
|
fi
|
||||||
if [ "$#" -ne 4 ] ; then
|
if [ "$#" -gt 4 ] ; then
|
||||||
echo "ERROR: Usage: mistCall SERVER USERNAME PASSWORD COMMAND" >&2
|
echo "ERROR: Usage: mistCall [SERVER] [USERNAME PASSWORD] COMMAND" >&2
|
||||||
return 3
|
return 3
|
||||||
fi
|
fi
|
||||||
|
ARG_CMD=""
|
||||||
|
ARG_SRV="localhost:4242"
|
||||||
|
ARG_USR=""
|
||||||
|
ARG_PWD=""
|
||||||
|
if [ "$#" -eq 1 ] ; then
|
||||||
|
ARG_CMD=$1
|
||||||
|
fi
|
||||||
|
if [ "$#" -eq 2 ] ; then
|
||||||
|
ARG_SRV=$1
|
||||||
|
ARG_CMD=$2
|
||||||
|
fi
|
||||||
|
if [ "$#" -eq 3 ] ; then
|
||||||
|
ARG_USR=$1
|
||||||
|
ARG_PWD=$2
|
||||||
|
ARG_CMD=$3
|
||||||
|
fi
|
||||||
|
if [ "$#" -eq 4 ] ; then
|
||||||
|
ARG_SRV=$1
|
||||||
|
ARG_USR=$2
|
||||||
|
ARG_PWD=$3
|
||||||
|
ARG_CMD=$4
|
||||||
|
fi
|
||||||
|
|
||||||
#Load auth, if any
|
#Load auth, if any
|
||||||
MIST_AUTH=`cat /tmp/MistBashAuth 2> /dev/null`
|
MIST_AUTH=`cat /tmp/MistBashAuth 2> /dev/null`
|
||||||
|
|
||||||
#Send request
|
#Send request
|
||||||
RESP=`curl -s -X POST -d "command={${MIST_AUTH}, ${4}, \"minimal\":1}" http://${1}/api/`
|
CMD=`urlencode "{${MIST_AUTH} ${ARG_CMD}}"`
|
||||||
|
RESP=`curl -s -X POST -d "command=$CMD" http://${ARG_SRV}/api2`
|
||||||
|
|
||||||
#Catch problems with reaching the server, display clear error message
|
#Catch problems with reaching the server, display clear error message
|
||||||
if [ "$?" != "0" ] ; then
|
if [ "$?" != "0" ] ; then
|
||||||
echo "ERROR: Could not contact server (${1}), is it correct and online?" >&2
|
echo "ERROR: Could not contact server (${ARG_SRV}), is it correct and online?" >&2
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#Check if this is a challenge
|
#Check if this is a challenge
|
||||||
if [ `echo $RESP | jq -r .authorize.status` == "CHALL" ] ; then
|
if [ `echo $RESP | jq -r .authorize.status` == "CHALL" ] ; then
|
||||||
echo "Challenge detected, (re)calculating login string..." >&2
|
echo "Challenge detected, (re)calculating login string..." >&2
|
||||||
PASSW=`echo -n $3 | md5sum | cut -f 1 -d " "`""
|
PASSW=`echo -n ${ARG_PWD} | md5sum | cut -f 1 -d " "`""
|
||||||
CHALL=`echo $RESP | jq -r .authorize.challenge`
|
CHALL=`echo $RESP | jq -r .authorize.challenge`
|
||||||
SUMMD=`echo -n $PASSW$CHALL | md5sum | cut -f 1 -d " "`
|
SUMMD=`echo -n $PASSW$CHALL | md5sum | cut -f 1 -d " "`
|
||||||
MIST_AUTH="\"authorize\":{\"username\":\"${2}\",\"password\":\"${SUMMD}\"}"
|
MIST_AUTH="\"authorize\":{\"username\":\"${ARG_USR}\",\"password\":\"${SUMMD}\"},"
|
||||||
#Repeat request
|
#Repeat request
|
||||||
RESP=`curl -s -X POST -d "command={${MIST_AUTH}, ${4}, \"minimal\":1}" http://${1}/api/`
|
CMD=`urlencode "{${MIST_AUTH} ${ARG_CMD}}"`
|
||||||
|
RESP=`curl -s -X POST -d "command=$CMD" http://${ARG_SRV}/api2`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#Still a challenge? We must have invalid credentials
|
#Still a challenge? We must have invalid credentials
|
||||||
|
|
Loading…
Add table
Reference in a new issue