From 1c2c6d5c663c517669c0bfff86f261762785b0a4 Mon Sep 17 00:00:00 2001 From: Chad Whitacre Date: Wed, 12 Sep 2012 19:26:17 -0400 Subject: [PATCH] Make participant_id mutable in the db (#80) --- gittip/authentication.py | 1 - schema.sql | 50 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 50 insertions(+), 1 deletion(-) diff --git a/gittip/authentication.py b/gittip/authentication.py index 472b4f175f..49f2794ba3 100644 --- a/gittip/authentication.py +++ b/gittip/authentication.py @@ -47,7 +47,6 @@ def load_session(where, val): , p.ctime , p.claimed_time , p.is_admin - , p.redirect , p.balance , p.goal , n.network diff --git a/schema.sql b/schema.sql index e63f53dac1..b87e48f60c 100644 --- a/schema.sql +++ b/schema.sql @@ -138,3 +138,53 @@ ALTER TABLE paydays RENAME COLUMN exchange_fees_volume TO charge_fees_volume; ALTER TABLE paydays ADD COLUMN nachs bigint DEFAULT 0; ALTER TABLE paydays ADD COLUMN ach_volume numeric(35,2) DEFAULT 0.00; ALTER TABLE paydays ADD COLUMN ach_fees_volume numeric(35,2) DEFAULT 0.00; + + +------------------------------------------------------------------------------- +-- https://github.com/whit537/www.gittip.com/issues/80 + +-- The redirect column ended up being YAGNI. I'm dropping it here because +-- it's implicated in constraints that we'd otherwise have to alter below. + +ALTER TABLE participants DROP redirect; + +BEGIN; + + -- We need to be able to change participant_id and have that cascade out to + -- other tables. Let's do this in a transaction, just for kicks. Kinda + -- gives me the willies to be changing constraints like this. I think it's + -- because I never created the constraints so explicitly in the first + -- place. The below is copied / pasted / edited from `\d participants`. + -- I *think* I'm doing this right. :^O + + ALTER TABLE "exchanges" DROP CONSTRAINT "exchanges_participant_id_fkey"; + ALTER TABLE "exchanges" ADD CONSTRAINT "exchanges_participant_id_fkey" + FOREIGN KEY (participant_id) REFERENCES participants(id) + ON UPDATE CASCADE ON DELETE RESTRICT; + + ALTER TABLE "social_network_users" DROP CONSTRAINT "social_network_users_participant_id_fkey"; + ALTER TABLE "social_network_users" ADD CONSTRAINT "social_network_users_participant_id_fkey" + FOREIGN KEY (participant_id) REFERENCES participants(id) + ON UPDATE CASCADE ON DELETE RESTRICT; + + ALTER TABLE "tips" DROP CONSTRAINT "tips_tippee_fkey"; + ALTER TABLE "tips" ADD CONSTRAINT "tips_tippee_fkey" + FOREIGN KEY (tippee) REFERENCES participants(id) + ON UPDATE CASCADE ON DELETE RESTRICT; + + ALTER TABLE "tips" DROP CONSTRAINT "tips_tipper_fkey"; + ALTER TABLE "tips" ADD CONSTRAINT "tips_tipper_fkey" + FOREIGN KEY (tipper) REFERENCES participants(id) + ON UPDATE CASCADE ON DELETE RESTRICT; + + ALTER TABLE "transfers" DROP CONSTRAINT "transfers_tippee_fkey"; + ALTER TABLE "transfers" ADD CONSTRAINT "transfers_tippee_fkey" + FOREIGN KEY (tippee) REFERENCES participants(id) + ON UPDATE CASCADE ON DELETE RESTRICT; + + ALTER TABLE "transfers" DROP CONSTRAINT "transfers_tipper_fkey"; + ALTER TABLE "transfers" ADD CONSTRAINT "transfers_tipper_fkey" + FOREIGN KEY (tipper) REFERENCES participants(id) + ON UPDATE CASCADE ON DELETE RESTRICT; + +END;