mirror of
https://github.com/coder/coder.git
synced 2026-06-02 20:48:20 +00:00
47 lines
1.5 KiB
PL/PgSQL
47 lines
1.5 KiB
PL/PgSQL
DROP INDEX IF EXISTS idx_chat_model_configs_ai_provider_id;
|
|
|
|
ALTER TABLE chat_model_configs
|
|
DROP COLUMN IF EXISTS ai_provider_id;
|
|
|
|
CREATE OR REPLACE FUNCTION delete_deleted_user_resources() RETURNS trigger
|
|
LANGUAGE plpgsql
|
|
AS $$
|
|
DECLARE
|
|
BEGIN
|
|
IF (NEW.deleted) THEN
|
|
-- Remove their api_keys.
|
|
DELETE FROM api_keys
|
|
WHERE user_id = OLD.id;
|
|
|
|
-- Remove their user_links.
|
|
-- Their login_type is preserved in the users table.
|
|
-- Matching this user back to the link can still be done by their
|
|
-- email if the account is undeleted. Although that is not a guarantee.
|
|
DELETE FROM user_links
|
|
WHERE user_id = OLD.id;
|
|
|
|
-- Remove their user_secrets.
|
|
-- user_secrets.user_id has ON DELETE CASCADE, but soft-delete
|
|
-- does not remove the users row so the FK cascade never fires.
|
|
DELETE FROM user_secrets
|
|
WHERE user_id = OLD.id;
|
|
|
|
-- Remove their organization memberships.
|
|
-- This also triggers group membership cleanup via
|
|
-- trigger_delete_group_members_on_org_member_delete.
|
|
DELETE FROM organization_members
|
|
WHERE user_id = OLD.id;
|
|
|
|
-- Remove their user_skills.
|
|
-- user_skills.user_id has ON DELETE CASCADE, but soft-delete
|
|
-- does not remove the users row so the FK cascade never fires.
|
|
DELETE FROM user_skills
|
|
WHERE user_id = OLD.id;
|
|
END IF;
|
|
RETURN NEW;
|
|
END;
|
|
$$;
|
|
|
|
DROP INDEX IF EXISTS idx_user_ai_provider_keys_ai_provider_id;
|
|
DROP TABLE IF EXISTS user_ai_provider_keys;
|