Eu ainda sou muito novo em scripts no bash, e apenas tentando algumas coisas que eu pensava serem coisas básicas. Quero executar o DDNS que atualiza do meu servidor executando o Ubuntu 14.04.
Tomando emprestado algum código do dnsimple, é isso que tenho até agora:
#!/bin/bash
LOGIN="email"
TOKEN="token"
DOMAIN_ID="domain"
RECORD_ID="record"
IP=`curl -s http://icanhazip.com/`
OUTPUT=`
curl -H "Accept: application/json" \
-H "Content-Type: application/json" \
-H "X-DNSimple-Domain-Token: $TOKEN" \
-X "PUT" \
-i "https://api.dnsimple.com/v1/domains/$DOMAIN_ID/records/$RECORD_ID" \
-d "{\"record\":{\"content\":\"$IP\"}}"`
if ! echo "$OUTPUT" | grep -q "(Status:\s200)"; then
echo "match"
$(echo "$OUTPUT" | grep -oP '(?<="message":")(.[^"]*)' >> /home/ddns/ddns.log)
$(echo "$OUTPUT"| grep -P '(Status:\s[0-9]{3}\s)' >> /home/ddns/ddns.log)
fi
A idéia é que seja executado a cada 5 minutos, o que eu estou trabalhando usando um cronjob. Desejo, então, verificar a saída do curl para ver se o status é "200" ou outro. Se for outra coisa, quero salvar a saída em um arquivo.
O que não consigo trabalhar é a if
afirmação. Pelo que entendi, o -q
no grep
comando irá fornecer um código de saída para a if
declaração. No entanto, eu não consigo fazê-lo funcionar. Onde eu errei?
DNSimple-Domain-Token
que não precisa da LOGIN
variável.
/var/tmp/icanhazip
) e, se não tiver sido alterado desde a última execução, exit 0
antes de fazer qualquer outra coisa. você não precisa atualizar sua entrada DDNS a cada 5 minutos, apenas quando o seu endereço IP for alterado.
if
verificação e sempre ecoar no arquivo de log? O dnssimple mostra um$LOGIN
antes$TOKEN
, mas você está sentindo falta disso. Talvez isso esteja causando falhas nas coisas?