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
);
|