2016-05-19 17:10:36 +03:00
|
|
|
-- Copyright (C) 2015 - 2016 Deutsche Telekom AG.
|
|
|
|
|
|
|
|
-- Author: Razvan Becheriu <razvan.becheriu@qualitance.com>
|
|
|
|
|
|
|
|
-- Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
-- you may not use this file except in compliance with the License.
|
|
|
|
-- You may obtain a copy of the License at
|
|
|
|
|
|
|
|
-- http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
-- Unless required by applicable law or agreed to in writing, software
|
|
|
|
-- distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
-- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
-- See the License for the specific language governing permissions and
|
|
|
|
-- limitations under the License.
|
|
|
|
|
2016-06-23 14:24:39 +02:00
|
|
|
-- This is the Kea schema specification for Cassandra CQL.
|
2016-05-19 17:10:36 +03:00
|
|
|
|
|
|
|
-- The schema is reasonably portable (with the exception of the engine
|
2016-06-23 14:24:39 +02:00
|
|
|
-- specification, which is Cassandra CQL-specific). Minor changes might be needed for
|
2016-05-19 17:10:36 +03:00
|
|
|
-- other databases.
|
|
|
|
|
|
|
|
-- To create the schema, either type the command:
|
|
|
|
|
|
|
|
-- cqlsh -u <user> -p <password> -k <database> -f dhcpdb_create.cql
|
|
|
|
|
2016-06-23 14:24:39 +02:00
|
|
|
-- ... at the command prompt, or log in to the CQL database and at the "cqlsh>"
|
2016-05-19 17:10:36 +03:00
|
|
|
-- prompt, issue the command:
|
|
|
|
|
|
|
|
-- SOURCE dhcpdb_create.cql
|
|
|
|
|
2016-06-23 14:24:39 +02:00
|
|
|
-- This script is also called from kea-admin, see kea-admin init cql
|
2016-05-19 17:10:36 +03:00
|
|
|
|
|
|
|
-- Over time, Kea database schema will evolve. Each version is marked with
|
|
|
|
-- major.minor version. This file is organized sequentially, i.e. database
|
|
|
|
-- is initialized to 1.0, then upgraded to 2.0 etc. This may be somewhat
|
|
|
|
-- sub-optimal, but it ensues consistency with upgrade scripts. (It is much
|
|
|
|
-- easier to maintain init and upgrade scripts if they look the same).
|
|
|
|
-- Since initialization is done only once, it's performance is not an issue.
|
|
|
|
|
|
|
|
-- This line starts database initialization to 1.0.
|
|
|
|
|
|
|
|
-- Holds the IPv4 leases.
|
|
|
|
CREATE TABLE lease4 (
|
|
|
|
address int,
|
|
|
|
hwaddr blob,
|
|
|
|
client_id blob,
|
|
|
|
valid_lifetime bigint,
|
|
|
|
expire bigint,
|
|
|
|
subnet_id int,
|
|
|
|
fqdn_fwd boolean,
|
|
|
|
fqdn_rev boolean,
|
|
|
|
hostname varchar,
|
|
|
|
state int,
|
|
|
|
PRIMARY KEY (address)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Create search indexes for lease4 table
|
|
|
|
CREATE INDEX lease4index1 ON lease4 (client_id);
|
|
|
|
CREATE INDEX lease4index2 ON lease4 (subnet_id);
|
|
|
|
CREATE INDEX lease4index3 ON lease4 (hwaddr);
|
|
|
|
CREATE INDEX lease4index4 ON lease4 (expire);
|
|
|
|
CREATE INDEX lease4index5 ON lease4 (state);
|
|
|
|
|
|
|
|
-- Holds the IPv6 leases.
|
|
|
|
-- N.B. The use of a VARCHAR for the address is temporary for development:
|
|
|
|
-- it will eventually be replaced by BINARY(16).
|
|
|
|
CREATE TABLE lease6 (
|
|
|
|
address varchar,
|
|
|
|
duid blob,
|
|
|
|
valid_lifetime bigint,
|
|
|
|
expire bigint,
|
|
|
|
subnet_id int,
|
|
|
|
pref_lifetime bigint,
|
|
|
|
lease_type int,
|
|
|
|
iaid int,
|
|
|
|
prefix_len int,
|
|
|
|
fqdn_fwd boolean,
|
|
|
|
fqdn_rev boolean,
|
|
|
|
hostname varchar,
|
|
|
|
hwaddr blob,
|
|
|
|
hwtype int,
|
|
|
|
hwaddr_source int,
|
|
|
|
state int,
|
|
|
|
PRIMARY KEY (address)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Create search indexes for lease6 table
|
|
|
|
CREATE INDEX lease6index1 ON lease6 (lease_type);
|
|
|
|
CREATE INDEX lease6index2 ON lease6 (duid);
|
|
|
|
CREATE INDEX lease6index3 ON lease6 (iaid);
|
|
|
|
CREATE INDEX lease6index4 ON lease6 (subnet_id);
|
|
|
|
CREATE INDEX lease6index5 ON lease6 (expire);
|
|
|
|
CREATE INDEX lease6index6 ON lease6 (state);
|
|
|
|
|
|
|
|
-- ... and a definition of lease6 types. This table is a convenience for
|
|
|
|
-- users of the database - if they want to view the lease table and use the
|
|
|
|
-- type names, they can join this table with the lease6 table.
|
|
|
|
-- Make sure those values match Lease6::LeaseType enum (see src/bin/dhcpsrv/
|
|
|
|
-- lease_mgr.h)
|
|
|
|
CREATE TABLE lease6_types (
|
|
|
|
lease_type int, -- Lease type code.
|
|
|
|
name varchar, -- Name of the lease type
|
|
|
|
PRIMARY KEY (lease_type)
|
|
|
|
);
|
|
|
|
--START TRANSACTION;
|
|
|
|
INSERT INTO lease6_types (lease_type, name) VALUES (0, 'IA_NA'); -- Non-temporary v6 addresses
|
|
|
|
INSERT INTO lease6_types (lease_type, name) VALUES (1, 'IA_TA'); -- Temporary v6 addresses
|
|
|
|
INSERT INTO lease6_types (lease_type, name) VALUES (2, 'IA_PD'); -- Prefix delegations
|
|
|
|
--COMMIT;
|
|
|
|
|
|
|
|
-- Kea keeps track of the hardware/MAC address source, i.e. how the address
|
|
|
|
-- was obtained. Depending on the technique and your network topology, it may
|
|
|
|
-- be more or less trustworthy. This table is a convenience for
|
|
|
|
-- users of the database - if they want to view the lease table and use the
|
|
|
|
-- type names, they can join this table with the lease6 table. For details,
|
|
|
|
-- see constants defined in src/lib/dhcp/dhcp/pkt.h for detailed explanation.
|
|
|
|
CREATE TABLE lease_hwaddr_source (
|
|
|
|
hwaddr_source int,
|
|
|
|
name varchar,
|
|
|
|
PRIMARY KEY (hwaddr_source)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Hardware address obtained from raw sockets
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (1, 'HWADDR_SOURCE_RAW');
|
|
|
|
|
|
|
|
-- Hardware address converted from IPv6 link-local address with EUI-64
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (2, 'HWADDR_SOURCE_IPV6_LINK_LOCAL');
|
|
|
|
|
|
|
|
-- Hardware address extracted from client-id (duid)
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (4, 'HWADDR_SOURCE_DUID');
|
|
|
|
|
|
|
|
-- Hardware address extracted from client address relay option (RFC6939)
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (8, 'HWADDR_SOURCE_CLIENT_ADDR_RELAY_OPTION');
|
|
|
|
|
|
|
|
-- Hardware address extracted from remote-id option (RFC4649)
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (16, 'HWADDR_SOURCE_REMOTE_ID');
|
|
|
|
|
|
|
|
-- Hardware address extracted from subscriber-id option (RFC4580)
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (32, 'HWADDR_SOURCE_SUBSCRIBER_ID');
|
|
|
|
|
|
|
|
-- Hardware address extracted from docsis options
|
|
|
|
INSERT INTO lease_hwaddr_source (hwaddr_source, name) VALUES (64, 'HWADDR_SOURCE_DOCSIS_CMTS');
|
|
|
|
|
|
|
|
-- -----------------------------------------------------
|
|
|
|
-- Table `dhcp4_options`
|
|
|
|
-- -----------------------------------------------------
|
|
|
|
CREATE TABLE dhcp4_options (
|
|
|
|
option_id int,
|
|
|
|
code int,
|
|
|
|
value blob,
|
|
|
|
formatted_value varchar,
|
|
|
|
space varchar,
|
|
|
|
persistent int,
|
|
|
|
dhcp_client_class varchar,
|
|
|
|
dhcp4_subnet_id int,
|
|
|
|
host_id int,
|
|
|
|
PRIMARY KEY (option_id)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Create search indexes for dhcp4_options table
|
|
|
|
CREATE INDEX dhcp4_optionsindex1 ON dhcp4_options (host_id);
|
|
|
|
|
|
|
|
-- -----------------------------------------------------
|
|
|
|
-- Table `dhcp6_options`
|
|
|
|
-- -----------------------------------------------------
|
|
|
|
CREATE TABLE dhcp6_options (
|
|
|
|
option_id int,
|
|
|
|
code int,
|
|
|
|
value blob,
|
|
|
|
formatted_value varchar,
|
|
|
|
space varchar,
|
|
|
|
persistent int,
|
|
|
|
dhcp_client_class varchar,
|
|
|
|
dhcp6_subnet_id int,
|
|
|
|
host_id int,
|
|
|
|
PRIMARY KEY (option_id)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Create search indexes for dhcp6_options table
|
|
|
|
CREATE INDEX dhcp6_optionsindex1 ON dhcp6_options (host_id);
|
|
|
|
|
|
|
|
-- Create table holding mapping of the lease states to their names.
|
|
|
|
-- This is not used in queries from the DHCP server but rather in
|
|
|
|
-- direct queries from the lease database management tools.
|
|
|
|
CREATE TABLE lease_state (
|
|
|
|
state int,
|
|
|
|
name varchar,
|
|
|
|
PRIMARY KEY (state)
|
|
|
|
);
|
|
|
|
|
|
|
|
-- Insert currently defined state names.
|
|
|
|
INSERT INTO lease_state (state, name) VALUES (0, 'default');
|
|
|
|
INSERT INTO lease_state (state, name) VALUES (1, 'declined');
|
|
|
|
INSERT INTO lease_state (state, name) VALUES (2, 'expired-reclaimed');
|
|
|
|
|
|
|
|
-- Finally, the version of the schema. We start at 1.0 during development.
|
|
|
|
-- This table is only modified during schema upgrades. For historical reasons
|
|
|
|
-- (related to the names of the columns in the BIND 10 DNS database file), the
|
|
|
|
-- first column is called "version" and not "major".
|
|
|
|
|
|
|
|
-- NOTE: this MUST be kept in step with src/lib/dhcpsrv/tests/schema_copy.h,
|
|
|
|
-- which defines the schema for the unit tests. If you are updating
|
|
|
|
-- the version number, the schema has changed: please ensure that
|
|
|
|
-- schema_copy.h has been updated as well.
|
|
|
|
CREATE TABLE schema_version (
|
|
|
|
version int,
|
|
|
|
minor int,
|
|
|
|
PRIMARY KEY (version)
|
|
|
|
);
|
|
|
|
--START TRANSACTION;
|
|
|
|
INSERT INTO schema_version (version, minor) VALUES (1, 0);
|
|
|
|
--COMMIT;
|