liquid_feedback_core

annotate update/core-update.v2.2.4-v2.2.5.sql @ 389:582d270d2653

Added column "admin_notice" to "issue" table, and value 'canceled_by_admin' to "issue_state" type
author jbe
date Sun Aug 11 21:34:58 2013 +0200 (2013-08-11)
parents
children 992ec266356d
rev   line source
jbe@389 1 -- NOTICE: The following command cannot be executed within a transaction block
jbe@389 2 -- and must be rolled back manually, if the update fails:
jbe@389 3 ALTER TYPE "issue_state" ADD VALUE 'canceled_by_admin' AFTER 'voting';
jbe@389 4
jbe@389 5 BEGIN;
jbe@389 6
jbe@389 7 CREATE OR REPLACE VIEW "liquid_feedback_version" AS
jbe@389 8 SELECT * FROM (VALUES ('2.2.5', 2, 2, 5))
jbe@389 9 AS "subquery"("string", "major", "minor", "revision");
jbe@389 10
jbe@389 11 ALTER TABLE "issue" ADD COLUMN "admin_notice" TEXT;
jbe@389 12 COMMENT ON COLUMN "issue"."admin_notice" IS 'Public notice by admin to explain manual interventions, or to announce corrections';
jbe@389 13
jbe@389 14 ALTER TABLE "issue" DROP CONSTRAINT "valid_state";
jbe@389 15 ALTER TABLE "issue" ADD
jbe@389 16 CONSTRAINT "valid_state" CHECK (
jbe@389 17 (
jbe@389 18 ("accepted" ISNULL AND "half_frozen" ISNULL AND "fully_frozen" ISNULL ) OR
jbe@389 19 ("accepted" NOTNULL AND "half_frozen" ISNULL AND "fully_frozen" ISNULL ) OR
jbe@389 20 ("accepted" NOTNULL AND "half_frozen" NOTNULL AND "fully_frozen" ISNULL ) OR
jbe@389 21 ("accepted" NOTNULL AND "half_frozen" NOTNULL AND "fully_frozen" NOTNULL)
jbe@389 22 ) AND (
jbe@389 23 ("state" = 'admission' AND "closed" ISNULL AND "accepted" ISNULL) OR
jbe@389 24 ("state" = 'discussion' AND "closed" ISNULL AND "accepted" NOTNULL AND "half_frozen" ISNULL) OR
jbe@389 25 ("state" = 'verification' AND "closed" ISNULL AND "half_frozen" NOTNULL AND "fully_frozen" ISNULL) OR
jbe@389 26 ("state" = 'voting' AND "closed" ISNULL AND "fully_frozen" NOTNULL) OR
jbe@389 27 ("state" = 'canceled_by_admin' AND "closed" NOTNULL) OR
jbe@389 28 ("state" = 'canceled_revoked_before_accepted' AND "closed" NOTNULL AND "accepted" ISNULL) OR
jbe@389 29 ("state" = 'canceled_issue_not_accepted' AND "closed" NOTNULL AND "accepted" ISNULL) OR
jbe@389 30 ("state" = 'canceled_after_revocation_during_discussion' AND "closed" NOTNULL AND "half_frozen" ISNULL) OR
jbe@389 31 ("state" = 'canceled_after_revocation_during_verification' AND "closed" NOTNULL AND "fully_frozen" ISNULL) OR
jbe@389 32 ("state" = 'canceled_no_initiative_admitted' AND "closed" NOTNULL AND "fully_frozen" NOTNULL AND "closed" = "fully_frozen") OR
jbe@389 33 ("state" = 'finished_without_winner' AND "closed" NOTNULL AND "fully_frozen" NOTNULL AND "closed" != "fully_frozen") OR
jbe@389 34 ("state" = 'finished_with_winner' AND "closed" NOTNULL AND "fully_frozen" NOTNULL AND "closed" != "fully_frozen")
jbe@389 35 ));
jbe@389 36
jbe@389 37 COMMENT ON TABLE "direct_population_snapshot" IS 'Snapshot of active members having either a "membership" in the "area" or an "interest" in the "issue"; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 38 COMMENT ON TABLE "direct_population_snapshot" IS 'Delegations increasing the weight of entries in the "direct_population_snapshot" table; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 39 COMMENT ON TABLE "direct_interest_snapshot" IS 'Snapshot of active members having an "interest" in the "issue"; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 40 COMMENT ON TABLE "delegating_interest_snapshot" IS 'Delegations increasing the weight of entries in the "direct_interest_snapshot" table; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 41 COMMENT ON TABLE "direct_supporter_snapshot" IS 'Snapshot of supporters of initiatives (weight is stored in "direct_interest_snapshot"); for corrections refer to column "issue_notice" of "issue" table';
jbe@389 42 COMMENT ON TABLE "direct_voter" IS 'Members having directly voted for/against initiatives of an issue; frontends must ensure that no voters are added or removed to/from this table when the issue has been closed; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 43 COMMENT ON TABLE "delegating_voter" IS 'Delegations increasing the weight of entries in the "direct_voter" table; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 44 COMMENT ON TABLE "vote" IS 'Manual and delegated votes without abstentions; frontends must ensure that no votes are added modified or removed when the issue has been closed; for corrections refer to column "issue_notice" of "issue" table';
jbe@389 45
jbe@389 46 COMMIT;

Impressum / About Us