Add backend id to database scheme
[platform/core/security/key-manager.git] / data / scripts / create_schema.sql
1 /*
2  *  Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  *  Licensed under the Apache License, Version 2.0 (the "License");
5  *  you may not use this file except in compliance with the License.
6  *  You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  *  Unless required by applicable law or agreed to in writing, software
11  *  distributed under the License is distributed on an "AS IS" BASIS,
12  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  *  See the License for the specific language governing permissions and
14  *  limitations under the License
15  *
16  *
17  * @file        create_schema.sql
18  * @author      Maciej Karpiuk (m.karpiuk2@samsung.com)
19  * @version     3.0
20  * @brief       DB script to create database schema.
21  */
22
23
24 -- create the tables
25 CREATE TABLE IF NOT EXISTS SCHEMA_INFO(name TEXT PRIMARY KEY NOT NULL,
26                                        value TEXT);
27
28 CREATE TABLE IF NOT EXISTS NAMES(name TEXT NOT NULL,
29                                  label TEXT NOT NULL,
30                                  idx INTEGER PRIMARY KEY AUTOINCREMENT,
31                                  UNIQUE(name, label));
32
33 CREATE TABLE IF NOT EXISTS OBJECTS(exportable INTEGER NOT NULL,
34                                    dataType INTEGER NOT NULL,
35                                    algorithmType INTEGER NOT NULL,
36                                    encryptionScheme INTEGER NOT NULL,
37                                    iv BLOB NOT NULL,
38                                    dataSize INTEGER NOT NULL,
39                                    data BLOB NOT NULL,
40                                    tag BLOB NOT NULL,
41                                    idx INTEGER NOT NULL,
42                                    backendId INTEGER NOT NULL DEFAULT 1,
43                                    FOREIGN KEY(idx) REFERENCES NAMES(idx) ON DELETE CASCADE,
44                                    PRIMARY KEY(idx, dataType));
45
46 CREATE TABLE IF NOT EXISTS KEYS(label TEXT PRIMARY KEY,
47                                 key BLOB NOT NULL);
48
49 CREATE TABLE IF NOT EXISTS PERMISSIONS(permissionLabel TEXT NOT NULL,
50                                        permissionMask INTEGER NOT NULL,
51                                        idx INTEGER NOT NULL,
52                                        FOREIGN KEY(idx) REFERENCES NAMES(idx) ON DELETE CASCADE,
53                                        PRIMARY KEY(permissionLabel, idx));
54
55
56 -- create views
57 CREATE VIEW IF NOT EXISTS [join_name_object_tables] AS
58    SELECT N.name, N.label, O.* FROM NAMES AS N
59        JOIN OBJECTS AS O ON O.idx=N.idx;
60
61 CREATE VIEW IF NOT EXISTS [join_name_permission_tables] AS
62    SELECT N.name, N.label, P.permissionMask, P.permissionLabel FROM NAMES AS N
63        JOIN PERMISSIONS AS P ON P.idx=N.idx;
64
65 CREATE VIEW IF NOT EXISTS [join_all_tables] AS
66    SELECT N.*, P.permissionLabel, P.permissionMask, O.dataType FROM NAMES AS N
67        JOIN OBJECTS AS O ON O.idx=N.idx
68        JOIN PERMISSIONS AS P ON P.idx=N.idx;
69
70
71 -- create indexes
72 CREATE INDEX IF NOT EXISTS perm_index_idx ON PERMISSIONS(idx);
73 CREATE INDEX IF NOT EXISTS name_index_idx ON NAMES(idx);
74