1 | /* $NetBSD: ip_scan.h,v 1.3 2012/07/22 14:27:51 darrenr Exp $ */ |
2 | |
3 | /* |
4 | * Copyright (C) 2012 by Darren Reed. |
5 | * |
6 | * See the IPFILTER.LICENCE file for details on licencing. |
7 | * |
8 | * @(#)ip_fil.h 1.35 6/5/96 |
9 | * Id: ip_scan.h,v 1.1.1.2 2012/07/22 13:45:34 darrenr Exp |
10 | */ |
11 | |
12 | #ifndef __IP_SCAN_H__ |
13 | #define __IP_SCAN_H__ 1 |
14 | |
15 | #ifdef sun |
16 | # include <sys/ioccom.h> |
17 | #endif |
18 | |
19 | #define IPSCAN_NAME "/dev/ipscan" |
20 | #define IPL_SCAN IPSCAN_NAME |
21 | #define ISC_TLEN 16 |
22 | |
23 | |
24 | struct fr_info; |
25 | struct frentry; |
26 | struct ip; |
27 | struct ipstate; |
28 | |
29 | |
30 | #if defined(__STDC__) || defined(__GNUC__) || defined(_AIX51) |
31 | # define SIOCADSCA _IOWR('r', 60, struct ipscan *) |
32 | # define SIOCRMSCA _IOWR('r', 61, struct ipscan *) |
33 | # define SIOCGSCST _IOWR('r', 62, struct ipscan *) |
34 | #else |
35 | # define SIOCADSCA _IOWR(r, 60, struct ipscan *) |
36 | # define SIOCRMSCA _IOWR(r, 61, struct ipscan *) |
37 | # define SIOCGSCST _IOWR(r, 62, struct ipscan *) |
38 | #endif |
39 | |
40 | struct action { |
41 | int act_val; /* what to do */ |
42 | struct in_addr act_ip; /* redirect IP# */ |
43 | u_short act_port; /* redirect port number */ |
44 | int act_else; /* what to do */ |
45 | struct in_addr act_eip; /* redirect IP# */ |
46 | u_short act_eport; /* redirect port number */ |
47 | }; |
48 | |
49 | |
50 | typedef struct sinfo { |
51 | char s_txt[ISC_TLEN]; /* text to match */ |
52 | char s_msk[ISC_TLEN]; /* mask of the above to check */ |
53 | int s_len; /* length of server text */ |
54 | } sinfo_t; |
55 | |
56 | |
57 | typedef struct ipscan { |
58 | struct ipscan *ipsc_next; |
59 | struct ipscan **ipsc_pnext; |
60 | char ipsc_tag[ISC_TLEN]; /* table entry protocol tag */ |
61 | sinfo_t ipsc_si[2]; /* client/server side information */ |
62 | int ipsc_hits; /* times this has been matched */ |
63 | int ipsc_active; /* # of active matches */ |
64 | int ipsc_fref; /* # of references from filter rules */ |
65 | int ipsc_sref; /* # of references from state entries */ |
66 | struct action ipsc_act; |
67 | } ipscan_t; |
68 | |
69 | |
70 | #define ipsc_cl ipsc_si[0] |
71 | #define ipsc_sl ipsc_si[1] |
72 | #define ipsc_ctxt ipsc_cl.s_txt |
73 | #define ipsc_cmsk ipsc_cl.s_msk |
74 | #define ipsc_clen ipsc_cl.s_len |
75 | #define ipsc_stxt ipsc_sl.s_txt |
76 | #define ipsc_smsk ipsc_sl.s_msk |
77 | #define ipsc_slen ipsc_sl.s_len |
78 | #define ipsc_action ipsc_act.act_val |
79 | #define ipsc_ip ipsc_act.act_ip |
80 | #define ipsc_port ipsc_act.act_port |
81 | #define ipsc_else ipsc_act.act_else |
82 | #define ipsc_eip ipsc_act.act_eip |
83 | #define ipsc_eport ipsc_act.act_eport |
84 | |
85 | #define ISC_A_NONE 0 |
86 | #define ISC_A_TRACK 1 |
87 | #define ISC_A_CLOSE 2 |
88 | #define ISC_A_REDIRECT 3 |
89 | |
90 | |
91 | typedef struct ipscanstat { |
92 | struct ipscan *iscs_list; |
93 | u_long iscs_acted; |
94 | u_long iscs_else; |
95 | int iscs_entries; |
96 | } ipscanstat_t; |
97 | |
98 | |
99 | extern int ipf_scan_ioctl(ipf_main_softc_t *, void *, ioctlcmd_t, int, int, void *); |
100 | extern int ipf_scan_init(void); |
101 | extern int ipf_scan_attachis(struct ipstate *); |
102 | extern int ipf_scan_attachfr(struct frentry *); |
103 | extern int ipf_scan_detachis(struct ipstate *); |
104 | extern int ipf_scan_detachfr(struct frentry *); |
105 | extern int ipf_scan_packet(struct fr_info *, struct ipstate *); |
106 | extern void ipf_scan_unload(ipf_main_softc_t *); |
107 | |
108 | #endif /* __IP_SCAN_H__ */ |
109 | |