summaryrefslogtreecommitdiffstats
path: root/src/conntrack/copy.c
diff options
context:
space:
mode:
authorPablo Neira Ayuso <pablo@netfilter.org>2018-03-13 18:44:11 +0100
committerPablo Neira Ayuso <pablo@netfilter.org>2018-03-24 21:37:32 +0100
commit2edc7ccd872c60f4a71218e34e737655d6e50efa (patch)
tree4294844e1e3f7b81f907f618ea09943552878b09 /src/conntrack/copy.c
parente870432649955d377a73ee5a72cb23f0f6b5e4c5 (diff)
conntrack: add synproxy support
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/conntrack/copy.c')
-rw-r--r--src/conntrack/copy.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/conntrack/copy.c b/src/conntrack/copy.c
index e6e4f7a..eca202e 100644
--- a/src/conntrack/copy.c
+++ b/src/conntrack/copy.c
@@ -498,6 +498,24 @@ static void copy_attr_connlabels_mask(struct nf_conntrack *dest,
dest->connlabels_mask = do_copy_attr_connlabels(dest->connlabels_mask, orig->connlabels_mask);
}
+static void copy_attr_synproxy_its(struct nf_conntrack *dest,
+ const struct nf_conntrack *orig)
+{
+ dest->synproxy.its = orig->synproxy.its;
+}
+
+static void copy_attr_synproxy_isn(struct nf_conntrack *dest,
+ const struct nf_conntrack *orig)
+{
+ dest->synproxy.isn = orig->synproxy.isn;
+}
+
+static void copy_attr_synproxy_tsoff(struct nf_conntrack *dest,
+ const struct nf_conntrack *orig)
+{
+ dest->synproxy.tsoff = orig->synproxy.tsoff;
+}
+
const copy_attr copy_attr_array[ATTR_MAX] = {
[ATTR_ORIG_IPV4_SRC] = copy_attr_orig_ipv4_src,
[ATTR_ORIG_IPV4_DST] = copy_attr_orig_ipv4_dst,
@@ -571,6 +589,9 @@ const copy_attr copy_attr_array[ATTR_MAX] = {
[ATTR_CONNLABELS_MASK] = copy_attr_connlabels_mask,
[ATTR_SNAT_IPV6] = copy_attr_snat_ipv6,
[ATTR_DNAT_IPV6] = copy_attr_dnat_ipv6,
+ [ATTR_SYNPROXY_ITS] = copy_attr_synproxy_its,
+ [ATTR_SYNPROXY_ISN] = copy_attr_synproxy_isn,
+ [ATTR_SYNPROXY_TSOFF] = copy_attr_synproxy_tsoff,
};
/* this is used by nfct_copy() with the NFCT_CP_OVERRIDE flag set. */