I have a bash file:
#!/bin/bash
# yesnobox.sh - An inputbox demon shell script
OUTPUT="/tmp/input.txt"
# create empty file
>$OUTPUT
# cleanup - add a trap that will remove $OUTPUT
# if any of the signals - SIGHUP SIGINT SIGTERM it received.
trap "rm $OUTPUT; exit" SIGHUP SIGINT SIGTERM
# show an inputbox
dialog --title "Inputbox" \
--backtitle "Search vacancies" \
--inputbox "Enter your query " 8 60 2>$OUTPUT
# get respose
respose=$?
# get data stored in $OUPUT using input redirection
name=$(<$OUTPUT)
curl -d '{"query":"developer", "turnOff":true}' -H "Content-Type: application/json" -X POST http://localhost:8080/explorer
in last string (curl command) I want to set variable name instead "developer". How to correctly insert it?
To access variables, you have to put a dollar sign in front of the name:
$name
However, variables do not get expanded inside strings enclosed in 'single quotes'. You should have them wrapped inside "double quotes" though, to prevent word splitting of the expanded value, if it might contain spaces.
So there are basically two ways, we either put the whole argument in double quotes to make the variable expandable, but then we have to escape the double quote characters inside, so that they end up in the actual parameter (command line shortened):
Alternatively, we can concatenate string literals enclosed in different quote types by writing them immediately next to each other:
Since the value for curls
-d
parameter is within single quotes means that there will be no parameter expansion, just adding the variable would not work. You can get around this by ending the string literal, adding the variable and then starting the string literal again:The extra double quotes around the variable are used to prevent unwanted shell parameter expansion.
@ByteCommander's answer is good, assuming you know that the value of
name
is a properly escaped JSON string literal. If you can't (or don't want to) make that assumption, use a tool likejq
to generate the JSON for you.Some might find this more readable and maintainable since it avoids using escaping, and sequences of single and double quotes, which are hard to follow and match.
Use Bash's equivalent of
sprintf
to template the substitution: