-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathStaphDBUpdate.py
executable file
·106 lines (96 loc) · 4.01 KB
/
StaphDBUpdate.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
#! /usr/bin/env python3
import sys
import sqldb
def update0(db):
if db[0].getItem('dbver','value') != '1.0':
raise TypeError("Wrong Database Version")
db[1].data.execute("alter table 'group' add 'notify'")
db[1].data.execute("update 'group' set notify = 'notify' where header='header'")
db[1].data.execute("alter table 'group' add 'msg'")
db[1].data.execute("update 'group' set msg = 'msg' where header='header'")
db[1].updateDB()
db[0].addItem(['dbver','1.1'])
print("DB version updated to 1.1")
def update1(db):
if db[0].getItem('dbver','value') != '1.1':
raise TypeError("Wrong Database Version")
db[0].addItem(['blacklist',''])
db[0].addItem(['dbver','1.2'])
print('DB version updated to 1.2')
def update2(db):
if db[0].getItem('dbver','value') != '1.2':
raise TypeError("Wrong Database Version")
db[0].data.execute("create table admin (header text, time text, last text)")
db[0].data.execute("insert into admin values ('header','time','last')")
db[0].updateDB()
db[0].addItem(['dbver','1.3'])
print('DB version updated to 1.3')
def update3(db):
if db[0].getItem('dbver','value') != '1.3':
raise TypeError("Wrong Database Version")
db[0].data.execute("create table auth (header text, pword text, atime text, gid text, key text)")
db[0].data.execute("insert into auth values('header','pword','atime','gid','key')")
db[0].updateDB()
db[0].addItem(['keyexp','1800'])
db[0].addItem(['dbver','1.4'])
print('DB version updated to 1.4')
def update4(db):
if db[0].getItem('dbver','value') != '1.4':
raise TypeError("Wrong Database Version")
db[1].data.execute("alter table 'group' add 'bansticker'")
db[1].data.execute("update 'group' set bansticker = ''")
db[1].data.execute("update 'group' set bansticker = 'bansticker' where header='header'")
db[1].updateDB()
db[0].addItem(['dbver','1.5'])
print('DB version updated to 1.5')
def update5(db):
if db[0].getItem('dbver','value') != '1.5':
raise TypeError("Wrong Database Version")
for item in db[1]:
if item != 'default':
if db[1].getItem(item,'bansticker') != '':
tmp = db[1].getItem(item,'bansticker').split('|')
tmp = '|'.join(['set:'+i for i in tmp])
db[1].chgItem(item,'bansticker',tmp)
db[1].data.execute("Alter Table 'group' add 'moderator'")
db[1].data.execute("Update 'group' set moderator = ''")
db[1].data.execute("update 'group' set moderator = 'moderator' where header='header'")
db[1].updateDB()
db[0].addItem(['dbver','1.6'])
print('DB version updated to 1.6')
def update6(db):
if db[0].getItem('dbver','value') != '1.6':
raise TypeError("Wrong Database Version")
db[0].data.execute('CREATE TABLE imgid (header text, fid text, atime text)')
db[0].data.execute("INSERT INTO imgid VALUES('header','fid','atime')")
db[0].updateDB()
db[0].addItem(['dbver','1.7'])
print('DB version updated to 1.7')
def main(args):
if len(args) == 0 or args[0] in ('-h','--help','-?'):
print(sys.argv[0]+' - Update StaphMB DB')
print('Synopsis:')
print('\t'+sys.argv[0]+' init.db')
exit()
tmp = sqldb.sqliteDB(args[0],'config')
db = [tmp,sqldb.sqliteDB(tmp,'group'),sqldb.sqliteDB(tmp,'warn')]
if db[0].getItem('dbver','value') == '1.0':
update0(db)
if db[0].getItem('dbver','value') == '1.1':
update1(db)
if db[0].getItem('dbver','value') == '1.2':
update2(db)
db.append(sqldb.sqliteDB(tmp,'admin'))
if db[0].getItem('dbver','value') == '1.3':
update3(db)
db.append(sqldb.sqliteDB(tmp,'auth'))
if db[0].getItem('dbver','value') == '1.4':
update4(db)
if db[0].getItem('dbver','value') == '1.5':
update5(db)
if db[0].getItem('dbver','value') == '1.6':
update6(db)
db.append(sqldb.sqliteDB(tmp,'imgid'))
print("Your database is up-to-date.")
if __name__ == '__main__':
main(sys.argv[1:])