Atualizar ddns_update_winco.sh

Melhorias e correção de bugs!
This commit is contained in:
walter 2025-06-07 16:20:00 +00:00
parent 15825fb0d0
commit dfed76e28e

View File

@ -1,56 +1,41 @@
#!/bin/bash
# Configurações
# Array associativo com hostname e suas credenciais
# Formato: "hostname:usuario:senha"
DDNS_CONFIGS=(
"subdominio1.ddns.com.br:usuario1:senha1"
"subdominio2.ddns.com.br:usuario2:senha2"
"subdominio3.ddns.com.br:usuario3:senha3"
# Adicione mais conforme necessário
# "meudominio.ddns.com.br:meuusuario:minhasenha"
)
DDNS_URL="http://members.ddns.com.br/nic/update"
LOG_FILE="/tmp/ddns_update.log"
IP_CACHE_FILE="/tmp/last_ip.txt"
DDNS_URL="http://members.ddns.com.br/nic/update"
# Array associativo com hostname e suas credenciais reais
DDNS_CONFIGS=(
"virtux1.ddns.com.br:virtux1.ddns.com.br:c6aa8858d0"
)
# Interfaces em ordem de prioridade para DETECTAR E USAR na atualização DDNS
INTERFACES_ORDERED=("eth8" "eth6" "eth7")
# Função para log
log_message() {
echo "$(date '+%Y-%m-%d %H:%M:%S') - $1" | tee -a "$LOG_FILE"
echo "[$(date +"%Y-%m-%d %H:%M:%S")] $1" | tee -a "$LOG_FILE"
}
# Função para obter IP público
get_public_ip() {
local ip=""
# Função para obter IP público usando interface
get_public_ip_from_interface() {
local iface="$1"
ip=$(curl -s --interface "$iface" https://ifconfig.me || curl -s --interface "$iface" https://icanhazip.com)
# Lista de serviços para verificar IP público (em ordem de preferência)
local services=(
"https://ifconfig.me/ip"
"https://api.ipify.org"
"https://ipecho.net/plain"
"https://icanhazip.com"
"https://ident.me"
)
for service in "${services[@]}"; do
ip=$(curl -s --connect-timeout 10 --max-time 15 "$service" | tr -d '\n\r ')
# Verifica se o IP é válido (formato IPv4)
if [[ $ip =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]; then
# Valida se é IP válido
if [[ "$ip" =~ ^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$ ]]; then
echo "$ip"
return 0
fi
done
else
return 1
fi
}
# Função para extrair dados da configuração
# Função para extrair partes da config
parse_config() {
local config="$1"
local field="$2"
# Separa hostname:usuario:senha
local hostname=$(echo "$config" | cut -d':' -f1)
local username=$(echo "$config" | cut -d':' -f2)
local password=$(echo "$config" | cut -d':' -f3-)
@ -62,10 +47,11 @@ parse_config() {
esac
}
# Função para atualizar DDNS
# Atualiza DDNS usando IP e interface de envio
update_ddns() {
local current_ip="$1"
local config="$2"
local iface="$3"
local hostname=$(parse_config "$config" "hostname")
local username=$(parse_config "$config" "username")
@ -73,19 +59,19 @@ update_ddns() {
local update_url="${DDNS_URL}?hostname=${hostname}&myip=${current_ip}"
log_message "Atualizando DDNS para $hostname com IP: $current_ip (usuário: $username)"
log_message "Atualizando DDNS para $hostname com IP: $current_ip (usuário: $username) via interface $iface"
# Faz a requisição de atualização com autenticação HTTP Basic
local response=$(curl -s --connect-timeout 15 --max-time 30 \
--user "${username}:${password}" \
response=$(curl -s --interface "$iface" \
--connect-timeout 15 --max-time 30 \
--user "$username:$password" \
"$update_url")
local curl_exit_code=$?
if [ $curl_exit_code -eq 0 ]; then
log_message "$hostname atualizado com sucesso. Resposta: $response"
if [ $curl_exit_code -eq 0 ] && [[ "$response" == *"good"* || "$response" == *"nochg"* ]]; then
log_message "SUCESSO: $hostname atualizado com IP $current_ip. Resposta: $response"
return 0
else
log_message "✗ Erro ao atualizar $hostname (curl exit code: $curl_exit_code)"
log_message "FALHA: Falha ao atualizar $hostname. Código: $curl_exit_code, Resposta: $response"
return 1
fi
}
@ -94,86 +80,45 @@ update_ddns() {
main() {
log_message "=== Iniciando verificação de IP público ==="
# Verifica se há configurações
if [ ${#DDNS_CONFIGS[@]} -eq 0 ]; then
log_message "ERRO: Nenhuma configuração definida no array DDNS_CONFIGS"
exit 1
fi
# Valida se as configurações não são os exemplos padrão
local has_default=false
for config in "${DDNS_CONFIGS[@]}"; do
if [[ "$config" =~ ^subdominio[123]\.ddns\.com\.br:usuario[123]:senha[123]$ ]]; then
has_default=true
# Obtém IP de forma prioritária e determina a interface que será usada
current_ip=""
used_interface=""
for iface in "${INTERFACES_ORDERED[@]}"; do
ip=$(get_public_ip_from_interface "$iface")
if [ $? -eq 0 ]; then
current_ip="$ip"
used_interface="$iface"
log_message "IP público encontrado através da interface $iface: $current_ip"
break
else
log_message "Interface $iface não retornou IP válido. Tentando próxima..."
fi
done
if [ "$has_default" = true ]; then
log_message "ERRO: Configurações padrão detectadas! Configure seus domínios e credenciais reais"
exit 1
fi
# Lista os domínios configurados
local hostnames=()
for config in "${DDNS_CONFIGS[@]}"; do
hostnames+=($(parse_config "$config" "hostname"))
done
log_message "Domínios configurados: ${hostnames[*]}"
# Obtém o IP público atual
current_ip=$(get_public_ip)
if [ -z "$current_ip" ]; then
log_message "ERRO: Não foi possível obter o IP público"
log_message "ERRO: Nenhum IP público pôde ser determinado pelas interfaces especificadas."
exit 1
fi
log_message "IP público detectado: $current_ip"
success_count=0
fail_count=0
# Verifica se existe cache do último IP
if [ -f "$IP_CACHE_FILE" ]; then
last_ip=$(cat "$IP_CACHE_FILE" 2>/dev/null)
if [ "$current_ip" = "$last_ip" ]; then
log_message "IP não mudou ($current_ip), não é necessário atualizar"
exit 0
else
log_message "IP mudou de $last_ip para $current_ip"
fi
else
log_message "Primeira execução ou cache não encontrado"
fi
# Contador de sucessos/falhas
local success_count=0
local fail_count=0
# Atualiza cada domínio com suas credenciais
log_message "--- Iniciando atualizações ---"
for config in "${DDNS_CONFIGS[@]}"; do
if update_ddns "$current_ip" "$config"; then
if update_ddns "$current_ip" "$config" "$used_interface"; then
((success_count++))
else
((fail_count++))
fi
# Pequena pausa entre as requisições para não sobrecarregar o servidor
sleep 2
done
# Salva o IP no cache apenas se pelo menos uma atualização foi bem-sucedida
if [ $success_count -gt 0 ]; then
echo "$current_ip" > "$IP_CACHE_FILE"
log_message "=== Resumo: $success_count sucessos, $fail_count falhas ==="
log_message "IP $current_ip salvo no cache"
else
log_message "=== ERRO: Todas as atualizações falharam! ==="
exit 1
fi
log_message "=== Resumo: $success_count sucesso(s), $fail_count falha(s) ==="
log_message "=== Processo concluído ==="
}
# Executa o script principal
main "$@"
main