START TRANSACTION; ALTER TABLE "tblDocumentContent" ADD COLUMN "revisiondate" TIMESTAMP default NULL; ALTER TABLE "tblUsers" ADD COLUMN "secret" varchar(50) default NULL; ALTER TABLE "tblWorkflows" ADD COLUMN "layoutdata" text default NULL; CREATE TABLE "tblUserSubstitutes" ( "id" SERIAL UNIQUE, "user" INTEGER default null, "substitute" INTEGER default null, UNIQUE ("user", "substitute"), CONSTRAINT "tblUserSubstitutes_user" FOREIGN KEY ("user") REFERENCES "tblUsers" ("id") ON DELETE CASCADE, CONSTRAINT "tblUserSubstitutes_substitute" FOREIGN KEY ("user") REFERENCES "tblUsers" ("id") ON DELETE CASCADE ); CREATE TABLE "tblDocumentCheckOuts" ( "document" INTEGER NOT NULL default '0', "version" INTEGER NOT NULL default '0', "userID" INTEGER NOT NULL default '0', "date" TIMESTAMP NOT NULL, "filename" varchar(255) NOT NULL default '', CONSTRAINT "tblDocumentCheckOuts_document" FOREIGN KEY ("document") REFERENCES "tblDocuments" ("id") ON DELETE CASCADE, CONSTRAINT "tblDocumentCheckOuts_user" FOREIGN KEY ("userID") REFERENCES "tblUsers" ("id") ON DELETE CASCADE ); CREATE TABLE "tblDocumentRecipients" ( "receiptID" SERIAL UNIQUE, "documentID" INTEGER NOT NULL default '0', "version" INTEGER NOT NULL default '0', "type" INTEGER NOT NULL default '0', "required" INTEGER NOT NULL default '0', UNIQUE ("documentID","version","type","required"), CONSTRAINT "tblDocumentRecipients_document" FOREIGN KEY ("documentID") REFERENCES "tblDocuments" ("id") ON DELETE CASCADE ); CREATE TABLE "tblDocumentReceiptLog" ( "receiptLogID" SERIAL UNIQUE, "receiptID" INTEGER NOT NULL default '0', "status" INTEGER NOT NULL default '0', "comment" text NOT NULL, "date" TIMESTAMP NOT NULL, "userID" INTEGER NOT NULL default '0', CONSTRAINT "tblDocumentReceiptLog_recipient" FOREIGN KEY ("receiptID") REFERENCES "tblDocumentRecipients" ("receiptID") ON DELETE CASCADE, CONSTRAINT "tblDocumentReceiptLog_user" FOREIGN KEY ("userID") REFERENCES "tblUsers" ("id") ON DELETE CASCADE ); CREATE TABLE "tblDocumentRevisors" ( "revisionID" SERIAL UNIQUE, "documentID" INTEGER NOT NULL default '0', "version" INTEGER NOT NULL default '0', "type" INTEGER NOT NULL default '0', "required" INTEGER NOT NULL default '0', "startdate" TIMESTAMP default NULL, UNIQUE ("documentID","version","type","required"), CONSTRAINT "tblDocumentRevisors_document" FOREIGN KEY ("documentID") REFERENCES "tblDocuments" ("id") ON DELETE CASCADE ); CREATE TABLE "tblDocumentRevisionLog" ( "revisionLogID" SERIAL UNIQUE, "revisionID" INTEGER NOT NULL default '0', "status" INTEGER NOT NULL default '0', "comment" text NOT NULL, "date" TIMESTAMP NOT NULL, "userID" INTEGER NOT NULL default '0', CONSTRAINT "tblDocumentRevisionLog_revision" FOREIGN KEY ("revisionID") REFERENCES "tblDocumentRevisors" ("revisionID") ON DELETE CASCADE, CONSTRAINT "tblDocumentRevisionLog_user" FOREIGN KEY ("userID") REFERENCES "tblUsers" ("id") ON DELETE CASCADE ); CREATE TABLE "tblTransmittals" ( "id" SERIAL UNIQUE, "name" text NOT NULL, "comment" text NOT NULL, "userID" INTEGER NOT NULL default '0', "date" TIMESTAMP default NULL, "public" INTEGER NOT NULL default '0', CONSTRAINT "tblTransmittals_user" FOREIGN KEY ("userID") REFERENCES "tblUsers" ("id") ON DELETE CASCADE ); CREATE TABLE "tblTransmittalItems" ( "id" SERIAL UNIQUE, "transmittal" INTEGER NOT NULL DEFAULT '0', "document" INTEGER default NULL, "version" INTEGER NOT NULL default '0', "date" TIMESTAMP default NULL, UNIQUE ("transmittal", "document", "version"), CONSTRAINT "tblTransmittalItems_document" FOREIGN KEY ("document") REFERENCES "tblDocuments" ("id") ON DELETE CASCADE, CONSTRAINT "tblTransmittalItem_transmittal" FOREIGN KEY ("transmittal") REFERENCES "tblTransmittals" ("id") ON DELETE CASCADE ); CREATE TABLE "tblRoles" ( "id" SERIAL UNIQUE, "name" varchar(50) default NULL, "role" INTEGER NOT NULL default '0', "noaccess" varchar(30) NOT NULL default '', UNIQUE ("name") ); INSERT INTO "tblRoles" ("id", "name", "role") VALUES (1, 'Admin', 1); SELECT nextval('"tblRoles_id_seq"'); INSERT INTO "tblRoles" ("id", "name", "role") VALUES (2, 'Guest', 2); SELECT nextval('"tblRoles_id_seq"'); INSERT INTO "tblRoles" ("id", "name", "role") VALUES (3, 'User', 0); SELECT nextval('"tblRoles_id_seq"'); ALTER TABLE "tblUsers" ALTER "role" DROP DEFAULT; ALTER TABLE "tblUsers" ALTER "role" SET NOT NULL; UPDATE "tblUsers" SET role=3 WHERE role=0; ALTER TABLE "tblUsers" ADD CONSTRAINT "tblUsers_role" FOREIGN KEY ("role") REFERENCES "tblRoles" ("id"); CREATE TABLE "tblAros" ( "id" SERIAL UNIQUE, "parent" INTEGER, "model" text NOT NULL, "foreignid" INTEGER NOT NULL DEFAULT '0', "alias" varchar(255) ); CREATE TABLE "tblAcos" ( "id" SERIAL UNIQUE, "parent" INTEGER, "model" text NOT NULL, "foreignid" INTEGER NOT NULL DEFAULT '0', "alias" varchar(255) ); CREATE TABLE "tblArosAcos" ( "id" SERIAL UNIQUE, "aro" INTEGER NOT NULL DEFAULT '0', "aco" INTEGER NOT NULL DEFAULT '0', "create" INTEGER NOT NULL DEFAULT '-1', "read" INTEGER NOT NULL DEFAULT '-1', "update" INTEGER NOT NULL DEFAULT '-1', "delete" INTEGER NOT NULL DEFAULT '-1', UNIQUE ("aco", "aro"), CONSTRAINT "tblArosAcos_acos" FOREIGN KEY ("aco") REFERENCES "tblAcos" ("id") ON DELETE CASCADE, CONSTRAINT "tblArosAcos_aros" FOREIGN KEY ("aro") REFERENCES "tblAros" ("id") ON DELETE CASCADE ); UPDATE "tblVersion" set "major"=6, "minor"=0, "subminor"=0; COMMIT;