auth.schema 1.1 KB

1234567891011121314151617181920212223242526272829303132
  1. CREATE TABLE IF NOT EXISTS user (
  2. name TEXT NOT NULL UNIQUE,
  3. display_name TEXT NOT NULL UNIQUE,
  4. salt TEXT NOT NULL,
  5. hash TEXT NOT NULL,
  6. totp_secret TEXT DEFAULT NULL,
  7. contact_email TEXT DEFAULT NULL
  8. );
  9. CREATE TABLE IF NOT EXISTS session (
  10. id TEXT PRIMARY KEY UNIQUE,
  11. username TEXT NOT NULL UNIQUE REFERENCES user(name) ON DELETE CASCADE
  12. );
  13. CREATE INDEX IF NOT EXISTS username_idx ON user(name);
  14. CREATE VIEW IF NOT EXISTS sess_user AS SELECT user.name AS name, session.id AS session FROM user JOIN session ON session.username=user.name;
  15. CREATE TABLE IF NOT EXISTS user_acl (
  16. username TEXT NOT NULL UNIQUE REFERENCES user(name) ON DELETE CASCADE,
  17. acl TEXT NOT NULL
  18. );
  19. CREATE TABLE IF NOT EXISTS change_request (
  20. username TEXT NOT NULL REFERENCES user(name) ON DELETE CASCADE,
  21. type TEXT NOT NULL,
  22. token TEXT PRIMARY KEY UNIQUE,
  23. secret TEXT,
  24. processed NUMERIC DEFAULT 0
  25. );
  26. CREATE VIEW IF NOT EXISTS change_request_full AS SELECT cr.username, u.display_name, cr.type, cr.token, cr.secret, cr.processed, u.contact_email from change_request AS cr JOIN user AS u ON u.name=cr.username;