OpenDNSSEC-enforcer  2.0.3
db_schema_mysql.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014 Jerry Lundström <lundstrom.jerry@gmail.com>
3  * Copyright (c) 2014 .SE (The Internet Infrastructure Foundation).
4  * Copyright (c) 2014 OpenDNSSEC AB (svb)
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  * notice, this list of conditions and the following disclaimer in the
14  * documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
20  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
22  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
24  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
25  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
26  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28 
29 const char* db_schema_mysql_create[] = {
30  "CREATE TABLE zone ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, policyId BIGINT UNSIGNED NOT NULL, name TEXT NOT NULL, signconfNeedsWriting INT UNSIGNED NOT NULL, signconfPath TEXT NOT NULL, nextChange INT NOT NULL, ttlEndDs INT UNSIGNED NOT NULL, ttlEndDk INT UNSIGNED NOT NULL, ttlEndRs INT UNSIGNED NOT NULL, rollKskNow INT UNSIGNED NOT NULL, rollZskNow INT UNSIGNED NOT NULL, rollCskNow INT UNSIGNED NOT NULL, inputAdapterType TEXT NO",
31  "T NULL, inputAdapterUri TEXT NOT NULL, outputAdapterType TEXT NOT NULL, outputAdapterUri TEXT NOT NULL, nextKskRoll INT UNSIGNED NOT NULL, nextZskRoll INT UNSIGNED NOT NULL, nextCskRoll INT UNSIGNED NOT NULL)",
32  0,
33  "CREATE INDEX zonePolicyId ON zone ( policyId )",
34  0,
35  "CREATE UNIQUE INDEX zoneName ON zone ( name(255) )",
36  0,
37  "CREATE TABLE keyData ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, zoneId BIGINT UNSIGNED NOT NULL, hsmKeyId BIGINT UNSIGNED NOT NULL, algorithm INT UNSIGNED NOT NULL, inception INT UNSIGNED NOT NULL, role INT NOT NULL, introducing INT UNSIGNED NOT NULL, shouldRevoke INT UNSIGNED NOT NULL, standby INT UNSIGNED NOT NULL, activeZsk INT UNSIGNED NOT NULL, publish INT UNSIGNED NOT NULL, activeKsk INT UNSIGNED NOT NULL, dsAtParent INT NOT ",
38  "NULL, keytag INT UNSIGNED NOT NULL, minimize INT UNSIGNED NOT NULL)",
39  0,
40  "CREATE INDEX keyDataZoneId ON keyData ( zoneId )",
41  0,
42  "CREATE INDEX keyDataHsmKeyId ON keyData ( hsmKeyId )",
43  0,
44  "CREATE TABLE keyState ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, keyDataId BIGINT UNSIGNED NOT NULL, type INT NOT NULL, state INT NOT NULL, lastChange INT UNSIGNED NOT NULL, minimize INT UNSIGNED NOT NULL, ttl INT UNSIGNED NOT NULL)",
45  0,
46  "CREATE INDEX keyStateKeyDataId ON keyState ( keyDataId )",
47  0,
48  "CREATE TABLE keyDependency ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, zoneId BIGINT UNSIGNED NOT NULL, fromKeyDataId BIGINT UNSIGNED NOT NULL, toKeyDataId BIGINT UNSIGNED NOT NULL, type INT NOT NULL)",
49  0,
50  "CREATE INDEX keyDependencyZoneId ON keyDependency ( zoneId )",
51  0,
52  "CREATE INDEX keyDependencyFromKeyDataId ON keyDependency ( fromKeyDataId )",
53  0,
54  "CREATE INDEX keyDependencyToKeyDataId ON keyDependency ( toKeyDataId )",
55  0,
56  "CREATE TABLE hsmKey ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, policyId BIGINT UNSIGNED NOT NULL, locator TEXT NOT NULL, state INT NOT NULL, bits INT UNSIGNED NOT NULL, algorithm INT UNSIGNED NOT NULL, role INT NOT NULL, inception INT UNSIGNED NOT NULL, isRevoked INT UNSIGNED NOT NULL, keyType INT NOT NULL, repository TEXT NOT NULL, backup INT NOT NULL)",
57  0,
58  "CREATE INDEX hsmKeyPolicyId ON hsmKey ( policyId )",
59  0,
60  "CREATE UNIQUE INDEX hsmKeyLocator ON hsmKey ( locator(255) )",
61  0,
62  "CREATE TABLE policy ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, name TEXT NOT NULL, description TEXT NOT NULL, signaturesResign INT UNSIGNED NOT NULL, signaturesRefresh INT UNSIGNED NOT NULL, signaturesJitter INT UNSIGNED NOT NULL, signaturesInceptionOffset INT UNSIGNED NOT NULL, signaturesValidityDefault INT UNSIGNED NOT NULL, signaturesValidityDenial INT UNSIGNED NOT NULL, signaturesValidityKeyset INT UNSIGNED, signaturesMaxZoneTtl INT UNSIGNED NOT NULL, denialType INT N",
63  "OT NULL, denialOptout INT UNSIGNED NOT NULL, denialTtl INT UNSIGNED NOT NULL, denialResalt INT UNSIGNED NOT NULL, denialAlgorithm INT UNSIGNED NOT NULL, denialIterations INT UNSIGNED NOT NULL, denialSaltLength INT UNSIGNED NOT NULL, denialSalt TEXT NOT NULL, denialSaltLastChange INT UNSIGNED NOT NULL, keysTtl INT UNSIGNED NOT NULL, keysRetireSafety INT UNSIGNED NOT NULL, keysPublishSafety INT UNSIGNED NOT NULL, keysShared INT UNSIGNED NOT NULL, keysPurgeAfter INT UNSIGNED NOT NULL, ",
64  " zonePropagationDelay INT UNSIGNED NOT NULL, zoneSoaTtl INT UNSIGNED NOT NULL, zoneSoaMinimum INT UNSIGNED NOT NULL, zoneSoaSerial INT NOT NULL, parentRegistrationDelay INT UNSIGNED NOT NULL, parentPropagationDelay INT UNSIGNED NOT NULL, parentDsTtl INT UNSIGNED NOT NULL, parentSoaTtl INT UNSIGNED NOT NULL, parentSoaMinimum INT UNSIGNED NOT NULL, passthrough INT UNSIGNED NOT NULL)",
65  0,
66  "CREATE UNIQUE INDEX policyName ON policy ( name(255) )",
67  0,
68  "CREATE TABLE policyKey ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, policyId BIGINT UNSIGNED NOT NULL, role INT NOT NULL, algorithm INT UNSIGNED NOT NULL, bits INT UNSIGNED NOT NULL, lifetime INT UNSIGNED NOT NULL, repository TEXT NOT NULL, standby INT UNSIGNED NOT NULL, manualRollover INT UNSIGNED NOT NULL, rfc5011 INT UNSIGNED NOT NULL, minimize INT UNSIGNED NOT NULL)",
69  0,
70  "CREATE INDEX policyKeyPolicyId ON policyKey ( policyId )",
71  0,
72  "CREATE TABLE databaseVersion ( id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL, rev INT UNSIGNED NOT NULL DEFAULT 1, version INT UNSIGNED NOT NULL)",
73  0,
74  0
75 };
76 
77 const char* db_schema_mysql_drop[] = {
78  "DROP TABLE IF EXISTS zone",
79  0,
80  "DROP TABLE IF EXISTS keyData",
81  0,
82  "DROP TABLE IF EXISTS keyState",
83  0,
84  "DROP TABLE IF EXISTS keyDependency",
85  0,
86  "DROP TABLE IF EXISTS hsmKey",
87  0,
88  "DROP TABLE IF EXISTS policy",
89  0,
90  "DROP TABLE IF EXISTS policyKey",
91  0,
92  "DROP TABLE IF EXISTS databaseVersion",
93  0,
94  0
95 };
const char * db_schema_mysql_drop[]
const char * db_schema_mysql_create[]