Some advances. TODO: test board.js, and then game.js, and then implement room.js
[vchess.git] / db / create.sql
CommitLineData
c326e657 1-- Database should be in this folder, and named 'vchess.sqlite'
86c9843c 2
da06a6eb 3create table Variants (
8d7e2786
BA
4 id integer primary key,
5 name varchar unique,
da06a6eb
BA
6 description text
7);
da06a6eb 8
8d7e2786
BA
9create table Users (
10 id integer primary key,
11 name varchar unique,
12 email varchar unique,
13 loginToken varchar,
14 loginTime datetime,
15 sessionToken varchar,
16 notify boolean
17);
18
da06a6eb 19create table Problems (
8d7e2786 20 id integer primary key,
da06a6eb 21 added datetime,
8d7e2786
BA
22 uid integer,
23 vid integer,
da06a6eb
BA
24 fen varchar,
25 instructions text,
26 solution text,
8d7e2786
BA
27 foreign key (uid) references Users(id),
28 foreign key (vid) references Variants(id)
29);
30
31-- All the following tables are for correspondance play only
32-- (Live games are stored only in browsers)
33
34create table Challenges (
35 id integer primary key,
36 added datetime,
37 uid integer,
38 vid integer,
39 foreign key (uid) references Users(id),
40 foreign key (vid) references Variants(id)
41);
42
43-- Store informations about players who accept a challenge
44create table WillPlay (
45 cid integer,
46 uid integer,
47 yes boolean,
48 foreign key (cid) references Challenges(id),
49 foreign key (uid) references Users(id)
50);
51
52create table Games (
53 id integer primary key,
54 vid integer,
55 fen varchar, --initial position
56 score varchar,
57 foreign key (vid) references Variants(id)
58);
59
60-- Store informations about players in a corr game
61create table Players (
fd08ab2c 62 gid integer,
8d7e2786
BA
63 uid integer,
64 color character,
fd08ab2c
BA
65 foreign key (gid) references Games(id),
66 foreign key (uid) references Users(id)
8d7e2786
BA
67);
68
69create table Moves (
70 gid integer,
71 move varchar,
72 played datetime, --when was this move played?
73 idx integer, --index of the move in the game
74 color character, --required for e.g. Marseillais Chess
75 foreign key (gid) references Games(id)
da06a6eb 76);
c326e657 77
8d7e2786 78pragma foreign_keys = on;