2015-03-12 14:03:53 -07:00
|
|
|
CREATE TABLE Config (
|
|
|
|
k varchar(16) PRIMARY KEY NOT NULL,
|
|
|
|
v varchar(1024) NOT NULL
|
2015-03-13 13:53:15 -07:00
|
|
|
);
|
2015-03-12 14:03:53 -07:00
|
|
|
|
2015-06-11 11:35:25 +02:00
|
|
|
CREATE TABLE Network (
|
|
|
|
id char(16) PRIMARY KEY NOT NULL,
|
|
|
|
name varchar(128) NOT NULL,
|
|
|
|
private integer NOT NULL DEFAULT(1),
|
|
|
|
enableBroadcast integer NOT NULL DEFAULT(1),
|
|
|
|
allowPassiveBridging integer NOT NULL DEFAULT(0),
|
|
|
|
v4AssignMode varchar(8) NOT NULL DEFAULT('none'),
|
|
|
|
v6AssignMode varchar(8) NOT NULL DEFAULT('none'),
|
|
|
|
multicastLimit integer NOT NULL DEFAULT(32),
|
|
|
|
creationTime integer NOT NULL DEFAULT(0),
|
2015-07-16 17:34:03 -07:00
|
|
|
revision integer NOT NULL DEFAULT(1),
|
|
|
|
memberRevisionCounter integer NOT NULL DEFAULT(1)
|
2015-06-11 11:35:25 +02:00
|
|
|
);
|
|
|
|
|
2015-07-29 15:09:23 -07:00
|
|
|
CREATE TABLE AuthToken (
|
|
|
|
id integer PRIMARY KEY NOT NULL,
|
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
|
|
|
authMode integer NOT NULL DEFAULT(1),
|
|
|
|
useCount integer NOT NULL DEFAULT(0),
|
|
|
|
maxUses integer NOT NULL DEFAULT(0),
|
|
|
|
expiresAt integer NOT NULL DEFAULT(0),
|
|
|
|
token varchar(256) NOT NULL
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE INDEX AuthToken_networkId_token ON AuthToken(networkId,token);
|
|
|
|
|
2015-06-11 11:35:25 +02:00
|
|
|
CREATE TABLE Node (
|
|
|
|
id char(10) PRIMARY KEY NOT NULL,
|
2015-06-29 14:52:09 -07:00
|
|
|
identity varchar(4096) NOT NULL
|
2015-06-11 11:35:25 +02:00
|
|
|
);
|
|
|
|
|
2015-06-13 11:34:31 +02:00
|
|
|
CREATE TABLE Gateway (
|
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
|
|
|
ip blob(16) NOT NULL,
|
|
|
|
ipVersion integer NOT NULL DEFAULT(4),
|
|
|
|
metric integer NOT NULL DEFAULT(0)
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE UNIQUE INDEX Gateway_networkId_ip ON Gateway (networkId, ip);
|
|
|
|
|
2015-03-12 14:03:53 -07:00
|
|
|
CREATE TABLE IpAssignment (
|
2015-06-11 11:35:25 +02:00
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
2015-06-29 15:34:26 -07:00
|
|
|
nodeId char(10) REFERENCES Node(id) ON DELETE CASCADE,
|
2015-06-29 10:40:31 -07:00
|
|
|
type integer NOT NULL DEFAULT(0),
|
2015-03-18 16:10:48 -07:00
|
|
|
ip blob(16) NOT NULL,
|
|
|
|
ipNetmaskBits integer NOT NULL DEFAULT(0),
|
|
|
|
ipVersion integer NOT NULL DEFAULT(4)
|
2015-03-12 14:03:53 -07:00
|
|
|
);
|
|
|
|
|
2015-06-13 10:05:34 +02:00
|
|
|
CREATE UNIQUE INDEX IpAssignment_networkId_ip ON IpAssignment (networkId, ip);
|
2015-03-12 14:03:53 -07:00
|
|
|
|
|
|
|
CREATE INDEX IpAssignment_networkId_nodeId ON IpAssignment (networkId, nodeId);
|
|
|
|
|
|
|
|
CREATE TABLE IpAssignmentPool (
|
2015-06-11 11:35:25 +02:00
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
2015-06-29 10:40:31 -07:00
|
|
|
ipRangeStart blob(16) NOT NULL,
|
|
|
|
ipRangeEnd blob(16) NOT NULL,
|
2015-04-21 19:49:04 -07:00
|
|
|
ipVersion integer NOT NULL DEFAULT(4)
|
2015-03-12 14:03:53 -07:00
|
|
|
);
|
|
|
|
|
2015-06-29 14:52:09 -07:00
|
|
|
CREATE UNIQUE INDEX IpAssignmentPool_networkId_ipRangeStart ON IpAssignmentPool (networkId,ipRangeStart);
|
2015-03-12 14:03:53 -07:00
|
|
|
|
|
|
|
CREATE TABLE Member (
|
2015-06-11 11:35:25 +02:00
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
|
|
|
nodeId char(10) NOT NULL REFERENCES Node(id) ON DELETE CASCADE,
|
2015-03-18 16:10:48 -07:00
|
|
|
authorized integer NOT NULL DEFAULT(0),
|
2015-06-11 11:35:25 +02:00
|
|
|
activeBridge integer NOT NULL DEFAULT(0),
|
2015-07-16 17:42:47 -07:00
|
|
|
memberRevision integer NOT NULL DEFAULT(0),
|
2015-06-11 11:35:25 +02:00
|
|
|
PRIMARY KEY (networkId, nodeId)
|
2015-03-12 14:03:53 -07:00
|
|
|
);
|
|
|
|
|
2015-04-20 17:47:12 -07:00
|
|
|
CREATE INDEX Member_networkId_activeBridge ON Member(networkId, activeBridge);
|
2015-07-16 17:34:03 -07:00
|
|
|
CREATE INDEX Member_networkId_memberRevision ON Member(networkId, memberRevision);
|
2015-04-20 17:47:12 -07:00
|
|
|
|
2015-04-20 15:46:20 -07:00
|
|
|
CREATE TABLE Relay (
|
2015-06-11 11:35:25 +02:00
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
2015-07-20 14:28:30 -07:00
|
|
|
address char(10) NOT NULL,
|
|
|
|
phyAddress varchar(64) NOT NULL
|
2015-04-20 15:46:20 -07:00
|
|
|
);
|
|
|
|
|
2015-07-20 14:28:30 -07:00
|
|
|
CREATE UNIQUE INDEX Relay_networkId_address ON Relay (networkId,address);
|
2015-04-21 16:41:35 -07:00
|
|
|
|
2015-03-12 14:03:53 -07:00
|
|
|
CREATE TABLE Rule (
|
2015-06-11 11:35:25 +02:00
|
|
|
networkId char(16) NOT NULL REFERENCES Network(id) ON DELETE CASCADE,
|
2015-06-13 10:05:34 +02:00
|
|
|
ruleNo integer NOT NULL,
|
2015-06-29 10:47:47 -07:00
|
|
|
nodeId char(10) REFERENCES Node(id),
|
2015-06-29 15:34:26 -07:00
|
|
|
sourcePort char(10),
|
|
|
|
destPort char(10),
|
2015-03-18 16:10:48 -07:00
|
|
|
vlanId integer,
|
|
|
|
vlanPcp integer,
|
|
|
|
etherType integer,
|
2015-03-12 14:03:53 -07:00
|
|
|
macSource char(12),
|
|
|
|
macDest char(12),
|
|
|
|
ipSource varchar(64),
|
|
|
|
ipDest varchar(64),
|
2015-03-18 16:10:48 -07:00
|
|
|
ipTos integer,
|
|
|
|
ipProtocol integer,
|
|
|
|
ipSourcePort integer,
|
|
|
|
ipDestPort integer,
|
2015-05-25 13:20:10 -07:00
|
|
|
flags integer,
|
|
|
|
invFlags integer,
|
2015-03-12 14:03:53 -07:00
|
|
|
"action" varchar(4096) NOT NULL DEFAULT('accept')
|
|
|
|
);
|
|
|
|
|
2015-06-13 10:05:34 +02:00
|
|
|
CREATE UNIQUE INDEX Rule_networkId_ruleNo ON Rule (networkId, ruleNo);
|