Milí majitelé routerů Turris,
toto fórum bylo 9. 12. 2016 zmrazeno a nahrazeno naším novým Turris fórem. Ještě chvíli bude dostupné k prohlížení, ale již zde není možné přispívat. Více informací naleznete v oznámení o uzavření fóra.
Dear Turris routers users,
this forum has been frozen on Dec 9th, 2016 and replaced by our new Turris forum. It will be read-only accessible for some time after. For more information, read the announcement about closing the forum.
/etc/config/network
vypadá takto:config interface 'wan6'
option proto '6in4'
option mtu '1480'
option 'peeraddr' '216.66.86.122' # adresa PoPu v Praze
option 'ip6addr' '2001:470:<xxx>::2/64' #spojovačka tunelu
option 'ip6prefix' '2001:470:<yyy>::/64' #nadelegovaný rozsah /64 nebo /48 (pozor, <xxx> a <yyy> jsou vždy různé)
#Následující volby platí pouze pro HE.net a slouží jen pro dynamickou aktualizaci IP adresy tunelu
option 'tunnelid' '<nnn>' #číselné ID tunelu
option 'username' '<username>'
option 'updatekey' '<updatekey>' #ve vlastnostech tunelu
/lib/netifd/proto/6in4.sh
. Bohužel jsem při hackování nebyl příliš důsledný, takže nemám k dispozici původní verzi, proto přikládám celý soubor tak jak funguje pro mě. Hlavní změna je v URL, na kterou se posílají aktualizace a použití políčka updatekey
namísto password
. V každém případě nový systém aktualizace podporuje standardní DynDNS formát, takže pro aktualizaci IP adresy je také možné použít DynDNS klienta zabudovaného v Turrisu.
#!/bin/sh # 6in4.sh - IPv6-in-IPv4 tunnel backend # Copyright (c) 2010-2012 OpenWrt.org [ -n "$INCLUDE_ONLY" ] || { . /lib/functions.sh . /lib/functions/network.sh . ../netifd-proto.sh init_proto "$@" } proto_6in4_setup() { local cfg="$1" local iface="$2" local link="6in4-$cfg" local mtu ttl ipaddr peeraddr ip6addr ip6prefix tunnelid username password updatekey json_get_vars mtu ttl ipaddr peeraddr ip6addr ip6prefix tunnelid username password updatekey [ -z "$peeraddr" ] && { proto_notify_error "$cfg" "MISSING_ADDRESS" proto_block_restart "$cfg" return } ( proto_add_host_dependency "$cfg" 0.0.0.0 ) [ -z "$ipaddr" ] && { local wanif if ! network_find_wan wanif || ! network_get_ipaddr ipaddr "$wanif"; then proto_notify_error "$cfg" "NO_WAN_LINK" return fi } proto_init_update "$link" 1 proto_add_ipv6_route "::" 0 [ -n "$ip6addr" ] && { local local6="${ip6addr%%/*}" local mask6="${ip6addr##*/}" [[ "$local6" = "$mask6" ]] && mask6= proto_add_ipv6_address "$local6" "$mask6" } [ -n "$ip6prefix" ] && proto_add_ipv6_prefix "$ip6prefix" proto_add_tunnel json_add_string mode sit json_add_int mtu "${mtu:-1280}" json_add_int ttl "${ttl:-64}" json_add_string local "$ipaddr" json_add_string remote "$peeraddr" proto_close_tunnel proto_send_update "$cfg" [ -n "$tunnelid" -a -n "$username" -a \( -n "$password" -o -n "$updatekey" \) ] && { [ "${#password}" == 32 -a -z "${password//[a-fA-F0-9]/}" ] || { password="$(echo -n "$password" | md5sum)"; password="${password%% *}" } [ -n "$updatekey" ] && password="$updatekey" local url="http://ipv4.tunnelbroker.net/nic/update?username=$username&password=$password&hostname=$tunnelid" local try=0 local max=3 while [ $((++try)) -le $max ]; do ( exec wget -qO/dev/null "$url" 2>/dev/null ) & local pid=$! ( sleep 5; kill $pid 2>/dev/null ) & wait $pid && break done } } proto_6in4_teardown() { local cfg="$1" } proto_6in4_init_config() { no_device=1 available=1 proto_config_add_string "ipaddr" proto_config_add_string "ip6addr" proto_config_add_string "ip6prefix" proto_config_add_string "peeraddr" proto_config_add_string "tunnelid" proto_config_add_string "username" proto_config_add_string "password" proto_config_add_string "updatekey" proto_config_add_int "mtu" proto_config_add_int "ttl" } [ -n "$INCLUDE_ONLY" ] || { add_protocol 6in4 }
Powered by mwForum 2.29.3 © 1999-2013 Markus Wichitill