Commit | Line | Data |
---|---|---|
c326e657 | 1 | -- Database should be in this folder, and named 'vchess.sqlite' |
86c9843c | 2 | |
da06a6eb | 3 | create table Variants ( |
bf20f404 BA |
4 | id integer primary key, |
5 | name varchar unique, | |
2c5d7b20 BA |
6 | description text, |
7 | noProblems boolean | |
da06a6eb | 8 | ); |
da06a6eb | 9 | |
8d7e2786 | 10 | create table Users ( |
bf20f404 BA |
11 | id integer primary key, |
12 | name varchar unique, | |
13 | email varchar unique, | |
14 | loginToken varchar, | |
15 | loginTime datetime, | |
16 | sessionToken varchar, | |
83494c7f | 17 | created datetime, |
d9a7a1e4 BA |
18 | notify boolean, |
19 | newsRead datetime | |
8d7e2786 BA |
20 | ); |
21 | ||
89021f18 BA |
22 | create table Problems ( |
23 | id integer primary key, | |
24 | added datetime, | |
604b951e | 25 | fen varchar, |
89021f18 BA |
26 | uid integer, |
27 | vid integer, | |
28 | instruction text, | |
29 | solution text, | |
30 | foreign key (uid) references Users(id), | |
31 | foreign key (vid) references Variants(id) | |
32 | ); | |
8d7e2786 | 33 | |
604b951e BA |
34 | create table News ( |
35 | id integer primary key, | |
36 | uid integer, | |
37 | added datetime, | |
38 | content text, | |
39 | foreign key (uid) references Users(id) | |
40 | ); | |
41 | ||
8d7e2786 | 42 | create table Challenges ( |
bf20f404 BA |
43 | id integer primary key, |
44 | added datetime, | |
45 | uid integer, | |
46 | target integer, | |
47 | vid integer, | |
7ba4a5bc | 48 | randomness integer, |
bf20f404 | 49 | fen varchar, |
71468011 | 50 | cadence varchar, |
bf20f404 BA |
51 | foreign key (uid) references Users(id), |
52 | foreign key (vid) references Variants(id) | |
8d7e2786 BA |
53 | ); |
54 | ||
55 | create table Games ( | |
bf20f404 BA |
56 | id integer primary key, |
57 | vid integer, | |
58 | fenStart varchar, --initial state | |
59 | fen varchar, --current state | |
0234201f BA |
60 | white integer, |
61 | black integer, | |
aae89b49 | 62 | score varchar default '*', |
dcd68c41 | 63 | scoreMsg varchar, |
71468011 | 64 | cadence varchar, |
afde7666 | 65 | randomness integer, --for rematch |
71468011 | 66 | created datetime, |
aae89b49 BA |
67 | drawOffer character default '', |
68 | rematchOffer character default '', | |
69 | deletedByWhite boolean, | |
70 | deletedByBlack boolean, | |
0234201f BA |
71 | foreign key (vid) references Variants(id), |
72 | foreign key (white) references Users(id), | |
73 | foreign key (black) references Users(id) | |
8d7e2786 BA |
74 | ); |
75 | ||
63ca2b89 BA |
76 | create table Chats ( |
77 | gid integer, | |
c547fbfb BA |
78 | name varchar, |
79 | msg varchar, | |
3837d4f7 | 80 | added datetime |
63ca2b89 BA |
81 | ); |
82 | ||
8d7e2786 | 83 | create table Moves ( |
bf20f404 | 84 | gid integer, |
f41ce580 | 85 | squares varchar, --description, appear/vanish/from/to |
bf20f404 BA |
86 | played datetime, --when was this move played? |
87 | idx integer, --index of the move in the game | |
bf20f404 | 88 | foreign key (gid) references Games(id) |
da06a6eb | 89 | ); |
c326e657 | 90 | |
0234201f BA |
91 | create index scoreIdx on Games(score); |
92 | ||
8d7e2786 | 93 | pragma foreign_keys = on; |