mirror of
https://github.com/wavetermdev/waveterm.git
synced 2024-12-22 16:48:23 +01:00
168 lines
5.0 KiB
SQL
168 lines
5.0 KiB
SQL
CREATE TABLE schema_migrations (version uint64,dirty bool);
|
|
CREATE UNIQUE INDEX version_unique ON schema_migrations (version);
|
|
CREATE TABLE client (
|
|
clientid varchar(36) NOT NULL,
|
|
userid varchar(36) NOT NULL,
|
|
activesessionid varchar(36) NOT NULL,
|
|
userpublickeybytes blob NOT NULL,
|
|
userprivatekeybytes blob NOT NULL,
|
|
winsize json NOT NULL
|
|
, clientopts json NOT NULL DEFAULT '');
|
|
CREATE TABLE session (
|
|
sessionid varchar(36) PRIMARY KEY,
|
|
name varchar(50) NOT NULL,
|
|
sessionidx int NOT NULL,
|
|
activescreenid varchar(36) NOT NULL,
|
|
notifynum int NOT NULL,
|
|
archived boolean NOT NULL,
|
|
archivedts bigint NOT NULL,
|
|
ownerid varchar(36) NOT NULL,
|
|
sharemode varchar(12) NOT NULL,
|
|
accesskey varchar(36) NOT NULL
|
|
);
|
|
CREATE TABLE window (
|
|
sessionid varchar(36) NOT NULL,
|
|
windowid varchar(36) NOT NULL,
|
|
curremoteownerid varchar(36) NOT NULL,
|
|
curremoteid varchar(36) NOT NULL,
|
|
curremotename varchar(50) NOT NULL,
|
|
nextlinenum int NOT NULL,
|
|
winopts json NOT NULL,
|
|
ownerid varchar(36) NOT NULL,
|
|
sharemode varchar(12) NOT NULL,
|
|
shareopts json NOT NULL,
|
|
PRIMARY KEY (sessionid, windowid)
|
|
);
|
|
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,
|
|
ownerid varchar(36) NOT NULL,
|
|
sharemode varchar(12) NOT NULL,
|
|
incognito boolean NOT NULL,
|
|
archived boolean NOT NULL,
|
|
archivedts bigint NOT NULL,
|
|
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,
|
|
selectedline int NOT NULL,
|
|
anchor json NOT NULL,
|
|
focustype varchar(12) NOT NULL,
|
|
PRIMARY KEY (sessionid, screenid, windowid)
|
|
);
|
|
CREATE TABLE remote_instance (
|
|
riid varchar(36) PRIMARY KEY,
|
|
name varchar(50) NOT NULL,
|
|
sessionid varchar(36) NOT NULL,
|
|
windowid varchar(36) NOT NULL,
|
|
remoteownerid varchar(36) NOT NULL,
|
|
remoteid varchar(36) NOT NULL,
|
|
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
|
|
);
|
|
CREATE TABLE line (
|
|
sessionid varchar(36) NOT NULL,
|
|
windowid varchar(36) NOT NULL,
|
|
userid varchar(36) NOT NULL,
|
|
lineid varchar(36) NOT NULL,
|
|
ts bigint NOT NULL,
|
|
linenum int NOT NULL,
|
|
linenumtemp boolean NOT NULL,
|
|
linetype varchar(10) NOT NULL,
|
|
linelocal boolean NOT NULL,
|
|
text text NOT NULL,
|
|
cmdid varchar(36) NOT NULL,
|
|
ephemeral boolean NOT NULL,
|
|
contentheight int NOT NULL,
|
|
star int NOT NULL,
|
|
archived boolean NOT NULL,
|
|
PRIMARY KEY (sessionid, windowid, lineid)
|
|
);
|
|
CREATE TABLE remote (
|
|
remoteid varchar(36) PRIMARY KEY,
|
|
physicalid varchar(36) NOT NULL,
|
|
remotetype varchar(10) NOT NULL,
|
|
remotealias varchar(50) NOT NULL,
|
|
remotecanonicalname varchar(200) NOT NULL,
|
|
remotesudo boolean NOT NULL,
|
|
remoteuser varchar(50) NOT NULL,
|
|
remotehost varchar(200) NOT NULL,
|
|
connectmode varchar(20) NOT NULL,
|
|
autoinstall boolean NOT NULL,
|
|
sshopts json NOT NULL,
|
|
remoteopts json NOT NULL,
|
|
lastconnectts bigint NOT NULL,
|
|
local boolean NOT NULL,
|
|
archived boolean NOT NULL,
|
|
remoteidx int NOT NULL
|
|
);
|
|
CREATE TABLE cmd (
|
|
sessionid varchar(36) NOT NULL,
|
|
cmdid varchar(36) NOT NULL,
|
|
remoteownerid varchar(36) NOT NULL,
|
|
remoteid varchar(36) NOT NULL,
|
|
remotename varchar(50) NOT NULL,
|
|
cmdstr text NOT NULL,
|
|
festate json NOT NULL,
|
|
statebasehash varchar(36) NOT NULL,
|
|
statediffhasharr json NOT NULL,
|
|
termopts json NOT NULL,
|
|
origtermopts json NOT NULL,
|
|
status varchar(10) NOT NULL,
|
|
startpk json NOT NULL,
|
|
doneinfo json NOT NULL,
|
|
runout json NOT NULL,
|
|
rtnstate boolean NOT NULL,
|
|
rtnbasehash varchar(36) NOT NULL,
|
|
rtndiffhasharr json NOT NULL,
|
|
PRIMARY KEY (sessionid, cmdid)
|
|
);
|
|
CREATE TABLE history (
|
|
historyid varchar(36) PRIMARY KEY,
|
|
ts bigint NOT NULL,
|
|
userid varchar(36) NOT NULL,
|
|
sessionid varchar(36) NOT NULL,
|
|
screenid varchar(36) NOT NULL,
|
|
windowid varchar(36) NOT NULL,
|
|
lineid int NOT NULL,
|
|
remoteownerid varchar(36) NOT NULL,
|
|
remoteid varchar(36) NOT NULL,
|
|
remotename varchar(50) NOT NULL,
|
|
haderror boolean NOT NULL,
|
|
cmdid varchar(36) NOT NULL,
|
|
cmdstr text NOT NULL,
|
|
ismetacmd boolean,
|
|
incognito boolean
|
|
);
|
|
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
|
|
);
|