File: schema

package info (click to toggle)
fiaif 1.19.2-11
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 1,444 kB
  • ctags: 188
  • sloc: sh: 2,936; awk: 531; makefile: 330; perl: 23; ansic: 10
file content (198 lines) | stat: -rw-r--r-- 4,057 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
/*****************************************************************************
 * FIAIF is an Intelligent firewall, version: $Revision: 1.140 $
 *
 * description: Automates a packet filtering firewall with iptables.
 *
 * Script Author:	Anders Fugmann <afu@fugmann.net>
 * 
 * FIAIF is an Intelligent firewall
 * Copyright (C) 2002-2004 Anders Peter Fugmann
 *
 * 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.
 ****************************************************************************/ 

/* This file contains the schema files for an sql database interface. */

/* The Zone table */
CREATE TABLE Zone (
	id INTEGER PRIMARY KEY,
	name TEXT
	dynamic INTEGER,
	global INTEGER,
	dhcp_server INTEGER
);

/* The Device table. Only one for each zone */
CREATE TABLE Device (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	ip TEXT,	
	net TEXT,
	mask TEXT,
	bcast TEXT,
	ip_extra TEXT,
	net_extra TEXT
);

/* A table for all available targets, used by INPUT, OUTPUT and FORWARD rules */
CREATE TABLE Targets (
	id INTEGER PRIMARY KEY,
	name TEXT
);

/* Helper table to specify a filter */
CREATE TABLE Filter (
	id INTEGER PRIMARY KEY,
	protocol TEXT,
	port TEXT,
	source_ip TEXT,
	dest_ip TEXT
);

/* The INPUT rules */
CREATE TABLE Input (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	target_id INTEGER,
	filter_id INTEGER
);

/* The OUTPUT rules */
CREATE TABLE Output (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	target_id INTEGER,
	filter_id INTEGER
);

/* The Forward rules */
CREATE TABLE Forward (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	source_zone_id INTEGER,
	target_id INTEGER,
	filter_id INTEGER
);

/* The Mark rules */
CREATE TABLE Mark (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	source_zone_id INTEGER,
	mark INTEGER,
	filter_id INTEGER
);

/* Table of all possible reply types */
CREATE TABLE ReplyType (
	id INTEGER PRIMARY KEY,
	type TEXT
);

/* Reply rule */
CREATE TABLE Reply (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	source_zone_id INTEGER,
	reply_type_id INTEGER,
	fitler_id INTEGER
);

/* Redirect rule */
CREATE TABLE Redirect (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	filter_id INTEGER,
	dest_ip TEXT,
	dest_port TEXT
);

/* IP_WATCH rule */
CREATE TABLE WatchIp (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	ip TEXT
);

/* ECN_REMOVE rule */
CREATE TABLE EcnRemove (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	ip TEXT
);

/* MAC_DROP rule */
CREATE TABLE MacDrop (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	MAC TEXT
);

/* IP_DROP rules */
CREATE TABLE IpDrop (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	ip TEXT
);

/* SNAT rules */
CREATE TABLE Snat (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	dest_zone_id INTEGER,
	filter_id INTEGER
);

/* Limit time types */
CREATE TABLE LimitTime (
	id INTEGER PRIMARY KEY,
	time TEXT
);

/* LIMIT rules */
CREATE TABLE Limit (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	order INTEGER,
	source_zone_id INTEGER,
	limit_nr INTEGER,
	limit_id INTEGER,
	burst INTEGER,
	target_id INTEGER,
	filter_id INTEGER
);

/* All supported shaping types (eg. CFQ, HTB) */
CREATE TABLE ShapeTypes (
	id INTEGER PRIMARY KEY,
	type TEXT
);

/* Traffic shaping setup */
CREATE TABLE TrafficShaping (
	id INTEGER PRIMARY KEY,
	zone_id INTEGER,
	enabled INTEGER
	type_id INTEGER,
	downlink INTEGER,
	uplink INTEGER	
);