CREATE TABLE job (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    host VARCHAR(255) NOT NULL,
    user VARCHAR(255) NOT NULL,
    command VARCHAR(255) NOT NULL,
    jobid VARCHAR(255),
    time VARCHAR(255),
    timezone VARCHAR(255),
    installed VARCHAR(255) NOT NULL DEFAULT CURRENT_TIMESTAMP,
    deleted VARCHAR(255),
    UNIQUE (host, user, jobid)
);

CREATE INDEX job_jobid ON job (jobid);
CREATE INDEX job_host ON job (host);
CREATE INDEX job_user ON job (user);
CREATE INDEX job_command ON job (command);
CREATE INDEX job_installed ON job (installed);
CREATE INDEX job_deleted ON job (deleted);

CREATE TABLE jobstart (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    jobid INTEGER NOT NULL REFERENCES job(id)
        ON DELETE RESTRICT ON UPDATE RESTRICT,
    command VARCHAR(255) NOT NULL,
    datetime VARCHAR(255) NOT NULL DEFAULT CURRENT_TIMESTAMP
);

CREATE INDEX jobstart_jobid ON jobstart (jobid);
CREATE INDEX jobstart_datetime ON jobstart (datetime);

CREATE TABLE jobfinish (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    jobid INTEGER NOT NULL REFERENCES job(id)
        ON DELETE RESTRICT ON UPDATE RESTRICT,
    command VARCHAR(255) NOT NULL,
    datetime VARCHAR(255) NOT NULL DEFAULT CURRENT_TIMESTAMP,
    status INT NOT NULL
);

CREATE INDEX jobfinish_jobid ON jobfinish (jobid);
CREATE INDEX jobfinish_datetime ON jobfinish (datetime);

CREATE TABLE jobwarn (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    jobid INTEGER NOT NULL REFERENCES job(id)
        ON DELETE RESTRICT ON UPDATE RESTRICT,
    datetime VARCHAR(255) NOT NULL DEFAULT CURRENT_TIMESTAMP,
    status INT NOT NULL
);

CREATE INDEX jobwarn_jobid ON jobwarn (jobid);
CREATE INDEX jobwarn_datetime ON jobwarn (datetime);

CREATE TABLE joboutput (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    finishid INTEGER NOT NULL UNIQUE REFERENCES jobfinish(id)
        ON DELETE RESTRICT ON UPDATE RESTRICT,
    stdout TEXT DEFAULT "" NOT NULL,
    stderr TEXT DEFAULT "" NOT NULL
);

CREATE TABLE jobconfig (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    jobid INTEGER NOT NULL UNIQUE REFERENCES job(id)
        ON DELETE RESTRICT ON UPDATE RESTRICT,
    graceperiod INTEGER,
    timeout INTEGER
);

CREATE TABLE jobnotify (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    configid INTEGER REFERENCES jobconfig(id)
        ON DELETE RESTRICT ON UPDATE RESTRICT,
    host VARCHAR(255) DEFAULT NULL,
    user VARCHAR(255) DEFAULT NULL,
    method VARCHAR(255) NOT NULL,
    address VARCHAR(255) NOT NULL,
    time VARCHAR(255) DEFAULT NULL,
    timezone VARCHAR(255) DEFAULT NULL,
    skip_ok BOOLEAN NOT NULL DEFAULT 0,
    skip_warning BOOLEAN NOT NULL DEFAULT 0,
    skip_error BOOLEAN NOT NULL DEFAULT 0,
    include_output BOOLEAN NOT NULL DEFAULT 0
);

CREATE INDEX jobnotify_host ON jobnotify (host);
CREATE INDEX jobnotify_user ON jobnotify (user);

CREATE TABLE rawcrontab (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    host VARCHAR(255) NOT NULL,
    user VARCHAR(255) NOT NULL,
    crontab TEXT NOT NULL,
    UNIQUE (host, user)
);

CREATE INDEX rawcrontab_host ON rawcrontab (host);
CREATE INDEX rawcrontab_user ON rawcrontab (user);
