<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN">
<html><body style='font-family: Arial,Helvetica,sans-serif'>
<p>How about:</p>
<p>iptables -I POSTROUTING -s 172.x.x.x/x -d 131.x.x.x -j SNAT<strong>&nbsp;</strong>--to-source 10.131.x.x<br />You should be able to leave out the "-s 172.x.x.x/x" bit if you want.</p>
<p>You will also need a route on your local gateway device to route all traffic to 131.x.x.x via leftsourceip.</p>
<p>This may not work because I don't know if the POSTROUTING chain will do anything to packets destined for the VPN. No promises here.</p>
<p>Nick</p>
<p>On 2013-09-23 08:38, Morten Brix Pedersen wrote:</p>
<blockquote type="cite" style="padding-left:5px; border-left:#1010ff 2px solid; margin-left:5px"><!-- html ignored --><!-- head ignored --><!-- meta ignored -->
<div dir="ltr">Hi,
<div>&nbsp;</div>
<div>I have the following setup:</div>
<div>&nbsp;</div>
<div>Side A (me):</div>
<div>Local ip: 172.x.x.x</div>
<div>Public ip: z.z.z.z</div>
<div>&nbsp;</div>
<div>Side B (them):</div>
<div>Remote ip: y.y.y.y</div>
<div>&nbsp;</div>
<div>They have assigned me address 10.131.x.x which I must NAT all traffic through to get to server ip 131.x.x.x. My server only has one network interface (eth0, with address 172.x.x.x)</div>
<div>&nbsp;</div>
<div>So this is my configuration:</div>
<div>&nbsp;</div>
<div>
<div>conn vpn</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; authby=secret</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; forceencaps=yes</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; auto=start</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; left=%defaultroute</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; leftid=z.z.z.z</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; leftsourceip=z.z.z.z</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; leftsubnet=10.131.x.x/32</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; right=y.y.y.y</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; rightid=y.y.y.y</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; rightsubnet=10.172.x.x/32</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; phase2alg=aes256-sha1</div>
<div>&nbsp; &nbsp; &nbsp; &nbsp; pfs=no</div>
</div>
<div>&nbsp;</div>
<div>The VPN tunnel is established:</div>
<div>&nbsp;</div>
<div>
<div>000 "vpn": 10.131.x.x/32===172.x.x.x[z.z.z.z]...y.y.y.y&lt;y.y.y.y&gt;===10.172.x.x/32; erouted; eroute owner: #3</div>
<div>000 "vpn": &nbsp; &nbsp; myip=z.z.z.z; hisip=unset;</div>
<div>000 "vpn": &nbsp; ike_life: 3600s; ipsec_life: 28800s; rekey_margin: 540s; rekey_fuzz: 100%; keyingtries: 0</div>
<div>000 "vpn": &nbsp; policy: PSK+ENCRYPT+TUNNEL+UP+IKEv2ALLOW+SAREFTRACK+lKOD+rKOD; prio: 32,32; interface: eth0;</div>
<div>000 "vpn": &nbsp; newest ISAKMP SA: #1; newest IPsec SA: #3;</div>
<div>000 "vpn": &nbsp; IKE algorithm newest: 3DES_CBC_192-SHA1-MODP1024</div>
<div>000 "vpn": &nbsp; ESP algorithms wanted: AES(12)_256-SHA1(2)_000; flags=-strict</div>
<div>000 "vpn": &nbsp; ESP algorithms loaded: AES(12)_256-SHA1(2)_160</div>
<div>000 "vpn": &nbsp; ESP algorithm newest: AES_256-HMAC_SHA1; pfsgroup=&lt;N/A&gt;</div>
<div>000</div>
<div>000 #3: "vpn":4500 STATE_QUICK_I2 (sent QI2, IPsec SA established); EVENT_SA_REPLACE in 27560s; newest IPSEC; eroute owner; isakmp#1; idle; import:admin initiate</div>
<div>000 #3: "vpn" esp.86884638@y.y.y.y <a href="mailto:esp.a7324109@172.31.2.203">esp.a7324109@172.31.2.203</a> tun.0@y.y.y.y tun.0@172.31.x.x ref=0 refhim=4294901761</div>
<div>000 #1: "vpn":4500 STATE_MAIN_I4 (ISAKMP SA established); EVENT_SA_REPLACE in 2076s; newest ISAKMP; lastdpd=4s(seq in:0 out:0); idle; import:admin initiate</div>
</div>
<div>&nbsp;</div>
<div>&nbsp;</div>
<div>Now I must access server ip 131.x.x.x but NAT it through our assigned ip address 1.131.x.x.</div>
<div>&nbsp;</div>
<div>How can I do that?</div>
<div>&nbsp;</div>
<div>Thanks.</div>
<div>&nbsp;</div>
<div>&nbsp;- Morten.</div>
</div>
<br />
<pre>_______________________________________________
<a href="mailto:Users@lists.openswan.org">Users@lists.openswan.org</a>
<a href="https://lists.openswan.org/mailman/listinfo/users">https://lists.openswan.org/mailman/listinfo/users</a>
Micropayments: <a href="https://flattr.com/thing/38387/IPsec-for-Linux-made-easy">https://flattr.com/thing/38387/IPsec-for-Linux-made-easy</a>
Building and Integrating Virtual Private Networks with Openswan:
<a href="http://www.amazon.com/gp/product/1904811256/104-3099591-2946327?n=283155">http://www.amazon.com/gp/product/1904811256/104-3099591-2946327?n=283155</a>
</pre>
</blockquote>
</body></html>