rev |
line source |
poelzi@79
|
1 BEGIN;
|
poelzi@79
|
2
|
poelzi@79
|
3 CREATE OR REPLACE VIEW "liquid_feedback_version" AS
|
jbe@86
|
4 SELECT * FROM (VALUES ('1.3.0', 1, 3, 0))
|
poelzi@79
|
5 AS "subquery"("string", "major", "minor", "revision");
|
poelzi@79
|
6
|
jbe@84
|
7 ALTER TABLE "supporter" ADD COLUMN
|
jbe@84
|
8 "auto_support" BOOLEAN NOT NULL DEFAULT FALSE;
|
poelzi@81
|
9
|
jbe@85
|
10 COMMENT ON COLUMN "supporter"."auto_support" IS 'Supporting member does not want to confirm new drafts of the initiative';
|
jbe@85
|
11
|
jbe@86
|
12
|
jbe@86
|
13 -- update comment for column "fully_frozen" of table "issue"
|
jbe@86
|
14
|
jbe@86
|
15 COMMENT ON COLUMN "issue"."fully_frozen" IS 'Point in time, when "verification_time" has elapsed and voting has started; Frontends must ensure that for fully_frozen issues additionally to the restrictions for half_frozen issues a) initiatives are not created, b) no interest is created or removed, c) no supporters are added or removed, d) no opinions are created, changed or deleted.';
|
jbe@86
|
16
|
jbe@86
|
17
|
jbe@86
|
18 -- update comment for column "autoreject" of table "membership"
|
jbe@86
|
19
|
jbe@86
|
20 COMMENT ON COLUMN "membership"."autoreject" IS 'TRUE = member votes against all initiatives, if he is neither direct_ or delegating_voter; Entries in the "interest" table can override this setting.';
|
jbe@86
|
21
|
jbe@86
|
22
|
jbe@86
|
23 -- allow column "autoreject" of table "interest" to be NULL
|
jbe@86
|
24 -- (thus defaulting to "membership")
|
jbe@86
|
25
|
jbe@86
|
26 ALTER TABLE "interest" ALTER COLUMN "autoreject" DROP NOT NULL;
|
jbe@86
|
27
|
jbe@86
|
28
|
jbe@86
|
29 -- new table "ignored_issue" to allow members to ignore particular issues in certain states
|
jbe@86
|
30
|
jbe@86
|
31 CREATE TABLE "ignored_issue" (
|
jbe@86
|
32 PRIMARY KEY ("issue_id", "member_id"),
|
jbe@86
|
33 "issue_id" INT4 REFERENCES "issue" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
jbe@86
|
34 "member_id" INT4 REFERENCES "member" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
jbe@86
|
35 "new" BOOLEAN NOT NULL DEFAULT FALSE,
|
jbe@86
|
36 "accepted" BOOLEAN NOT NULL DEFAULT FALSE,
|
jbe@86
|
37 "half_frozen" BOOLEAN NOT NULL DEFAULT FALSE,
|
jbe@86
|
38 "fully_frozen" BOOLEAN NOT NULL DEFAULT FALSE );
|
jbe@86
|
39 CREATE INDEX "ignored_issue_member_id_idx" ON "ignored_issue" ("member_id");
|
jbe@86
|
40
|
jbe@86
|
41 COMMENT ON TABLE "ignored_issue" IS 'Table to store member specific options to ignore issues in selected states';
|
jbe@86
|
42
|
jbe@86
|
43 COMMENT ON COLUMN "ignored_issue"."new" IS 'Selects issues which are neither closed nor accepted';
|
jbe@86
|
44 COMMENT ON COLUMN "ignored_issue"."accepted" IS 'Selects issues which are accepted but not (half_)frozen or closed';
|
jbe@86
|
45 COMMENT ON COLUMN "ignored_issue"."half_frozen" IS 'Selects issues which are half_frozen but not fully_frozen or closed';
|
jbe@86
|
46 COMMENT ON COLUMN "ignored_issue"."fully_frozen" IS 'Selects issues which are fully_frozen (in voting) and not closed';
|
jbe@86
|
47
|
jbe@86
|
48
|
jbe@86
|
49 -- allow area and issue delegations with trustee_id set to NULL
|
jbe@86
|
50 -- (indicating that global or area delegation is void for that area or issue)
|
jbe@86
|
51
|
jbe@86
|
52 ALTER TABLE "delegation" ALTER COLUMN "trustee_id" DROP NOT NULL;
|
jbe@86
|
53
|
jbe@86
|
54 ALTER TABLE "delegation" ADD CONSTRAINT "no_global_delegation_to_null"
|
jbe@86
|
55 CHECK ("trustee_id" NOTNULL OR "scope" != 'global');
|
jbe@86
|
56
|
jbe@86
|
57
|
jbe@86
|
58 -- disable and delete "copy_autoreject" trigger on table "interest"
|
jbe@86
|
59
|
jbe@86
|
60 DROP TRIGGER "copy_autoreject" ON "interest";
|
jbe@86
|
61 DROP FUNCTION "copy_autoreject_trigger"();
|
jbe@86
|
62
|
jbe@86
|
63
|
jbe@86
|
64 -- update comments on delegation views
|
jbe@86
|
65
|
jbe@86
|
66 COMMENT ON VIEW "active_delegation" IS 'Helper view for views "global_delegation", "area_delegation" and "issue_delegation": Contains delegations where the truster_id refers to an active member and includes those delegations where trustee_id is NULL';
|
jbe@86
|
67
|
jbe@86
|
68 COMMENT ON VIEW "area_delegation" IS 'Resulting area delegations from active members; can include rows with trustee_id set to NULL';
|
jbe@86
|
69
|
jbe@86
|
70 COMMENT ON VIEW "issue_delegation" IS 'Resulting issue delegations from active members; can include rows with trustee_id set to NULL';
|
jbe@86
|
71
|
jbe@86
|
72
|
jbe@86
|
73 --
|
jbe@86
|
74
|
jbe@86
|
75 DROP FUNCTION "delegation_chain"
|
jbe@86
|
76 ( "member"."id"%TYPE,
|
jbe@86
|
77 "area"."id"%TYPE,
|
jbe@86
|
78 "issue"."id"%TYPE );
|
jbe@86
|
79
|
jbe@86
|
80 DROP FUNCTION "delegation_chain"
|
jbe@86
|
81 ( "member"."id"%TYPE,
|
jbe@86
|
82 "area"."id"%TYPE,
|
jbe@86
|
83 "issue"."id"%TYPE,
|
jbe@86
|
84 "member"."id"%TYPE );
|
jbe@86
|
85
|
jbe@86
|
86 DROP TYPE "delegation_chain_row";
|
jbe@86
|
87
|
jbe@86
|
88 CREATE TYPE "delegation_chain_row" AS (
|
jbe@86
|
89 "index" INT4,
|
jbe@86
|
90 "member_id" INT4,
|
jbe@86
|
91 "member_active" BOOLEAN,
|
jbe@86
|
92 "participation" BOOLEAN,
|
jbe@86
|
93 "overridden" BOOLEAN,
|
jbe@86
|
94 "scope_in" "delegation_scope",
|
jbe@86
|
95 "scope_out" "delegation_scope",
|
jbe@86
|
96 "disabled_out" BOOLEAN,
|
jbe@86
|
97 "loop" "delegation_chain_loop_tag" );
|
jbe@86
|
98
|
jbe@86
|
99 COMMENT ON TYPE "delegation_chain_row" IS 'Type of rows returned by "delegation_chain"(...) functions';
|
jbe@86
|
100
|
jbe@86
|
101 COMMENT ON COLUMN "delegation_chain_row"."index" IS 'Index starting with 0 and counting up';
|
jbe@86
|
102 COMMENT ON COLUMN "delegation_chain_row"."participation" IS 'In case of delegation chains for issues: interest, for areas: membership, for global delegation chains: always null';
|
jbe@86
|
103 COMMENT ON COLUMN "delegation_chain_row"."overridden" IS 'True, if an entry with lower index has "participation" set to true';
|
jbe@86
|
104 COMMENT ON COLUMN "delegation_chain_row"."scope_in" IS 'Scope of used incoming delegation';
|
jbe@86
|
105 COMMENT ON COLUMN "delegation_chain_row"."scope_out" IS 'Scope of used outgoing delegation';
|
jbe@86
|
106 COMMENT ON COLUMN "delegation_chain_row"."disabled_out" IS 'Outgoing delegation is explicitly disabled by a delegation with trustee_id set to NULL';
|
jbe@86
|
107 COMMENT ON COLUMN "delegation_chain_row"."loop" IS 'Not null, if member is part of a loop, see "delegation_chain_loop_tag" type';
|
jbe@86
|
108
|
jbe@86
|
109
|
jbe@86
|
110 CREATE FUNCTION "delegation_chain"
|
jbe@86
|
111 ( "member_id_p" "member"."id"%TYPE,
|
jbe@86
|
112 "area_id_p" "area"."id"%TYPE,
|
jbe@86
|
113 "issue_id_p" "issue"."id"%TYPE,
|
jbe@86
|
114 "simulate_trustee_id_p" "member"."id"%TYPE )
|
jbe@86
|
115 RETURNS SETOF "delegation_chain_row"
|
jbe@86
|
116 LANGUAGE 'plpgsql' STABLE AS $$
|
jbe@86
|
117 DECLARE
|
jbe@86
|
118 "issue_row" "issue"%ROWTYPE;
|
jbe@86
|
119 "visited_member_ids" INT4[]; -- "member"."id"%TYPE[]
|
jbe@86
|
120 "loop_member_id_v" "member"."id"%TYPE;
|
jbe@86
|
121 "output_row" "delegation_chain_row";
|
jbe@86
|
122 "output_rows" "delegation_chain_row"[];
|
jbe@86
|
123 "delegation_row" "delegation"%ROWTYPE;
|
jbe@86
|
124 "row_count" INT4;
|
jbe@86
|
125 "i" INT4;
|
jbe@86
|
126 "loop_v" BOOLEAN;
|
jbe@86
|
127 BEGIN
|
jbe@86
|
128 SELECT * INTO "issue_row" FROM "issue" WHERE "id" = "issue_id_p";
|
jbe@86
|
129 "visited_member_ids" := '{}';
|
jbe@86
|
130 "loop_member_id_v" := NULL;
|
jbe@86
|
131 "output_rows" := '{}';
|
jbe@86
|
132 "output_row"."index" := 0;
|
jbe@86
|
133 "output_row"."member_id" := "member_id_p";
|
jbe@86
|
134 "output_row"."member_active" := TRUE;
|
jbe@86
|
135 "output_row"."participation" := FALSE;
|
jbe@86
|
136 "output_row"."overridden" := FALSE;
|
jbe@86
|
137 "output_row"."disabled_out" := FALSE;
|
jbe@86
|
138 "output_row"."scope_out" := NULL;
|
jbe@86
|
139 LOOP
|
jbe@86
|
140 IF "visited_member_ids" @> ARRAY["output_row"."member_id"] THEN
|
jbe@86
|
141 "loop_member_id_v" := "output_row"."member_id";
|
jbe@86
|
142 ELSE
|
jbe@86
|
143 "visited_member_ids" :=
|
jbe@86
|
144 "visited_member_ids" || "output_row"."member_id";
|
jbe@86
|
145 END IF;
|
jbe@86
|
146 IF "output_row"."participation" THEN
|
jbe@86
|
147 "output_row"."overridden" := TRUE;
|
jbe@86
|
148 END IF;
|
jbe@86
|
149 "output_row"."scope_in" := "output_row"."scope_out";
|
jbe@86
|
150 IF EXISTS (
|
jbe@86
|
151 SELECT NULL FROM "member"
|
jbe@86
|
152 WHERE "id" = "output_row"."member_id" AND "active"
|
jbe@86
|
153 ) THEN
|
jbe@86
|
154 IF "area_id_p" ISNULL AND "issue_id_p" ISNULL THEN
|
jbe@86
|
155 SELECT * INTO "delegation_row" FROM "delegation"
|
jbe@86
|
156 WHERE "truster_id" = "output_row"."member_id"
|
jbe@86
|
157 AND "scope" = 'global';
|
jbe@86
|
158 ELSIF "area_id_p" NOTNULL AND "issue_id_p" ISNULL THEN
|
jbe@86
|
159 "output_row"."participation" := EXISTS (
|
jbe@86
|
160 SELECT NULL FROM "membership"
|
jbe@86
|
161 WHERE "area_id" = "area_id_p"
|
jbe@86
|
162 AND "member_id" = "output_row"."member_id"
|
jbe@86
|
163 );
|
jbe@86
|
164 SELECT * INTO "delegation_row" FROM "delegation"
|
jbe@86
|
165 WHERE "truster_id" = "output_row"."member_id"
|
jbe@86
|
166 AND ("scope" = 'global' OR "area_id" = "area_id_p")
|
jbe@86
|
167 ORDER BY "scope" DESC;
|
jbe@86
|
168 ELSIF "area_id_p" ISNULL AND "issue_id_p" NOTNULL THEN
|
jbe@86
|
169 "output_row"."participation" := EXISTS (
|
jbe@86
|
170 SELECT NULL FROM "interest"
|
jbe@86
|
171 WHERE "issue_id" = "issue_id_p"
|
jbe@86
|
172 AND "member_id" = "output_row"."member_id"
|
jbe@86
|
173 );
|
jbe@86
|
174 SELECT * INTO "delegation_row" FROM "delegation"
|
jbe@86
|
175 WHERE "truster_id" = "output_row"."member_id"
|
jbe@86
|
176 AND ("scope" = 'global' OR
|
jbe@86
|
177 "area_id" = "issue_row"."area_id" OR
|
jbe@86
|
178 "issue_id" = "issue_id_p"
|
jbe@86
|
179 )
|
jbe@86
|
180 ORDER BY "scope" DESC;
|
jbe@86
|
181 ELSE
|
jbe@86
|
182 RAISE EXCEPTION 'Either area_id or issue_id or both must be NULL.';
|
jbe@86
|
183 END IF;
|
jbe@86
|
184 ELSE
|
jbe@86
|
185 "output_row"."member_active" := FALSE;
|
jbe@86
|
186 "output_row"."participation" := FALSE;
|
jbe@86
|
187 "output_row"."scope_out" := NULL;
|
jbe@86
|
188 "delegation_row" := ROW(NULL);
|
jbe@86
|
189 END IF;
|
jbe@86
|
190 IF
|
jbe@86
|
191 "output_row"."member_id" = "member_id_p" AND
|
jbe@86
|
192 "simulate_trustee_id_p" NOTNULL
|
jbe@86
|
193 THEN
|
jbe@86
|
194 "output_row"."scope_out" := CASE
|
jbe@86
|
195 WHEN "area_id_p" ISNULL AND "issue_id_p" ISNULL THEN 'global'
|
jbe@86
|
196 WHEN "area_id_p" NOTNULL AND "issue_id_p" ISNULL THEN 'area'
|
jbe@86
|
197 WHEN "area_id_p" ISNULL AND "issue_id_p" NOTNULL THEN 'issue'
|
jbe@86
|
198 END;
|
jbe@86
|
199 "output_rows" := "output_rows" || "output_row";
|
jbe@86
|
200 "output_row"."member_id" := "simulate_trustee_id_p";
|
jbe@86
|
201 ELSIF "delegation_row"."trustee_id" NOTNULL THEN
|
jbe@86
|
202 "output_row"."scope_out" := "delegation_row"."scope";
|
jbe@86
|
203 "output_rows" := "output_rows" || "output_row";
|
jbe@86
|
204 "output_row"."member_id" := "delegation_row"."trustee_id";
|
jbe@86
|
205 ELSIF "delegation_row"."scope" NOTNULL THEN
|
jbe@86
|
206 "output_row"."scope_out" := "delegation_row"."scope";
|
jbe@86
|
207 "output_row"."disabled_out" := TRUE;
|
jbe@86
|
208 "output_rows" := "output_rows" || "output_row";
|
jbe@86
|
209 EXIT;
|
jbe@86
|
210 ELSE
|
jbe@86
|
211 "output_row"."scope_out" := NULL;
|
jbe@86
|
212 "output_rows" := "output_rows" || "output_row";
|
jbe@86
|
213 EXIT;
|
jbe@86
|
214 END IF;
|
jbe@86
|
215 EXIT WHEN "loop_member_id_v" NOTNULL;
|
jbe@86
|
216 "output_row"."index" := "output_row"."index" + 1;
|
jbe@86
|
217 END LOOP;
|
jbe@86
|
218 "row_count" := array_upper("output_rows", 1);
|
jbe@86
|
219 "i" := 1;
|
jbe@86
|
220 "loop_v" := FALSE;
|
jbe@86
|
221 LOOP
|
jbe@86
|
222 "output_row" := "output_rows"["i"];
|
jbe@86
|
223 EXIT WHEN "output_row" ISNULL;
|
jbe@86
|
224 IF "loop_v" THEN
|
jbe@86
|
225 IF "i" + 1 = "row_count" THEN
|
jbe@86
|
226 "output_row"."loop" := 'last';
|
jbe@86
|
227 ELSIF "i" = "row_count" THEN
|
jbe@86
|
228 "output_row"."loop" := 'repetition';
|
jbe@86
|
229 ELSE
|
jbe@86
|
230 "output_row"."loop" := 'intermediate';
|
jbe@86
|
231 END IF;
|
jbe@86
|
232 ELSIF "output_row"."member_id" = "loop_member_id_v" THEN
|
jbe@86
|
233 "output_row"."loop" := 'first';
|
jbe@86
|
234 "loop_v" := TRUE;
|
jbe@86
|
235 END IF;
|
jbe@86
|
236 IF "area_id_p" ISNULL AND "issue_id_p" ISNULL THEN
|
jbe@86
|
237 "output_row"."participation" := NULL;
|
jbe@86
|
238 END IF;
|
jbe@86
|
239 RETURN NEXT "output_row";
|
jbe@86
|
240 "i" := "i" + 1;
|
jbe@86
|
241 END LOOP;
|
jbe@86
|
242 RETURN;
|
jbe@86
|
243 END;
|
jbe@86
|
244 $$;
|
jbe@86
|
245
|
jbe@86
|
246 COMMENT ON FUNCTION "delegation_chain"
|
jbe@86
|
247 ( "member"."id"%TYPE,
|
jbe@86
|
248 "area"."id"%TYPE,
|
jbe@86
|
249 "issue"."id"%TYPE,
|
jbe@86
|
250 "member"."id"%TYPE )
|
jbe@86
|
251 IS 'Helper function for frontends to display delegation chains; Not part of internal voting logic';
|
jbe@86
|
252
|
jbe@86
|
253 CREATE FUNCTION "delegation_chain"
|
jbe@86
|
254 ( "member_id_p" "member"."id"%TYPE,
|
jbe@86
|
255 "area_id_p" "area"."id"%TYPE,
|
jbe@86
|
256 "issue_id_p" "issue"."id"%TYPE )
|
jbe@86
|
257 RETURNS SETOF "delegation_chain_row"
|
jbe@86
|
258 LANGUAGE 'plpgsql' STABLE AS $$
|
jbe@86
|
259 DECLARE
|
jbe@86
|
260 "result_row" "delegation_chain_row";
|
jbe@86
|
261 BEGIN
|
jbe@86
|
262 FOR "result_row" IN
|
jbe@86
|
263 SELECT * FROM "delegation_chain"(
|
jbe@86
|
264 "member_id_p", "area_id_p", "issue_id_p", NULL
|
jbe@86
|
265 )
|
jbe@86
|
266 LOOP
|
jbe@86
|
267 RETURN NEXT "result_row";
|
jbe@86
|
268 END LOOP;
|
jbe@86
|
269 RETURN;
|
jbe@86
|
270 END;
|
jbe@86
|
271 $$;
|
jbe@86
|
272
|
jbe@86
|
273 COMMENT ON FUNCTION "delegation_chain"
|
jbe@86
|
274 ( "member"."id"%TYPE,
|
jbe@86
|
275 "area"."id"%TYPE,
|
jbe@86
|
276 "issue"."id"%TYPE )
|
jbe@86
|
277 IS 'Shortcut for "delegation_chain"(...) function where 4th parameter is null';
|
jbe@86
|
278
|
jbe@86
|
279
|
jbe@86
|
280 -- delete entries of "ignored_issue" table in "delete_member"(...) and "delete_private_data"() functions
|
jbe@86
|
281
|
jbe@86
|
282 CREATE OR REPLACE FUNCTION "delete_member"("member_id_p" "member"."id"%TYPE)
|
jbe@86
|
283 RETURNS VOID
|
jbe@86
|
284 LANGUAGE 'plpgsql' VOLATILE AS $$
|
jbe@86
|
285 BEGIN
|
jbe@86
|
286 UPDATE "member" SET
|
jbe@86
|
287 "last_login" = NULL,
|
jbe@86
|
288 "login" = NULL,
|
jbe@86
|
289 "password" = NULL,
|
jbe@86
|
290 "active" = FALSE,
|
jbe@86
|
291 "notify_email" = NULL,
|
jbe@86
|
292 "notify_email_unconfirmed" = NULL,
|
jbe@86
|
293 "notify_email_secret" = NULL,
|
jbe@86
|
294 "notify_email_secret_expiry" = NULL,
|
jbe@86
|
295 "notify_email_lock_expiry" = NULL,
|
jbe@86
|
296 "password_reset_secret" = NULL,
|
jbe@86
|
297 "password_reset_secret_expiry" = NULL,
|
jbe@86
|
298 "organizational_unit" = NULL,
|
jbe@86
|
299 "internal_posts" = NULL,
|
jbe@86
|
300 "realname" = NULL,
|
jbe@86
|
301 "birthday" = NULL,
|
jbe@86
|
302 "address" = NULL,
|
jbe@86
|
303 "email" = NULL,
|
jbe@86
|
304 "xmpp_address" = NULL,
|
jbe@86
|
305 "website" = NULL,
|
jbe@86
|
306 "phone" = NULL,
|
jbe@86
|
307 "mobile_phone" = NULL,
|
jbe@86
|
308 "profession" = NULL,
|
jbe@86
|
309 "external_memberships" = NULL,
|
jbe@86
|
310 "external_posts" = NULL,
|
jbe@86
|
311 "statement" = NULL
|
jbe@86
|
312 WHERE "id" = "member_id_p";
|
jbe@86
|
313 -- "text_search_data" is updated by triggers
|
jbe@86
|
314 DELETE FROM "setting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
315 DELETE FROM "setting_map" WHERE "member_id" = "member_id_p";
|
jbe@86
|
316 DELETE FROM "member_relation_setting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
317 DELETE FROM "member_image" WHERE "member_id" = "member_id_p";
|
jbe@86
|
318 DELETE FROM "contact" WHERE "member_id" = "member_id_p";
|
jbe@86
|
319 DELETE FROM "area_setting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
320 DELETE FROM "issue_setting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
321 DELETE FROM "initiative_setting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
322 DELETE FROM "suggestion_setting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
323 DELETE FROM "membership" WHERE "member_id" = "member_id_p";
|
jbe@86
|
324 DELETE FROM "delegation" WHERE "truster_id" = "member_id_p";
|
jbe@86
|
325 DELETE FROM "ignored_voting" WHERE "member_id" = "member_id_p";
|
jbe@86
|
326 DELETE FROM "direct_voter" USING "issue"
|
jbe@86
|
327 WHERE "direct_voter"."issue_id" = "issue"."id"
|
jbe@86
|
328 AND "issue"."closed" ISNULL
|
jbe@86
|
329 AND "member_id" = "member_id_p";
|
jbe@86
|
330 RETURN;
|
jbe@86
|
331 END;
|
jbe@86
|
332 $$;
|
jbe@86
|
333
|
jbe@86
|
334 CREATE OR REPLACE FUNCTION "delete_private_data"()
|
jbe@86
|
335 RETURNS VOID
|
jbe@86
|
336 LANGUAGE 'plpgsql' VOLATILE AS $$
|
jbe@86
|
337 BEGIN
|
jbe@86
|
338 UPDATE "member" SET
|
jbe@86
|
339 "last_login" = NULL,
|
jbe@86
|
340 "login" = NULL,
|
jbe@86
|
341 "password" = NULL,
|
jbe@86
|
342 "notify_email" = NULL,
|
jbe@86
|
343 "notify_email_unconfirmed" = NULL,
|
jbe@86
|
344 "notify_email_secret" = NULL,
|
jbe@86
|
345 "notify_email_secret_expiry" = NULL,
|
jbe@86
|
346 "notify_email_lock_expiry" = NULL,
|
jbe@86
|
347 "password_reset_secret" = NULL,
|
jbe@86
|
348 "password_reset_secret_expiry" = NULL,
|
jbe@86
|
349 "organizational_unit" = NULL,
|
jbe@86
|
350 "internal_posts" = NULL,
|
jbe@86
|
351 "realname" = NULL,
|
jbe@86
|
352 "birthday" = NULL,
|
jbe@86
|
353 "address" = NULL,
|
jbe@86
|
354 "email" = NULL,
|
jbe@86
|
355 "xmpp_address" = NULL,
|
jbe@86
|
356 "website" = NULL,
|
jbe@86
|
357 "phone" = NULL,
|
jbe@86
|
358 "mobile_phone" = NULL,
|
jbe@86
|
359 "profession" = NULL,
|
jbe@86
|
360 "external_memberships" = NULL,
|
jbe@86
|
361 "external_posts" = NULL,
|
jbe@86
|
362 "statement" = NULL;
|
jbe@86
|
363 -- "text_search_data" is updated by triggers
|
jbe@86
|
364 DELETE FROM "invite_code";
|
jbe@86
|
365 DELETE FROM "setting";
|
jbe@86
|
366 DELETE FROM "setting_map";
|
jbe@86
|
367 DELETE FROM "member_relation_setting";
|
jbe@86
|
368 DELETE FROM "member_image";
|
jbe@86
|
369 DELETE FROM "contact";
|
jbe@86
|
370 DELETE FROM "session";
|
jbe@86
|
371 DELETE FROM "area_setting";
|
jbe@86
|
372 DELETE FROM "issue_setting";
|
jbe@86
|
373 DELETE FROM "initiative_setting";
|
jbe@86
|
374 DELETE FROM "suggestion_setting";
|
jbe@86
|
375 DELETE FROM "ignored_voting";
|
jbe@86
|
376 DELETE FROM "direct_voter" USING "issue"
|
jbe@86
|
377 WHERE "direct_voter"."issue_id" = "issue"."id"
|
jbe@86
|
378 AND "issue"."closed" ISNULL;
|
jbe@86
|
379 RETURN;
|
jbe@86
|
380 END;
|
jbe@86
|
381 $$;
|
jbe@86
|
382
|
jbe@86
|
383
|
poelzi@79
|
384 COMMIT;
|