2022-07-01 19:50:09 +02:00
|
|
|
CREATE TABLE schema_migrations (version uint64,dirty bool);
|
|
|
|
CREATE UNIQUE INDEX version_unique ON schema_migrations (version);
|
2022-08-17 21:24:09 +02:00
|
|
|
CREATE TABLE client (
|
2022-09-22 07:02:38 +02:00
|
|
|
clientid varchar(36) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
userid varchar(36) NOT NULL,
|
2022-08-27 01:21:19 +02:00
|
|
|
activesessionid varchar(36) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
userpublickeybytes blob NOT NULL,
|
2022-10-04 20:45:24 +02:00
|
|
|
userprivatekeybytes blob NOT NULL,
|
|
|
|
winsize json NOT NULL
|
2023-02-27 07:22:20 +01:00
|
|
|
, clientopts json NOT NULL DEFAULT '', feopts json NOT NULL DEFAULT '{}');
|
2022-07-01 19:50:09 +02:00
|
|
|
CREATE TABLE session (
|
|
|
|
sessionid varchar(36) PRIMARY KEY,
|
2022-08-08 17:34:59 +02:00
|
|
|
name varchar(50) NOT NULL,
|
|
|
|
sessionidx int NOT NULL,
|
|
|
|
activescreenid varchar(36) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
notifynum int NOT NULL,
|
2022-12-25 22:03:11 +01:00
|
|
|
archived boolean NOT NULL,
|
2022-12-25 22:21:48 +01:00
|
|
|
archivedts bigint NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
ownerid varchar(36) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
sharemode varchar(12) NOT NULL,
|
|
|
|
accesskey varchar(36) NOT NULL
|
2022-07-01 19:50:09 +02:00
|
|
|
);
|
|
|
|
CREATE TABLE window (
|
|
|
|
sessionid varchar(36) NOT NULL,
|
|
|
|
windowid varchar(36) NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
curremoteownerid varchar(36) NOT NULL,
|
2022-08-24 11:14:16 +02:00
|
|
|
curremoteid varchar(36) NOT NULL,
|
|
|
|
curremotename varchar(50) NOT NULL,
|
2022-09-22 07:02:38 +02:00
|
|
|
nextlinenum int NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
winopts json NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
ownerid varchar(36) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
sharemode varchar(12) NOT NULL,
|
|
|
|
shareopts json NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
PRIMARY KEY (sessionid, windowid)
|
|
|
|
);
|
2022-08-08 17:34:59 +02:00
|
|
|
CREATE TABLE screen (
|
|
|
|
sessionid varchar(36) NOT NULL,
|
|
|
|
screenid varchar(36) NOT NULL,
|
|
|
|
name varchar(50) NOT NULL,
|
|
|
|
activewindowid varchar(36) NOT NULL,
|
|
|
|
screenidx int NOT NULL,
|
|
|
|
screenopts json NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
ownerid varchar(36) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
sharemode varchar(12) NOT NULL,
|
2022-12-20 03:52:08 +01:00
|
|
|
incognito boolean NOT NULL,
|
2022-12-25 22:03:11 +01:00
|
|
|
archived boolean NOT NULL,
|
2022-12-25 22:21:48 +01:00
|
|
|
archivedts bigint NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
PRIMARY KEY (sessionid, screenid)
|
|
|
|
);
|
|
|
|
CREATE TABLE screen_window (
|
|
|
|
sessionid varchar(36) NOT NULL,
|
|
|
|
screenid varchar(36) NOT NULL,
|
|
|
|
windowid varchar(36) NOT NULL,
|
|
|
|
name varchar(50) NOT NULL,
|
|
|
|
layout json NOT NULL,
|
2022-10-11 10:11:04 +02:00
|
|
|
selectedline int NOT NULL,
|
|
|
|
anchor json NOT NULL,
|
|
|
|
focustype varchar(12) NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
PRIMARY KEY (sessionid, screenid, windowid)
|
|
|
|
);
|
|
|
|
CREATE TABLE remote_instance (
|
|
|
|
riid varchar(36) PRIMARY KEY,
|
|
|
|
name varchar(50) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
sessionid varchar(36) NOT NULL,
|
|
|
|
windowid varchar(36) NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
remoteownerid varchar(36) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
remoteid varchar(36) NOT NULL,
|
2022-11-28 09:13:00 +01:00
|
|
|
festate json NOT NULL,
|
|
|
|
statebasehash varchar(36) NOT NULL,
|
|
|
|
statediffhasharr json NOT NULL
|
|
|
|
);
|
|
|
|
CREATE TABLE state_base (
|
|
|
|
basehash varchar(36) PRIMARY KEY,
|
|
|
|
ts bigint NOT NULL,
|
|
|
|
version varchar(200) NOT NULL,
|
|
|
|
data blob NOT NULL
|
|
|
|
);
|
|
|
|
CREATE TABLE state_diff (
|
|
|
|
diffhash varchar(36) PRIMARY KEY,
|
|
|
|
ts bigint NOT NULL,
|
|
|
|
basehash varchar(36) NOT NULL,
|
|
|
|
diffhasharr json NOT NULL,
|
|
|
|
data blob NOT NULL
|
2022-07-01 19:50:09 +02:00
|
|
|
);
|
|
|
|
CREATE TABLE line (
|
|
|
|
sessionid varchar(36) NOT NULL,
|
|
|
|
windowid varchar(36) NOT NULL,
|
|
|
|
userid varchar(36) NOT NULL,
|
2022-09-21 02:01:25 +02:00
|
|
|
lineid varchar(36) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
ts bigint NOT NULL,
|
2022-09-21 02:01:25 +02:00
|
|
|
linenum int NOT NULL,
|
|
|
|
linenumtemp boolean NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
linetype varchar(10) NOT NULL,
|
2022-09-21 02:01:25 +02:00
|
|
|
linelocal boolean NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
text text NOT NULL,
|
|
|
|
cmdid varchar(36) NOT NULL,
|
2022-08-24 06:05:49 +02:00
|
|
|
ephemeral boolean NOT NULL,
|
2022-11-28 09:13:00 +01:00
|
|
|
contentheight int NOT NULL,
|
2022-12-06 07:59:00 +01:00
|
|
|
star int NOT NULL,
|
2023-02-21 06:39:29 +01:00
|
|
|
archived boolean NOT NULL, renderer varchar(50) NOT NULL DEFAULT '', bookmarked boolean NOT NULL DEFAULT 0, pinned boolean NOT NULL DEFAULT 0,
|
2022-07-01 19:50:09 +02:00
|
|
|
PRIMARY KEY (sessionid, windowid, lineid)
|
|
|
|
);
|
|
|
|
CREATE TABLE remote (
|
|
|
|
remoteid varchar(36) PRIMARY KEY,
|
2022-08-17 21:24:09 +02:00
|
|
|
physicalid varchar(36) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
remotetype varchar(10) NOT NULL,
|
2022-08-17 21:24:09 +02:00
|
|
|
remotealias varchar(50) NOT NULL,
|
|
|
|
remotecanonicalname varchar(200) NOT NULL,
|
|
|
|
remotesudo boolean NOT NULL,
|
|
|
|
remoteuser varchar(50) NOT NULL,
|
|
|
|
remotehost varchar(200) NOT NULL,
|
2022-08-21 21:31:29 +02:00
|
|
|
connectmode varchar(20) NOT NULL,
|
2022-10-04 20:45:24 +02:00
|
|
|
autoinstall boolean NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
sshopts json NOT NULL,
|
2022-08-21 21:31:29 +02:00
|
|
|
remoteopts json NOT NULL,
|
2022-09-14 02:11:36 +02:00
|
|
|
lastconnectts bigint NOT NULL,
|
2022-10-04 20:45:24 +02:00
|
|
|
local boolean NOT NULL,
|
2022-09-14 21:06:55 +02:00
|
|
|
archived boolean NOT NULL,
|
|
|
|
remoteidx int NOT NULL
|
2022-07-01 19:50:09 +02:00
|
|
|
);
|
2022-08-08 17:34:59 +02:00
|
|
|
CREATE TABLE cmd (
|
2022-07-01 19:50:09 +02:00
|
|
|
sessionid varchar(36) NOT NULL,
|
|
|
|
cmdid varchar(36) NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
remoteownerid varchar(36) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
remoteid varchar(36) NOT NULL,
|
2022-08-24 22:21:54 +02:00
|
|
|
remotename varchar(50) NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
cmdstr text NOT NULL,
|
2022-12-06 07:59:00 +01:00
|
|
|
festate json NOT NULL,
|
|
|
|
statebasehash varchar(36) NOT NULL,
|
|
|
|
statediffhasharr json NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
termopts json NOT NULL,
|
2022-09-22 07:02:38 +02:00
|
|
|
origtermopts json NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
status varchar(10) NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
startpk json NOT NULL,
|
2022-12-06 07:59:00 +01:00
|
|
|
doneinfo json NOT NULL,
|
2022-08-08 17:34:59 +02:00
|
|
|
runout json NOT NULL,
|
2022-12-20 03:52:08 +01:00
|
|
|
rtnstate boolean NOT NULL,
|
2022-12-06 07:59:00 +01:00
|
|
|
rtnbasehash varchar(36) NOT NULL,
|
|
|
|
rtndiffhasharr json NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
PRIMARY KEY (sessionid, cmdid)
|
|
|
|
);
|
|
|
|
CREATE TABLE history (
|
2022-08-11 21:07:41 +02:00
|
|
|
historyid varchar(36) PRIMARY KEY,
|
|
|
|
ts bigint NOT NULL,
|
|
|
|
userid varchar(36) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
sessionid varchar(36) NOT NULL,
|
2022-08-11 21:07:41 +02:00
|
|
|
screenid varchar(36) NOT NULL,
|
2022-07-01 19:50:09 +02:00
|
|
|
windowid varchar(36) NOT NULL,
|
2022-08-11 21:07:41 +02:00
|
|
|
lineid int NOT NULL,
|
2022-08-28 23:24:05 +02:00
|
|
|
remoteownerid varchar(36) NOT NULL,
|
|
|
|
remoteid varchar(36) NOT NULL,
|
|
|
|
remotename varchar(50) NOT NULL,
|
2022-08-12 08:45:15 +02:00
|
|
|
haderror boolean NOT NULL,
|
2022-08-11 21:07:41 +02:00
|
|
|
cmdid varchar(36) NOT NULL,
|
2022-08-28 23:24:05 +02:00
|
|
|
cmdstr text NOT NULL,
|
2022-12-20 03:52:08 +01:00
|
|
|
ismetacmd boolean,
|
|
|
|
incognito boolean
|
2022-07-01 19:50:09 +02:00
|
|
|
);
|
2023-01-29 06:15:05 +01:00
|
|
|
CREATE TABLE activity (
|
|
|
|
day varchar(20) PRIMARY KEY,
|
|
|
|
uploaded boolean NOT NULL,
|
|
|
|
tdata json NOT NULL,
|
|
|
|
tzname varchar(50) NOT NULL,
|
|
|
|
tzoffset int NOT NULL,
|
|
|
|
clientversion varchar(20) NOT NULL,
|
|
|
|
clientarch varchar(20) NOT NULL
|
2023-02-27 07:22:20 +01:00
|
|
|
, buildtime varchar(20) NOT NULL DEFAULT '-', osrelease varchar(20) NOT NULL DEFAULT '-');
|
2023-02-21 00:42:27 +01:00
|
|
|
CREATE TABLE bookmark (
|
|
|
|
bookmarkid varchar(36) PRIMARY KEY,
|
|
|
|
createdts bigint NOT NULL,
|
|
|
|
cmdstr text NOT NULL,
|
|
|
|
alias varchar(50) NOT NULL,
|
|
|
|
tags json NOT NULL,
|
|
|
|
description text NOT NULL
|
|
|
|
);
|
|
|
|
CREATE TABLE bookmark_order (
|
|
|
|
tag varchar(50) NOT NULL,
|
|
|
|
bookmarkid varchar(36) NOT NULL,
|
|
|
|
orderidx int NOT NULL,
|
|
|
|
PRIMARY KEY (tag, bookmarkid)
|
|
|
|
);
|
|
|
|
CREATE TABLE bookmark_cmd (
|
|
|
|
bookmarkid varchar(36) NOT NULL,
|
2023-02-21 06:39:29 +01:00
|
|
|
sessionid varchar(36) NOT NULL,
|
2023-02-21 00:42:27 +01:00
|
|
|
cmdid varchar(36) NOT NULL,
|
2023-02-21 06:39:29 +01:00
|
|
|
PRIMARY KEY (bookmarkid, sessionid, cmdid)
|
2023-02-21 00:42:27 +01:00
|
|
|
);
|