liquid_feedback_core

changeset 50:c45df7907da6 v1.0.2

Bugfix in "delete_private_data"(); Extended "delete_member_data"(...)

- Do not delete delegations in "delete_private_data"()
- Delete area memberships in "delete_member_data"(...)
- Update script for new version 1.0.2
author jbe
date Wed Apr 21 20:07:21 2010 +0200 (2010-04-21)
parents d54d0d8f42dc
children 5aee2ba01e7c
files core.sql update/core-update.v1.0.1-v1.0.2.sql
line diff
     1.1 --- a/core.sql	Tue Apr 20 18:01:18 2010 +0200
     1.2 +++ b/core.sql	Wed Apr 21 20:07:21 2010 +0200
     1.3 @@ -6,7 +6,7 @@
     1.4  BEGIN;
     1.5  
     1.6  CREATE VIEW "liquid_feedback_version" AS
     1.7 -  SELECT * FROM (VALUES ('1.0.1', 1, 0, 1))
     1.8 +  SELECT * FROM (VALUES ('1.0.2', 1, 0, 2))
     1.9    AS "subquery"("string", "major", "minor", "revision");
    1.10  
    1.11  
    1.12 @@ -3225,6 +3225,7 @@
    1.13        DELETE FROM "member_image"       WHERE "member_id" = "member_id_p";
    1.14        DELETE FROM "contact"            WHERE "member_id" = "member_id_p";
    1.15        DELETE FROM "delegation"         WHERE "truster_id" = "member_id_p";
    1.16 +      DELETE FROM "membership"         WHERE "member_id" = "member_id_p";
    1.17        DELETE FROM "area_setting"       WHERE "member_id" = "member_id_p";
    1.18        DELETE FROM "issue_setting"      WHERE "member_id" = "member_id_p";
    1.19        DELETE FROM "initiative_setting" WHERE "member_id" = "member_id_p";
    1.20 @@ -3240,7 +3241,40 @@
    1.21    RETURNS VOID
    1.22    LANGUAGE 'plpgsql' VOLATILE AS $$
    1.23      BEGIN
    1.24 -      PERFORM "delete_member_data"("id") FROM "member";
    1.25 +      UPDATE "member" SET
    1.26 +        "login"                        = NULL,
    1.27 +        "password"                     = NULL,
    1.28 +        "notify_email"                 = NULL,
    1.29 +        "notify_email_unconfirmed"     = NULL,
    1.30 +        "notify_email_secret"          = NULL,
    1.31 +        "notify_email_secret_expiry"   = NULL,
    1.32 +        "password_reset_secret"        = NULL,
    1.33 +        "password_reset_secret_expiry" = NULL,
    1.34 +        "organizational_unit"          = NULL,
    1.35 +        "internal_posts"               = NULL,
    1.36 +        "realname"                     = NULL,
    1.37 +        "birthday"                     = NULL,
    1.38 +        "address"                      = NULL,
    1.39 +        "email"                        = NULL,
    1.40 +        "xmpp_address"                 = NULL,
    1.41 +        "website"                      = NULL,
    1.42 +        "phone"                        = NULL,
    1.43 +        "mobile_phone"                 = NULL,
    1.44 +        "profession"                   = NULL,
    1.45 +        "external_memberships"         = NULL,
    1.46 +        "external_posts"               = NULL,
    1.47 +        "statement"                    = NULL;
    1.48 +      -- "text_search_data" is updated by triggers
    1.49 +      UPDATE "member_history" SET "login" = NULL;
    1.50 +      DELETE FROM "setting";
    1.51 +      DELETE FROM "setting_map";
    1.52 +      DELETE FROM "member_relation_setting";
    1.53 +      DELETE FROM "member_image";
    1.54 +      DELETE FROM "contact";
    1.55 +      DELETE FROM "area_setting";
    1.56 +      DELETE FROM "issue_setting";
    1.57 +      DELETE FROM "initiative_setting";
    1.58 +      DELETE FROM "suggestion_setting";
    1.59        DELETE FROM "invite_code";
    1.60        DELETE FROM "session";
    1.61        DELETE FROM "direct_voter" USING "issue"
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/update/core-update.v1.0.1-v1.0.2.sql	Wed Apr 21 20:07:21 2010 +0200
     2.3 @@ -0,0 +1,100 @@
     2.4 +BEGIN;
     2.5 +
     2.6 +CREATE OR REPLACE VIEW "liquid_feedback_version" AS
     2.7 +  SELECT * FROM (VALUES ('1.0.2', 1, 0, 2))
     2.8 +  AS "subquery"("string", "major", "minor", "revision");
     2.9 + 
    2.10 +CREATE OR REPLACE FUNCTION "delete_member_data"("member_id_p" "member"."id"%TYPE)
    2.11 +  RETURNS VOID
    2.12 +  LANGUAGE 'plpgsql' VOLATILE AS $$
    2.13 +    BEGIN
    2.14 +      UPDATE "member" SET
    2.15 +        "login"                        = NULL,
    2.16 +        "password"                     = NULL,
    2.17 +        "notify_email"                 = NULL,
    2.18 +        "notify_email_unconfirmed"     = NULL,
    2.19 +        "notify_email_secret"          = NULL,
    2.20 +        "notify_email_secret_expiry"   = NULL,
    2.21 +        "password_reset_secret"        = NULL,
    2.22 +        "password_reset_secret_expiry" = NULL,
    2.23 +        "organizational_unit"          = NULL,
    2.24 +        "internal_posts"               = NULL,
    2.25 +        "realname"                     = NULL,
    2.26 +        "birthday"                     = NULL,
    2.27 +        "address"                      = NULL,
    2.28 +        "email"                        = NULL,
    2.29 +        "xmpp_address"                 = NULL,
    2.30 +        "website"                      = NULL,
    2.31 +        "phone"                        = NULL,
    2.32 +        "mobile_phone"                 = NULL,
    2.33 +        "profession"                   = NULL,
    2.34 +        "external_memberships"         = NULL,
    2.35 +        "external_posts"               = NULL,
    2.36 +        "statement"                    = NULL
    2.37 +        WHERE "id" = "member_id_p";
    2.38 +      -- "text_search_data" is updated by triggers
    2.39 +      UPDATE "member_history" SET "login" = NULL
    2.40 +        WHERE "member_id" = "member_id_p";
    2.41 +      DELETE FROM "setting"            WHERE "member_id" = "member_id_p";
    2.42 +      DELETE FROM "setting_map"        WHERE "member_id" = "member_id_p";
    2.43 +      DELETE FROM "member_relation_setting" WHERE "member_id" = "member_id_p";
    2.44 +      DELETE FROM "member_image"       WHERE "member_id" = "member_id_p";
    2.45 +      DELETE FROM "contact"            WHERE "member_id" = "member_id_p";
    2.46 +      DELETE FROM "delegation"         WHERE "truster_id" = "member_id_p";
    2.47 +      DELETE FROM "membership"         WHERE "member_id" = "member_id_p";
    2.48 +      DELETE FROM "area_setting"       WHERE "member_id" = "member_id_p";
    2.49 +      DELETE FROM "issue_setting"      WHERE "member_id" = "member_id_p";
    2.50 +      DELETE FROM "initiative_setting" WHERE "member_id" = "member_id_p";
    2.51 +      DELETE FROM "suggestion_setting" WHERE "member_id" = "member_id_p";
    2.52 +      RETURN;
    2.53 +    END;
    2.54 +  $$;
    2.55 +
    2.56 +CREATE OR REPLACE FUNCTION "delete_private_data"()
    2.57 +  RETURNS VOID
    2.58 +  LANGUAGE 'plpgsql' VOLATILE AS $$
    2.59 +    BEGIN
    2.60 +      UPDATE "member" SET
    2.61 +        "login"                        = NULL,
    2.62 +        "password"                     = NULL,
    2.63 +        "notify_email"                 = NULL,
    2.64 +        "notify_email_unconfirmed"     = NULL,
    2.65 +        "notify_email_secret"          = NULL,
    2.66 +        "notify_email_secret_expiry"   = NULL,
    2.67 +        "password_reset_secret"        = NULL,
    2.68 +        "password_reset_secret_expiry" = NULL,
    2.69 +        "organizational_unit"          = NULL,
    2.70 +        "internal_posts"               = NULL,
    2.71 +        "realname"                     = NULL,
    2.72 +        "birthday"                     = NULL,
    2.73 +        "address"                      = NULL,
    2.74 +        "email"                        = NULL,
    2.75 +        "xmpp_address"                 = NULL,
    2.76 +        "website"                      = NULL,
    2.77 +        "phone"                        = NULL,
    2.78 +        "mobile_phone"                 = NULL,
    2.79 +        "profession"                   = NULL,
    2.80 +        "external_memberships"         = NULL,
    2.81 +        "external_posts"               = NULL,
    2.82 +        "statement"                    = NULL;
    2.83 +      -- "text_search_data" is updated by triggers
    2.84 +      UPDATE "member_history" SET "login" = NULL;
    2.85 +      DELETE FROM "setting";
    2.86 +      DELETE FROM "setting_map";
    2.87 +      DELETE FROM "member_relation_setting";
    2.88 +      DELETE FROM "member_image";
    2.89 +      DELETE FROM "contact";
    2.90 +      DELETE FROM "area_setting";
    2.91 +      DELETE FROM "issue_setting";
    2.92 +      DELETE FROM "initiative_setting";
    2.93 +      DELETE FROM "suggestion_setting";
    2.94 +      DELETE FROM "invite_code";
    2.95 +      DELETE FROM "session";
    2.96 +      DELETE FROM "direct_voter" USING "issue"
    2.97 +        WHERE "direct_voter"."issue_id" = "issue"."id"
    2.98 +        AND "issue"."closed" ISNULL;
    2.99 +      RETURN;
   2.100 +    END;
   2.101 +  $$;
   2.102 +
   2.103 +COMMIT;

Impressum / About Us