Sign up form and other stuff
[recipes.git] / backend / sql / version_1.sql
index 9673d25..1685cd1 100644 (file)
@@ -8,18 +8,42 @@ CREATE TABLE [Version] (
 CREATE TABLE [User] (
     [id] INTEGER PRIMARY KEY,
     [email] TEXT NOT NULL,
-    [password] TEXT NOT NULL, -- Hashed and salted.
-    [name] TEXT NOT NULL
+    [name] TEXT,
+    [default_servings] INTEGER DEFAULT 4,
+
+    [password] TEXT NOT NULL, -- argon2(password_plain, salt).
+
+    [creation_datetime] DATETIME NOT NULL, -- Updated when the validation email is sent.
+    [validation_token] TEXT, -- If not null then the user has not validated his account yet.
+
+    [is_admin] INTEGER NOT NULL DEFAULT FALSE
 );
 
-CREATE TABLE [Recipe] (
+CREATE UNIQUE INDEX [User_email_index] ON [User] ([email]);
+
+CREATE TABLE [UserLoginToken] (
     [id] INTEGER PRIMARY KEY,
     [user_id] INTEGER NOT NULL,
+    [last_login_datetime] DATETIME,
+    [token] TEXT NOT NULL, --  24 alphanumeric character token. Can be stored in a cookie to be able to authenticate without a password.
+
+    [ip] TEXT, -- Can be ipv4 or ipv6
+    [user_agent] TEXT,
+
+    FOREIGN KEY([user_id]) REFERENCES [User]([id]) ON DELETE CASCADE
+);
+
+CREATE INDEX [UserLoginToken_token_index] ON [UserLoginToken] ([token]);
+
+CREATE TABLE [Recipe] (
+    [id] INTEGER PRIMARY KEY,
+    [user_id] INTEGER, -- Can be null if a user is deleted.
     [title] TEXT NOT NULL,
     [estimate_time] INTEGER,
     [description] TEXT,
+    [servings] INTEGER DEFAULT 4,
 
-    FOREIGN KEY([user_id]) REFERENCES [User]([id])
+    FOREIGN KEY([user_id]) REFERENCES [User]([id]) ON DELETE SET NULL
 );
 
 CREATE TABLE [Quantity] (
@@ -34,8 +58,8 @@ CREATE TABLE [Ingredient] (
     [quantity_id] INTEGER,
     [input_step_id] INTEGER NOT NULL,
 
-    FOREIGN KEY([quantity_id]) REFERENCES Quantity([id]),
-    FOREIGN KEY([input_step_id]) REFERENCES Step([id])
+    FOREIGN KEY([quantity_id]) REFERENCES Quantity([id]) ON DELETE CASCADE,
+    FOREIGN KEY([input_step_id]) REFERENCES Step([id]) ON DELETE CASCADE
 );
 
 CREATE TABLE [Group] (
@@ -44,7 +68,7 @@ CREATE TABLE [Group] (
     [recipe_id] INTEGER,
     name TEXT,
 
-    FOREIGN KEY([recipe_id]) REFERENCES [Recipe]([id])
+    FOREIGN KEY([recipe_id]) REFERENCES [Recipe]([id]) ON DELETE CASCADE
 );
 
 CREATE INDEX [Group_order_index] ON [Group] ([order]);
@@ -55,7 +79,7 @@ CREATE TABLE [Step] (
     [action] TEXT NOT NULL,
     [group_id] INTEGER NOT NULL,
 
-    FOREIGN KEY(group_id) REFERENCES [Group](id)
+    FOREIGN KEY(group_id) REFERENCES [Group](id) ON DELETE CASCADE
 );
 
 CREATE INDEX [Step_order_index] ON [Group] ([order]);
@@ -67,7 +91,7 @@ CREATE TABLE [IntermediateSubstance] (
     [output_step_id] INTEGER NOT NULL,
     [input_step_id] INTEGER NOT NULL,
 
-    FOREIGN KEY([quantity_id]) REFERENCES [Quantity]([id]),
-    FOREIGN KEY([output_step_id]) REFERENCES [Step]([id]),
-    FOREIGN KEY([input_step_id]) REFERENCES [Step]([id])
+    FOREIGN KEY([quantity_id]) REFERENCES [Quantity]([id]) ON DELETE CASCADE,
+    FOREIGN KEY([output_step_id]) REFERENCES [Step]([id]) ON DELETE CASCADE,
+    FOREIGN KEY([input_step_id]) REFERENCES [Step]([id]) ON DELETE CASCADE
 );