109 lines
2.9 KiB
C
109 lines
2.9 KiB
C
/* $NetBSD: ip_scan.h,v 1.2 2012/07/22 14:27:35 darrenr Exp $ */
|
|
|
|
/*
|
|
* Copyright (C) 2012 by Darren Reed.
|
|
*
|
|
* See the IPFILTER.LICENCE file for details on licencing.
|
|
*
|
|
* @(#)ip_fil.h 1.35 6/5/96
|
|
* Id: ip_scan.h,v 1.1.1.2 2012/07/22 13:44:24 darrenr Exp $
|
|
*/
|
|
|
|
#ifndef __IP_SCAN_H__
|
|
#define __IP_SCAN_H__ 1
|
|
|
|
#ifdef sun
|
|
# include <sys/ioccom.h>
|
|
#endif
|
|
|
|
#define IPSCAN_NAME "/dev/ipscan"
|
|
#define IPL_SCAN IPSCAN_NAME
|
|
#define ISC_TLEN 16
|
|
|
|
|
|
struct fr_info;
|
|
struct frentry;
|
|
struct ip;
|
|
struct ipstate;
|
|
|
|
|
|
#if defined(__STDC__) || defined(__GNUC__) || defined(_AIX51)
|
|
# define SIOCADSCA _IOWR('r', 60, struct ipscan *)
|
|
# define SIOCRMSCA _IOWR('r', 61, struct ipscan *)
|
|
# define SIOCGSCST _IOWR('r', 62, struct ipscan *)
|
|
#else
|
|
# define SIOCADSCA _IOWR(r, 60, struct ipscan *)
|
|
# define SIOCRMSCA _IOWR(r, 61, struct ipscan *)
|
|
# define SIOCGSCST _IOWR(r, 62, struct ipscan *)
|
|
#endif
|
|
|
|
struct action {
|
|
int act_val; /* what to do */
|
|
struct in_addr act_ip; /* redirect IP# */
|
|
u_short act_port; /* redirect port number */
|
|
int act_else; /* what to do */
|
|
struct in_addr act_eip; /* redirect IP# */
|
|
u_short act_eport; /* redirect port number */
|
|
};
|
|
|
|
|
|
typedef struct sinfo {
|
|
char s_txt[ISC_TLEN]; /* text to match */
|
|
char s_msk[ISC_TLEN]; /* mask of the above to check */
|
|
int s_len; /* length of server text */
|
|
} sinfo_t;
|
|
|
|
|
|
typedef struct ipscan {
|
|
struct ipscan *ipsc_next;
|
|
struct ipscan **ipsc_pnext;
|
|
char ipsc_tag[ISC_TLEN]; /* table entry protocol tag */
|
|
sinfo_t ipsc_si[2]; /* client/server side information */
|
|
int ipsc_hits; /* times this has been matched */
|
|
int ipsc_active; /* # of active matches */
|
|
int ipsc_fref; /* # of references from filter rules */
|
|
int ipsc_sref; /* # of references from state entries */
|
|
struct action ipsc_act;
|
|
} ipscan_t;
|
|
|
|
|
|
#define ipsc_cl ipsc_si[0]
|
|
#define ipsc_sl ipsc_si[1]
|
|
#define ipsc_ctxt ipsc_cl.s_txt
|
|
#define ipsc_cmsk ipsc_cl.s_msk
|
|
#define ipsc_clen ipsc_cl.s_len
|
|
#define ipsc_stxt ipsc_sl.s_txt
|
|
#define ipsc_smsk ipsc_sl.s_msk
|
|
#define ipsc_slen ipsc_sl.s_len
|
|
#define ipsc_action ipsc_act.act_val
|
|
#define ipsc_ip ipsc_act.act_ip
|
|
#define ipsc_port ipsc_act.act_port
|
|
#define ipsc_else ipsc_act.act_else
|
|
#define ipsc_eip ipsc_act.act_eip
|
|
#define ipsc_eport ipsc_act.act_eport
|
|
|
|
#define ISC_A_NONE 0
|
|
#define ISC_A_TRACK 1
|
|
#define ISC_A_CLOSE 2
|
|
#define ISC_A_REDIRECT 3
|
|
|
|
|
|
typedef struct ipscanstat {
|
|
struct ipscan *iscs_list;
|
|
u_long iscs_acted;
|
|
u_long iscs_else;
|
|
int iscs_entries;
|
|
} ipscanstat_t;
|
|
|
|
|
|
extern int ipf_scan_ioctl __P((ipf_main_softc_t *, caddr_t, ioctlcmd_t, int, int, void *));
|
|
extern int ipf_scan_init __P((void));
|
|
extern int ipf_scan_attachis __P((struct ipstate *));
|
|
extern int ipf_scan_attachfr __P((struct frentry *));
|
|
extern int ipf_scan_detachis __P((struct ipstate *));
|
|
extern int ipf_scan_detachfr __P((struct frentry *));
|
|
extern int ipf_scan_packet __P((struct fr_info *, struct ipstate *));
|
|
extern void ipf_scan_unload __P((ipf_main_softc_t *));
|
|
|
|
#endif /* __IP_SCAN_H__ */
|