/* * Copyright (c) 2003+ Evgeniy Polyakov <johnpol@2ka.mxt.ru> * * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _XT_OSF_H #define _XT_OSF_H #include <linux/types.h> #define MAXGENRELEN 32 #define XT_OSF_GENRE (1<<0) #define XT_OSF_TTL (1<<1) #define XT_OSF_LOG (1<<2) #define XT_OSF_INVERT (1<<3) #define XT_OSF_LOGLEVEL_ALL 0 /* log all matched fingerprints */ #define XT_OSF_LOGLEVEL_FIRST 1 /* log only the first matced fingerprint */ #define XT_OSF_LOGLEVEL_ALL_KNOWN 2 /* do not log unknown packets */ #define XT_OSF_TTL_TRUE 0 /* True ip and fingerprint TTL comparison */ #define XT_OSF_TTL_LESS 1 /* Check if ip TTL is less than fingerprint one */ #define XT_OSF_TTL_NOCHECK 2 /* Do not compare ip and fingerprint TTL at all */ struct xt_osf_info { char genre[MAXGENRELEN]; __u32 len; __u32 flags; __u32 loglevel; __u32 ttl; }; /* * Wildcard MSS (kind of). * It is used to implement a state machine for the different wildcard values * of the MSS and window sizes. */ struct xt_osf_wc { __u32 wc; __u32 val; }; /* * This struct represents IANA options * http://www.iana.org/assignments/tcp-parameters */ struct xt_osf_opt { __u16 kind, length; struct xt_osf_wc wc; }; struct xt_osf_user_finger { struct xt_osf_wc wss; __u8 ttl, df; __u16 ss, mss; __u16 opt_num; char genre[MAXGENRELEN]; char version[MAXGENRELEN]; char subtype[MAXGENRELEN]; /* MAX_IPOPTLEN is maximum if all options are NOPs or EOLs */ struct xt_osf_opt opt[MAX_IPOPTLEN]; }; struct xt_osf_nlmsg { struct xt_osf_user_finger f; struct iphdr ip; struct tcphdr tcp; }; /* Defines for IANA option kinds */ enum iana_options { OSFOPT_EOL = 0, /* End of options */ OSFOPT_NOP, /* NOP */ OSFOPT_MSS, /* Maximum segment size */ OSFOPT_WSO, /* Window scale option */ OSFOPT_SACKP, /* SACK permitted */ OSFOPT_SACK, /* SACK */ OSFOPT_ECHO, OSFOPT_ECHOREPLY, OSFOPT_TS, /* Timestamp option */ OSFOPT_POCP, /* Partial Order Connection Permitted */ OSFOPT_POSP, /* Partial Order Service Profile */ /* Others are not used in the current OSF */ OSFOPT_EMPTY = 255, }; /* * Initial window size option state machine: multiple of mss, mtu or * plain numeric value. Can also be made as plain numeric value which * is not a multiple of specified value. */ enum xt_osf_window_size_options { OSF_WSS_PLAIN = 0, OSF_WSS_MSS, OSF_WSS_MTU, OSF_WSS_MODULO, OSF_WSS_MAX, }; /* * Add/remove fingerprint from the kernel. */ enum xt_osf_msg_types { OSF_MSG_ADD, OSF_MSG_REMOVE, OSF_MSG_MAX, }; enum xt_osf_attr_type { OSF_ATTR_UNSPEC, OSF_ATTR_FINGER, OSF_ATTR_MAX, }; #endif /* _XT_OSF_H */
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
ipset | Folder | 0755 |
|
|
nf_conntrack_common.h | File | 4.09 KB | 0644 |
|
nf_conntrack_ftp.h | File | 375 B | 0644 |
|
nf_conntrack_sctp.h | File | 595 B | 0644 |
|
nf_conntrack_tcp.h | File | 1.24 KB | 0644 |
|
nf_conntrack_tuple_common.h | File | 708 B | 0644 |
|
nf_nat.h | File | 1.12 KB | 0644 |
|
nf_tables.h | File | 31.31 KB | 0644 |
|
nf_tables_compat.h | File | 668 B | 0644 |
|
nfnetlink.h | File | 2.01 KB | 0644 |
|
nfnetlink_acct.h | File | 522 B | 0644 |
|
nfnetlink_compat.h | File | 2.33 KB | 0644 |
|
nfnetlink_conntrack.h | File | 5.42 KB | 0644 |
|
nfnetlink_cthelper.h | File | 1.11 KB | 0644 |
|
nfnetlink_cttimeout.h | File | 2.8 KB | 0644 |
|
nfnetlink_log.h | File | 2.51 KB | 0644 |
|
nfnetlink_queue.h | File | 2.88 KB | 0644 |
|
x_tables.h | File | 4.3 KB | 0644 |
|
xt_AUDIT.h | File | 655 B | 0644 |
|
xt_CHECKSUM.h | File | 500 B | 0644 |
|
xt_CLASSIFY.h | File | 154 B | 0644 |
|
xt_CONNMARK.h | File | 136 B | 0644 |
|
xt_CONNSECMARK.h | File | 238 B | 0644 |
|
xt_CT.h | File | 790 B | 0644 |
|
xt_DSCP.h | File | 634 B | 0644 |
|
xt_HMARK.h | File | 841 B | 0644 |
|
xt_IDLETIMER.h | File | 1.3 KB | 0644 |
|
xt_LED.h | File | 407 B | 0644 |
|
xt_LOG.h | File | 579 B | 0644 |
|
xt_MARK.h | File | 121 B | 0644 |
|
xt_NFLOG.h | File | 326 B | 0644 |
|
xt_NFQUEUE.h | File | 716 B | 0644 |
|
xt_RATEEST.h | File | 305 B | 0644 |
|
xt_SECMARK.h | File | 486 B | 0644 |
|
xt_TCPMSS.h | File | 172 B | 0644 |
|
xt_TCPOPTSTRIP.h | File | 344 B | 0644 |
|
xt_TEE.h | File | 240 B | 0644 |
|
xt_TPROXY.h | File | 483 B | 0644 |
|
xt_addrtype.h | File | 1021 B | 0644 |
|
xt_bpf.h | File | 340 B | 0644 |
|
xt_cgroup.h | File | 149 B | 0644 |
|
xt_cluster.h | File | 311 B | 0644 |
|
xt_comment.h | File | 167 B | 0644 |
|
xt_connbytes.h | File | 514 B | 0644 |
|
xt_connlabel.h | File | 217 B | 0644 |
|
xt_connlimit.h | File | 512 B | 0644 |
|
xt_connmark.h | File | 691 B | 0644 |
|
xt_conntrack.h | File | 2.43 KB | 0644 |
|
xt_cpu.h | File | 136 B | 0644 |
|
xt_dccp.h | File | 420 B | 0644 |
|
xt_devgroup.h | File | 366 B | 0644 |
|
xt_dscp.h | File | 638 B | 0644 |
|
xt_ecn.h | File | 673 B | 0644 |
|
xt_esp.h | File | 355 B | 0644 |
|
xt_hashlimit.h | File | 1.83 KB | 0644 |
|
xt_helper.h | File | 125 B | 0644 |
|
xt_iprange.h | File | 518 B | 0644 |
|
xt_ipvs.h | File | 588 B | 0644 |
|
xt_length.h | File | 158 B | 0644 |
|
xt_limit.h | File | 610 B | 0644 |
|
xt_mac.h | File | 135 B | 0644 |
|
xt_mark.h | File | 197 B | 0644 |
|
xt_multiport.h | File | 658 B | 0644 |
|
xt_nfacct.h | File | 238 B | 0644 |
|
xt_osf.h | File | 3.27 KB | 0644 |
|
xt_owner.h | File | 306 B | 0644 |
|
xt_physdev.h | File | 469 B | 0644 |
|
xt_pkttype.h | File | 125 B | 0644 |
|
xt_policy.h | File | 914 B | 0644 |
|
xt_quota.h | File | 337 B | 0644 |
|
xt_rateest.h | File | 774 B | 0644 |
|
xt_realm.h | File | 157 B | 0644 |
|
xt_recent.h | File | 966 B | 0644 |
|
xt_rpfilter.h | File | 257 B | 0644 |
|
xt_sctp.h | File | 2.22 KB | 0644 |
|
xt_set.h | File | 1.72 KB | 0644 |
|
xt_socket.h | File | 382 B | 0644 |
|
xt_state.h | File | 268 B | 0644 |
|
xt_statistic.h | File | 653 B | 0644 |
|
xt_string.h | File | 601 B | 0644 |
|
xt_tcpmss.h | File | 190 B | 0644 |
|
xt_tcpudp.h | File | 1.16 KB | 0644 |
|
xt_time.h | File | 667 B | 0644 |
|
xt_u32.h | File | 689 B | 0644 |
|