forked from PX4/flight_review
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setup_db.py
executable file
·152 lines (132 loc) · 6.59 KB
/
setup_db.py
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
#! /usr/bin/env python3
# Script to create or upgrade the SQLite DB
import sqlite3 as lite
import sys
import os
# this is needed for the following imports
sys.path.append(os.path.join(os.path.dirname(os.path.realpath(__file__)), 'plot_app'))
from plot_app.config import get_db_filename, get_log_filepath, \
get_cache_filepath, get_kml_filepath, get_overview_img_filepath
log_dir = get_log_filepath()
if not os.path.exists(log_dir):
print('creating log directory '+log_dir)
os.makedirs(log_dir)
cur_dir = get_cache_filepath()
if not os.path.exists(cur_dir):
print('creating cache directory '+cur_dir)
os.makedirs(cur_dir)
cur_dir = get_kml_filepath()
if not os.path.exists(cur_dir):
print('creating kml directory '+cur_dir)
os.makedirs(cur_dir)
cur_dir = get_overview_img_filepath()
if not os.path.exists(cur_dir):
print('creating overview image directory '+cur_dir)
os.makedirs(cur_dir)
print('creating DB at '+get_db_filename())
con = lite.connect(get_db_filename())
with con:
cur = con.cursor()
# Logs table (contains information not found in the log file)
cur.execute("PRAGMA table_info('Logs')")
columns = cur.fetchall()
if len(columns) == 0:
cur.execute("CREATE TABLE Logs("
"Id TEXT, " # log id (part of the file name)
"Title TEXT, "
"Description TEXT, "
"OriginalFilename TEXT, "
"Date TIMESTAMP, " # date & time when uploaded
"AllowForAnalysis INTEGER, " # if 1 allow for statistical analysis
"Obfuscated INTEGER, "
"Source TEXT, " # where it comes from: 'webui', 'CI', 'QGroundControl'
"Email TEXT, " # email (may be empty)
"WindSpeed INT, " # Wind speed in beaufort scale
"Rating TEXT, " # how the flight was rated
"Feedback TEXT, " # additional feedback
"Type TEXT, " # upload type: 'personal' (or '') or 'flightreport'
"VideoUrl TEXT, "
"ErrorLabels TEXT, " # the type of error (if any) that occurred during flight
"Public INT, " # if 1 this log can be publicly listed
"Token TEXT, " # Security token (currently used to delete the entry)
"CONSTRAINT Id_PK PRIMARY KEY (Id))")
else:
# try to upgrade
column_names = [ x[1] for x in columns]
if not 'Email' in column_names:
print('Adding column Email')
cur.execute("ALTER TABLE Logs ADD COLUMN Email TEXT DEFAULT ''")
if not 'WindSpeed' in column_names:
print('Adding column WindSpeed')
cur.execute("ALTER TABLE Logs ADD COLUMN WindSpeed INT DEFAULT -1")
if not 'Rating' in column_names:
print('Adding column Rating')
cur.execute("ALTER TABLE Logs ADD COLUMN Rating TEXT DEFAULT ''")
if not 'Feedback' in column_names:
print('Adding column Feedback')
cur.execute("ALTER TABLE Logs ADD COLUMN Feedback TEXT DEFAULT ''")
if not 'Type' in column_names:
print('Adding column Type')
cur.execute("ALTER TABLE Logs ADD COLUMN Type TEXT DEFAULT ''")
if not 'VideoUrl' in column_names:
print('Adding column VideoUrl')
cur.execute("ALTER TABLE Logs ADD COLUMN VideoUrl TEXT DEFAULT ''")
if not 'ErrorLabels' in column_names:
print('Adding column ErrorLabels')
cur.execute("ALTER TABLE Logs ADD COLUMN ErrorLabels TEXT DEFAULT ''")
if not 'Public' in column_names:
print('Adding column Public')
cur.execute("ALTER TABLE Logs ADD COLUMN Public INT DEFAULT 0")
if not 'Token' in column_names:
print('Adding column Token')
cur.execute("ALTER TABLE Logs ADD COLUMN Token TEXT DEFAULT ''")
# LogsGenerated table (information from the log file, for faster access)
cur.execute("PRAGMA table_info('LogsGenerated')")
columns = cur.fetchall()
if len(columns) == 0:
cur.execute("CREATE TABLE LogsGenerated("
"Id TEXT, " # log id
"Duration INT, " # logging duration in [s]
"MavType TEXT, " # vehicle type
"Estimator TEXT, "
"AutostartId INT, " # airframe config
"Hardware TEXT, " # board
"Software TEXT, " # software (git tag)
"NumLoggedErrors INT, " # number of logged error messages (or more severe)
"NumLoggedWarnings INT, "
"FlightModes TEXT, " # all flight modes as comma-separated int's
"SoftwareVersion TEXT, " # release version
"UUID TEXT, " # vehicle UUID (sys_uuid in log)
"FlightModeDurations TEXT, " # comma-separated list of <flight_mode_int>:<duration_sec>
"StartTime INT, " #UTC Timestap from GPS log (useful when uploading multiple logs)
"VehicleFlightTime INT, " # Seconds of lifetime flight time at start of flight
"CONSTRAINT Id_PK PRIMARY KEY (Id))")
else:
# try to upgrade
column_names = [ x[1] for x in columns]
if not 'SoftwareVersion' in column_names:
print('Adding column SoftwareVersion')
cur.execute("ALTER TABLE LogsGenerated ADD COLUMN SoftwareVersion TEXT DEFAULT ''")
if not 'UUID' in column_names:
print('Adding column UUID')
cur.execute("ALTER TABLE LogsGenerated ADD COLUMN UUID TEXT DEFAULT ''")
if not 'FlightModeDurations' in column_names:
print('Adding column FlightModeDurations')
cur.execute("ALTER TABLE LogsGenerated ADD COLUMN FlightModeDurations TEXT DEFAULT ''")
if not 'StartTime' in column_names:
print('Adding column StartTime')
cur.execute("ALTER TABLE LogsGenerated ADD COLUMN StartTime INT DEFAULT 0")
if not 'VehicleFlightTime' in column_names:
print('Adding column VehicleFlightTime')
cur.execute("ALTER TABLE LogsGenerated ADD COLUMN VehicleFlightTime INT")
# Vehicle table (contains information about a vehicle)
cur.execute("PRAGMA table_info('Vehicle')")
columns = cur.fetchall()
if len(columns) == 0:
cur.execute("CREATE TABLE Vehicle("
"UUID TEXT, " # vehicle UUID (sys_uuid in log)
"LatestLogId TEXT, " # log id of latest uploaded log file
"Name TEXT, " # vehicle Name (as provided by the uploader)
"FlightTime INTEGER, " # latest flight time in seconds
"CONSTRAINT UUID_PK PRIMARY KEY (UUID))")
con.close()