From 3ba10a3f64c08de3772f538bd0b8d5a83757c8dc Mon Sep 17 00:00:00 2001 From: Charles Lambert <4685059+celamb4@users.noreply.github.com> Date: Thu, 5 Dec 2024 13:49:24 -0600 Subject: [PATCH] Rename triggers to include schema for uniqueness in schema based multi-tenant environments (#583) Co-authored-by: Charles Lambert --- pgsync/base.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/pgsync/base.py b/pgsync/base.py index 4fcf933c..608b7ac3 100644 --- a/pgsync/base.py +++ b/pgsync/base.py @@ -670,7 +670,7 @@ def create_triggers( ]: self.drop_triggers(schema, [table]) queries.append( - f'CREATE TRIGGER "{table}_{name}" ' + f'CREATE TRIGGER "{schema}_{table}_{name}" ' f'AFTER {" OR ".join(tg_op)} ON "{schema}"."{table}" ' f"FOR EACH {level} EXECUTE PROCEDURE " f"{schema}.{TRIGGER_FUNC}()", @@ -696,7 +696,7 @@ def drop_triggers( logger.debug(f"Dropping trigger on table: {schema}.{table}") for name in ("notify", "truncate"): queries.append( - f'DROP TRIGGER IF EXISTS "{table}_{name}" ON ' + f'DROP TRIGGER IF EXISTS "{schema}_{table}_{name}" ON ' f'"{schema}"."{table}"' ) if join_queries: @@ -732,7 +732,7 @@ def disable_trigger(self, schema: str, table: str) -> None: self.execute( sa.text( f'ALTER TABLE "{schema}"."{table}" ' - f"DISABLE TRIGGER {table}_{name}" + f"DISABLE TRIGGER {schema}_{table}_{name}" ) ) @@ -749,7 +749,7 @@ def enable_trigger(self, schema: str, table, str) -> None: self.execute( sa.text( f'ALTER TABLE "{schema}"."{table}" ' - f"ENABLE TRIGGER {table}_{name}" + f"ENABLE TRIGGER {schema}_{table}_{name}" ) )