Re: new target - ebtables dynamic snat, kernel and userspace patch

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Shai Tahar wrote:
in case you manipulate the data in the connection, such as in tproxy scenario (squid etc') a new connection goes out (with the same tuple) but the mac address is diffrent (the source mac is the device interface)

assuming A,B,C are mac address and 1,2,3 are ip address

[user]<--->[transparent bridge]<--->[server]
A1 B2 C3


Your next steps misunderstand how MAC addresses work. MAC changes at each physical NIC card plugged into the cable.

Corrections follow...

user initiates a connection A1--->C3

Correction:
 user initiates query A1---->?3
 network responds  ===> go to 3 via B
 user initiates connection A1--->B3


the connection is redirected into B2,

Correction:
   the connection succeeds.
   packets get forwarded

NORMAL OPERATION:
   B2 relays packets to C3...
   server sends reply packets C3--->B1

  B2 proceeds to shuffle packets like so
   out A1-->B3::B1-->C3
   and back C3-->B1::B3-->A1

the connection is terminated as a socket to a local application on the traparent bridge machine.

YOUR SCENARIO OPERATION:

  B2 relays packets to local app.

  local app initiates query B1---->?3
  network responds  ===> go to 3 via C
  local app initiates connection B1--->C3


  B2 proceeds to shuffle packets like so
   out A1-->B3:local-app:B1-->C3
   and back  C3-->B1:local-app:B3-->A1


As you can see there is no difference between normal correct MAC operation and the existing tproxy scenario as viewed by C3 and A1.


AYJ


a new connection goes out from B2, masked as B1--->C3 (the target changes B1 into A1) in return, the server answers A1 C3--->A1, the connection is redirected into the localhost
the data then forwarded to the user B3--->A1 (the target changes B3 int C3)

Shai Tahar
Storwize

Jan Engelhardt wrote:
On Thursday 2009-09-24 09:43, Shai Tahar wrote:

---- README ---
ebt_dyn_snat - ebtable dynamic snat
   Authors:
     Shai Tahar <shai.tahar@xxxxxxxxxxxx>

Changes source mac address according to source ip address based on local
arp table
   to be used when source ip address is snated

Copyright (C) 2009 Storwize

ebtables target for transparent bridge
[user]<--->[transparent bridge]<--->[server]

if the transparent bridge maskes user ip address towards the server,
the bridge normally would replace the source mac address

Well, if you want to have the client's original MAC address in the
packet, do not SNAT it. It (seems) as simple as that.

Even better, plug the client machine directly into the server NIC.

Amos
--
Please be using
  Current Stable Squid 2.7.STABLE7 or 3.0.STABLE19
  Current Beta Squid 3.1.0.13
--
To unsubscribe from this list: send the line "unsubscribe netfilter-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Netfitler Users]     [LARTC]     [Bugtraq]     [Yosemite Forum]

  Powered by Linux