Difference between revisions of "NAT Gateway by iptables dnsmasq"

From WebOS Internals
Jump to navigation Jump to search
(→‎Make dhcp/dns availalbe to usb0 (only do once): Added dhcp-host line restricted addresses to 1 address)
(major update / changed IPs to match the palm's default usb IP. this makes much easier to do this over ssh)
Line 9: Line 9:
 
reboot
 
reboot
 
</nowiki></pre>
 
</nowiki></pre>
 +
 +
 
==Make dhcp/dns availalbe to usb0 (only do once)==
 
==Make dhcp/dns availalbe to usb0 (only do once)==
 
get root terminal and use the following to make dhcp/dns available to usb0
 
get root terminal and use the following to make dhcp/dns available to usb0
Line 14: Line 16:
 
mount -o remount,rw /
 
mount -o remount,rw /
 
echo interface=usb0 >> /etc/dnsmasq.palm.conf
 
echo interface=usb0 >> /etc/dnsmasq.palm.conf
echo dhcp-host=192.169.2.1 >> /etc/dnsmasq.palm.conf
+
echo dhcp-host=192.169.0.202 >> /etc/dnsmasq.palm.conf
echo dhcp-range=192.168.2.2,192.168.2.2,15m >> /etc/dnsmasq.palm.conf
+
echo dhcp-range=192.168.0.203,192.168.0.203,15m >> /etc/dnsmasq.palm.conf
 
stop dnsmasq
 
stop dnsmasq
 
start dnsmasq
 
start dnsmasq
 
mount -o remount,ro /
 
mount -o remount,ro /
 
</nowiki></pre>
 
</nowiki></pre>
 +
 +
==Make Sure usb is correct address==
 +
Attach the usb cable between your computer and palm.
 +
Run <pre>ifconfig usb0</pre> on your palm and make sure the IP is 192.168.0.202
 +
 +
<pre><nowiki>
 +
ifconfig usb0 up
 +
ifconfig usb0 192.168.0.202
 +
</nowiki></pre>
 +
 +
Technically, you don't need this address but it sure makes it easier if you are using ssh to get your root terminal as this appears to be the default usb address :/
 +
 +
==A note on SSH root terminal==
 +
<b>novaterm</b> users skip this step.
 +
 +
You'll want to connect to the root terminal from here on out using usbnet. So open your computers connection to the usbnet.
  
 
==Setup packet forwarding to tether usb0 (cable) to ppp0 (EVDO)==
 
==Setup packet forwarding to tether usb0 (cable) to ppp0 (EVDO)==
Line 25: Line 43:
  
 
<pre><nowiki>
 
<pre><nowiki>
ifconfig usb0 up
 
ifconfig usb0 192.168.2.1
 
 
sysctl -w net.ipv4.conf.default.forwarding=1
 
sysctl -w net.ipv4.conf.default.forwarding=1
 
sysctl -w net.ipv4.conf.all.forwarding=1
 
sysctl -w net.ipv4.conf.all.forwarding=1
iptables -t nat -A POSTROUTING -o ppp0 -s 192.168.2.0/24 -j MASQUERADE
+
iptables -t nat -A POSTROUTING -o ppp0 -s 192.168.0.0/24 -j MASQUERADE
iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 3074 -j DNAT --to-destination 192.168.2.2
+
iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 3074 -j DNAT --to-destination 192.168.0.203
iptables -t nat -A PREROUTING -i ppp0 -p udp -m multiport --dports 88,3074 -j DNAT --to-destination 192.168.2.2
+
iptables -t nat -A PREROUTING -i ppp0 -p udp -m multiport --dports 88,3074 -j DNAT --to-destination 192.168.0.203
iptables -A FORWARD -i ppp0 -d 192.168.2.2 -p tcp --dport 3074 -j ACCEPT
+
iptables -A FORWARD -i ppp0 -d 192.168.0.203 -p tcp --dport 3074 -j ACCEPT
iptables -A FORWARD -i ppp0 -d 192.168.2.2 -p udp -m multiport --dports 88,3074 -j ACCEPT
+
iptables -A FORWARD -i ppp0 -d 192.168.0.203 -p udp -m multiport --dports 88,3074 -j ACCEPT
 
</nowiki></pre>
 
</nowiki></pre>
  
Line 40: Line 56:
  
 
<pre><nowiki>
 
<pre><nowiki>
ifconfig usb0 up
 
ifconfig usb0 192.168.2.1
 
 
sysctl -w net.ipv4.conf.default.forwarding=1
 
sysctl -w net.ipv4.conf.default.forwarding=1
 
sysctl -w net.ipv4.conf.all.forwarding=1
 
sysctl -w net.ipv4.conf.all.forwarding=1
iptables -t nat -A POSTROUTING -o eth0 -s 192.168.2.0/24 -j MASQUERADE
+
iptables -t nat -A POSTROUTING -o eth0 -s 192.168.0.0/24 -j MASQUERADE
iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 3074 -j DNAT --to-destination 192.168.2.2
+
iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 3074 -j DNAT --to-destination 192.168.0.203
iptables -t nat -A PREROUTING -i eth0 -p udp -m multiport --dports 88,3074 -j DNAT --to-destination 192.168.2.2
+
iptables -t nat -A PREROUTING -i eth0 -p udp -m multiport --dports 88,3074 -j DNAT --to-destination 192.168.0.203
iptables -A FORWARD -i eth0 -d 192.168.2.2 -p tcp --dport 3074 -j ACCEPT
+
iptables -A FORWARD -i eth0 -d 192.168.0.203 -p tcp --dport 3074 -j ACCEPT
iptables -A FORWARD -i eth0 -d 192.168.2.2 -p udp -m multiport --dports 88,3074 -j ACCEPT
+
iptables -A FORWARD -i eth0 -d 192.168.0.203 -p udp -m multiport --dports 88,3074 -j ACCEPT
 
</nowiki></pre>
 
</nowiki></pre>
  

Revision as of 04:12, 4 January 2011

The following guide can be followed on the palm to make a NAT gateway from a usb0 (tether) to ppp0 (EVDO). It is also possible this can be adapted to use a palm pre as a usb wireless adapter, that is NAT gateway from usb0 to eth0. Since wpa_supplicant and wireless tools are included with webos it is also possible that these could be adapted to build your own wifi hotspot from built in commands.

https://help.ubuntu.com/community/Internet/ConnectionSharing

Turn on USBnet on palm

get a root terminal and enter the commands: This requires a reboot so exit anything you're doing on your phone.

usbnet enable
reboot


Make dhcp/dns availalbe to usb0 (only do once)

get root terminal and use the following to make dhcp/dns available to usb0

mount -o remount,rw /
echo interface=usb0 >> /etc/dnsmasq.palm.conf
echo dhcp-host=192.169.0.202 >> /etc/dnsmasq.palm.conf
echo dhcp-range=192.168.0.203,192.168.0.203,15m >> /etc/dnsmasq.palm.conf
stop dnsmasq
start dnsmasq
mount -o remount,ro /

Make Sure usb is correct address

Attach the usb cable between your computer and palm.

Run

ifconfig usb0

on your palm and make sure the IP is 192.168.0.202

ifconfig usb0 up
ifconfig usb0 192.168.0.202

Technically, you don't need this address but it sure makes it easier if you are using ssh to get your root terminal as this appears to be the default usb address :/

A note on SSH root terminal

novaterm users skip this step.

You'll want to connect to the root terminal from here on out using usbnet. So open your computers connection to the usbnet.

Setup packet forwarding to tether usb0 (cable) to ppp0 (EVDO)

You will need to shut off wifi on your phone (it won't work otherwise). To do this tap on the upper left hand corner where the wifi icon is. Select "Wi-Fi" -> Turn off Wi-Fi

sysctl -w net.ipv4.conf.default.forwarding=1
sysctl -w net.ipv4.conf.all.forwarding=1
iptables -t nat -A POSTROUTING -o ppp0 -s 192.168.0.0/24 -j MASQUERADE
iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 3074 -j DNAT --to-destination 192.168.0.203
iptables -t nat -A PREROUTING -i ppp0 -p udp -m multiport --dports 88,3074 -j DNAT --to-destination 192.168.0.203
iptables -A FORWARD -i ppp0 -d 192.168.0.203 -p tcp --dport 3074 -j ACCEPT
iptables -A FORWARD -i ppp0 -d 192.168.0.203 -p udp -m multiport --dports 88,3074 -j ACCEPT

Setup packet forwarding to tether usb0 (cable) to eth0 (Wi-Fi)

Make sure your Wi-Fi is on and connected to an Access Point.

sysctl -w net.ipv4.conf.default.forwarding=1
sysctl -w net.ipv4.conf.all.forwarding=1
iptables -t nat -A POSTROUTING -o eth0 -s 192.168.0.0/24 -j MASQUERADE
iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 3074 -j DNAT --to-destination 192.168.0.203
iptables -t nat -A PREROUTING -i eth0 -p udp -m multiport --dports 88,3074 -j DNAT --to-destination 192.168.0.203
iptables -A FORWARD -i eth0 -d 192.168.0.203 -p tcp --dport 3074 -j ACCEPT
iptables -A FORWARD -i eth0 -d 192.168.0.203 -p udp -m multiport --dports 88,3074 -j ACCEPT

Setup your computer

On Ubuntu Linux 10.04 in network manager right click the icon select "Edit Connections". Find the wired interface probably named "Auto usb" edit and uncheck "connect automatically" box.

Windows / Mac instructions coming soon.

Trouble Shooting

Make sure both these values are 1.

sysctl net.ipv4.conf.default.forwarding net.ipv4.conf.all.forwarding

Beware, the palms seems to like setting this to 0 whenever network settings are changed.

References